harperdb 4.5.0-beta.2 → 4.5.0-beta.3

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 TJ=Object.create;var Rf=Object.defineProperty;var AJ=Object.getOwnPropertyDescriptor;var RJ=Object.getOwnPropertyNames;var yJ=Object.getPrototypeOf,bJ=Object.prototype.hasOwnProperty;var a=(e,t)=>Rf(e,"name",{value:t,configurable:!0});var be=(e,t)=>()=>(e&&(t=e(e=0)),t);var I=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),ve=(e,t)=>{for(var r in t)Rf(e,r,{get:t[r],enumerable:!0})},rD=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of RJ(t))!bJ.call(e,s)&&s!==r&&Rf(e,s,{get:()=>t[s],enumerable:!(n=AJ(t,s))||n.enumerable});return e};var M=(e,t,r)=>(r=e!=null?TJ(yJ(e)):{},rD(t||!e||!e.__esModule?Rf(r,"default",{value:e,enumerable:!0}):r,e)),C=e=>rD(Rf({},"__esModule",{value:!0}),e);var nt=I((Bye,iD)=>{var{join:OJ,dirname:nD}=require("node:path"),{existsSync:NJ,readFileSync:wJ}=require("node:fs");function IJ(){let t=__dirname,r,n=0;for(;!NJ(r=OJ(t,"package.json"));)if(t===(t=nD(t))||n++>10)throw new Error("Could not find package root");return r}a(IJ,"findPackageJson");var sD=IJ(),CJ=JSON.parse(wJ(sD,"utf8")),PJ=nD(sD);iD.exports={packageJson:CJ,PACKAGE_ROOT:PJ}});var rm=I((kye,oD)=>{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}=nt(),p=["bin","components","dataLayer","resources","server","sqlTranslator","upgrade","utility","validation"],_="ts-build";if(l){let g=!1,A=!1;if((A=s(n(d,_)))?g=e.sync(p.map(E=>`${E}/**/*.ts`),{cwd:d}).some(E=>{let R=0,N=0;try{R=i(n(d,E)).mtimeMs-5e3,N=i(n(d,_,E.replace(/.ts$/,".js"))).mtimeMs}catch{}return R>N}):g=!0,g){console.log("Compiling TypeScript...");let E=u("npx",["tsc"],{cwd:d});if(E.stdout?.length&&console.log(E.stdout.toString()),E.stderr?.length&&console.log(E.stderr.toString()),A){let R=n(t(),"harperdb-tsc.pid"),N=!1;if(s(R))try{process.kill(+o(R,"utf8"),0),N=!0}catch{}if(!N){console.log("Starting background TypeScript compilation...");let v=f("npx",["tsc","--watch"],{detached:!0,cwd:d,stdio:"ignore"});c(R,v.pid.toString()),v.unref()}}}}let h=oD.constructor,S=h._findPath;h._findPath=function(g,A,E){if(g.startsWith(".")&&!E&&A.length===1&&A[0].startsWith(d)&&!A[0].includes("node_modules")){let R=r(d,A[0]),N;R.startsWith(_)?N=n(d,r(_,R)):N=n(d,_,R);let v=n(N,g),k=v+".js";if(s(k))return k;if(v.includes(".")&&s(v))return v}return S(g,A,E)}}});var G={};ve(G,{AUTH_AUDIT_STATUS:()=>zs,AUTH_AUDIT_TYPES:()=>ua,BOOT_PROPS_FILE_NAME:()=>t2,BOOT_PROP_PARAMS:()=>lD,CLUSTERING_FLAG:()=>w2,CLUSTERING_PROCESSES:()=>FJ,CLUSTER_MESSAGE_TYPE_ENUM:()=>zA,CLUSTER_OPERATIONS:()=>E2,CONFIG_PARAMS:()=>x,CONFIG_PARAM_MAP:()=>uD,DATABASES_DIR_NAME:()=>yc,DATABASES_PARAM_CONFIG:()=>A2,DEFAULT_DATABASE_NAME:()=>qJ,ESCAPED_FORWARD_SLASH_REGEX:()=>XJ,FORWARD_SLASH_REGEX:()=>QJ,FUNC_VAL:()=>M2,GEO_CONVERSION_ENUM:()=>S2,HDB_COMPONENT_CONFIG_FILE:()=>MJ,HDB_CONFIG_FILE:()=>DJ,HDB_DEFAULT_CONFIG_FILE:()=>LJ,HDB_FILE_PERMISSIONS:()=>n2,HDB_HOME_DIR_NAME:()=>e2,HDB_PID_FILE:()=>GJ,HDB_PROCESS_SERVICES:()=>kJ,HDB_PROC_NAME:()=>vJ,HDB_RESTART_SCRIPT:()=>UJ,HDB_ROOT_DIR_NAME:()=>$A,HDB_SETTINGS_NAMES:()=>WA,HDB_SUPPORT_ADDRESS:()=>cD,INFO_TABLE_HASH_ATTRIBUTE:()=>l2,INSERT_MAX_CHARACTER_SIZE:()=>a2,INSTALL_PROMPTS:()=>o2,ITC_EVENT_TYPES:()=>QA,JOB_STATUS_ENUM:()=>_2,JOB_TYPE_ENUM:()=>R2,JWT_ENUM:()=>bf,LAUNCH_SERVICE_SCRIPTS:()=>KJ,LEGACY_CONFIG_PARAMS:()=>T2,LEGACY_DATABASES_DIR_NAME:()=>im,LICENSE_FILE_NAME:()=>f2,LICENSE_KEY_DIR_NAME:()=>YA,LICENSE_VALUES:()=>y2,LOG_LEVELS:()=>VJ,LOG_NAMES:()=>$J,MEM_SETTING_KEY:()=>ZJ,METADATA_PROPERTY:()=>N2,NODE_ERROR_CODES:()=>O2,OPERATIONS_ENUM:()=>$t,PERMS_CRUD_ENUM:()=>D2,PERMS_UPDATE_RELEASE_TIMESTAMP:()=>P2,PRE_4_0_0_VERSION:()=>v2,PROCESS_DESCRIPTORS:()=>HJ,PROCESS_NAME_ENV_PROP:()=>i2,RAM_ALLOCATION_ENUM:()=>b2,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:()=>am,REG_KEY_FILE_NAME:()=>d2,RESTART_TIMEOUT_MS:()=>r2,ROLE_TYPES_ENUM:()=>YJ,S3_BUCKET_AUTH_KEYS:()=>h2,SEARCH_NOT_FOUND_MESSAGE:()=>zJ,SEARCH_WILDCARDS:()=>L2,SERVICE_ACTIONS_ENUM:()=>g2,SUPPORT_HELP_MSG:()=>WJ,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:()=>u2,SYSTEM_SCHEMA_NAME:()=>yf,SYSTEM_TABLE_NAMES:()=>du,THREAD_TYPES:()=>JA,TIME_STAMP_NAMES:()=>C2,TIME_STAMP_NAMES_ENUM:()=>I2,TRANSACTIONS_DIR_NAME:()=>s2,UNICODE_FORWARD_SLASH:()=>JJ,UNICODE_PERIOD:()=>jJ,UPGRADE_JSON_FIELD_NAMES_ENUM:()=>c2,VALID_S3_FILE_TYPES:()=>p2,VALID_SQL_OPS_ENUM:()=>m2,VALUE_SEARCH_COMPARATORS:()=>om,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:()=>jA});var nm,sm,DJ,LJ,$A,MJ,vJ,UJ,aD,qA,VA,KA,xJ,BJ,HJ,kJ,FJ,GJ,qJ,$J,VJ,KJ,YJ,cD,WJ,zJ,jJ,QJ,JJ,XJ,ZJ,yf,e2,YA,t2,r2,n2,yc,im,s2,i2,lD,o2,a2,c2,du,l2,u2,d2,f2,_2,$t,p2,h2,m2,E2,g2,S2,WA,T2,x,uD,A2,R2,zA,y2,b2,O2,N2,w2,dD,fD,I2,C2,P2,om,jA,D2,L2,M2,am,bf,QA,JA,v2,zs,ua,B=be(()=>{nm=require("node:path"),sm=M(nt()),DJ="harperdb-config.yaml",LJ="defaultConfig.yaml",$A="hdb",MJ="config.yaml",vJ="harperdb.js",UJ="restartHdb.js",aD="HarperDB",qA="Custom Functions",VA="Clustering Hub",KA="Clustering Leaf",xJ="Clustering Ingest Service",BJ="Clustering Reply Service",HJ={HDB:aD,CLUSTERING_HUB:VA,CLUSTERING_LEAF:KA,CLUSTERING_INGEST_SERVICE:xJ,CLUSTERING_REPLY_SERVICE:BJ,CUSTOM_FUNCTIONS:qA,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"},kJ={harperdb:aD,"clustering hub":VA,"clustering leaf":KA,"custom functions":qA,custom_functions:qA,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},FJ={CLUSTERING_HUB_PROC_DESCRIPTOR:VA,CLUSTERING_LEAF_PROC_DESCRIPTOR:KA},GJ="hdb.pid",qJ="data",$J={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},VJ={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},KJ={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")},YJ={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},cD="support@harperdb.io",WJ=`For support, please submit a request at https://harperdbhelp.zendesk.com/hc/en-us/requests/new or contact ${cD}`,zJ="None of the specified records were found.",jJ="U+002E",QJ=/\//g,JJ="U+002F",XJ=/U\+002F/g,ZJ="--max-old-space-size=",yf="system",e2=".harperdb",YA="keys",t2="hdb_boot_properties.file",r2=6e4,n2=448,yc="database",im="schema",s2="transactions",i2="PROCESS_NAME",lD={SETTINGS_PATH_KEY:"settings_path"},o2={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"},a2=250,c2={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"},l2="info_id",u2={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"},d2="060493.ks",f2=".license",_2={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},$t={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"},p2={CSV:".csv",JSON:".json"},h2={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},m2={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},E2={[$t.INSERT]:$t.INSERT,[$t.UPDATE]:$t.UPDATE,[$t.UPSERT]:$t.UPSERT,[$t.DELETE]:$t.DELETE},g2={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"},S2={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},WA={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"},T2={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_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"},uD={settings_path:lD.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];uD[t.toLowerCase()]=t}A2={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},R2={csv_file_load:"csv_file_load",csv_data_load:$t.CSV_DATA_LOAD,csv_url_load:$t.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"},zA={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"},y2={VERSION_DEFAULT:"2.2.0"},b2={DEVELOPMENT:8192,DEFAULT:512},O2={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},N2=Symbol("metadata"),w2="__clustering__",dD="__createdtime__",fD="__updatedtime__",I2={CREATED_TIME:dD,UPDATED_TIME:fD},C2=[dD,fD],P2=15984864e5,om={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},jA={"<":"LESS","<=":"LESS_OR_EQ",">":"GREATER",">=":"GREATER_OR_EQ","...":"BETWEEN"},D2={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},L2=["*","%"],M2="func_val",am={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},bf={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"},JA={HTTP:"http"},v2="3.x.x",zs={SUCCESS:"success",FAILURE:"failure"},ua={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"}});var da=I((Fye,hD)=>{"use strict";var _D=require("minimist");hD.exports=U2;function U2(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=pD(process.env),n=pD(_D(process.argv))):(r=process.env,n=_D(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(U2,"assignCMDENVVariables");function pD(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(pD,"objKeysToLowerCase")});var yi=I(js=>{"use strict";global.Resource=js.Resource=void 0;global.tables=js.tables={};global.databases=js.databases={};global.getUser=js.getUser=void 0;global.authenticateUser=js.authenticateUser=void 0;global.server=js.server={};global.contentTypes=js.contentTypes=null;global.threads=js.threads=[];global.logger={};js._assignPackageExport=(e,t)=>{global[e]=js[e]=t}});var Y=I((PD,DD)=>{"use strict";var ao=require("fs-extra"),{workerData:x2,threadId:B2,isMainThread:H2}=require("worker_threads"),Oi=require("path"),SD=require("yaml"),TD=require("properties-reader"),Vt=(B(),C(G)),mD=da(),k2=require("os"),{PACKAGE_ROOT:tR}=nt(),{_assignPackageExport:F2}=yi(),ED=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),hr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},AD={STDOUT:"stdOut",STDERR:"stdErr"},G2=Oi.join(tR,"logs"),q2=Oi.join(tR,"config/yaml/",Vt.HDB_DEFAULT_CONFIG_FILE),$2=1e4,XA,bi,Ss,Pr,cm,Of,lm,fa,Nf;Nf===void 0&&RD();Object.assign(PD,{notify:wD,fatal:ID,error:um,warn:CD,info:bD,debug:ND,trace:OD,setLogLevel:J2,log_level:Pr,loggerWithTag:Y2,suppressLogging:W2,initLogSettings:RD,logCustomLevel:j2,closeLogFile:rR,logsAtLevel:V2,getLogFilePath:a(()=>lm,"getLogFilePath"),OUTPUTS:AD,AuthAuditLog:e4});F2("logger",DD.exports);var ZA;function V2(e){return hr[Pr]<=hr[e]}a(V2,"logsAtLevel");function RD(e=!1){try{if(Nf===void 0||e){rR();let t=Q2(),r=mD(["ROOTPATH"]);try{Nf=TD(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!ao.pathExistsSync(Oi.join(r.ROOTPATH,Vt.HDB_CONFIG_FILE)))throw n}if({level:Pr,config_log_path:Of,to_file:bi,to_stream:Ss}=X2(r.ROOTPATH?Oi.join(r.ROOTPATH,Vt.HDB_CONFIG_FILE):Nf.get("settings_path")),cm=Vt.LOG_NAMES.HDB,lm=Oi.join(Of,cm),H2)try{require("segfault-handler").registerHandler(Oi.join(Of,"crash.log"))}catch{}}}catch(t){if(Nf=void 0,t.code===Vt.NODE_ERROR_CODES.ENOENT||t.code===Vt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=mD(Object.keys(Vt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Vt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Vt.CONFIG_PARAMS.LOGGING_LEVEL){Pr=l;continue}if(c===Vt.CONFIG_PARAMS.LOGGING_STDSTREAMS){Ss=l;continue}c===Vt.CONFIG_PARAMS.LOGGING_FILE&&(bi=c),c===Vt.CONFIG_PARAMS.LOGGING_CONSOLE&&(XA=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=Z2();bi=bi===void 0?s:bi,bi=gD(bi),Ss=Ss===void 0?i:Ss,Ss=gD(Ss),Pr=Pr===void 0?n:Pr,Of=G2,cm=Vt.LOG_NAMES.INSTALL,lm=Oi.join(Of,cm);return}throw um("Error initializing log settings"),um(t),t}process.env.DEV_MODE&&(Ss=!0),K2()}a(RD,"initLogSettings");var _a=!0;function K2(){bi&&(process.stdout.write=function(e){return typeof e=="string"&&_a&&XA!==!1&&(eR(),e=e.toString(),e[e.length-1]===`
3
- `&&(e=e.slice(0,-1)),ao.appendFileSync(fa,Qs("stdout",[e]))),ED.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&_a&&XA!==!1&&(eR(),e[e.length-1]===`
4
- `&&(e=e.slice(0,-1)),ao.appendFileSync(fa,Qs("stderr",[e]))),ED.apply(process.stderr,arguments)})}a(K2,"stdioLogging");function Y2(e,t){let r={tagName:e.replace(/ /g,"-")};return{notify:n(wD,"notify"),fatal:n(ID,"fatal"),error:n(um,"error"),warn:n(CD,"warn"),info:n(bD,"info"),debug:n(ND,"debug"),trace:n(OD,"trace")};function n(s,i){return!t||hr[Pr]<=hr[i]?function(...o){return s(r,...o)}:null}}a(Y2,"loggerWithTag");function W2(e){try{_a=!1,e()}finally{_a=!0}}a(W2,"suppressLogging");var z2=x2?.name?.replace(/ /g,"-")||"main";function Qs(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||z2+"/"+B2);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 AJ=Object.create;var Rf=Object.defineProperty;var RJ=Object.getOwnPropertyDescriptor;var yJ=Object.getOwnPropertyNames;var bJ=Object.getPrototypeOf,OJ=Object.prototype.hasOwnProperty;var a=(e,t)=>Rf(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)Rf(e,r,{get:t[r],enumerable:!0})},sD=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of yJ(t))!OJ.call(e,s)&&s!==r&&Rf(e,s,{get:()=>t[s],enumerable:!(n=RJ(t,s))||n.enumerable});return e};var M=(e,t,r)=>(r=e!=null?AJ(bJ(e)):{},sD(t||!e||!e.__esModule?Rf(r,"default",{value:e,enumerable:!0}):r,e)),C=e=>sD(Rf({},"__esModule",{value:!0}),e);var st=w((Hye,aD)=>{var{join:NJ,dirname:iD}=require("node:path"),{existsSync:wJ,readFileSync:IJ}=require("node:fs");function CJ(){let t=__dirname,r,n=0;for(;!wJ(r=NJ(t,"package.json"));)if(t===(t=iD(t))||n++>10)throw new Error("Could not find package root");return r}a(CJ,"findPackageJson");var oD=CJ(),PJ=JSON.parse(IJ(oD,"utf8")),DJ=iD(oD);aD.exports={packageJson:PJ,PACKAGE_ROOT:DJ}});var rm=w((Fye,cD)=>{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 A=0,O=0;try{A=i(n(d,E)).mtimeMs-5e3,O=i(n(d,_,E.replace(/.ts$/,".js"))).mtimeMs}catch{}return A>O}):g=!0,g){console.log("Compiling TypeScript...");let E=u("npx",["tsc"],{cwd:d});if(E.stdout?.length&&console.log(E.stdout.toString()),E.stderr?.length&&console.log(E.stderr.toString()),R){let A=n(t(),"harperdb-tsc.pid"),O=!1;if(s(A))try{process.kill(+o(A,"utf8"),0),O=!0}catch{}if(!O){console.log("Starting background TypeScript compilation...");let v=f("npx",["tsc","--watch"],{detached:!0,cwd:d,stdio:"ignore"});c(A,v.pid.toString()),v.unref()}}}}let h=cD.constructor,S=h._findPath;h._findPath=function(g,R,E){if(g.startsWith(".")&&!E&&R.length===1&&R[0].startsWith(d)&&!R[0].includes("node_modules")){let A=r(d,R[0]),O;A.startsWith(_)?O=n(d,r(_,A)):O=n(d,_,A);let v=n(O,g),F=v+".js";if(s(F))return F;if(v.includes(".")&&s(v))return v}return S(g,R,E)}}});var q={};ve(q,{AUTH_AUDIT_STATUS:()=>Ws,AUTH_AUDIT_TYPES:()=>ua,BOOT_PROPS_FILE_NAME:()=>r2,BOOT_PROP_PARAMS:()=>dD,CLUSTERING_FLAG:()=>I2,CLUSTERING_PROCESSES:()=>GJ,CLUSTER_MESSAGE_TYPE_ENUM:()=>zA,CLUSTER_OPERATIONS:()=>g2,CONFIG_PARAMS:()=>B,CONFIG_PARAM_MAP:()=>fD,DATABASES_DIR_NAME:()=>yc,DATABASES_PARAM_CONFIG:()=>R2,DEFAULT_DATABASE_NAME:()=>$J,ESCAPED_FORWARD_SLASH_REGEX:()=>ZJ,FORWARD_SLASH_REGEX:()=>JJ,FUNC_VAL:()=>v2,GEO_CONVERSION_ENUM:()=>T2,HDB_COMPONENT_CONFIG_FILE:()=>vJ,HDB_CONFIG_FILE:()=>LJ,HDB_DEFAULT_CONFIG_FILE:()=>MJ,HDB_FILE_PERMISSIONS:()=>s2,HDB_HOME_DIR_NAME:()=>t2,HDB_PID_FILE:()=>qJ,HDB_PROCESS_SERVICES:()=>FJ,HDB_PROC_NAME:()=>UJ,HDB_RESTART_SCRIPT:()=>xJ,HDB_ROOT_DIR_NAME:()=>$A,HDB_SETTINGS_NAMES:()=>WA,HDB_SUPPORT_ADDRESS:()=>uD,INFO_TABLE_HASH_ATTRIBUTE:()=>u2,INSERT_MAX_CHARACTER_SIZE:()=>c2,INSTALL_PROMPTS:()=>a2,ITC_EVENT_TYPES:()=>QA,JOB_STATUS_ENUM:()=>p2,JOB_TYPE_ENUM:()=>y2,JWT_ENUM:()=>bf,LAUNCH_SERVICE_SCRIPTS:()=>YJ,LEGACY_CONFIG_PARAMS:()=>A2,LEGACY_DATABASES_DIR_NAME:()=>im,LICENSE_FILE_NAME:()=>_2,LICENSE_KEY_DIR_NAME:()=>YA,LICENSE_VALUES:()=>b2,LOG_LEVELS:()=>KJ,LOG_NAMES:()=>VJ,MEM_SETTING_KEY:()=>e2,METADATA_PROPERTY:()=>w2,NODE_ERROR_CODES:()=>N2,OPERATIONS_ENUM:()=>Vt,PERMS_CRUD_ENUM:()=>L2,PERMS_UPDATE_RELEASE_TIMESTAMP:()=>D2,PRE_4_0_0_VERSION:()=>U2,PROCESS_DESCRIPTORS:()=>kJ,PROCESS_NAME_ENV_PROP:()=>o2,RAM_ALLOCATION_ENUM:()=>O2,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:()=>am,REG_KEY_FILE_NAME:()=>f2,RESTART_TIMEOUT_MS:()=>n2,ROLE_TYPES_ENUM:()=>WJ,S3_BUCKET_AUTH_KEYS:()=>m2,SEARCH_NOT_FOUND_MESSAGE:()=>jJ,SEARCH_WILDCARDS:()=>M2,SERVICE_ACTIONS_ENUM:()=>S2,SUPPORT_HELP_MSG:()=>zJ,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:()=>d2,SYSTEM_SCHEMA_NAME:()=>yf,SYSTEM_TABLE_NAMES:()=>du,THREAD_TYPES:()=>JA,TIME_STAMP_NAMES:()=>P2,TIME_STAMP_NAMES_ENUM:()=>C2,TRANSACTIONS_DIR_NAME:()=>i2,UNICODE_FORWARD_SLASH:()=>XJ,UNICODE_PERIOD:()=>QJ,UPGRADE_JSON_FIELD_NAMES_ENUM:()=>l2,VALID_S3_FILE_TYPES:()=>h2,VALID_SQL_OPS_ENUM:()=>E2,VALUE_SEARCH_COMPARATORS:()=>om,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:()=>jA});var nm,sm,LJ,MJ,$A,vJ,UJ,xJ,lD,qA,VA,KA,BJ,HJ,kJ,FJ,GJ,qJ,$J,VJ,KJ,YJ,WJ,uD,zJ,jJ,QJ,JJ,XJ,ZJ,e2,yf,t2,YA,r2,n2,s2,yc,im,i2,o2,dD,a2,c2,l2,du,u2,d2,f2,_2,p2,Vt,h2,m2,E2,g2,S2,T2,WA,A2,B,fD,R2,y2,zA,b2,O2,N2,w2,I2,_D,pD,C2,P2,D2,om,jA,L2,M2,v2,am,bf,QA,JA,U2,Ws,ua,H=be(()=>{nm=require("node:path"),sm=M(st()),LJ="harperdb-config.yaml",MJ="defaultConfig.yaml",$A="hdb",vJ="config.yaml",UJ="harperdb.js",xJ="restartHdb.js",lD="HarperDB",qA="Custom Functions",VA="Clustering Hub",KA="Clustering Leaf",BJ="Clustering Ingest Service",HJ="Clustering Reply Service",kJ={HDB:lD,CLUSTERING_HUB:VA,CLUSTERING_LEAF:KA,CLUSTERING_INGEST_SERVICE:BJ,CLUSTERING_REPLY_SERVICE:HJ,CUSTOM_FUNCTIONS:qA,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"},FJ={harperdb:lD,"clustering hub":VA,"clustering leaf":KA,"custom functions":qA,custom_functions:qA,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},GJ={CLUSTERING_HUB_PROC_DESCRIPTOR:VA,CLUSTERING_LEAF_PROC_DESCRIPTOR:KA},qJ="hdb.pid",$J="data",VJ={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},KJ={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},YJ={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")},WJ={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},uD="support@harperdb.io",zJ=`For support, please submit a request at https://harperdbhelp.zendesk.com/hc/en-us/requests/new or contact ${uD}`,jJ="None of the specified records were found.",QJ="U+002E",JJ=/\//g,XJ="U+002F",ZJ=/U\+002F/g,e2="--max-old-space-size=",yf="system",t2=".harperdb",YA="keys",r2="hdb_boot_properties.file",n2=6e4,s2=448,yc="database",im="schema",i2="transactions",o2="PROCESS_NAME",dD={SETTINGS_PATH_KEY:"settings_path"},a2={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"},c2=250,l2={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"},u2="info_id",d2={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"},f2="060493.ks",_2=".license",p2={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},Vt={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"},h2={CSV:".csv",JSON:".json"},m2={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},E2={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},g2={[Vt.INSERT]:Vt.INSERT,[Vt.UPDATE]:Vt.UPDATE,[Vt.UPSERT]:Vt.UPSERT,[Vt.DELETE]:Vt.DELETE},S2={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"},T2={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},WA={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"},A2={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"},fD={settings_path:dD.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];fD[t.toLowerCase()]=t}R2={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},y2={csv_file_load:"csv_file_load",csv_data_load:Vt.CSV_DATA_LOAD,csv_url_load:Vt.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"},zA={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"},b2={VERSION_DEFAULT:"2.2.0"},O2={DEVELOPMENT:8192,DEFAULT:512},N2={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},w2=Symbol("metadata"),I2="__clustering__",_D="__createdtime__",pD="__updatedtime__",C2={CREATED_TIME:_D,UPDATED_TIME:pD},P2=[_D,pD],D2=15984864e5,om={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},jA={"<":"LESS","<=":"LESS_OR_EQ",">":"GREATER",">=":"GREATER_OR_EQ","...":"BETWEEN"},L2={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},M2=["*","%"],v2="func_val",am={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},bf={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"},JA={HTTP:"http"},U2="3.x.x",Ws={SUCCESS:"success",FAILURE:"failure"},ua={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"}});var da=w((Gye,ED)=>{"use strict";var hD=require("minimist");ED.exports=x2;function x2(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=mD(process.env),n=mD(hD(process.argv))):(r=process.env,n=hD(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(x2,"assignCMDENVVariables");function mD(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(mD,"objKeysToLowerCase")});var Ri=w(zs=>{"use strict";global.Resource=zs.Resource=void 0;global.tables=zs.tables={};global.databases=zs.databases={};global.getUser=zs.getUser=void 0;global.authenticateUser=zs.authenticateUser=void 0;global.server=zs.server={};global.contentTypes=zs.contentTypes=null;global.threads=zs.threads=[];global.logger={};zs._assignPackageExport=(e,t)=>{global[e]=zs[e]=t}});var z=w((LD,MD)=>{"use strict";var oo=require("fs-extra"),{workerData:B2,threadId:H2,isMainThread:k2}=require("worker_threads"),bi=require("path"),AD=require("yaml"),RD=require("properties-reader"),Kt=(H(),C(q)),gD=da(),F2=require("os"),{PACKAGE_ROOT:tR}=st(),{_assignPackageExport:G2}=Ri(),SD=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),mr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},yD={STDOUT:"stdOut",STDERR:"stdErr"},q2=bi.join(tR,"logs"),$2=bi.join(tR,"config/yaml/",Kt.HDB_DEFAULT_CONFIG_FILE),V2=1e4,XA,yi,gs,Cr,cm,Of,lm,fa,Nf;Nf===void 0&&bD();Object.assign(LD,{notify:CD,fatal:PD,error:um,warn:DD,info:ND,debug:ID,trace:wD,setLogLevel:X2,log_level:Cr,loggerWithTag:W2,suppressLogging:z2,initLogSettings:bD,logCustomLevel:Q2,closeLogFile:rR,logsAtLevel:K2,getLogFilePath:a(()=>lm,"getLogFilePath"),OUTPUTS:yD,AuthAuditLog:t4});G2("logger",MD.exports);var ZA;function K2(e){return mr[Cr]<=mr[e]}a(K2,"logsAtLevel");function bD(e=!1){try{if(Nf===void 0||e){rR();let t=J2(),r=gD(["ROOTPATH"]);try{Nf=RD(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!oo.pathExistsSync(bi.join(r.ROOTPATH,Kt.HDB_CONFIG_FILE)))throw n}if({level:Cr,config_log_path:Of,to_file:yi,to_stream:gs}=Z2(r.ROOTPATH?bi.join(r.ROOTPATH,Kt.HDB_CONFIG_FILE):Nf.get("settings_path")),cm=Kt.LOG_NAMES.HDB,lm=bi.join(Of,cm),k2)try{require("segfault-handler").registerHandler(bi.join(Of,"crash.log"))}catch{}}}catch(t){if(Nf=void 0,t.code===Kt.NODE_ERROR_CODES.ENOENT||t.code===Kt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=gD(Object.keys(Kt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Kt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Kt.CONFIG_PARAMS.LOGGING_LEVEL){Cr=l;continue}if(c===Kt.CONFIG_PARAMS.LOGGING_STDSTREAMS){gs=l;continue}c===Kt.CONFIG_PARAMS.LOGGING_FILE&&(yi=c),c===Kt.CONFIG_PARAMS.LOGGING_CONSOLE&&(XA=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=e4();yi=yi===void 0?s:yi,yi=TD(yi),gs=gs===void 0?i:gs,gs=TD(gs),Cr=Cr===void 0?n:Cr,Of=q2,cm=Kt.LOG_NAMES.INSTALL,lm=bi.join(Of,cm);return}throw um("Error initializing log settings"),um(t),t}process.env.DEV_MODE&&(gs=!0),Y2()}a(bD,"initLogSettings");var _a=!0;function Y2(){yi&&(process.stdout.write=function(e){return typeof e=="string"&&_a&&XA!==!1&&(eR(),e=e.toString(),e[e.length-1]===`
3
+ `&&(e=e.slice(0,-1)),oo.appendFileSync(fa,js("stdout",[e]))),SD.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&_a&&XA!==!1&&(eR(),e[e.length-1]===`
4
+ `&&(e=e.slice(0,-1)),oo.appendFileSync(fa,js("stderr",[e]))),SD.apply(process.stderr,arguments)})}a(Y2,"stdioLogging");function W2(e,t){let r={tagName:e.replace(/ /g,"-")};return{notify:n(CD,"notify"),fatal:n(PD,"fatal"),error:n(um,"error"),warn:n(DD,"warn"),info:n(ND,"info"),debug:n(ID,"debug"),trace:n(wD,"trace")};function n(s,i){return!t||mr[Cr]<=mr[i]?function(...o){return s(r,...o)}:null}}a(W2,"loggerWithTag");function z2(e){try{_a=!1,e()}finally{_a=!0}}a(z2,"suppressLogging");var j2=B2?.name?.replace(/ /g,"-")||"main";function js(e,t){let r=new Date(Date.now()).toISOString(),n="",s=t.length,i=s-1,o=[e],c=0,l;for(typeof t[0]=="object"&&(t[0]?.tagName?(o.push(t[0]?.tagName),c++):t[0]?.serviceName&&(l=t[0]?.serviceName,c++)),o.unshift(l||j2+"/"+H2);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(Qs,"createLogRecord");function wf(e){if(bi){if(yD(e),Ss){_a=!1;try{process.stdout.write(e)}finally{_a=!0}}}else Ss&&process.stdout.write(e)}a(wf,"logStdOut");function dm(e){if(bi){if(yD(e),Ss){_a=!1;try{process.stderr.write(e)}finally{_a=!0}}}else Ss&&process.stderr.write(e)}a(dm,"logStdErr");function yD(e){eR(),fa?ao.appendFileSync(fa,e):ZA||console.log(e)}a(yD,"logToFile");function rR(){try{ao.closeSync(fa)}catch{}fa=null}a(rR,"closeLogFile");function eR(){if(!fa){try{fa=ao.openSync(lm,"a")}catch(e){ZA||(ZA=!0,console.error(e))}setTimeout(()=>{rR()},$2).unref()}}a(eR,"openLogFile");function bD(...e){hr[Pr]<=hr.info&&wf(Qs("info",e))}a(bD,"info");function OD(...e){hr[Pr]<=hr.trace&&wf(Qs("trace",e))}a(OD,"trace");function um(...e){hr[Pr]<=hr.error&&dm(Qs("error",e))}a(um,"error");function ND(...e){hr[Pr]<=hr.debug&&wf(Qs("debug",e))}a(ND,"debug");function wD(...e){hr[Pr]<=hr.notify&&wf(Qs("notify",e))}a(wD,"notify");function ID(...e){hr[Pr]<=hr.fatal&&dm(Qs("fatal",e))}a(ID,"fatal");function CD(...e){hr[Pr]<=hr.warn&&dm(Qs("warn",e))}a(CD,"warn");function j2(e,t,...r){t===AD.STDERR?dm(Qs(e,r)):wf(Qs(e,r))}a(j2,"logCustomLevel");function Q2(){let e;try{e=k2.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=Oi.join(e,Vt.HDB_HOME_DIR_NAME,Vt.BOOT_PROPS_FILE_NAME);return ao.existsSync(t)||(t=Oi.join(tR,"utility/hdb_boot_properties.file")),t}a(Q2,"getPropsFilePath");function J2(e){Pr=e}a(J2,"setLogLevel");function gD(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(gD,"autoCastBoolean");function X2(e){try{if(e.includes("config/settings.js")){let o=TD(e);return{level:o.get(Vt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:Oi.dirname(o.get(Vt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(Vt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(Vt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=SD.parseDocument(ao.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===Vt.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(X2,"getLogConfig");function Z2(){try{let e=SD.parseDocument(ao.readFileSync(q2,"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(Z2,"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 nR=I((Vye,LD)=>{"use strict";var t4=require("util"),r4=require("path"),n4=require("child_process"),s4=t4.promisify(n4.execFile),i4=1e3*1e3*10;LD.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 vt=I((Yye,vD)=>{"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",MD={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},p4=Object.values(MD);vD.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:MD,TRANSACTIONS_DBIS:p4,OVERFLOW_MARKER:_4}});var Hn=I((Wye,$D)=>{"use strict";var UD=(B(),C(G)),xD=vt(),BD={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},HD=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),kD={500:HD("There was an error processing your request."),400:"Invalid request"},h4=kD[BD.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 ${xD.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${xD.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 ${UD.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 ${UD.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"},FD={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")},GD={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")},qD={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={...FD,...g4,...m4,...A4,...R4,...y4,...b4,...O4,...T4,...GD,...qD,...N4,...w4,...E4};$D.exports={CHECK_LOGS_WRAPPER:HD,HDB_ERROR_MSGS:I4,DEFAULT_ERROR_MSGS:kD,DEFAULT_ERROR_RESP:h4,HTTP_STATUS_CODES:BD,LMDB_ERRORS_ENUM:S4,AUTHENTICATION_ERROR_MSGS:FD,VALIDATION_ERROR_MSGS:GD,ITC_ERRORS:qD}});var pe=I((jye,YD)=>{"use strict";var fu=Hn(),C4=Y(),P4=(B(),C(G)),fm=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,VD),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)}},sR=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}},iR=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function VD(e,t,r,n=P4.LOG_LEVELS.ERROR,s=null,i=!1){if(KD(e))return e;let o=new fm(e,t,r,n,s);return i&&delete o.stack,o}a(VD,"handleHDBError");function KD(e){return e.__proto__.constructor.name===fm.name}a(KD,"isHDBError");YD.exports={isHDBError:KD,handleHDBError:VD,ClientError:sR,ServerError:iR,hdb_errors:fu}});var Et=I((Jye,ZD)=>{"use strict";var Lf=(B(),C(G)),D4=oe(),_n=ce(),Mf=require("path"),L4=require("minimist"),WD=require("fs-extra"),zD=require("lodash");_n.initSync();var{CONFIG_PARAMS:pa,DATABASES_PARAM_CONFIG:If,SYSTEM_SCHEMA_NAME:_m}=Lf,Cf,Pf,Df;function jD(){if(Cf!==void 0)return Cf;if(_n.getHdbBasePath()!==void 0)return Cf=_n.get(pa.STORAGE_PATH)||Mf.join(_n.getHdbBasePath(),Lf.DATABASES_DIR_NAME),Cf}a(jD,"getBaseSchemaPath");function QD(){if(Pf!==void 0)return Pf;if(_n.getHdbBasePath()!==void 0)return Pf=XD(_m),Pf}a(QD,"getSystemSchemaPath");function JD(){if(Df!==void 0)return Df;if(_n.getHdbBasePath()!==void 0)return Df=_n.get(Lf.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Mf.join(_n.getHdbBasePath(),Lf.TRANSACTIONS_DIR_NAME),Df}a(JD,"getTransactionAuditStoreBasePath");function M4(e,t){let r=_n.get(pa.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Mf.join(JD(),e.toString())}a(M4,"getTransactionAuditStorePath");function XD(e,t){e=e.toString(),t=t&&t.toString();let r=_n.get(Lf.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Mf.join(jD(),e)}a(XD,"getSchemaPath");function v4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,L4(process.argv));let n=r[pa.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=_n.get(pa.DATABASES);l=l??{};let u=c?.tables?.[t]?.[If.PATH];if(u)return zD.set(l,[_m,If.TABLES,t,If.PATH],u),_n.setProperty(pa.DATABASES,l),u;let f=c?.[If.PATH];if(f)return zD.set(l,[_m,If.PATH],f),_n.setProperty(pa.DATABASES,l),f}}let s=r[pa.STORAGE_PATH.toUpperCase()];if(s){if(!WD.pathExistsSync(s))throw new Error(s+" does not exist");let i=Mf.join(s,e);return WD.mkdirsSync(i),_n.setProperty(pa.STORAGE_PATH,s),i}return QD()}a(v4,"initSystemSchemaPaths");function U4(){Cf=void 0,Pf=void 0,Df=void 0}a(U4,"resetPaths");ZD.exports={getBaseSchemaPath:jD,getSystemSchemaPath:QD,getTransactionAuditStorePath:M4,getTransactionAuditStoreBasePath:JD,getSchemaPath:XD,initSystemSchemaPaths:v4,resetPaths:U4}});var pn=I((tbe,sL)=>{"use strict";var x4=Hn().LMDB_ERRORS_ENUM,Zye=require("lmdb"),B4=vt(),ebe=require("buffer").Buffer,{OVERFLOW_MARKER:eL,MAX_SEARCH_KEY_LENGTH:pm}=B4,tL=["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(tL.includes(typeof e))return e.length>pm?[e.slice(0,pm)+eL]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(tL.includes(typeof i))i.length>pm?r.push(i.slice(0,pm)+eL):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,rL=0;function nL(){rL=Date.now()-performance.now()}a(nL,"adjustStartTime");nL();var q4=6e4;setInterval(nL,q4).unref();function $4(){let e=performance.now()+rL;return e>hm?(hm=e,e):(hm+=488e-6,hm)}a($4,"getNextMonotonicTime");sL.exports={validateEnv:H4,stringifyData:k4,convertKeyValueToWrite:F4,getNextMonotonicTime:$4,getIndexedValues:G4}});var vf=I((nbe,iL)=>{"use strict";var V4=(B(),C(G)).OPERATIONS_ENUM,oR=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}};iL.exports=oR});var Uf=I((obe,lL)=>{"use strict";var ibe=vf(),mm=(B(),C(G)),aR=oe(),oL=Y(),K4=require("uuid"),{handleHDBError:Em,hdb_errors:Y4}=pe(),{HDB_ERROR_MSGS:gm,HTTP_STATUS_CODES:Sm}=Y4;lL.exports=aL;function aL(e,t,r){for(let s=0;s<t.length;s++)cL(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];W4(i,r,e.operation)}}a(aL,"processRows");aL.validateAttribute=cL;function cL(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(aR.isEmptyOrZeroLength(e)||aR.isEmpty(e.trim()))throw Em(new Error,gm.ATTR_NAME_NULLISH_ERR,Sm.BAD_REQUEST,void 0,void 0,!0)}a(cL,"validateAttribute");function W4(e,t,r){if(!e.hasOwnProperty(t)||aR.isEmptyOrZeroLength(e[t])){if(r===mm.OPERATIONS_ENUM.INSERT||r===mm.OPERATIONS_ENUM.UPSERT){e[t]=K4.v4();return}throw oL.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 oL.error(e),Em(new Error,gm.HASH_VAL_LENGTH_ERR,Sm.BAD_REQUEST,void 0,void 0,!0)}a(W4,"validateHash")});var uL,kn,cR,_u=be(()=>{uL=require("events"),kn=class extends uL.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new cR;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)}},cR=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 EL(e){uR=e}function J4(){Q4=setInterval(function(){for(let e of lR)if(e.stale){let t=e.getContext()?.url;pL.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 dR,_L,pL,hL,mL,dL,lR,z4,xf,fL,uR,bc,Tm,j4,Q4,Am=be(()=>{dR=M(pn()),_L=M(pe()),pL=M(Y()),hL=M(ce());B();mL=M(oe()),dL=100,lR=new Set,z4=(0,mL.convertToMS)(hL.get(x.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(EL,"replicationConfirmation");bc=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),lR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(lR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(xf&&!this.overloadChecked&&performance.now()-fL>z4)throw new _L.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,dR.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 A=g[_===0?"before":"beforeIntermediate"];if(A){let E=A();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?.letItLinger?2:0;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)<dL>>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 xf||(xf=s,fL=performance.now(),xf.then(()=>{xf=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];uR&&_&&i.push(uR(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)+dL/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 bc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,dR.getNextMonotonicTime)())}getReadTxn(){}},j4=3e4;a(J4,"startMonitoringTxns");J4()});function Ot(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 bc;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({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var gL,Oc=be(()=>{gL=M(yi());Am();a(Ot,"transaction");(0,gL._assignPackageExport)("transaction",Ot);Ot.commit=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Ot.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 _R(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?_R(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",R=f(h.conditions,!E,_);return E?(N,v)=>R.some(k=>k(N,v)):(N,v)=>R.every(k=>k(N,v))}let g=(h.attribute||h[0])===r.primaryKey,A=kf(h,r,i,c,g,_);return p&&S<d.length-1&&_&&(_=o3(r.primaryStore,h.estimated_count,_)),A}).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 mn.ClientError(`Search condition for ${o} must have a value`);if(Array.isArray(o)){let E=o[0],R=wi(n.attributes,E);if(R.relationship){if(o.length<2)throw new mn.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let N=R.definition?.tableClass||R.elements?.definition?.tableClass,v=new Map,k=mu({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,N,s,v);if(R.relationship.to){i[o[0]]=v;let F=!!wi(N.attributes,R.relationship.to)?.elements;k=r3(k,R,N.primaryStore,F,v)}if(R.relationship.from){let F=a(K=>(K?.key!==void 0&&(K=K.key),mu({attribute:R.relationship.from,value:K},t,r,n,s,v)),"searchEntry");R.elements?(i[o[0]]=v,k=n3(k,R,N.primaryStore,v,F)):k=k.flatMap(F)}return k}else if(o.length===1)o=o[0];else throw new mn.ClientError("Unable to query by attribute "+JSON.stringify(o))}let u,f,d,p;c instanceof Date&&(c=c.getTime());let _;switch(pR[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]=Ni.MAXIMUM_KEY;break;case"starts_with":u=c.toString(),f=c+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":u=c[0],u instanceof Date&&(u=u.getTime()),f=c[1],f instanceof Date&&(f=f.getTime()),d=l==="gele"||l==="gtle"||l==="between",p=l==="gtlt"||l==="gtle";break;case"equals":case void 0:u=c,f=c,d=!0;break;case"ne":if(c===null){u=c,p=!0;break}case"sort":case"contains":case"ends_with":u=!0,_=!0;break;default:throw new mn.ClientError(`Unknown query comparator "${l}"`)}let h,S=o===n.primaryKey||o==null;if(typeof u=="string"&&u.length>Ts.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,Ts.MAX_SEARCH_KEY_LENGTH)+Ts.OVERFLOW_MARKER,p=!1,h=kf(e,n,null,i,S)),typeof f=="string"&&f.length>Ts.MAX_SEARCH_KEY_LENGTH&&(f=f.slice(0,Ts.MAX_SEARCH_KEY_LENGTH)+Ts.OVERFLOW_MARKER,d=!0,h=h??kf(e,n,null,i,S)),r){let E=u;u=f,f=E,E=!p,p=!d,d=E}let g=S?n.primaryStore:n.indices[o];if(!g||g.isIndexing||_||c===null&&!g.indexNulls){if(s===!1&&!g)throw new mn.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&_)throw new mn.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(g?.isIndexing)throw new mn.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&g&&!g.indexNulls)throw new mn.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(h=h??kf(e,n,null,i,S),!h)throw new mn.ClientError(`Unknown search operator ${e.comparator}`)}let A={start:u,end:f,inclusiveEnd:d,exclusiveStart:p,values:!0,versions:S,transaction:t,reverse:r};if(S){let E=g.getRange(A).map(h?function({key:R,value:N}){return this?.isSync?N&&h(N)?R:ha.SKIP:new Promise((v,k)=>setImmediate(()=>{try{v(N&&h(N)?R:ha.SKIP)}catch(F){k(F)}}))}:R=>R.value==null&&!(R.metadataFlags&(Fn|Ea))?ha.SKIP:R);return E.hasEntries=!0,E}else return g?g.getRange(A).map(h?function({key:E,value:R}){let N;return typeof E=="string"&&E.length>Ts.MAX_SEARCH_KEY_LENGTH?N=n.primaryStore.get(R):N={[o]:E},this.isSync?h(N)?R:ha.SKIP:new Promise((v,k)=>setImmediate(()=>{try{v(h(N)?R:ha.SKIP)}catch(F){k(F)}}))}:({value:E})=>E):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:E,value:R}){return this.isSync?R&&h(R)?E:ha.SKIP:new Promise((N,v)=>setImmediate(()=>{try{N(R&&h(R)?E:ha.SKIP)}catch(k){v(k)}}))})}function wi(e,t){if(Array.isArray(t))if(t.length>1){let r=wi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?wi(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 kf(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=wi(t.attributes,f),p=d.definition?.tableClass||d.elements.definition?.tableClass,_=n?.[f],h=kf({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,A=a((E,R)=>{let N,v;if(S){if(S.from&&h.idFilter){if(!g)if(h.idFilter.idSet?.size===1){for(let F of h.idFilter.idSet)e={attribute:S.from,value:F};g=u(S.from,h.idFilter,!0,!0)}else g=u(S.from,h.idFilter,!1,!0);let k=g(E);return g.idFilter&&(A.idFilter=g.idFilter),k}v=S(E,r,R),N=v?.value}else N=E[f];return N?Array.isArray(N)?N.some(h):h(N,v):!1},"recordFilter");return A}}switch(l instanceof Date&&(l=l.getTime()),pR[o]||o){case Ts.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,Ni.compareKeys)(f,l[0])>=0&&(0,Ni.compareKeys)(f,l[1])<=0,!0);case"gt":return u(c,f=>(0,Ni.compareKeys)(f,l)>0);case"ge":return u(c,f=>(0,Ni.compareKeys)(f,l)>=0);case"lt":return u(c,f=>(0,Ni.compareKeys)(f,l)<0);case"le":return u(c,f=>(0,Ni.compareKeys)(f,l)<=0);case"ne":return u(c,f=>(0,Ni.compareKeys)(f,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new mn.ClientError(`Unknown query comparator "${o}"`)}function u(f,d,p,_){let h;p=p&&!s&&t?.indices[f]&&i>3,p&&(e.estimated_count==null&&ym(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(p=!1));let S=0,g=3;function A(E){let R=E[f],N;if(typeof R!="object"||!R||_?N=d(R):Array.isArray(R)?N=R.some(d):R instanceof Date&&(N=d(R.getTime())),p&&(g++,!N&&!A.idFilter&&++S/g*(i-g)>h)){let v=mu(e,r.transaction.getReadTxn(),!1,t).map(Eu),k=new Set(v);A.idFilter=F=>k.has(Eu(F)),A.idFilter.idSet=k}return N}return a(A,"recordFilter"),s&&(A.idFilter=d),A}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/co(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=pR[n]||n,n===Ts.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=wi(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*co(e.indices[i.relationship.from])/(co(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=co(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=e3*co(e.primaryStore)+1:n==="between"?r.estimated_count=Z4*co(e.primaryStore)+1:n==="sort"?r.estimated_count=co(e.primaryStore)+1:r.estimated_count=X4*co(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(ma=e,pu.lastIndex=0,s3.test(e))try{let t=Bf(new hu,"");if(hn!==ma.length)throw new SyntaxError("Unable to parse query, unexpected end of query");return t}catch(t){throw t.statusCode=400,t.message=`Unable to parse query, ${t.message} at position ${hn} in '${ma}'`,t}else return new URLSearchParams(e)}function Bf(e,t){let r=pu,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(ma);){hn=r.lastIndex;let[,f,d]=n;if(o){if(f)throw new SyntaxError(`expected operator, but encountered '${f}'`);o=!1,c=!1}else c=!0;let p;switch(d){case"=":if(s!=null){if(f.length<=2)i=f;else throw new SyntaxError(`invalid FIQL operator ${f}`);l=SL}else{if(l=decodeURIComponent,i="equals",!f)throw new SyntaxError("attribute must be specified before equality comparator");s=Hf(f)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=t3[d],l=fR[i]?SL:decodeURIComponent,!f)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=Hf(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"&&TL(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(Hf(f)),s=void 0;break;case"(":pu.lastIndex=hn;let _=Bf(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=AL(_);break;default:throw new SyntaxError(`unknown query function call ${f}`)}ma[hn]===","?r.lastIndex=++hn:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!f)throw new SyntaxError("property sets must have a defined parent property name");pu.lastIndex=hn,p=Bf([],"}"),p.name=f,e.push(p),ma[hn]===","?r.lastIndex=++hn:o=!0;break;case"[":pu.lastIndex=hn,f?(p=Bf(new hu,"]"),p.name=f):p=Bf(e.conditions?new hu:[],"]"),e.conditions?(Rm(e,u),e.conditions.push(p),s=null):e.push(p),ma[hn]===","?r.lastIndex=++hn:o=!0;break;case")":case"]":case"}":if(t===d[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(f)};i==="eq"&&TL(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(Hf(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=hn),hn===ma.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 Hf(e){return e.indexOf(".")>-1?e.split(".").map(Hf):decodeURIComponent(e)}function SL(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return r[0]==="$"?parseInt(r.slice(1),36):+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(isNaN(r)?decodeURIComponent(r):+r);if(t==="string")return decodeURIComponent(r);throw new mn.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function TL(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new mn.ClientError("wildcard can only be used at the end of a string")}function AL(e){let t=RL(e[0]);return e.length>1&&(t.next=AL(e.slice(1))),t}function RL(e){if(Array.isArray(e)){let t=RL(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 co(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/co(e)}var mn,Ts,Ni,ha,X4,Z4,e3,t3,fR,pR,s3,pu,i3,hn,ma,hu,Nc,Ff=be(()=>{mn=M(pe()),Ts=M(vt()),Ni=require("ordered-binary"),ha=require("lmdb");Gf();X4=.3,Z4=.1,e3=.05,t3={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},fR={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(_R,"executeConditions");a(mu,"searchByIndex");a(wi,"findAttribute");a(r3,"joinTo");a(n3,"joinFrom");pR={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(kf,"filterByType");a(ym,"estimateCondition");s3=/[()[\]|!<>.]|(=\w*=)/,pu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,i3=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(bm,"parseQuery");a(Bf,"parseBlock");a(Rm,"assignOperator");a(Hf,"decodeProperty");a(SL,"typedDecoding");a(TL,"wildcardDecoding");a(AL,"toSortObject");a(RL,"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(co,"estimatedEntryCount");a(o3,"intersectionEstimate");Nc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});var mR={};ve(mR,{MultiPartId:()=>Nm,Resource:()=>Vr,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 yL(e,t){if(wc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(wc=!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){wc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return wc=!0,null;e[e.length-1]==="/"&&(wc=!0)}return t.coerceId(decodeURIComponent(e))}function Gn(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 Nc(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 Ot(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 qn(e,t){let r=new NL.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 hR(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):hR(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(hR(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(hR(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 bL,OL,NL,a3,Vr,Om,wc,Nm,ga=be(()=>{bL=require("crypto");_u();OL=M(yi()),NL=M(pe());Oc();Ff();a3={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Vr=class{static{a(this,"Resource")}#e;#t;#n;static transactions;static directURLMapping=!1;constructor(t,r){this.#e=t;let n=r?.getContext?r.getContext()??null:void 0;this.#t=n!==void 0?n:r||null}static get=Gn(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=Gn(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):qn(t,"put")},{hasContent:!0,type:"update"});static patch=Gn(function(t,r,n,s){return t.patch?t.patch(s,r):qn(t,"patch")},{hasContent:!0,type:"update"});static delete=Gn(function(t,r,n,s){return t.delete?t.delete(r):qn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,bL.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={}),Ot(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):qn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=Gn(function(t,r,n,s){return t.invalidate?t.invalidate(r):qn(t,"delete")},{hasContent:!1,type:"update"});static post=Gn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=Gn(function(t,r,n,s){return t.connect?t.connect(s,r):qn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Gn(function(t,r,n,s){return t.subscribe?t.subscribe(r):qn(t,"subscribe")},{type:"read"});static publish=Gn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.publish?t.publish(s,r):qn(t,"publish")},{hasContent:!0,type:"create"});static search=Gn(function(t,r,n,s){let i=t.search?t.search(r):qn(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=Gn(function(t,r,n,s){return t.search?t.search(s,r):qn(t,"search")},{hasContent:!0,type:"read"});static copy=Gn(function(t,r,n,s){return t.copy?t.copy(s,r):qn(t,"copy")},{hasContent:!0,type:"create"});static move=Gn(function(t,r,n,s){return t.move?t.move(s,r):qn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#n)return(await this.constructor.create(this.#e,t,this.#t)).#e;qn(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:yL(t,this),isCollection:wc}}let i=yL(t,this);return wc?{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 kn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new kn}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,OL._assignPackageExport)("Resource",Vr);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(yL,"pathToId");Nm=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(Gn,"transactional");a(qn,"missingMethod");a(hR,"selectFromObject");a(wm,"transformForSelect")});var Sa,ER=be(()=>{Sa=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var CL={};ve(CL,{Resources:()=>Im,keyArrayToString:()=>gu,resetResources:()=>l3,resources:()=>Ii});function l3(){return Ii=new Im}function gu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var wL,IL,Im,Ii,Su=be(()=>{Oc();ER();wL=M(Y()),IL=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 IL.ServerError(`Conflicting paths for ${t}`);wL.default.error(c),i.Resource=new Sa(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let f=this.get(c.slice(0,u));f&&(f.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s=0,i,o=t.length;for(;n<o;){s=n,n=t.indexOf("/",n),n===-1&&(n=o);let u=n===o?t:t.slice(0,n),f=this.get(u),d=-1;if(!f&&n===o&&(d=u.indexOf("?",s),d!==-1)){let p=u.slice(0,d);f=this.get(p)}if(f&&(!r||f.exportTypes?.[r]!==!1)){if(f.relativeURL=t.slice(d!==-1?d:n),!f.hasSubPaths)return f;i=f}n+=2}if(i)return i;let c=t.indexOf("?"),l=c>-1?t.slice(0,c):t;return i=this.get(l),!i&&l.indexOf(".")>-1&&(i=this.get(l.split(".")[0])),i&&(!r||i.exportTypes?.[r]!==!1)?i.relativeURL=c>-1?t.slice(c):"":i||(i=this.get(""),i&&(!r||i.exportTypes?.[r]!==!1)&&(t.charAt(0)!=="/"&&(t="/"+t),i.relativeURL=t)),i}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Ot(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:()=>We});var PL,We,Kr=be(()=>{PL=M(yi()),We={};(0,PL._assignPackageExport)("server",We)});var TR={};ve(TR,{loadGQLSchema:()=>f3,start:()=>SR,startOnMainThread:()=>d3});function SR({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 A of d.definitions)switch(A.kind){case l.OBJECT_TYPE_DEFINITION:let k=function(K){if(K.kind==="NonNullType"){let Z=k(K.type);return Z.nullable=!1,Z}if(K.kind==="ListType")return{type:"array",elements:k(K.type)};let ae={type:K.name?.value};return Object.defineProperty(ae,"location",{value:K.loc.startToken}),ae};a(k,"getProperty");let E=A.name.value,R=[],N={table:null,database:null,properties:R};p.set(E,N);for(let K of A.directives){if(K.name.value==="table"){for(let ae of K.arguments)N[ae.name.value]=ae.value.value;N.schema&&(N.database=N.schema),N.table||(N.table=E),N.audit&&(N.audit=N.audit!=="false"),N.attributes=N.properties,_.push(N)}if(K.name.value==="sealed"&&(N.sealed=!0),K.name.value==="splitSegments"&&(N.splitSegments=!0),K.name.value==="replicate"&&(N.replicate=!0),K.name.value==="export"){N.export=!0;for(let ae of K.arguments)typeof N.export!="object"&&(N.export={}),N.export[ae.name.value]=ae.value.value}}let v=!1,F={};for(let K of A.fields){let re=k(K.type);re.name=K.name.value,R.push(re),F[re.name]=void 0;for(let ae of K.directives){let Z=ae.name.value;if(Z==="primaryKey")v?console.warn("Can not define two attributes as a primary key at",ae.loc):(re.isPrimaryKey=!0,v=!0);else if(Z==="indexed")re.indexed=!0;else if(Z==="computed"){for(let se of ae.arguments||[])if(se.name.value==="from"){let W=se.value.value;re.computed={from:g(W,se,F)},re.version==null&&(re.version=W)}else se.name.value==="version"&&(re.version=se.value.value);re.computed=re.computed||!0}else if(Z==="relationship"){let se={};for(let W of ae.arguments)se[W.name.value]=W.value.value;re.relationship=se}else if(Z==="createdTime")re.assignCreatedTime=!0;else if(Z==="updatedTime")re.assignUpdatedTime=!0;else if(Z==="expiresAt")re.expiresAt=!0;else if(Z==="allow"){let se=re.authorizedRoles=[];for(let W of ae.arguments)W.name.value==="role"&&se.push(W.value.value)}else server.knownGraphQLDirectives.includes(Z)&&console.warn(`@${Z} is an unknown directive, at`,ae.loc)}}N.type=E,E==="Query"&&(h=N)}function S(A){let E=p.get(A.type);E?(Object.defineProperty(A,"properties",{value:E.properties}),Object.defineProperty(A,"definition",{value:E})):A.type==="array"?S(A.elements):u3.includes(A.type)||(0,LL.getWorkerIndex)()===0&&console.error(`The type ${A.type} is unknown at line ${A.location.line}, column ${A.location.column}, in ${s}`)}a(S,"connectPropertyType");for(let A of p.values())for(let E of A.properties)S(E);for(let A of _)A.tableClass=e(A),A.export&&(A.export.name===""?i.set((0,gR.dirname)(n),A.tableClass):i.set((0,gR.dirname)(n)+"/"+(A.export.name||A.type),A.tableClass,A.export));function g(A,E,R){return new DL.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${A}; } } } } computed;`,{filename:s,lineOffset:E.loc.startToken.line-1,columnOffset:E.loc.startToken.column}).runInThisContext()(R)}a(g,"createComputedFrom")}}var gR,DL,LL,u3,d3,f3,ML=be(()=>{gR=require("path"),DL=require("node:vm");Pe();LL=M(tt()),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(SR,"start");d3=SR,f3=SR({ensureTable:lt}).handleFile});var FL={};ve(FL,{parse:()=>RR,streamAsJSON:()=>qf,stringify:()=>Ic});function qf(e){return new AR({value:e})}function vL(e){return console.error(e),JSON.stringify(e.toString())}function UL(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Ic(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===HL)return kL(e);if(t.resolution)return t.resolution.then(()=>Ic(e));throw t}}function kL(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+=kL(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Ic(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function RR(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),h3.test(e)?_3.parse(e):JSON.parse(e)):null}var xL,BL,_3,p3,HL,AR,h3,yR=be(()=>{xL=require("stream"),BL=M(require("json-bigint-fixes")),_3=(0,BL.default)({useNativeBigInt:!0}),p3=1e4,HL={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw HL};a(qf,"streamAsJSON");AR=class extends xL.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),vL)}catch(s){yield vL(s)}else yield Ic(t)}else yield Ic(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);UL(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 UL(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(vL,"handleError");a(UL,"when");a(Ic,"stringify");a(kL,"jsStringify");h3=/[[,:]\s*-?\d{16,}/;a(RR,"parse")});var Ci=I(Pm=>{var Cm=Y();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:()=>Pi,blobsWereEncoded:()=>Pc,databasePaths:()=>Mm,decodeBlobsWithWrites:()=>wR,decodeFromDatabase:()=>Dc,decodeWithBlobCallback:()=>IR,deleteBlob:()=>jL,deleteBlobsInObject:()=>Aa,deleteRootBlobPathsForDB:()=>NR,encodeBlobsAsBuffers:()=>O3,encodeBlobsWithFilePath:()=>km,findBlobsInObject:()=>Yf,getFileId:()=>Bm,getFilePathForBlob:()=>JL,getRootBlobPathsForDB:()=>Hm,setDeletionDelay:()=>S3});function WL(){}function jL(e){let t=JL(e);t&&setTimeout(()=>{(0,Qe.unlink)(t,r=>{r&&Ta.default.debug?.("Error trying to remove blob file",r)})},zL)}function S3(e){zL=e}function QL(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 A3(t),t.source?bR(e,t.source,t):t.contentBuffer?T3(e,t):bR(e,Vf.Readable.from(e.stream()),t),t}function bR(e,t,r){let{filePath:n,fileId:s,store:i,compress:o,flush:c}=r;return r.saving=new Promise((l,u)=>{let f=s+":blob";if(!i.attemptLock(f,0))throw new Error(`Unable to get lock for blob file ${s}`);let d=(0,Qe.createWriteStream)(n,{autoClose:!1,flags:"w"});if(t.errored){let g=Buffer.from(t.errored.toString());d.end(Buffer.concat([h(BigInt(g.length)+0xff000000000000n),g]));return}let p=!1;e.size!==void 0&&(d.write(h(e.size)),p=!0);let _;o?(p||d.write(E3),_=(0,Um.createDeflate)(),t.pipe(_).pipe(d)):(p||d.write(m3),t.pipe(d)),t.on("error",S);function h(g){let A=BigInt(g),E=new Uint8Array(mr),R=new DataView(E.buffer);return A|=BigInt(o?OR:YL)<<48n,R.setBigInt64(0,A),E}a(h,"createHeader");function S(g){i.unlock(f,0);let A=d.fd;g?(A&&(0,Qe.close)(A),u(g)):c?(0,Qe.fdatasync)(A,E=>{E&&u(E),l(),(0,Qe.close)(A)}):(l(),(0,Qe.close)(A))}a(S,"finished"),d.on("error",S).on("finish",()=>{if(p)S();else{let g=_?_.bytesWritten:d.bytesWritten-mr;e.size=g,(0,Qe.write)(d.fd,h(g),0,mr,0,S)}})}),e}function Bm(e){return En.get(e)?.fileId}function JL(e){let t=En.get(e);return t?.fileId&&Kf(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)(x.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,uo.join)(n,e.databaseName)):t=[(0,uo.join)((0,xm.getHdbBasePath)(),"blobs",e.databaseName)],Mm.set(e,t)}return t}async function NR(e){let t=Mm.get(e);t&&await Promise.all(t.map(r=>XL(r)))}async function XL(e){for(let t of await(0,Xs.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await XL((0,uo.join)(e,t.name));else try{await(0,Xs.unlink)((0,uo.join)(e,t.name))}catch(r){Ta.default.warn?.("Error deleting file",r)}try{await(0,Xs.rmdir)(e)}catch(t){Ta.default.warn?.("Error deleting directory",t)}}function Kf({storageIndex:e,fileId:t,store:r}){let n=Hm(r);return(0,uo.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<KL))return e.size=n,bR(e,Vf.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=Kf(e),o=(0,uo.dirname)(i);(0,Qe.existsSync)(o)||(0,VL.ensureDirSync)(o),e.filePath=i}function R3(){let e=$L.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,Qe.existsSync)(n))for(let c of(0,Qe.readdirSync)(n)){let l=parseInt(c,16);i===2&&c.length>3&&(l=parseInt(c.slice(-3),16),l+=parseInt(c.slice(0,-3),16)*68719476736),l>o&&(o=l)}s+=o,n=(0,uo.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)),$L.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(!Xs.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let o=await(0,Xs.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,Pc=!1;try{return e()}finally{Au=void 0,Js=void 0}}function O3(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 wR(e,t){try{Dr=[],Cc=t,e()}catch(n){throw Cc=void 0,Dr=void 0,n}Cc=void 0;let r=Dr.length<2?Dr[0]:Promise.all(Dr);return Dr=void 0,r}function IR(e,t){try{return Cc=t,e()}finally{Cc=void 0}}function Dc(e,t){return Js=t,e()}function Aa(e){Yf(e,t=>{jL(t)})}function Yf(e,t){if(e instanceof Pi)t(e);else if(e.constructor===Object||Array.isArray(e))for(let r in e)typeof e[r]=="object"&&Yf(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 lo,Xs,Qe,Um,Vf,VL,xm,uo,Ta,KL,mr,YL,OR,GL,m3,E3,qL,En,Cc,Pi,Au,Dr,Js,Pc,$f,Dm,g3,Lm,zL,Mm,$L,vm,As=be(()=>{lo=require("msgpackr"),Xs=require("node:fs/promises"),Qe=require("node:fs"),Um=require("node:zlib"),Vf=require("node:stream"),VL=require("fs-extra"),xm=M(ce());B();uo=require("path"),Ta=M(Ci());fo();KL=8192,mr=8,YL=0,OR=1,GL=255,m3=new Uint8Array([0,YL,255,255,255,255,255,255]),E3=new Uint8Array([0,OR,255,255,255,255,255,255]),qL=0xffffffffffff,En=new WeakMap,Pi=global.Blob||N3(),Pc=!1,$f=new Uint8Array(8),Dm=new DataView($f.buffer),g3=6e4;a(WL,"InstanceOfBlobWithNoConstructor");WL.prototype=Pi.prototype;Lm=class e extends WL{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}=t;return s&&(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),s?s.toString():(CR(this.bytes().then(i=>t.contentBuffer=i)),"")}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=Kf(t),o,c=a(async()=>{let l,u=mr;try{if(l=await(0,Xs.readFile)(i),l.length>=mr){l.copy($f,0,0,mr);let d=Dm.getBigUint64(0);if(Number(d>>48n)===GL)throw new Error("Error in blob: "+buffer.subarray(mr));if(u=Number(d&0xffffffffffffn),u<n&&(u=n),u<qL&&(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]===OR?new Promise((d,p)=>{(0,Um.deflate)(l.subarray(mr),(_,h)=>{_?p(_):d(f(h))})}):f(l.subarray(mr))},"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(h){h.enqueue(r),h.close()}});let i=Kf(t),o,c=0,l=0,u,f,d,p=this;return new ReadableStream({start(){let h=1e3,S=a((g,A)=>{(0,Qe.open)(i,"r",(E,R)=>{if(E){if(E.code==="ENOENT"&&d!==!1&&(Ta.default.debug?.("File does not exist yet, waiting for it to be created",i,h),h-- >0))return setTimeout(()=>{_(),S(g,A)},20).unref();A(E),p.#e?.forEach(N=>N(E))}else o=R,g(R)})},"openFile");return new Promise(S)},pull:a(h=>{let S=0,g=100;return new Promise(a(function A(E,R){function N(k){(0,Qe.close)(o),u&&u.close(),R(k),p.#e?.forEach(F=>F(k))}a(N,"onError");let v=Buffer.allocUnsafe(262144);(0,Qe.read)(o,v,0,v.length,c,(k,F,K)=>{if(l+=F,k)return N(k);if(c===0){if(F<mr){g-- >0&&d!==!1?(_(),Ta.default.debug?.("File was empty, waiting for data to be written",i,g),setTimeout(()=>A(E,R),20).unref()):(Ta.default.debug?.("File was empty, throwing error",i,g),R(new Error(`Blob ${t.fileId} was empty`)));return}K.copy($f,0,0,mr);let re=Dm.getBigUint64(0);if(Number(re>>48n)===GL)return N(new Error("Error in blob: "+K.subarray(mr)));if(S=Number(re&0xffffffffffffn),S<qL&&p.size!==S&&(p.size=S,p.#t))for(let ae of p.#t)ae(S);K=K.subarray(mr,F),l-=mr}else if(F===0){let re=Buffer.allocUnsafe(8);return(0,Qe.read)(o,re,0,mr,0,ae=>{if(ae)return N(ae);if($f.set(re),S=Number(Dm.getBigUint64(0)&0xffffffffffffn),S>l){d!==!1?(f=setTimeout(()=>{N(new Error("File read timed out"))},g3).unref(),u=(0,Qe.watch)(i,{persistent:!1},()=>{clearTimeout(f),u.close(),_(),A(E,R)})):N(new Error("Blob is incomplete"));return}(0,Qe.close)(o),h.close(),E()})}else K=K.subarray(0,F);if(n!==void 0||s!==void 0){if(n&&l<n)return c+=F,A(E,R);s&&l>=s&&(l>s&&(K=K.subarray(0,s-c)),l=S=s),n&&n>c&&(K=K.subarray(n-c))}c+=F;try{h.enqueue(K)}catch(re){return Ta.default.debug?.("Error enqueuing chunk",re),E()}l===S&&((0,Qe.close)(o),h.close()),E()})},"readMore"))},"pull"),cancel(){(0,Qe.close)(o),clearTimeout(f),u&&u.close()}});function _(){if(d===void 0){let h=t.store,S=t.fileId+":blob";d=!h.attemptLock(S,0,()=>{d=!1,h.unlock(S,0)}),d||h.unlock(S,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 QL(this).saving??Promise.resolve()}},zL=500;a(jL,"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(En.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof Vf.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=Vf.Readable.from(e);else throw new Error("Invalid source type");return r};a(QL,"saveBlob");a(bR,"writeBlobWithStream");a(Bm,"getFileId");a(JL,"getFilePathForBlob");Mm=new Map;a(Hm,"getRootBlobPathsForDB");a(NR,"deleteRootBlobPathsForDB");a(XL,"rimrafSteadily");a(Kf,"getFilePath");a(T3,"writeBlobWithBuffer");a(A3,"generateFilePath");$L=new Map;a(R3,"getNextFileId");vm=128;a(y3,"getNextStorageIndex");a(b3,"createFrequencyTableForStoragePaths");a(km,"encodeBlobsWithFilePath");a(O3,"encodeBlobsAsBuffers");a(wR,"decodeBlobsWithWrites");a(IR,"decodeWithBlobCallback");a(Dc,"decodeFromDatabase");a(Aa,"deleteBlobsInObject");a(Yf,"findBlobsInObject");(0,lo.addExtension)({Class:Pi,type:11,unpack:a(function(e){let t=(0,lo.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(En.set(r,{storageIndex:t[1],fileId:t[2],store:Js}),Cc)return Cc(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(Au!==void 0&&(Pc=!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<KL)return r.size=t.contentBuffer.length,(0,lo.pack)([r,t.contentBuffer])}if(Au!==void 0){if(t=QL(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=Au,(0,lo.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,Qe.readFileSync)(Kf(t));if(n.length>=mr&&(n.copy($f,0,0,mr),Number(Dm.getBigUint64(0)&0xffffffffffffn)===n.length-mr))return Buffer.concat([(0,lo.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,lo.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});a(N3,"polyfillBlob")});var oM={};ve(oM,{asyncSerialization:()=>CR,contentTypes:()=>MR,findBestSerializer:()=>qm,getDeserializer:()=>po,registerContentHandlers:()=>jf,serialize:()=>Qf,serializeMessage:()=>ya,toCsvStream:()=>Gm});function I3(e){try{return e?.[0]===123?LR(e):e}catch{return e}}function jf(e){e.register(P3,{serializers:[{regex:/^application\/json$/,serializer:qf},{regex:/^application\/cbor$/,serializer:a(function(t){return new Lc.EncoderStream(zf).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?Mc.Readable.from((0,Di.encodeIter)(t,zf)):(0,Di.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,Di.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Lc.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 _=Yr.get(u);if(_){let h=(_.q||1)*d;h>s&&(n=_,i=_.type||u,s=h,o=p)}}if(!n){if(r)throw new tM.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(Yr.keys()).join(", "),406);n=Yr.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function Qf(e,t,r){let n=eM&&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 Pi)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}),DR.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,_o.createBrotliCompress)({params:{[_o.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?_o.constants.BROTLI_MODE_TEXT:_o.constants.BROTLI_MODE_GENERIC,[_o.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>eM?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,_o.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function ya(e,t,r){if(e?.contentType!=null&&e.data!=null)return e.data;Ra=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 Ra?.length>0?(Ra.length===1?Ra[0]:Promise.all(Ra)).then(()=>ya(e,t,!0)):n}finally{Ra=void 0}}function CR(e){if(Ra)Ra.push(e);else throw new Error("Unable to serialize asynchronously")}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 po(e="",t=!1){let r=v3(e),n=r.type&&Yr.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)&&DR.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 LR(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=Mc.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 Di,Lc,_o,tM,Mc,rM,PR,nM,DR,w3,sM,Wf,LR,zf,Yr,MR,ZL,iM,C3,P3,eM,Ra,L3,fo=be(()=>{yR();Di=require("msgpackr"),Lc=require("cbor-x"),_o=require("zlib"),tM=M(pe()),Mc=M(require("stream"));Kr();rM=M(yi()),PR=M(ce());B();nM=M(require("yaml")),DR=M(Ci());As();({Transform:w3}=require("json2csv")),sM=PR.default.get(x.SERIALIZATION_BIGINT)!==!1,Wf=sM?Ic:JSON.stringify,LR=sM?RR:JSON.parse,zf={useRecords:!1,useToJSON:!0},Yr=new Map,MR=Yr;We.contentTypes=MR;(0,rM._assignPackageExport)("contentTypes",MR);Yr.set("application/json",{serializeStream:qf,serialize:Wf,deserialize(e){return LR(e)},q:.8});ZL=new Lc.Encoder(zf);Yr.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new Lc.EncoderStream(zf).end(e)},serialize:ZL.encode,deserialize:ZL.decode,q:1});Yr.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?Mc.Readable.from((0,Di.encodeIter)(e,zf)):(0,Di.pack)(e)},serialize:Di.pack,deserialize:Di.unpack,q:.9});Yr.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});Yr.set("text/plain",{serialize(e){return e.toString()},serializeStream(e){return Mc.Readable.from(e.map?e.map(t=>t.toString()):e)},deserialize(e){return e.toString()},q:.2});Yr.set("text/yaml",{serialize(e){return nM.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Yr.set("text/event-stream",{serializeStream:a(function(e){return Mc.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(js,"createLogRecord");function wf(e){if(yi){if(OD(e),gs){_a=!1;try{process.stdout.write(e)}finally{_a=!0}}}else gs&&process.stdout.write(e)}a(wf,"logStdOut");function dm(e){if(yi){if(OD(e),gs){_a=!1;try{process.stderr.write(e)}finally{_a=!0}}}else gs&&process.stderr.write(e)}a(dm,"logStdErr");function OD(e){eR(),fa?oo.appendFileSync(fa,e):ZA||console.log(e)}a(OD,"logToFile");function rR(){try{oo.closeSync(fa)}catch{}fa=null}a(rR,"closeLogFile");function eR(){if(!fa){try{fa=oo.openSync(lm,"a")}catch(e){ZA||(ZA=!0,console.error(e))}setTimeout(()=>{rR()},V2).unref()}}a(eR,"openLogFile");function ND(...e){mr[Cr]<=mr.info&&wf(js("info",e))}a(ND,"info");function wD(...e){mr[Cr]<=mr.trace&&wf(js("trace",e))}a(wD,"trace");function um(...e){mr[Cr]<=mr.error&&dm(js("error",e))}a(um,"error");function ID(...e){mr[Cr]<=mr.debug&&wf(js("debug",e))}a(ID,"debug");function CD(...e){mr[Cr]<=mr.notify&&wf(js("notify",e))}a(CD,"notify");function PD(...e){mr[Cr]<=mr.fatal&&dm(js("fatal",e))}a(PD,"fatal");function DD(...e){mr[Cr]<=mr.warn&&dm(js("warn",e))}a(DD,"warn");function Q2(e,t,...r){t===yD.STDERR?dm(js(e,r)):wf(js(e,r))}a(Q2,"logCustomLevel");function J2(){let e;try{e=F2.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=bi.join(e,Kt.HDB_HOME_DIR_NAME,Kt.BOOT_PROPS_FILE_NAME);return oo.existsSync(t)||(t=bi.join(tR,"utility/hdb_boot_properties.file")),t}a(J2,"getPropsFilePath");function X2(e){Cr=e}a(X2,"setLogLevel");function TD(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(TD,"autoCastBoolean");function Z2(e){try{if(e.includes("config/settings.js")){let o=RD(e);return{level:o.get(Kt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:bi.dirname(o.get(Kt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(Kt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(Kt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=AD.parseDocument(oo.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===Kt.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(Z2,"getLogConfig");function e4(){try{let e=AD.parseDocument(oo.readFileSync($2,"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(e4,"getDefaultConfig");function t4(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(t4,"AuthAuditLog")});var nR=w((Kye,vD)=>{"use strict";var r4=require("util"),n4=require("path"),s4=require("child_process"),i4=r4.promisify(s4.execFile),o4=1e3*1e3*10;vD.exports={findPs:a4};async function a4(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await i4("ps",["wwxo",`pid,${r}`],{maxBuffer:o4});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:n4.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(a4,"findPs")});var vt=w((Wye,xD)=>{"use strict";var c4="__dbis__",l4="__txns__",u4="__environment_name__",d4="__dbi_defintion__",f4={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"},_4=["__createdtime__","__updatedtime__"],p4="\uFFFF",UD={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},h4=Object.values(UD);xD.exports={AUDIT_STORE_NAME:l4,INTERNAL_DBIS_NAME:c4,DBI_DEFINITION_NAME:d4,SEARCH_TYPES:f4,TIMESTAMP_NAMES:_4,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:u4,TRANSACTIONS_DBI_NAMES_ENUM:UD,TRANSACTIONS_DBIS:h4,OVERFLOW_MARKER:p4}});var Bn=w((zye,KD)=>{"use strict";var BD=(H(),C(q)),HD=vt(),kD={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},FD=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),GD={500:FD("There was an error processing your request."),400:"Invalid request"},m4=GD[kD.INTERNAL_SERVER_ERROR],E4={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")},g4={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},S4={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"},T4={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 ${HD.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${HD.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"},A4={ATTR_NAME_LENGTH_ERR:a(e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${BD.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 ${BD.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"},qD={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"},R4={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."},y4={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")},b4={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"},O4={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},N4={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")},$D={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")},VD={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")},w4={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"},I4={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},C4={...qD,...S4,...E4,...R4,...y4,...b4,...O4,...N4,...A4,...$D,...VD,...w4,...I4,...g4};KD.exports={CHECK_LOGS_WRAPPER:FD,HDB_ERROR_MSGS:C4,DEFAULT_ERROR_MSGS:GD,DEFAULT_ERROR_RESP:m4,HTTP_STATUS_CODES:kD,LMDB_ERRORS_ENUM:T4,AUTHENTICATION_ERROR_MSGS:qD,VALIDATION_ERROR_MSGS:$D,ITC_ERRORS:VD}});var pe=w((Qye,zD)=>{"use strict";var fu=Bn(),P4=z(),D4=(H(),C(q)),fm=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,YD),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&&P4[s](i)}},sR=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}},iR=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function YD(e,t,r,n=D4.LOG_LEVELS.ERROR,s=null,i=!1){if(WD(e))return e;let o=new fm(e,t,r,n,s);return i&&delete o.stack,o}a(YD,"handleHDBError");function WD(e){return e.__proto__.constructor.name===fm.name}a(WD,"isHDBError");zD.exports={isHDBError:WD,handleHDBError:YD,ClientError:sR,ServerError:iR,hdb_errors:fu}});var gt=w((Xye,tL)=>{"use strict";var Lf=(H(),C(q)),L4=se(),fn=ae(),Mf=require("path"),M4=require("minimist"),jD=require("fs-extra"),QD=require("lodash");fn.initSync();var{CONFIG_PARAMS:pa,DATABASES_PARAM_CONFIG:If,SYSTEM_SCHEMA_NAME:_m}=Lf,Cf,Pf,Df;function JD(){if(Cf!==void 0)return Cf;if(fn.getHdbBasePath()!==void 0)return Cf=fn.get(pa.STORAGE_PATH)||Mf.join(fn.getHdbBasePath(),Lf.DATABASES_DIR_NAME),Cf}a(JD,"getBaseSchemaPath");function XD(){if(Pf!==void 0)return Pf;if(fn.getHdbBasePath()!==void 0)return Pf=eL(_m),Pf}a(XD,"getSystemSchemaPath");function ZD(){if(Df!==void 0)return Df;if(fn.getHdbBasePath()!==void 0)return Df=fn.get(Lf.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Mf.join(fn.getHdbBasePath(),Lf.TRANSACTIONS_DIR_NAME),Df}a(ZD,"getTransactionAuditStoreBasePath");function v4(e,t){let r=fn.get(pa.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Mf.join(ZD(),e.toString())}a(v4,"getTransactionAuditStorePath");function eL(e,t){e=e.toString(),t=t&&t.toString();let r=fn.get(Lf.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Mf.join(JD(),e)}a(eL,"getSchemaPath");function U4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,M4(process.argv));let n=r[pa.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!L4.isObject(n))throw o;i=n}for(let o of i){let c=o[_m];if(!c)continue;let l=fn.get(pa.DATABASES);l=l??{};let u=c?.tables?.[t]?.[If.PATH];if(u)return QD.set(l,[_m,If.TABLES,t,If.PATH],u),fn.setProperty(pa.DATABASES,l),u;let f=c?.[If.PATH];if(f)return QD.set(l,[_m,If.PATH],f),fn.setProperty(pa.DATABASES,l),f}}let s=r[pa.STORAGE_PATH.toUpperCase()];if(s){if(!jD.pathExistsSync(s))throw new Error(s+" does not exist");let i=Mf.join(s,e);return jD.mkdirsSync(i),fn.setProperty(pa.STORAGE_PATH,s),i}return XD()}a(U4,"initSystemSchemaPaths");function x4(){Cf=void 0,Pf=void 0,Df=void 0}a(x4,"resetPaths");tL.exports={getBaseSchemaPath:JD,getSystemSchemaPath:XD,getTransactionAuditStorePath:v4,getTransactionAuditStoreBasePath:ZD,getSchemaPath:eL,initSystemSchemaPaths:U4,resetPaths:x4}});var _n=w((rbe,oL)=>{"use strict";var B4=Bn().LMDB_ERRORS_ENUM,ebe=require("lmdb"),H4=vt(),tbe=require("buffer").Buffer,{OVERFLOW_MARKER:rL,MAX_SEARCH_KEY_LENGTH:pm}=H4,nL=["number","string","symbol","boolean","bigint"];function k4(e){if(e=e?.primaryStore||e,!e)throw new Error(B4.ENV_REQUIRED)}a(k4,"validateEnv");function F4(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(F4,"stringifyData");function G4(e){return e instanceof Date?e.valueOf():e}a(G4,"convertKeyValueToWrite");function q4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(nL.includes(typeof e))return e.length>pm?[e.slice(0,pm)+rL]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(nL.includes(typeof i))i.length>pm?r.push(i.slice(0,pm)+rL):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(q4,"getIndexedValues");var hm=0,sL=0;function iL(){sL=Date.now()-performance.now()}a(iL,"adjustStartTime");iL();var $4=6e4;setInterval(iL,$4).unref();function V4(){let e=performance.now()+sL;return e>hm?(hm=e,e):(hm+=488e-6,hm)}a(V4,"getNextMonotonicTime");oL.exports={validateEnv:k4,stringifyData:F4,convertKeyValueToWrite:G4,getNextMonotonicTime:V4,getIndexedValues:q4}});var vf=w((sbe,aL)=>{"use strict";var K4=(H(),C(q)).OPERATIONS_ENUM,oR=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=K4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};aL.exports=oR});var Uf=w((abe,dL)=>{"use strict";var obe=vf(),mm=(H(),C(q)),aR=se(),cL=z(),Y4=require("uuid"),{handleHDBError:Em,hdb_errors:W4}=pe(),{HDB_ERROR_MSGS:gm,HTTP_STATUS_CODES:Sm}=W4;dL.exports=lL;function lL(e,t,r){for(let s=0;s<t.length;s++)uL(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];z4(i,r,e.operation)}}a(lL,"processRows");lL.validateAttribute=uL;function uL(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(aR.isEmptyOrZeroLength(e)||aR.isEmpty(e.trim()))throw Em(new Error,gm.ATTR_NAME_NULLISH_ERR,Sm.BAD_REQUEST,void 0,void 0,!0)}a(uL,"validateAttribute");function z4(e,t,r){if(!e.hasOwnProperty(t)||aR.isEmptyOrZeroLength(e[t])){if(r===mm.OPERATIONS_ENUM.INSERT||r===mm.OPERATIONS_ENUM.UPSERT){e[t]=Y4.v4();return}throw cL.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 cL.error(e),Em(new Error,gm.HASH_VAL_LENGTH_ERR,Sm.BAD_REQUEST,void 0,void 0,!0)}a(z4,"validateHash")});var fL,Hn,cR,_u=be(()=>{fL=require("events"),Hn=class extends fL.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new cR;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)}},cR=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 SL(e){uR=e}function X4(){J4=setInterval(function(){for(let e of lR)if(e.stale){let t=e.getContext()?.url;mL.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},Q4).unref()}var dR,hL,mL,EL,gL,_L,lR,j4,xf,pL,uR,bc,Tm,Q4,J4,Am=be(()=>{dR=M(_n()),hL=M(pe()),mL=M(z()),EL=M(ae());H();gL=M(se()),_L=100,lR=new Set,j4=(0,gL.convertToMS)(EL.get(B.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(SL,"replicationConfirmation");bc=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),lR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(lR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(xf&&!this.overloadChecked&&performance.now()-pL>j4)throw new hL.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,dR.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?.letItLinger?2:0;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)<_L>>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 xf||(xf=s,pL=performance.now(),xf.then(()=>{xf=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];uR&&_&&i.push(uR(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)+_L/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 bc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,dR.getNextMonotonicTime)())}getReadTxn(){}},Q4=3e4;a(X4,"startMonitoringTxns");X4()});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 bc;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({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var TL,Oc=be(()=>{TL=M(Ri());Am();a(Nt,"transaction");(0,TL._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 _R(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?_R(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",A=f(h.conditions,!E,_);return E?(O,v)=>A.some(F=>F(O,v)):(O,v)=>A.every(F=>F(O,v))}let g=(h.attribute||h[0])===r.primaryKey,R=kf(h,r,i,c,g,_);return p&&S<d.length-1&&_&&(_=a3(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],A=Ni(n.attributes,E);if(A.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 O=A.definition?.tableClass||A.elements?.definition?.tableClass,v=new Map,F=mu({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,O,s,v);if(A.relationship.to){i[o[0]]=v;let G=!!Ni(O.attributes,A.relationship.to)?.elements;F=n3(F,A,O.primaryStore,G,v)}if(A.relationship.from){let G=a(Y=>(Y?.key!==void 0&&(Y=Y.key),mu({attribute:A.relationship.from,value:Y},t,r,n,s,v)),"searchEntry");A.elements?(i[o[0]]=v,F=s3(F,A,O.primaryStore,v,G)):F=F.flatMap(G)}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(pR[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]=Oi.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>Ss.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,Ss.MAX_SEARCH_KEY_LENGTH)+Ss.OVERFLOW_MARKER,p=!1,h=kf(e,n,null,i,S)),typeof f=="string"&&f.length>Ss.MAX_SEARCH_KEY_LENGTH&&(f=f.slice(0,Ss.MAX_SEARCH_KEY_LENGTH)+Ss.OVERFLOW_MARKER,d=!0,h=h??kf(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??kf(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:A,value:O}){return this?.isSync?O&&h(O)?A:ha.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(O&&h(O)?A:ha.SKIP)}catch(G){F(G)}}))}:A=>A.value==null&&!(A.metadataFlags&(kn|Ea))?ha.SKIP:A);return E.hasEntries=!0,E}else return g?g.getRange(R).map(h?function({key:E,value:A}){let O;return typeof E=="string"&&E.length>Ss.MAX_SEARCH_KEY_LENGTH?O=n.primaryStore.get(A):O={[o]:E},this.isSync?h(O)?A:ha.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(h(O)?A:ha.SKIP)}catch(G){F(G)}}))}:({value:E})=>E):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:E,value:A}){return this.isSync?A&&h(A)?E:ha.SKIP:new Promise((O,v)=>setImmediate(()=>{try{O(A&&h(A)?E:ha.SKIP)}catch(F){v(F)}}))})}function Ni(e,t){if(Array.isArray(t))if(t.length>1){let r=Ni(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?Ni(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 n3(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 s3(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 kf(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=Ni(t.attributes,f),p=d.definition?.tableClass||d.elements.definition?.tableClass,_=n?.[f],h=kf({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},p,r,_?.[f]?.joined,c[1]===p.primaryKey,i);if(!h)return;if(_){_.filters||(_.filters=[]),_.filters.push(h);return}let S=t.propertyResolvers?.[f],g,R=a((E,A)=>{let O,v;if(S){if(S.from&&h.idFilter){if(!g)if(h.idFilter.idSet?.size===1){for(let G of h.idFilter.idSet)e={attribute:S.from,value:G};g=u(S.from,h.idFilter,!0,!0)}else g=u(S.from,h.idFilter,!1,!0);let F=g(E);return g.idFilter&&(R.idFilter=g.idFilter),F}v=S(E,r,A),O=v?.value}else O=E[f];return O?Array.isArray(O)?O.some(h):h(O,v):!1},"recordFilter");return R}}switch(l instanceof Date&&(l=l.getTime()),pR[o]||o){case Ss.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,Oi.compareKeys)(f,l[0])>=0&&(0,Oi.compareKeys)(f,l[1])<=0,!0);case"gt":return u(c,f=>(0,Oi.compareKeys)(f,l)>0);case"ge":return u(c,f=>(0,Oi.compareKeys)(f,l)>=0);case"lt":return u(c,f=>(0,Oi.compareKeys)(f,l)<0);case"le":return u(c,f=>(0,Oi.compareKeys)(f,l)<=0);case"ne":return u(c,f=>(0,Oi.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 A=E[f],O;if(typeof A!="object"||!A||_?O=d(A):Array.isArray(A)?O=A.some(d):A instanceof Date&&(O=d(A.getTime())),p&&(g++,!O&&!R.idFilter&&++S/g*(i-g)>h)){let v=mu(e,r.transaction.getReadTxn(),!1,t).map(Eu),F=new Set(v);R.idFilter=G=>F.has(Eu(G)),R.idFilter.idSet=F}return O}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/ao(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=pR[n]||n,n===Ss.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=Ni(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*ao(e.indices[i.relationship.from])/(ao(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=ao(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=t3*ao(e.primaryStore)+1:n==="between"?r.estimated_count=e3*ao(e.primaryStore)+1:n==="sort"?r.estimated_count=ao(e.primaryStore)+1:r.estimated_count=Z4*ao(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(ma=e,pu.lastIndex=0,i3.test(e))try{let t=Bf(new hu,"");if(pn!==ma.length)throw new SyntaxError("Unable to parse query, unexpected end of query");return t}catch(t){throw t.statusCode=400,t.message=`Unable to parse query, ${t.message} at position ${pn} in '${ma}'`,t}else return new URLSearchParams(e)}function Bf(e,t){let r=pu,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(ma);){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=AL}else{if(l=decodeURIComponent,i="equals",!f)throw new SyntaxError("attribute must be specified before equality comparator");s=Hf(f)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=r3[d],l=fR[i]?AL:decodeURIComponent,!f)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=Hf(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"&&RL(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(Hf(f)),s=void 0;break;case"(":pu.lastIndex=pn;let _=Bf(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=yL(_);break;default:throw new SyntaxError(`unknown query function call ${f}`)}ma[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=Bf([],"}"),p.name=f,e.push(p),ma[pn]===","?r.lastIndex=++pn:o=!0;break;case"[":pu.lastIndex=pn,f?(p=Bf(new hu,"]"),p.name=f):p=Bf(e.conditions?new hu:[],"]"),e.conditions?(Rm(e,u),e.conditions.push(p),s=null):e.push(p),ma[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"&&RL(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(Hf(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?o3:pu,r.lastIndex=pn),pn===ma.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 Hf(e){return e.indexOf(".")>-1?e.split(".").map(Hf):decodeURIComponent(e)}function AL(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 RL(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 yL(e){let t=bL(e[0]);return e.length>1&&(t.next=yL(e.slice(1))),t}function bL(e){if(Array.isArray(e)){let t=bL(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 ao(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function a3(e,t,r){return t*r/ao(e)}var hn,Ss,Oi,ha,Z4,e3,t3,r3,fR,pR,i3,pu,o3,pn,ma,hu,Nc,Ff=be(()=>{hn=M(pe()),Ss=M(vt()),Oi=require("ordered-binary"),ha=require("lmdb");Gf();Z4=.3,e3=.1,t3=.05,r3={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},fR={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(_R,"executeConditions");a(mu,"searchByIndex");a(Ni,"findAttribute");a(n3,"joinTo");a(s3,"joinFrom");pR={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(kf,"filterByType");a(ym,"estimateCondition");i3=/[()[\]|!<>.]|(=\w*=)/,pu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,o3=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(bm,"parseQuery");a(Bf,"parseBlock");a(Rm,"assignOperator");a(Hf,"decodeProperty");a(AL,"typedDecoding");a(RL,"wildcardDecoding");a(yL,"toSortObject");a(bL,"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(ao,"estimatedEntryCount");a(a3,"intersectionEstimate");Nc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});var mR={};ve(mR,{MultiPartId:()=>Nm,Resource:()=>$r,snake_case:()=>l3,transformForSelect:()=>wm});function l3(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function OL(e,t){if(wc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(wc=!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){wc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return wc=!0,null;e[e.length-1]==="/"&&(wc=!0)}return t.coerceId(decodeURIComponent(e))}function Fn(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 Nc(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 Gn(e,t){let r=new IL.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 hR(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):hR(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(hR(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(hR(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 NL,wL,IL,c3,$r,Om,wc,Nm,ga=be(()=>{NL=require("crypto");_u();wL=M(Ri()),IL=M(pe());Oc();Ff();c3={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=Fn(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=Fn(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):Gn(t,"put")},{hasContent:!0,type:"update"});static patch=Fn(function(t,r,n,s){return t.patch?t.patch(s,r):Gn(t,"patch")},{hasContent:!0,type:"update"});static delete=Fn(function(t,r,n,s){return t.delete?t.delete(r):Gn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,NL.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):Gn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=Fn(function(t,r,n,s){return t.invalidate?t.invalidate(r):Gn(t,"delete")},{hasContent:!1,type:"update"});static post=Fn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=Fn(function(t,r,n,s){return t.connect?t.connect(s,r):Gn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Fn(function(t,r,n,s){return t.subscribe?t.subscribe(r):Gn(t,"subscribe")},{type:"read"});static publish=Fn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.publish?t.publish(s,r):Gn(t,"publish")},{hasContent:!0,type:"create"});static search=Fn(function(t,r,n,s){let i=t.search?t.search(r):Gn(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=Fn(function(t,r,n,s){return t.search?t.search(s,r):Gn(t,"search")},{hasContent:!0,type:"read"});static copy=Fn(function(t,r,n,s){return t.copy?t.copy(s,r):Gn(t,"copy")},{hasContent:!0,type:"create"});static move=Fn(function(t,r,n,s){return t.move?t.move(s,r):Gn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#n)return(await this.constructor.create(this.#e,t,this.#t)).#e;Gn(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&&c3[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:OL(t,this),isCollection:wc}}let i=OL(t,this);return wc?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r.getContext?.(),o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(f=>f.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u.#e===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let f of l){let d=f.#e,p=u.get(d);p?p.push(f):u.set(d,[f])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s.#n=!0),s}subscribe(t){return new Hn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Hn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this.#e}getContext(){return this.#t}};(0,wL._assignPackageExport)("Resource",$r);a(l3,"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(OL,"pathToId");Nm=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(Fn,"transactional");a(Gn,"missingMethod");a(hR,"selectFromObject");a(wm,"transformForSelect")});var Sa,ER=be(()=>{Sa=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var DL={};ve(DL,{Resources:()=>Im,keyArrayToString:()=>gu,resetResources:()=>u3,resources:()=>wi});function u3(){return wi=new Im}function gu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var CL,PL,Im,wi,Su=be(()=>{Oc();ER();CL=M(z()),PL=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 PL.ServerError(`Conflicting paths for ${t}`);CL.default.error(c),i.Resource=new Sa(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let f=this.get(c.slice(0,u));f&&(f.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s=0,i,o=t.length;for(;n<o;){s=n,n=t.indexOf("/",n),n===-1&&(n=o);let u=n===o?t:t.slice(0,n),f=this.get(u),d=-1;if(!f&&n===o&&(d=u.indexOf("?",s),d!==-1)){let p=u.slice(0,d);f=this.get(p)}if(f&&(!r||f.exportTypes?.[r]!==!1)){if(f.relativeURL=t.slice(d!==-1?d:n),!f.hasSubPaths)return f;i=f}n+=2}if(i)return i;let c=t.indexOf("?"),l=c>-1?t.slice(0,c):t;return i=this.get(l),!i&&l.indexOf(".")>-1&&(i=this.get(l.split(".")[0])),i&&(!r||i.exportTypes?.[r]!==!1)?i.relativeURL=c>-1?t.slice(c):"":i||(i=this.get(""),i&&(!r||i.exportTypes?.[r]!==!1)&&(t.charAt(0)!=="/"&&(t="/"+t),i.relativeURL=t)),i}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Nt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(u3,"resetResources");a(gu,"keyArrayToString")});var Tu={};ve(Tu,{server:()=>Ye});var LL,Ye,Vr=be(()=>{LL=M(Ri()),Ye={};(0,LL._assignPackageExport)("server",Ye)});var TR={};ve(TR,{loadGQLSchema:()=>_3,start:()=>SR,startOnMainThread:()=>f3});function SR({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 X=F(Y.type);return X.nullable=!1,X}if(Y.kind==="ListType")return{type:"array",elements:F(Y.type)};let ie={type:Y.name?.value};return Object.defineProperty(ie,"location",{value:Y.loc.startToken}),ie};a(F,"getProperty");let E=R.name.value,A=[],O={table:null,database:null,properties:A};p.set(E,O);for(let Y of R.directives){if(Y.name.value==="table"){for(let ie of Y.arguments)O[ie.name.value]=ie.value.value;O.schema&&(O.database=O.schema),O.table||(O.table=E),O.audit&&(O.audit=O.audit!=="false"),O.attributes=O.properties,_.push(O)}if(Y.name.value==="sealed"&&(O.sealed=!0),Y.name.value==="splitSegments"&&(O.splitSegments=!0),Y.name.value==="replicate"&&(O.replicate=!0),Y.name.value==="export"){O.export=!0;for(let ie of Y.arguments)typeof O.export!="object"&&(O.export={}),O.export[ie.name.value]=ie.value.value}}let v=!1,G={};for(let Y of R.fields){let te=F(Y.type);te.name=Y.name.value,A.push(te),G[te.name]=void 0;for(let ie of Y.directives){let X=ie.name.value;if(X==="primaryKey")v?console.warn("Can not define two attributes as a primary key at",ie.loc):(te.isPrimaryKey=!0,v=!0);else if(X==="indexed")te.indexed=!0;else if(X==="computed"){for(let ne of ie.arguments||[])if(ne.name.value==="from"){let Q=ne.value.value;te.computed={from:g(Q,ne,G)},te.version==null&&(te.version=Q)}else ne.name.value==="version"&&(te.version=ne.value.value);te.computed=te.computed||!0}else if(X==="relationship"){let ne={};for(let Q of ie.arguments)ne[Q.name.value]=Q.value.value;te.relationship=ne}else if(X==="createdTime")te.assignCreatedTime=!0;else if(X==="updatedTime")te.assignUpdatedTime=!0;else if(X==="expiresAt")te.expiresAt=!0;else if(X==="allow"){let ne=te.authorizedRoles=[];for(let Q of ie.arguments)Q.name.value==="role"&&ne.push(Q.value.value)}else server.knownGraphQLDirectives.includes(X)&&console.warn(`@${X} is an unknown directive, at`,ie.loc)}}O.type=E,E==="Query"&&(h=O)}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):d3.includes(R.type)||(0,vL.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,gR.dirname)(n),R.tableClass):i.set((0,gR.dirname)(n)+"/"+(R.export.name||R.type),R.tableClass,R.export));function g(R,E,A){return new ML.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${R}; } } } } computed;`,{filename:s,lineOffset:E.loc.startToken.line-1,columnOffset:E.loc.startToken.column}).runInThisContext()(A)}a(g,"createComputedFrom")}}var gR,ML,vL,d3,f3,_3,UL=be(()=>{gR=require("path"),ML=require("node:vm");Pe();vL=M(et()),d3=["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(SR,"start");f3=SR,_3=SR({ensureTable:dt}).handleFile});var qL={};ve(qL,{parse:()=>RR,streamAsJSON:()=>qf,stringify:()=>Ic});function qf(e){return new AR({value:e})}function xL(e){return console.error(e),JSON.stringify(e.toString())}function BL(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Ic(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===FL)return GL(e);if(t.resolution)return t.resolution.then(()=>Ic(e));throw t}}function GL(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+=GL(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Ic(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function RR(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),m3.test(e)?p3.parse(e):JSON.parse(e)):null}var HL,kL,p3,h3,FL,AR,m3,yR=be(()=>{HL=require("stream"),kL=M(require("json-bigint-fixes")),p3=(0,kL.default)({useNativeBigInt:!0}),h3=1e4,FL={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw FL};a(qf,"streamAsJSON");AR=class extends HL.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),xL)}catch(s){yield xL(s)}else yield Ic(t)}else yield Ic(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);BL(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>h3?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 BL(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(xL,"handleError");a(BL,"when");a(Ic,"stringify");a(GL,"jsStringify");m3=/[[,:]\s*-?\d{16,}/;a(RR,"parse")});var Ii=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:()=>Ci,blobsWereEncoded:()=>Pc,databasePaths:()=>Mm,decodeBlobsWithWrites:()=>wR,decodeFromDatabase:()=>Dc,decodeWithBlobCallback:()=>IR,deleteBlob:()=>JL,deleteBlobsInObject:()=>Aa,deleteRootBlobPathsForDB:()=>NR,encodeBlobsAsBuffers:()=>N3,encodeBlobsWithFilePath:()=>km,findBlobsInObject:()=>Yf,getFileId:()=>Bm,getFilePathForBlob:()=>ZL,getRootBlobPathsForDB:()=>Hm,setDeletionDelay:()=>T3});function jL(){}function JL(e){let t=ZL(e);t&&setTimeout(()=>{(0,je.unlink)(t,r=>{r&&Ta.default.debug?.("Error trying to remove blob file",r)})},QL)}function T3(e){QL=e}function XL(e){let t=mn.get(e);if(!t)t={storageIndex:0,fileId:null,store:Qs},mn.set(e,t);else{if(t.saving)return t;t.store=Qs}return R3(t),t.source?bR(e,t.source,t):t.contentBuffer?A3(e,t):bR(e,Vf.Readable.from(e.stream()),t),t}function bR(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(g3),_=(0,Um.createDeflate)(),t.pipe(_).pipe(d)):(p||d.write(E3),t.pipe(d)),t.on("error",S);function h(g){let R=BigInt(g),E=new Uint8Array(Er),A=new DataView(E.buffer);return R|=BigInt(o?OR:zL)<<48n,A.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 ZL(e){let t=mn.get(e);return t?.fileId&&Kf(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,lo.join)(n,e.databaseName)):t=[(0,lo.join)((0,xm.getHdbBasePath)(),"blobs",e.databaseName)],Mm.set(e,t)}return t}async function NR(e){let t=Mm.get(e);t&&await Promise.all(t.map(r=>eM(r)))}async function eM(e){for(let t of await(0,Js.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await eM((0,lo.join)(e,t.name));else try{await(0,Js.unlink)((0,lo.join)(e,t.name))}catch(r){Ta.default.warn?.("Error deleting file",r)}try{await(0,Js.rmdir)(e)}catch(t){Ta.default.warn?.("Error deleting directory",t)}}function Kf({storageIndex:e,fileId:t,store:r}){let n=Hm(r);return(0,lo.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 A3(e,t){let r=t.contentBuffer,n=r.length;if(!(n<WL))return e.size=n,bR(e,Vf.Readable.from([r]),t)}function R3(e){let t=Hm(e.store),r=y3(),n=t?.length>1?b3(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=Kf(e),o=(0,lo.dirname)(i);(0,je.existsSync)(o)||(0,YL.ensureDirSync)(o),e.filePath=i}function y3(){let e=KL.get(Qs);if(!e){let t=0,r=Hm(Qs);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,lo.join)(n,o.toString(16))}t=Math.max(t,s)}e=new BigInt64Array([BigInt(t)+1n]),e=new BigInt64Array(Qs.getUserSharedBuffer("blob-file-id",e.buffer)),KL.set(Qs,e)}return Number(Atomics.add(e,0,1n))}function b3(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,O3(e)),e.frequencyTable[t%vm]}async function O3(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,Qs=r,Pc=!1;try{return e()}finally{Au=void 0,Qs=void 0}}function N3(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 wR(e,t){try{Pr=[],Cc=t,e()}catch(n){throw Cc=void 0,Pr=void 0,n}Cc=void 0;let r=Pr.length<2?Pr[0]:Promise.all(Pr);return Pr=void 0,r}function IR(e,t){try{return Cc=t,e()}finally{Cc=void 0}}function Dc(e,t){return Qs=t,e()}function Aa(e){Yf(e,t=>{JL(t)})}function Yf(e,t){if(e instanceof Ci)t(e);else if(e.constructor===Object||Array.isArray(e))for(let r in e)typeof e[r]=="object"&&Yf(e[r],t)}function w3(){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 co,Js,je,Um,Vf,YL,xm,lo,Ta,WL,Er,zL,OR,$L,E3,g3,VL,mn,Cc,Ci,Au,Pr,Qs,Pc,$f,Dm,S3,Lm,QL,Mm,KL,vm,Ts=be(()=>{co=require("msgpackr"),Js=require("node:fs/promises"),je=require("node:fs"),Um=require("node:zlib"),Vf=require("node:stream"),YL=require("fs-extra"),xm=M(ae());H();lo=require("path"),Ta=M(Ii());uo();WL=8192,Er=8,zL=0,OR=1,$L=255,E3=new Uint8Array([0,zL,255,255,255,255,255,255]),g3=new Uint8Array([0,OR,255,255,255,255,255,255]),VL=0xffffffffffff,mn=new WeakMap,Ci=global.Blob||w3(),Pc=!1,$f=new Uint8Array(8),Dm=new DataView($f.buffer),S3=6e4;a(jL,"InstanceOfBlobWithNoConstructor");jL.prototype=Ci.prototype;Lm=class e extends jL{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):(PR()&&CR(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=Kf(t),o,c=a(async()=>{let l,u=Er;try{if(l=await(0,Js.readFile)(i),l.length>=Er){l.copy($f,0,0,Er);let d=Dm.getBigUint64(0);if(Number(d>>48n)===$L)throw new Error("Error in blob: "+buffer.subarray(Er));if(u=Number(d&0xffffffffffffn),u<n&&(u=n),u<VL&&(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]===OR?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(h){h.enqueue(r),h.close()}});let i=Kf(t),o,c=0,l=0,u,f,d,p=this;return new ReadableStream({start(){let h=1e3,S=a((g,R)=>{(0,je.open)(i,"r",(E,A)=>{if(E){if(E.code==="ENOENT"&&d!==!1&&(Ta.default.debug?.("File does not exist yet, waiting for it to be created",i,h),h-- >0))return setTimeout(()=>{_(),S(g,R)},20).unref();R(E),p.#e?.forEach(O=>O(E))}else o=A,g(A)})},"openFile");return new Promise(S)},pull:a(h=>{let S=0,g=100;return new Promise(a(function R(E,A){function O(F){(0,je.close)(o),u&&u.close(),A(F),p.#e?.forEach(G=>G(F))}a(O,"onError");let v=Buffer.allocUnsafe(262144);(0,je.read)(o,v,0,v.length,c,(F,G,Y)=>{if(l+=G,F)return O(F);if(c===0){if(G<Er){g-- >0&&d!==!1?(_(),Ta.default.debug?.("File was empty, waiting for data to be written",i,g),setTimeout(()=>R(E,A),20).unref()):(Ta.default.debug?.("File was empty, throwing error",i,g),A(new Error(`Blob ${t.fileId} was empty`)));return}Y.copy($f,0,0,Er);let te=Dm.getBigUint64(0);if(Number(te>>48n)===$L)return O(new Error("Error in blob: "+Y.subarray(Er)));if(S=Number(te&0xffffffffffffn),S<VL&&p.size!==S&&(p.size=S,p.#t))for(let ie of p.#t)ie(S);Y=Y.subarray(Er,G),l-=Er}else if(G===0){let te=Buffer.allocUnsafe(8);return(0,je.read)(o,te,0,Er,0,ie=>{if(ie)return O(ie);if($f.set(te),S=Number(Dm.getBigUint64(0)&0xffffffffffffn),S>l){d!==!1?(f=setTimeout(()=>{O(new Error("File read timed out"))},S3).unref(),u=(0,je.watch)(i,{persistent:!1},()=>{clearTimeout(f),u.close(),_(),R(E,A)})):O(new Error("Blob is incomplete"));return}(0,je.close)(o),h.close(),E()})}else Y=Y.subarray(0,G);if(n!==void 0||s!==void 0){if(n&&l<n)return c+=G,R(E,A);s&&l>=s&&(l>s&&(Y=Y.subarray(0,s-c)),l=S=s),n&&n>c&&(Y=Y.subarray(n-c))}c+=G;try{h.enqueue(Y)}catch(te){return Ta.default.debug?.("Error enqueuing chunk",te),E()}l===S&&((0,je.close)(o),h.close()),E()})},"readMore"))},"pull"),cancel(){(0,je.close)(o),clearTimeout(f),u&&u.close()}});function _(){if(d===void 0){let h=t.store,S=t.fileId+":blob";d=!h.attemptLock(S,0,()=>{d=!1,h.unlock(S,0)}),d||h.unlock(S,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 XL(this).saving??Promise.resolve()}},QL=500;a(JL,"deleteBlob");a(T3,"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 Vf.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=Vf.Readable.from(e);else throw new Error("Invalid source type");return r};a(XL,"saveBlob");a(bR,"writeBlobWithStream");a(Bm,"getFileId");a(ZL,"getFilePathForBlob");Mm=new Map;a(Hm,"getRootBlobPathsForDB");a(NR,"deleteRootBlobPathsForDB");a(eM,"rimrafSteadily");a(Kf,"getFilePath");a(A3,"writeBlobWithBuffer");a(R3,"generateFilePath");KL=new Map;a(y3,"getNextFileId");vm=128;a(b3,"getNextStorageIndex");a(O3,"createFrequencyTableForStoragePaths");a(km,"encodeBlobsWithFilePath");a(N3,"encodeBlobsAsBuffers");a(wR,"decodeBlobsWithWrites");a(IR,"decodeWithBlobCallback");a(Dc,"decodeFromDatabase");a(Aa,"deleteBlobsInObject");a(Yf,"findBlobsInObject");(0,co.addExtension)({Class:Ci,type:11,unpack:a(function(e){let t=(0,co.unpack)(e),r=new Lm;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(!Qs)throw new Error("No store specified, can not load blob from storage");if(mn.set(r,{storageIndex:t[1],fileId:t[2],store:Qs}),Cc)return Cc(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&&(Pc=!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<WL)return r.size=t.contentBuffer.length,(0,co.pack)([r,t.contentBuffer])}if(Au!==void 0){if(t=XL(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=Au,(0,co.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,je.readFileSync)(Kf(t));if(n.length>=Er&&(n.copy($f,0,0,Er),Number(Dm.getBigUint64(0)&0xffffffffffffn)===n.length-Er))return Buffer.concat([(0,co.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,co.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});a(w3,"polyfillBlob")});var cM={};ve(cM,{asyncSerialization:()=>CR,contentTypes:()=>vR,findBestSerializer:()=>qm,getDeserializer:()=>po,hasAsyncSerialization:()=>PR,registerContentHandlers:()=>jf,serialize:()=>Qf,serializeMessage:()=>Ra,toCsvStream:()=>Gm});function C3(e){try{return e?.[0]===123?MR(e):e}catch{return e}}function jf(e){e.register(D3,{serializers:[{regex:/^application\/json$/,serializer:qf},{regex:/^application\/cbor$/,serializer:a(function(t){return new Lc.EncoderStream(zf).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?Mc.Readable.from((0,Pi.encodeIter)(t,zf)):(0,Pi.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,Pi.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Lc.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 nM.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 Qf(e,t,r){let n=rM&&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 Ci)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}),LR.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,_o.createBrotliCompress)({params:{[_o.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?_o.constants.BROTLI_MODE_TEXT:_o.constants.BROTLI_MODE_GENERIC,[_o.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>rM?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,_o.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function Ra(e,t,r){if(e?.contentType!=null&&e.data!=null)return e.data;fo=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 fo?.length>0?(fo.length===1?fo[0]:Promise.all(fo)).then(()=>Ra(e,t,!0)):n}finally{fo=void 0}}function CR(e){if(fo)fo.push(e);else throw new Error("Unable to serialize asynchronously")}function PR(){return!!fo}function L3(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 v3(e){return M3.includes(e)}function U3(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 po(e="",t=!1){let r=U3(e),n=r.type&&Kr.get(r.type)?.deserialize||x3(r);return t?s=>L3(s).then(n):n}function x3(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!v3(e.parameters.charset)&&LR.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 MR(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function B3(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=Mc.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 I3(n,s);return r.pipe(i)}var Pi,Lc,_o,nM,Mc,sM,DR,iM,LR,I3,oM,Wf,MR,zf,Kr,vR,tM,aM,P3,D3,rM,fo,M3,uo=be(()=>{yR();Pi=require("msgpackr"),Lc=require("cbor-x"),_o=require("zlib"),nM=M(pe()),Mc=M(require("stream"));Vr();sM=M(Ri()),DR=M(ae());H();iM=M(require("yaml")),LR=M(Ii());Ts();({Transform:I3}=require("json2csv")),oM=DR.default.get(B.SERIALIZATION_BIGINT)!==!1,Wf=oM?Ic:JSON.stringify,MR=oM?RR:JSON.parse,zf={useRecords:!1,useToJSON:!0},Kr=new Map,vR=Kr;Ye.contentTypes=vR;(0,sM._assignPackageExport)("contentTypes",vR);Kr.set("application/json",{serializeStream:qf,serialize:Wf,deserialize(e){return MR(e)},q:.8});tM=new Lc.Encoder(zf);Kr.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new Lc.EncoderStream(zf).end(e)},serialize:tM.encode,deserialize:tM.decode,q:1});Kr.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?Mc.Readable.from((0,Pi.encodeIter)(e,zf)):(0,Pi.pack)(e)},serialize:Pi.pack,deserialize:Pi.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 Mc.Readable.from(e.map?e.map(t=>t.toString()):e)},deserialize(e){return e.toString()},q:.2});Kr.set("text/yaml",{serialize(e){return iM.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Kr.set("text/event-stream",{serializeStream:a(function(e){return Mc.Readable.from(B3(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,125 @@ 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});Yr.set("application/x-www-form-urlencoded",{deserialize(e){let t=Buffer.isBuffer(e)?e.toString("utf8"):e,r={};for(let[n,s]of new URLSearchParams(t))if(r.hasOwnProperty(n)){let i=r[n];Array.isArray(i)?i.push(s):r.key=[i,s]}else r[n]=s;return r},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});iM={type:"application/json",serializeStream:qf,serialize:Wf,deserialize:I3,q:.5};Yr.set("*/*",iM);Yr.set("",iM);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");eM=PR.default.get(x.HTTP_COMPRESSIONTHRESHOLD);a(Qf,"serialize");a(ya,"serializeMessage");a(CR,"asyncSerialization");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(po,"getDeserializer");a(U3,"deserializerUnknownType");a(x3,"transformIterable");a(Gm,"toCsvStream")});var UR={};ve(UR,{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 aM(e){if(typeof e!="object"||e===null)throw new Li("Request body must be an object.");if(!("query"in e))throw new Li("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Li("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Li("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Li("Request body `operationName` field must be a string.")}function vR(e){return parseInt(e.value,10)}function lM(e){return parseFloat(e.value)}function uM(e,t,r){let n=r.get(e.name.value);return dM(n)?fM(n,t):{attribute:t,value:n}}function dM(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function fM(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],dM(n)?fM(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:vR(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:lM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return uM(e.value,t,r);case Le.Kind.OBJECT:return _M(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 _M(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:vR(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:lM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return uM(e.value,e.name.value,t);case Le.Kind.OBJECT:return _M(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 pM(e,t){return $m(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:pM(r.selectionSet,t)}:r.name.value)}async function G3(e,t,r,n){let s=Ii.getMatch(e.name.value,"graphql");if(s===void 0)throw new br(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:pM(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 hM(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return vR(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]:hM(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=hM(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 cM({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 aM(r),cM(r,e)}case"POST":{let r=await po(e.headers.get("content-type"),!0)(e._nodeRequest);return aM(r),cM(r,e)}default:throw new Li("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 Li)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 Li)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,Li,mM=be(()=>{Le=M(require("graphql"));fo();Su();a(B3,"assertExecutableDefinitionNode");a(aM,"assertRequestParams");a(vR,"processIntValueNode");a(lM,"processFloatValueNode");a(uM,"processVariableNode");a(dM,"isObject");a(fM,"transformObjectIntoQueryCondition");a(H3,"processObjectFieldNode");a(_M,"processObjectValueNode");a(k3,"processArgumentNode");a(F3,"buildConditionsQuery");a($m,"fillInFragments");a(pM,"buildSelectQuery");a(G3,"processFieldNode");a(hM,"processConstValueNode");a(q3,"resolveVariables");a($3,"executeOperation");a(cM,"resolver");br=class extends Error{static{a(this,"GraphQLQueryingError")}},Li=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 vi=I((Ybe,SM)=>{"use strict";var gM=oe(),EM=(B(),C(G)),Ru=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Mi=require("joi"),ba={schema_format:{pattern:Ru,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},Y3=Mi.alternatives(Mi.string().min(1).max(ba.schema_length.maximum).pattern(Ru).messages({"string.pattern.base":"{:#label} "+ba.schema_format.message}),Mi.number(),Mi.array()).required(),W3=Mi.alternatives(Mi.string().min(1).max(ba.schema_length.maximum).pattern(Ru).messages({"string.pattern.base":"{:#label} "+ba.schema_format.message}),Mi.number()),z3=Mi.alternatives(Mi.string().min(1).max(ba.schema_length.maximum).pattern(Ru).messages({"string.pattern.base":"{:#label} "+ba.schema_format.message}),Mi.number()).required();function j3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ba.schema_length.maximum?`'${e}' maximum of 250 characters`:Ru.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(j3,"checkValidTable");function Q3(e,t){return gM.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(Q3,"validateSchemaExists");function J3(e,t){let r=t.state.ancestors[0].schema;return gM.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(J3,"validateTableExists");function X3(e,t){return e.toLowerCase()===EM.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${EM.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(X3,"validateSchemaName");SM.exports={common_validators:ba,schema_regex:Ru,hdb_schema_table:Y3,validateSchemaExists:Q3,validateTableExists:J3,validateSchemaName:X3,checkValidTable:j3,hdb_database:W3,hdb_table:z3}});var ut=I((zbe,TM)=>{"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};TM.exports={validateObject:Z3,validateObjectAsync:eX,validateBySchema:tX};function Z3(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(Z3,"validateObject");async function eX(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(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 BR=I((Qbe,RM)=>{var{hdb_table:rX,hdb_database:AM}=vi(),nX=ut(),xR=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=xR.object({database:AM,schema:AM,table:rX,records:xR.array().items(xR.object().custom(iX)).required()});RM.exports=function(e){return nX.validateBySchema(e,oX)}});var bM=I((Xbe,yM)=>{"use strict";var HR=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")}};yM.exports=HR});var NM=I((eOe,OM)=>{"use strict";var kR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};OM.exports=kR});var DM={};ve(DM,{HAS_EXPIRATION:()=>Ym,HAS_RESIDENCY_ID:()=>YR,HAS_STRUCTURE_UPDATE:()=>zm,LAST_TIMESTAMP_PLACEHOLDER:()=>t_,LOCAL_TIMESTAMP:()=>aX,METADATA:()=>Jf,NEW_TIMESTAMP_PLACEHOLDER:()=>IM,NO_TIMESTAMP:()=>FR,PENDING_LOCAL_TIME:()=>WR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>KR,RecordEncoder:()=>VR,TIMESTAMP_ASSIGN_LAST:()=>lX,TIMESTAMP_ASSIGN_NEW:()=>CM,TIMESTAMP_ASSIGN_PREVIOUS:()=>PM,TIMESTAMP_PLACEHOLDER:()=>Vm,TIMESTAMP_RECORD_PREVIOUS:()=>GR,handleLocalTimeForGets:()=>jm,recordUpdater:()=>zR,removeEntry:()=>Uc});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?.[Jf];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?.[Jf]>=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[Jf];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,vc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<vc.length;u++){let f=vc[u].deref();(!f||f.isDone||f.isCommitted)&&vc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function zR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,p){d||l==null?yu=i?.localTime?GR|PM:FR:yu=l?i?.localTime?GR|16384:CM|16384:FR;let _=u?.expiresAt;if(_>=0&&(c|=Ym),Zf=c,qR=_,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:yu>0},S,g=0;try{let A=i?.residencyId,E=u?.residencyId;E&&($R=E,Zf|=YR,g|=xc),A!==E&&(g|=Bc,A||(A=0)),c&Ym&&(g|=n_),u?.originatingOperation&&(g|=r_),d&&(h.ifVersion=S=i?.version??null),i&&i.value&&i.metadataFlags&$n&&(r.getBinaryFast(i.localTime)||Aa(i.value));let R;if(u?.omitLocalRecord||(R=km(()=>e.put(n,s,h),n,e.rootStore),Pc&&(g|=$n)),l){let N=u?.user?.username;if(p&&(km(()=>e.encoder.encode(p),n,e.rootStore),Pc&&(g|=$n)),e.encoder.hasStructureUpdate&&(g|=zm,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let v=i?.localTime,k=r.get(v);if(k){let F=Nt(k).previousLocalTime;return R=r.put(v,bu(o,t,n,F,u?.nodeId??server.replication.getThisNodeId(r)??0,N,f,Xf,g,E,A,_),{ifVersion:S}),R}}R=r.put(s===void 0?IM:t_,bu(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,N,f,Xf,g,E,A,_,u?.originatingOperation),{append:f!=="invalidate",instructedWrite:!0,ifVersion:S})}return R}catch(A){throw A.message+=" id: "+n+" options: "+h,A}}}function Uc(e,t,r){if(t)return t.value&&t.metadataFlags&$n&&!e.auditStore.getBinaryFast(t.localTime)&&Aa(t.value),e.remove(t.key,r)}var wM,Km,Vm,t_,KR,IM,aX,Jf,e_,cX,FR,CM,lX,PM,GR,Ym,YR,WR,zm,uX,Xf,yu,Zf,qR,$R,VR,vc,Ou=be(()=>{wM=require("msgpackr");ho();Km=M(Y());As();As();Vm=new Uint8Array([1,1,1,1,4,64,0,0]),t_=new Uint8Array([1,1,1,1,1,0,0,0]),KR=new Uint8Array([1,1,1,1,3,64,0,0]),IM=new Uint8Array([1,1,1,1,0,64,0,0]),aX=Symbol("local-timestamp"),Jf=Symbol("metadata"),e_=new Uint8Array(8),cX=new DataView(e_.buffer,0,8),FR=0,CM=0,lX=1,PM=3,GR=4,Ym=16,YR=32,WR=1,zm=256,yu=0,Zf=-1,qR=-1,$R=0,VR=class extends wM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(yu||Zf>=0){let o=0,c=yu;c&&(o+=8,yu=0);let l=Zf,u=qR,f=$R;l>=0&&(o+=4,Zf=-1,u>=0&&(o+=8,qR=-1),f&&(o+=4,$R=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),Pc&&(l|=$n),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&YR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=Dc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[Jf]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:Dc(()=>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");vc=[];setInterval(()=>{for(let e=0;e<vc.length;e++){let t=vc[e].deref();!t||t.isDone||t.isCommitted?vc.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(zR,"recordUpdater");a(Uc,"removeEntry")});var s_=I((oOe,MM)=>{"use strict";var LM=ce(),fX=(B(),C(G)),{RecordEncoder:_X}=(Ou(),C(DM));LM.initSync();var pX=LM.get(fX.CONFIG_PARAMS.STORAGE_CACHING)!==!1,jR=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})}};MM.exports=jR});var i_=I((cOe,vM)=>{"use strict";var Vn=ce(),Rs=(B(),C(G));Vn.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=Vn.get(Rs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Vn.get(Rs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Vn.get(Rs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Vn.get(Rs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Vn.get(Rs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Vn.get(Rs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Vn.get(Rs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Vn.get(Rs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Vn.get(Rs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Vn.get(Rs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Vn.get(Rs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Vn.get(Rs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};vM.exports=Qm;Qm.MAX_DBS=1e4});var dt=I((uOe,VM)=>{"use strict";var JR=require("lmdb"),Zs=require("fs-extra"),Kn=require("path"),Jm=pn(),BM=Y(),Sn=Hn().LMDB_ERRORS_ENUM,Xm=NM(),XR=s_(),HM=i_(),Oa=vt(),UM=(B(),C(G)),{table:hX,resetDatabases:mX}=(Pe(),C(rt)),xM=ce(),ei=Oa.INTERNAL_DBIS_NAME,kM=Oa.DBI_DEFINITION_NAME,EX="data.mdb",gX="lock.mdb",o_=".mdb",SX="-lock",QR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ys(t,r),this.key_type=this.dbi[Oa.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Oa.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new JR.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(Sn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Sn.ENV_NAME_REQUIRED)}a(Zm,"pathEnvNameValidation");async function ZR(e,t,r=!0){try{await Zs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Sn.INVALID_BASE_PATH):n}try{let n=Kn.join(e,t+o_);return await Zs.access(n,Zs.constants.R_OK|Zs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Zs.access(Kn.join(e,t,EX),Zs.constants.R_OK|Zs.constants.F_OK),Kn.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(ZR,"validateEnvironmentPath");function eE(e,t){if(Jm.validateEnv(e),t===void 0)throw new Error(Sn.DBI_NAME_REQUIRED)}a(eE,"validateEnvDBIName");async function TX(e,t,r=!1,n=!1){Zm(e,t);let s=Kn.basename(e);t=t.toString();let i=xM.get(UM.CONFIG_PARAMS.DATABASES);i||xM.setProperty(UM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await ZR(e,t,n),FM(e,t,r)}catch(o){if(o.message===Sn.INVALID_ENVIRONMENT){let c=Kn.join(e,t);await Zs.mkdirp(n?c:e);let l=new HM(n?c:c+o_,!1),u=JR.open(l);u.dbis=Object.create(null);let f=new XR(!1);u.openDB(ei,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=ey(e,t,r);return u[Oa.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=Kn.join(e,t);return hX({table:t,database:Kn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(AX,"copyEnvironment");async function FM(e,t,r=!1){Zm(e,t),t=t.toString();let n=ey(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 ZR(e,t),i=Kn.join(e,t+o_),o=s!=i,c=new HM(s,o),l=JR.open(c);l.dbis=Object.create(null);let u=qM(l);for(let f=0;f<u.length;f++)ys(l,u[f]);return l[Oa.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(FM,"openEnvironment");async function RX(e,t,r=!1){Zm(e,t),t=t.toString();let n=Kn.join(e,t+o_),s=await ZR(e,t);if(global.lmdb_map!==void 0){let i=ey(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await GM(o),delete global.lmdb_map[i]}}await Zs.remove(s),await Zs.remove(s===n?s+SX:Kn.join(Kn.dirname(s),gX))}a(RX,"deleteEnvironment");async function GM(e){Jm.validateEnv(e);let t=e[Oa.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(GM,"closeEnvironment");function ey(e,t,r=!1){let s=`${Kn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(ey,"getCachedEnvironmentName");function yX(e){Jm.validateEnv(e);let t=Object.create(null),r=ys(e,ei);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==ei)try{t[n]=Object.assign(new Xm,s)}catch{BM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(yX,"listDBIDefinitions");function qM(e){Jm.validateEnv(e);let t=[],r=ys(e,ei);for(let{key:n}of r.getRange({start:!1}))n!==ei&&t.push(n);return t}a(qM,"listDBIs");function bX(e,t){let n=ys(e,ei).getEntry(t),s=new Xm;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{BM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(bX,"getDBIDefinition");function $M(e,t,r,n=!r){if(eE(e,t),t=t.toString(),t===ei)throw new Error(Sn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ys(e,t)}catch(s){if(s.message===Sn.DBI_DOES_NOT_EXIST){let i=new XR(r,n===!0),o=e.openDB(t,i),c=new Xm(r===!0,n);return o[kM]=c,ys(e,ei).putSync(t,c),e.dbis[t]=o,o}throw s}}a($M,"createDBI");function ys(e,t){if(eE(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==ei?r=bX(e,t):r=new Xm,r===void 0)throw new Error(Sn.DBI_DOES_NOT_EXIST);let n;try{let s=new XR(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[kM]=r,e.dbis[t]=n,n}a(ys,"openDBI");function OX(e,t){eE(e,t),t=t.toString();let r=ys(e,t),n=r.getStats();return r[Oa.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(OX,"statDBI");async function NX(e,t){try{let r=Kn.join(e,t+o_);return(await Zs.stat(r)).size}catch{throw new Error(Sn.INVALID_ENVIRONMENT)}}a(NX,"environmentDataSize");function wX(e,t){if(eE(e,t),t=t.toString(),t===ei)throw new Error(Sn.CANNOT_DROP_INTERNAL_DBIS_NAME);ys(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ys(e,ei).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{ys(e,i)}catch(o){if(o.message===Sn.DBI_DOES_NOT_EXIST)$M(e,i,i!==t,i===t),n=!0;else throw o}}n&&mX()}a(IX,"initializeDBIs");VM.exports={openDBI:ys,openEnvironment:FM,createEnvironment:TX,listDBIs:qM,listDBIDefinitions:yX,createDBI:$M,dropDBI:wX,statDBI:OX,deleteEnvironment:RX,initializeDBIs:IX,TransactionCursor:QR,environmentDataSize:NX,copyEnvironment:AX,closeEnvironment:GM}});var YM=I((fOe,KM)=>{"use strict";var ty=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};KM.exports=ty});var zM=I((pOe,WM)=>{"use strict";var ry=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}};WM.exports=ry});var QM=I((mOe,jM)=>{"use strict";var ny=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};jM.exports=ny});var kc=I((AOe,ZM)=>{"use strict";var CX=dt(),PX=YM(),DX=zM(),LX=QM(),Ui=pn(),a_=Hn().LMDB_ERRORS_ENUM,MX=vt(),mo=(B(),C(G)),vX=oe(),UX=require("uuid"),gOe=require("lmdb"),{handleHDBError:xX,hdb_errors:BX}=pe(),{OVERFLOW_MARKER:SOe,MAX_SEARCH_KEY_LENGTH:TOe}=MX,JM=ce();JM.initSync();var tE=JM.get(mo.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),sy=mo.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Hc=mo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function HX(e,t,r,n,s=Ui.getNextMonotonicTime()){cy(e,t,r,n),iy(e,t,r);let i=new PX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];XM(u,!0,s);let f=kX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return oy(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][mo.FUNC_VAL],n[o]=c)}let l=Ui.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[Hc])})}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 XM(e,t,r){let n=r>0;(n||!Number.isInteger(e[Hc]))&&(e[Hc]=r||(r=Ui.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[sy]))&&(e[sy]=r||Ui.getNextMonotonicTime()):delete e[sy]}a(XM,"setTimestamps");function iy(e,t,r){r.indexOf(mo.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(mo.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(mo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(mo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),CX.initializeDBIs(e,t,r)}a(iy,"initializeTransaction");async function GX(e,t,r,n,s=Ui.getNextMonotonicTime()){cy(e,t,r,n),iy(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=ay(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(p),l.push(d)}return oy(c,l,n,i,s,o)}a(GX,"updateRecords");async function qX(e,t,r,n,s=Ui.getNextMonotonicTime()){try{cy(e,t,r,n)}catch(l){throw xX(l,l.message,BX.HTTP_STATUS_CODES.BAD_REQUEST)}iy(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=ay(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return oy(o,c,n,i,s)}a(qX,"upsertRecords");async function oy(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||Ui.getNextMonotonicTime(),FX(r,i),n}a(oy,"finalizeWrite");function ay(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(XM(r,!f,o),Number.isInteger(r[Hc])&&u[Hc]>r[Hc])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 A=u[h];if(typeof S=="function"){let R=S([[u]]);Array.isArray(R)&&(S=R[0][mo.FUNC_VAL],r[h]=S)}if(S===A)continue;let E=Ui.getIndexedValues(A);if(E){tE&&g.prefetch(E.map(R=>({key:R,value:n})),rE);for(let R=0,N=E.length;R<N;R++)g.remove(E[R],n)}if(E=Ui.getIndexedValues(S),E){tE&&g.prefetch(E.map(R=>({key:R,value:n})),rE);for(let R=0,N=E.length;R<N;R++)g.put(E[R],n)}}let _={...u,...r};c.put(n,_,_[Hc])},"do_put");return l?d=c.ifVersion(n,l.version,p):d=c.ifNoExists(n,p),d.then(_=>_?!0:ay(e,t,r,n,s,i,o))}a(ay,"updateUpsertRecord");function $X(e,t,r){if(Ui.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 cy(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(cy,"validateWrite");function rE(){}a(rE,"noop");ZM.exports={insertRecords:HX,updateRecords:GX,upsertRecords:qX}});var Eo=I((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"}]},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 nE=I((bOe,ev)=>{var{common_validators:xi}=vi(),l_=ut(),c_="is required",Zt={database:{presence:!1,format:xi.schema_format,length:xi.schema_length},schema:{presence:!1,format:xi.schema_format,length:xi.schema_length},table:{presence:!0,format:xi.schema_format,length:xi.schema_length},attribute:{presence:!0,format:xi.schema_format,length:xi.schema_length},hash_attribute:{presence:!0,format:xi.schema_format,length:xi.schema_length}};function u_(e){for(let t in e)e[t]=e[t]===null||e[t]===void 0||typeof e[t]=="object"?e[t]:e[t].toString();return e}a(u_,"makeAttributesStrings");function KX(e){return e=u_(e),Zt.table.presence=!1,Zt.attribute.presence=!1,Zt.hash_attribute.presence=!1,l_.validateObject(e,Zt)}a(KX,"schema_object");function YX(e){return e=u_(e),Zt.table.presence={message:c_},Zt.attribute.presence=!1,Zt.hash_attribute.presence=!1,l_.validateObject(e,Zt)}a(YX,"table_object");function WX(e){return e=u_(e),Zt.table.presence={message:c_},Zt.attribute.presence=!1,l_.validateObject(e,Zt)}a(WX,"create_table_object");function zX(e){return e=u_(e),Zt.table.presence={message:c_},Zt.attribute.presence={message:c_},Zt.hash_attribute.presence=!1,l_.validateObject(e,Zt)}a(zX,"attribute_object");function jX(e){return e=u_(e),Zt.table.presence={message:c_},Zt.attribute.presence=!1,Zt.hash_attribute.presence=!1,l_.validateObject(e,Zt)}a(jX,"describe_table");function QX(e){if(e){if(!Array.isArray(e))throw new Error("residence must be a string array");if(e.length===0)throw new Error("residence cannot be an empty array");for(let t=0;t<e.length;t++)if(typeof e[t]!="string")throw new Error(`residence must be a string array, item '${e[t]}' is not a string`)}}a(QX,"validateTableResidence");ev.exports={schema_object:KX,create_table_object:WX,table_object:YX,attribute_object:zX,describe_table:jX,validateTableResidence:QX}});var rv=I((NOe,tv)=>{"use strict";var JX=require("uuid"),ly=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||JX.v4(),this.schema_table=`${this.schema}.${this.table}`}};tv.exports=ly});var sE=I((IOe,nv)=>{"use strict";var XX=rv(),uy=class extends XX{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}};nv.exports=uy});var iv=I((POe,sv)=>{"use strict";sv.exports=eZ;var ZX="inserted";function eZ(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===ZX?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(eZ,"returnObject")});var iE=I((MOe,lv)=>{"use strict";var tZ=(B(),C(G)),dy=dt(),rZ=kc(),{getSystemSchemaPath:nZ,getSchemaPath:sZ}=Et(),LOe=Eo(),iZ=nE(),oZ=sE(),aZ=iv(),{handleHDBError:ov,hdb_errors:cv}=pe(),av=oe(),{HTTP_STATUS_CODES:cZ}=cv,lZ="inserted";lv.exports=uZ;async function uZ(e){let t=iZ.attribute_object(e);if(t)throw ov(new Error,t.message,cv.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&av.checkGlobalSchemaTable(e.schema,e.table);if(r)throw ov(new Error,r,cZ.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=av.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 oZ(e.schema,e.table,e.attribute,e.id);try{let i=await dy.openEnvironment(sZ(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}`);dy.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await dy.openEnvironment(nZ(),tZ.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await rZ.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return aZ(lZ,c,{records:[s]},l)}catch(i){throw i}}a(uZ,"lmdbCreateAttribute")});var d_=I((xOe,dv)=>{"use strict";var go=oe(),uv=Y(),UOe=BR(),{getDatabases:dZ}=(Pe(),C(rt)),{ClientError:Fc}=pe();dv.exports=fZ;function fZ(e){if(go.isEmpty(e))throw new Fc("invalid update parameters defined.");if(go.isEmptyOrZeroLength(e.schema))throw new Fc("invalid schema specified.");if(go.isEmptyOrZeroLength(e.table))throw new Fc("invalid table specified.");if(!Array.isArray(e.records))throw new Fc("records must be an array");let t=dZ()[e.schema]?.[e.table];if(go.isEmpty(t))throw new Fc(`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&&go.isEmptyOrZeroLength(o[r]))throw uv.error("a valid hash attribute must be provided with update record:",o),new Fc("a valid hash attribute must be provided with update record, check log for more info");if(!go.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw uv.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Fc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!go.isEmpty(o[r])&&o[r]!==""&&n.has(go.autoCast(o[r]))&&(o.skip=!0),n.add(go.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(fZ,"insertUpdateValidate")});var _v=I((HOe,fv)=>{"use strict";var fy=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};fv.exports=fy});var mv=I((FOe,hv)=>{"use strict";var _y=dt(),_Z=Y(),pv=Hn().LMDB_ERRORS_ENUM;hv.exports=pZ;async function pZ(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 _y.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==pv.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await _y.closeEnvironment(global.lmdb_map[n]),await _y.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==pv.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){_Z.error(t)}}a(pZ,"cleanLMDBMap")});var Cv=I(($Oe,Iv)=>{"use strict";var py=require("recursive-iterator"),hZ=require("alasql"),hy=require("clone"),Ev=oe(),{handleHDBError:gv,hdb_errors:mZ}=pe(),{HDB_ERROR_MSGS:Sv,HTTP_STATUS_CODES:Tv}=mZ,{getDatabases:EZ}=(Pe(),C(rt)),gZ=["DISTINCT_ARRAY"],Av=Symbol("validateTables"),my=Symbol("validateTable"),qOe=Symbol("getAllColumns"),Rv=Symbol("validateAllColumns"),oE=Symbol("findColumn"),yv=Symbol("validateOrderBy"),f_=Symbol("validateSegment"),Ey=Symbol("validateColumn"),bv=Symbol("setColumnsForTable"),Ov=Symbol("checkColumnsForAsterisk"),Nv=Symbol("validateGroupBy"),wv=Symbol("hasColumns"),gy=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[Av](),this[Ov](),this[Rv]()}[Av](){if(this[wv]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[my](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[my](t.table)})}}[wv](){let t=!1,r=new py(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[my](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=EZ();if(!r[t.databaseid])throw gv(new Error,Sv.SCHEMA_NOT_FOUND(t.databaseid),Tv.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw gv(new Error,Sv.TABLE_NOT_FOUND(t.databaseid,t.tableid),Tv.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=hy(s);i.table=hy(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)}[Ov](){let t=new py(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[bv](r.tableid)}[bv](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new hZ.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[Rv](){this[f_](this.statement.columns,!1),this[f_](this.statement.joins,!1),this[f_](this.statement.where,!1),this[Nv](this.statement.group,!1),this[f_](this.statement.order,!0)}[f_](t,r){if(!t)return;let n=new py(t),s=[];for(let{node:i,path:o}of n)!Ev.isEmpty(i)&&!Ev.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[yv](i):s.push(this[Ey](i)));return s}[Nv](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&gZ.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=hy(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`}[yv](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[Ey](t)}[Ey](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]}};Iv.exports=gy});var Mv=I((KOe,Lv)=>{"use strict";var Pv=require("lodash"),__=require("mathjs"),SZ=require("jsonata"),Dv=oe();Lv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Pv.uniqWith(e,Pv.isEqual):e,"distinct_array"),searchJSON:TZ,mad:p_.bind(null,__.mad),mean:p_.bind(null,__.mean),mode:p_.bind(null,__.mode),prod:p_.bind(null,__.prod),median:p_.bind(null,__.median)};function p_(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(p_,"aggregateFunction");function TZ(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(Dv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Dv.isEmpty(this.__ala__.res[r])){let n=SZ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(TZ,"searchJSON")});var Uv=I((WOe,vv)=>{"use strict";var er=require("moment"),Sy="YYYY-MM-DDTHH:mm:ss.SSSZZ";er.suppressDeprecationWarnings=!0;vv.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(Sy),"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(Sy),"get_server_time"),offset_utc:a((e,t)=>er(e).utc().utcOffset(t).format(Sy),"offset_utc")}});var kv=I((jOe,Hv)=>{"use strict";var AZ=require("@turf/area"),RZ=require("@turf/length"),yZ=require("@turf/circle"),bZ=require("@turf/difference"),OZ=require("@turf/distance"),NZ=require("@turf/boolean-contains"),wZ=require("@turf/boolean-equal"),IZ=require("@turf/boolean-disjoint"),CZ=require("@turf/helpers"),xv=(B(),C(G)),qe=oe(),So=Y();Hv.exports={geoArea:PZ,geoLength:DZ,geoCircle:LZ,geoDifference:MZ,geoDistance:Bv,geoNear:vZ,geoContains:UZ,geoEqual:xZ,geoCrosses:BZ,geoConvert:HZ};function PZ(e){if(qe.isEmpty(e))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return AZ.default(e)}catch(t){return So.trace(t,e),NaN}}a(PZ,"geoArea");function DZ(e,t){if(qe.isEmpty(e))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return RZ.default(e,{units:t||"kilometers"})}catch(r){return So.trace(r,e),NaN}}a(DZ,"geoLength");function LZ(e,t,r){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return yZ.default(e,t,{units:r||"kilometers"})}catch(n){return So.trace(n,e,t),NaN}}a(LZ,"geoCircle");function MZ(e,t){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return bZ(e,t)}catch(r){return So.trace(r,e,t),NaN}}a(MZ,"geoDifference");function Bv(e,t,r){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return OZ.default(e,t,{units:r||"kilometers"})}catch(n){return So.trace(n,e,t),NaN}}a(Bv,"geoDistance");function vZ(e,t,r,n){if(qe.isEmpty(e)||qe.isEmpty(t))return!1;if(qe.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return Bv(e,t,n)<=r}catch(s){return So.trace(s,e,t),!1}}a(vZ,"geoNear");function UZ(e,t){if(qe.isEmpty(e)||qe.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return NZ.default(e,t)}catch(r){return So.trace(r,e,t),!1}}a(UZ,"geoContains");function xZ(e,t){if(qe.isEmpty(e)||qe.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return wZ.default(e,t)}catch(r){return So.trace(r,e,t),!1}}a(xZ,"geoEqual");function BZ(e,t){if(qe.isEmpty(e)||qe.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return!IZ.default(e,t)}catch(r){return So.trace(r,e,t),!1}}a(BZ,"geoCrosses");function HZ(e,t,r){if(qe.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(qe.isEmpty(t))throw new Error("geo_type is required");if(qe.isEmpty(xv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(xv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=qe.autoCastJSON(e)),CZ[t](e,r)}a(HZ,"geoConvert")});var aE=I((JOe,Fv)=>{var Gc=Mv(),Yn=Uv(),Bi=kv();Fv.exports=e=>{e.aggr.mad=e.aggr.MAD=Gc.mad,e.aggr.mean=e.aggr.MEAN=Gc.mean,e.aggr.mode=e.aggr.MODE=Gc.mode,e.aggr.prod=e.aggr.PROD=Gc.prod,e.aggr.median=e.aggr.MEDIAN=Gc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Gc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Gc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Yn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Yn.current_time,e.fn.extract=e.fn.EXTRACT=Yn.extract,e.fn.date=e.fn.DATE=Yn.date,e.fn.date_format=e.fn.DATE_FORMAT=Yn.date_format,e.fn.date_add=e.fn.DATE_ADD=Yn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Yn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Yn.date_diff,e.fn.now=e.fn.NOW=Yn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Yn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Yn.get_server_time,e.fn.getdate=e.fn.GETDATE=Yn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Yn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Bi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Bi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Bi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Bi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Bi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Bi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Bi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Bi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Bi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Bi.geoNear}});var Vv=I((XOe,$v)=>{"use strict";var h_=require("lodash"),Tn=require("alasql");Tn.options.cache=!1;var kZ=aE(),Gv=require("clone"),cE=require("recursive-iterator"),Ue=Y(),ze=oe(),Nu=Wn(),FZ=(B(),C(G)),{hdb_errors:GZ}=pe(),{getDatabases:qv}=(Pe(),C(rt)),qZ="IS NULL",ti="There was a problem performing this search. Please check the logs and try again.";kZ(Tn);var Ty=class{static{a(this,"SQLSearch")}constructor(t,r){if(ze.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(),ze.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!ze.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(ti)}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(ti)}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(ti)}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(ti)}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(ti)}}_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(Gv(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=h_.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=qv()[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)){Ue.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){Ue.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(FZ.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&&h_.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 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(Gv(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(qZ)>-1&&this.tables.forEach(s=>{let i={columnid:qv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=h_.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 Nu.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(ti)}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 Nu.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(ti)}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 Nu.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(ti)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await Nu.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(ti)}}}_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 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=h_.difference(h,[..._.keys].map(g=>g.toString()));for(let g=0,A=S.length;g<A;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=h_.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(ti)}}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 Nu.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 Tn.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(GZ.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 Nu.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(ti)}}return Object.values(Object.values(this.data)[0].__merged_data)}};$v.exports=Ty});var Wr=I((eNe,Kv)=>{"use strict";var $Z=Cv();Kv.exports={searchByConditions:KZ,searchByHash:YZ,searchByValue:WZ,search:zZ};var Ay=Wn(),{transformReq:Ry}=oe(),VZ=Vv();async function KZ(e){return Ry(e),Ay.searchByConditions(e)}a(KZ,"searchByConditions");async function YZ(e){Ry(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of Ay.searchByHash(e))r&&t.push(r);return t}a(YZ,"searchByHash");async function WZ(e){Ry(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of Ay.searchByValue(e))t.push(r);return t}a(WZ,"searchByValue");function zZ(e,t){try{let r=new $Z(e);r.validate(),new VZ(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(zZ,"search")});var To=I((rNe,jv)=>{"use strict";var m_=require("crypto"),jZ=ce(),{CONFIG_PARAMS:QZ}=(B(),C(G)),Wv="aes-256-cbc",JZ=32,XZ=16,yy=64,zv=32,ZZ=yy+zv,Yv=new Map;jv.exports={encrypt:e6,decrypt:t6,createNatsTableStreamName:r6};function e6(e){let t=m_.randomBytes(JZ),r=m_.randomBytes(XZ),n=m_.createCipheriv(Wv,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(e6,"encrypt");function t6(e){let t=e.substr(0,yy),r=e.substr(yy,zv),n=e.substr(ZZ,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=m_.createDecipheriv(Wv,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(t6,"decrypt");function r6(e,t){let r=jZ.get(QZ.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=Yv.get(r);return n||(n=m_.createHash("md5").update(r).digest("hex"),Yv.set(r,n)),n}a(r6,"createNatsTableStreamName")});var Ao=I((iNe,Xv)=>{"use strict";var sNe=Wr(),E_=Y(),Qv=nE(),n6=To(),lE=oe(),{handleHDBError:uE,hdb_errors:s6}=pe(),{HDB_ERROR_MSGS:dE,HTTP_STATUS_CODES:by}=s6,Jv=ce();Jv.initSync();var{getDatabases:Oy}=(Pe(),C(rt)),i6=require("fs-extra"),o6=(B(),C(G));Xv.exports={describeAll:a6,describeTable:fE,describeSchema:c6};async function a6(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=Oy(),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){E_.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 E_.error("Got an error in describeAll"),E_.error(t),uE(new Error,dE.DESCRIBE_ALL_ERR)}}a(a6,"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=Qv.describe_table(e);if(i)throw i;let c=Oy()[r];if(!c)throw uE(new Error,dE.SCHEMA_NOT_FOUND(e.schema),by.NOT_FOUND);let l=c[n];if(!l)throw uE(new Error,dE.TABLE_NOT_FOUND(e.schema,e.table),by.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 i6.stat(l.primaryStore.env.path)).size}catch(_){E_.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")),Jv.get(o6.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(p.clustering_stream_name=n6.createNatsTableStreamName(p.schema,p.name));try{let _=await l.getRecordCount({exactCount:e.exact_count==="true"});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(_){E_.warn(`unable to stat table dbi due to ${_}`)}return p}a(fE,"descTable");async function c6(e){lE.transformReq(e);let t=Qv.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=Oy()[n];if(!i)throw uE(new Error,dE.SCHEMA_NOT_FOUND(e.schema),by.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(c6,"describeSchema")});var bs=I((lNe,nU)=>{var l6=Eo(),{callbackify:eU,promisify:u6}=require("util"),{getDatabases:tU}=(Pe(),C(rt));nU.exports={setSchemaDataToGlobal:Zv,getTableSchema:d6,getSystemSchema:f6,setSchemaDataToGlobalAsync:u6(Zv)};var rU=Ao(),aNe=eU(rU.describeAll),cNe=eU(rU.describeTable);function Zv(e){global.hdb_schema=tU(),e&&e()}a(Zv,"setSchemaDataToGlobal");function d6(e,t,r){let n=tU()[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(d6,"getTableSchema");function f6(){return l6}a(f6,"getSystemSchema")});var wy=I((dNe,oU)=>{var _6=ut(),Ny=require("joi"),{hdb_table:p6,hdb_database:sU}=vi(),iU={schema:sU,database:sU,table:p6},h6={date:Ny.date().iso().required()},m6={timestamp:Ny.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};oU.exports=function(e,t){let r=t==="timestamp"?{...iU,...m6}:{...iU,...h6},n=Ny.object(r);return _6.validateBySchema(e,n)}});var lU=I((fNe,cU)=>{var E6=ut(),Iy=require("joi"),{hdb_table:g6,hdb_database:aU}=vi(),S6=Iy.object({schema:aU,database:aU,table:g6,hash_values:Iy.array().required(),ids:Iy.array()});cU.exports=function(e){return E6.validateBySchema(e,S6)}});var Ly=I((_Ne,uU)=>{"use strict";var Cy=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}},Py=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}},Dy=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};uU.exports={InsertObject:Cy,NoSQLSeachObject:Py,DeleteResponseObject:Dy}});var Vc=I((hNe,hU)=>{"use strict";var fU=wy(),T6=lU(),qc=oe(),dU=require("moment"),_U=Y(),{promisify:A6,callbackify:R6}=require("util"),$c=(B(),C(G)),y6=bs(),My=A6(y6.getTableSchema),vy=Wn(),{DeleteResponseObject:b6}=Ly(),{handleHDBError:Na,hdb_errors:O6}=pe(),{HDB_ERROR_MSGS:_E,HTTP_STATUS_CODES:wa}=O6,N6="records successfully deleted",w6=R6(pU);hU.exports={delete:w6,deleteRecord:pU,deleteFilesBefore:I6,deleteAuditLogsBefore:C6};async function I6(e){let t=fU(e,"date");if(t)throw Na(t,t.message,wa.BAD_REQUEST,void 0,void 0,!0);if(qc.transformReq(e),!dU(e.date,dU.ISO_8601).isValid())throw Na(new Error,_E.INVALID_DATE,wa.BAD_REQUEST,$c.LOG_LEVELS.ERROR,_E.INVALID_DATE,!0);let n=qc.checkSchemaTableExist(e.schema,e.table);if(n)throw Na(new Error,n,wa.NOT_FOUND,$c.LOG_LEVELS.ERROR,n,!0);let s=await vy.deleteRecordsBefore(e);if(await My(e.schema,e.table),_U.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(I6,"deleteFilesBefore");async function C6(e){let t=fU(e,"timestamp");if(t)throw Na(t,t.message,wa.BAD_REQUEST,void 0,void 0,!0);if(qc.transformReq(e),isNaN(e.timestamp))throw Na(new Error,_E.INVALID_VALUE("Timestamp"),wa.BAD_REQUEST,$c.LOG_LEVELS.ERROR,_E.INVALID_VALUE("Timestamp"),!0);let r=qc.checkSchemaTableExist(e.schema,e.table);if(r)throw Na(new Error,r,wa.NOT_FOUND,$c.LOG_LEVELS.ERROR,r,!0);let n=await vy.deleteAuditLogsBefore(e);return await My(e.schema,e.table),_U.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(C6,"deleteAuditLogsBefore");async function pU(e){e.ids&&(e.hash_values=e.ids);let t=T6(e);if(t)throw Na(t,t.message,wa.BAD_REQUEST,void 0,void 0,!0);qc.transformReq(e);let r=qc.checkSchemaTableExist(e.schema,e.table);if(r)throw Na(new Error,r,wa.NOT_FOUND,$c.LOG_LEVELS.ERROR,r,!0);try{await My(e.schema,e.table);let n=await vy.deleteRecords(e);return qc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${N6}`),n}catch(n){if(n.message===$c.SEARCH_NOT_FOUND_MESSAGE){let s=new b6;return s.message=$c.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(pU,"deleteRecord")});var pE={};ve(pE,{HASH_FUNCTION:()=>T_,hash:()=>By,validate:()=>Hy});function Uy(e=S_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(g_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function By(e,t=T_[EU?.toUpperCase()]??"sha256"){return xy[t](e)}function Hy(e,t,r=T_[EU?.toUpperCase()]??"sha256"){return e?P6[r](e,t):!1}var g_,wu,mU,EU,S_,gU,T_,xy,P6,hE=be(()=>{g_=M(require("node:crypto")),wu=M(require("argon2")),mU=M(ce());B();EU=(0,mU.get)(x.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),S_=16,gU=9,T_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(T_||{});a(Uy,"generateSalt");xy={md5:a((e,t=void 0)=>{t=t??Uy(gU);let r=g_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??Uy(S_);let r=g_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=Uy(S_),r=await wu.hash(e,{type:wu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},P6={md5:a((e,t)=>{let r=e.slice(0,gU);return e===xy.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,S_);return e===xy.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await wu.verify(e.slice(S_),t),"argon2id")};a(By,"hash");a(Hy,"validate")});var TU=I((SNe,SU)=>{var ky=ut(),zr={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function D6(e){return zr.password.presence=!0,zr.username.presence=!0,zr.role.presence=!0,zr.active.presence=!0,ky.validateObject(e,zr)}a(D6,"addUserValidation");function L6(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,ky.validateObject(e,zr)}a(L6,"alterUserValidation");function M6(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,ky.validateObject(e,zr)}a(M6,"dropUserValidation");SU.exports={addUserValidation:D6,alterUserValidation:L6,dropUserValidation:M6}});var St=I((RNe,RU)=>{"use strict";var{platform:ANe}=require("os"),v6="nats-server.zip",Fy="nats-server",U6=process.platform==="win32"?`${Fy}.exe`:Fy,x6=/^[^\s.,*>]+$/,AU="__request__",B6=a(e=>`${e}.${AU}`,"REQUEST_SUBJECT"),H6={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},k6={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},F6={HUB:"hub.pid",LEAF:"leaf.pid"},G6={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},q6={SUCCESS:"success",ERROR:"error"},$6={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},V6={TXN:"txn",MSGID:"msgid"},Iu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},K6={[Iu.ERR]:1,[Iu.WRN]:2,[Iu.INF]:3,[Iu.DBG]:4,[Iu.TRC]:5},Y6={debug:"-D",trace:"-DVV"};RU.exports={NATS_SERVER_ZIP:v6,NATS_SERVER_NAME:Fy,NATS_BINARY_NAME:U6,PID_FILES:F6,NATS_CONFIG_FILES:k6,SERVER_SUFFIX:G6,NATS_TERM_CONSTRAINTS_RX:x6,REQUEST_SUFFIX:AU,UPDATE_REMOTE_RESPONSE_STATUSES:q6,CLUSTER_STATUS_STATUSES:$6,REQUEST_SUBJECT:B6,SUBJECT_PREFIXES:V6,MSG_HEADERS:H6,LOG_LEVELS:Iu,LOG_LEVEL_FLAGS:Y6,LOG_LEVEL_HIERARCHY:K6}});var Gy=I(yU=>{"use strict";var W6={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()}});aM={type:"application/json",serializeStream:qf,serialize:Wf,deserialize:C3,q:.5};Kr.set("*/*",aM);Kr.set("",aM);a(C3,"tryJSONParse");a(jf,"registerContentHandlers");P3=require("fastify-plugin"),D3=P3(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");rM=DR.default.get(B.HTTP_COMPRESSIONTHRESHOLD);a(Qf,"serialize");a(Ra,"serializeMessage");a(CR,"asyncSerialization");a(PR,"hasAsyncSerialization");a(L3,"streamToBuffer");M3=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(v3,"isBufferEncoding");a(U3,"parseContentType");a(po,"getDeserializer");a(x3,"deserializerUnknownType");a(B3,"transformIterable");a(Gm,"toCsvStream")});var xR={};ve(xR,{start:()=>Y3});function H3(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 lM(e){if(typeof e!="object"||e===null)throw new Di("Request body must be an object.");if(!("query"in e))throw new Di("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Di("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Di("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Di("Request body `operationName` field must be a string.")}function UR(e){return parseInt(e.value,10)}function dM(e){return parseFloat(e.value)}function fM(e,t,r){let n=r.get(e.name.value);return _M(n)?pM(n,t):{attribute:t,value:n}}function _M(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function pM(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],_M(n)?pM(n,t):{attribute:t,value:n}))}function k3(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:UR(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:dM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return fM(e.value,t,r);case Le.Kind.OBJECT:return hM(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 hM(e,t,r){return e.fields.flatMap(n=>k3(n,t,r))}function F3(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:UR(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:dM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return fM(e.value,e.name.value,t);case Le.Kind.OBJECT:return hM(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 G3(e,t){return e.flatMap(r=>F3(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 mM(e,t){return $m(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:mM(r.selectionSet,t)}:r.name.value)}async function q3(e,t,r,n){let s=wi.getMatch(e.name.value,"graphql");if(s===void 0)throw new br(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:mM(e.selectionSet,r),conditions:G3(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 EM(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return UR(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]:EM(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new br(`Value type, ${e.kind}, is not supported.`)}}function $3(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=EM(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 V3(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=$3(e.variableDefinitions,t),i=await Promise.all($m(e.selectionSet,r).map(c=>q3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function uM({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(H3(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 V3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function K3(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 lM(r),uM(r,e)}case"POST":{let r=await po(e.headers.get("content-type"),!0)(e._nodeRequest);return lM(r),uM(r,e)}default:throw new Di("Method Not Allowed",405,{Allow:"GET, POST"})}}function Y3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await K3(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Di)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 Di)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,Di,gM=be(()=>{Le=M(require("graphql"));uo();Su();a(H3,"assertExecutableDefinitionNode");a(lM,"assertRequestParams");a(UR,"processIntValueNode");a(dM,"processFloatValueNode");a(fM,"processVariableNode");a(_M,"isObject");a(pM,"transformObjectIntoQueryCondition");a(k3,"processObjectFieldNode");a(hM,"processObjectValueNode");a(F3,"processArgumentNode");a(G3,"buildConditionsQuery");a($m,"fillInFragments");a(mM,"buildSelectQuery");a(q3,"processFieldNode");a(EM,"processConstValueNode");a($3,"resolveVariables");a(V3,"executeOperation");a(uM,"resolver");br=class extends Error{static{a(this,"GraphQLQueryingError")}},Di=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(K3,"graphqlQueryingHandler");a(Y3,"start")});var Mi=w((Wbe,AM)=>{"use strict";var TM=se(),SM=(H(),C(q)),Ru=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Li=require("joi"),ya={schema_format:{pattern:Ru,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},W3=Li.alternatives(Li.string().min(1).max(ya.schema_length.maximum).pattern(Ru).messages({"string.pattern.base":"{:#label} "+ya.schema_format.message}),Li.number(),Li.array()).required(),z3=Li.alternatives(Li.string().min(1).max(ya.schema_length.maximum).pattern(Ru).messages({"string.pattern.base":"{:#label} "+ya.schema_format.message}),Li.number()),j3=Li.alternatives(Li.string().min(1).max(ya.schema_length.maximum).pattern(Ru).messages({"string.pattern.base":"{:#label} "+ya.schema_format.message}),Li.number()).required();function Q3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ya.schema_length.maximum?`'${e}' maximum of 250 characters`:Ru.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(Q3,"checkValidTable");function J3(e,t){return TM.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(J3,"validateSchemaExists");function X3(e,t){let r=t.state.ancestors[0].schema;return TM.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(X3,"validateTableExists");function Z3(e,t){return e.toLowerCase()===SM.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${SM.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(Z3,"validateSchemaName");AM.exports={common_validators:ya,schema_regex:Ru,hdb_schema_table:W3,validateSchemaExists:J3,validateTableExists:X3,validateSchemaName:Z3,checkValidTable:Q3,hdb_database:z3,hdb_table:j3}});var ft=w((jbe,RM)=>{"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};RM.exports={validateObject:eX,validateObjectAsync:tX,validateBySchema:rX};function eX(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(eX,"validateObject");async function tX(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(tX,"validateObjectAsync");function rX(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(rX,"validateBySchema")});var HR=w((Jbe,bM)=>{var{hdb_table:nX,hdb_database:yM}=Mi(),sX=ft(),BR=require("joi"),iX={undefined:"undefined",null:"null"},oX=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||iX[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"),aX=BR.object({database:yM,schema:yM,table:nX,records:BR.array().items(BR.object().custom(oX)).required()});bM.exports=function(e){return sX.validateBySchema(e,aX)}});var NM=w((Zbe,OM)=>{"use strict";var kR=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")}};OM.exports=kR});var IM=w((tOe,wM)=>{"use strict";var FR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};wM.exports=FR});var MM={};ve(MM,{HAS_EXPIRATION:()=>Ym,HAS_RESIDENCY_ID:()=>WR,HAS_STRUCTURE_UPDATE:()=>zm,LAST_TIMESTAMP_PLACEHOLDER:()=>t_,LOCAL_TIMESTAMP:()=>cX,METADATA:()=>Jf,NEW_TIMESTAMP_PLACEHOLDER:()=>PM,NO_TIMESTAMP:()=>GR,PENDING_LOCAL_TIME:()=>zR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>YR,RecordEncoder:()=>KR,TIMESTAMP_ASSIGN_LAST:()=>uX,TIMESTAMP_ASSIGN_NEW:()=>DM,TIMESTAMP_ASSIGN_PREVIOUS:()=>LM,TIMESTAMP_PLACEHOLDER:()=>Vm,TIMESTAMP_RECORD_PREVIOUS:()=>qR,handleLocalTimeForGets:()=>jm,recordUpdater:()=>jR,removeEntry:()=>Uc});function fX(){return e_[0]=e_[0]^64,lX.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?.[Jf];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?.[Jf]>=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[Jf];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,vc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<vc.length;u++){let f=vc[u].deref();(!f||f.isDone||f.isCommitted)&&vc.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?yu=i?.localTime?qR|LM:GR:yu=l?i?.localTime?qR|16384:DM|16384:GR;let _=u?.expiresAt;if(_>=0&&(c|=Ym),Zf=c,$R=_,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:yu>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(VR=E,Zf|=WR,g|=xc),R!==E&&(g|=Bc,R||(R=0)),c&Ym&&(g|=n_),u?.originatingOperation&&(g|=r_),d&&(h.ifVersion=S=i?.version??null),i&&i.value&&i.metadataFlags&qn&&(r.getBinaryFast(i.localTime)||Aa(i.value));let A;if(s!==void 0&&(A=km(()=>e.put(n,s,h),n,e.rootStore),Pc&&(g|=qn)),l){let O=u?.user?.username;if(p&&(km(()=>e.encoder.encode(p),n,e.rootStore),Pc&&(g|=qn)),e.encoder.hasStructureUpdate&&(g|=zm,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let v=i?.localTime,F=r.get(v);if(F){let G=wt(F).previousLocalTime;return A=r.put(v,bu(o,t,n,G,u?.nodeId??server.replication.getThisNodeId(r)??0,O,f,Xf,g,E,R,_),{ifVersion:S}),A}}A=r.put(s===void 0?PM:t_,bu(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,O,f,Xf,g,E,R,_,u?.originatingOperation),{append:f!=="invalidate",instructedWrite:!0,ifVersion:S})}return A}catch(R){throw R.message+=" id: "+n+" options: "+h,R}}}function Uc(e,t,r){if(t)return t.value&&t.metadataFlags&qn&&!e.auditStore.getBinaryFast(t.localTime)&&Aa(t.value),e.remove(t.key,r)}var CM,Km,Vm,t_,YR,PM,cX,Jf,e_,lX,GR,DM,uX,LM,qR,Ym,WR,zR,zm,dX,Xf,yu,Zf,$R,VR,KR,vc,Ou=be(()=>{CM=require("msgpackr");ho();Km=M(z());Ts();Ts();Vm=new Uint8Array([1,1,1,1,4,64,0,0]),t_=new Uint8Array([1,1,1,1,1,0,0,0]),YR=new Uint8Array([1,1,1,1,3,64,0,0]),PM=new Uint8Array([1,1,1,1,0,64,0,0]),cX=Symbol("local-timestamp"),Jf=Symbol("metadata"),e_=new Uint8Array(8),lX=new DataView(e_.buffer,0,8),GR=0,DM=0,uX=1,LM=3,qR=4,Ym=16,WR=32,zR=1,zm=256,yu=0,Zf=-1,$R=-1,VR=0,KR=class extends CM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(yu||Zf>=0){let o=0,c=yu;c&&(o+=8,yu=0);let l=Zf,u=$R,f=VR;l>=0&&(o+=4,Zf=-1,u>=0&&(o+=8,$R=-1),f&&(o+=4,VR=0));let d=dX=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),Pc&&(l|=qn),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=fX(),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&WR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=Dc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[Jf]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:Dc(()=>super.decode(t,r),this.rootStore)}catch(c){return Km.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(fX,"getTimestamp");a(jm,"handleLocalTimeForGets");vc=[];setInterval(()=>{for(let e=0;e<vc.length;e++){let t=vc[e].deref();!t||t.isDone||t.isCommitted?vc.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(Uc,"removeEntry")});var s_=w((aOe,UM)=>{"use strict";var vM=ae(),_X=(H(),C(q)),{RecordEncoder:pX}=(Ou(),C(MM));vM.initSync();var hX=vM.get(_X.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=hX&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:pX})}};UM.exports=QR});var i_=w((lOe,xM)=>{"use strict";var $n=ae(),As=(H(),C(q));$n.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=$n.get(As.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||$n.get(As.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||$n.get(As.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",$n.get(As.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=$n.get(As.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),$n.get(As.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=$n.get(As.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=$n.get(As.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};xM.exports=Qm;Qm.MAX_DBS=1e4});var _t=w((dOe,YM)=>{"use strict";var XR=require("lmdb"),Xs=require("fs-extra"),Vn=require("path"),Jm=_n(),kM=z(),gn=Bn().LMDB_ERRORS_ENUM,Xm=IM(),ZR=s_(),FM=i_(),ba=vt(),BM=(H(),C(q)),{table:mX,resetDatabases:EX}=(Pe(),C(tt)),HM=ae(),Zs=ba.INTERNAL_DBIS_NAME,GM=ba.DBI_DEFINITION_NAME,gX="data.mdb",SX="lock.mdb",o_=".mdb",TX="-lock",JR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=Rs(t,r),this.key_type=this.dbi[ba.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[ba.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new XR.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 ey(e,t,r=!0){try{await Xs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(gn.INVALID_BASE_PATH):n}try{let n=Vn.join(e,t+o_);return await Xs.access(n,Xs.constants.R_OK|Xs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Xs.access(Vn.join(e,t,gX),Xs.constants.R_OK|Xs.constants.F_OK),Vn.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(ey,"validateEnvironmentPath");function eE(e,t){if(Jm.validateEnv(e),t===void 0)throw new Error(gn.DBI_NAME_REQUIRED)}a(eE,"validateEnvDBIName");async function AX(e,t,r=!1,n=!1){Zm(e,t);let s=Vn.basename(e);t=t.toString();let i=HM.get(BM.CONFIG_PARAMS.DATABASES);i||HM.setProperty(BM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await ey(e,t,n),qM(e,t,r)}catch(o){if(o.message===gn.INVALID_ENVIRONMENT){let c=Vn.join(e,t);await Xs.mkdirp(n?c:e);let l=new FM(n?c:c+o_,!1),u=XR.open(l);u.dbis=Object.create(null);let f=new ZR(!1);u.openDB(Zs,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=ty(e,t,r);return u[ba.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(AX,"createEnvironment");async function RX(e,t,r,n=!0){Zm(e,t),t=t.toString();let s=Vn.join(e,t);return mX({table:t,database:Vn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(RX,"copyEnvironment");async function qM(e,t,r=!1){Zm(e,t),t=t.toString();let n=ty(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 ey(e,t),i=Vn.join(e,t+o_),o=s!=i,c=new FM(s,o),l=XR.open(c);l.dbis=Object.create(null);let u=VM(l);for(let f=0;f<u.length;f++)Rs(l,u[f]);return l[ba.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(qM,"openEnvironment");async function yX(e,t,r=!1){Zm(e,t),t=t.toString();let n=Vn.join(e,t+o_),s=await ey(e,t);if(global.lmdb_map!==void 0){let i=ty(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await $M(o),delete global.lmdb_map[i]}}await Xs.remove(s),await Xs.remove(s===n?s+TX:Vn.join(Vn.dirname(s),SX))}a(yX,"deleteEnvironment");async function $M(e){Jm.validateEnv(e);let t=e[ba.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a($M,"closeEnvironment");function ty(e,t,r=!1){let s=`${Vn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(ty,"getCachedEnvironmentName");function bX(e){Jm.validateEnv(e);let t=Object.create(null),r=Rs(e,Zs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Zs)try{t[n]=Object.assign(new Xm,s)}catch{kM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(bX,"listDBIDefinitions");function VM(e){Jm.validateEnv(e);let t=[],r=Rs(e,Zs);for(let{key:n}of r.getRange({start:!1}))n!==Zs&&t.push(n);return t}a(VM,"listDBIs");function OX(e,t){let n=Rs(e,Zs).getEntry(t),s=new Xm;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{kM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(OX,"getDBIDefinition");function KM(e,t,r,n=!r){if(eE(e,t),t=t.toString(),t===Zs)throw new Error(gn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Rs(e,t)}catch(s){if(s.message===gn.DBI_DOES_NOT_EXIST){let i=new ZR(r,n===!0),o=e.openDB(t,i),c=new Xm(r===!0,n);return o[GM]=c,Rs(e,Zs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(KM,"createDBI");function Rs(e,t){if(eE(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Zs?r=OX(e,t):r=new Xm,r===void 0)throw new Error(gn.DBI_DOES_NOT_EXIST);let n;try{let s=new ZR(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[GM]=r,e.dbis[t]=n,n}a(Rs,"openDBI");function NX(e,t){eE(e,t),t=t.toString();let r=Rs(e,t),n=r.getStats();return r[ba.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(NX,"statDBI");async function wX(e,t){try{let r=Vn.join(e,t+o_);return(await Xs.stat(r)).size}catch{throw new Error(gn.INVALID_ENVIRONMENT)}}a(wX,"environmentDataSize");function IX(e,t){if(eE(e,t),t=t.toString(),t===Zs)throw new Error(gn.CANNOT_DROP_INTERNAL_DBIS_NAME);Rs(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Rs(e,Zs).removeSync(t)}a(IX,"dropDBI");function CX(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{Rs(e,i)}catch(o){if(o.message===gn.DBI_DOES_NOT_EXIST)KM(e,i,i!==t,i===t),n=!0;else throw o}}n&&EX()}a(CX,"initializeDBIs");YM.exports={openDBI:Rs,openEnvironment:qM,createEnvironment:AX,listDBIs:VM,listDBIDefinitions:bX,createDBI:KM,dropDBI:IX,statDBI:NX,deleteEnvironment:yX,initializeDBIs:CX,TransactionCursor:JR,environmentDataSize:wX,copyEnvironment:RX,closeEnvironment:$M}});var zM=w((_Oe,WM)=>{"use strict";var ry=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};WM.exports=ry});var QM=w((hOe,jM)=>{"use strict";var ny=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}};jM.exports=ny});var XM=w((EOe,JM)=>{"use strict";var sy=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};JM.exports=sy});var kc=w((ROe,tv)=>{"use strict";var PX=_t(),DX=zM(),LX=QM(),MX=XM(),vi=_n(),a_=Bn().LMDB_ERRORS_ENUM,vX=vt(),mo=(H(),C(q)),UX=se(),xX=require("uuid"),SOe=require("lmdb"),{handleHDBError:BX,hdb_errors:HX}=pe(),{OVERFLOW_MARKER:TOe,MAX_SEARCH_KEY_LENGTH:AOe}=vX,ZM=ae();ZM.initSync();var tE=ZM.get(mo.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),iy=mo.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Hc=mo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function kX(e,t,r,n,s=vi.getNextMonotonicTime()){ly(e,t,r,n),oy(e,t,r);let i=new DX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];ev(u,!0,s);let f=FX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return ay(o,c,n,i,s)}a(kX,"insertRecords");function FX(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][mo.FUNC_VAL],n[o]=c)}let l=vi.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[Hc])})}a(FX,"insertRecord");function GX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(GX,"removeSkippedRecords");function ev(e,t,r){let n=r>0;(n||!Number.isInteger(e[Hc]))&&(e[Hc]=r||(r=vi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[iy]))&&(e[iy]=r||vi.getNextMonotonicTime()):delete e[iy]}a(ev,"setTimestamps");function oy(e,t,r){r.indexOf(mo.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(mo.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(mo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(mo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),PX.initializeDBIs(e,t,r)}a(oy,"initializeTransaction");async function qX(e,t,r,n,s=vi.getNextMonotonicTime()){ly(e,t,r,n),oy(e,t,r);let i=new LX,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],p;try{p=cy(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(p),l.push(d)}return ay(c,l,n,i,s,o)}a(qX,"updateRecords");async function $X(e,t,r,n,s=vi.getNextMonotonicTime()){try{ly(e,t,r,n)}catch(l){throw BX(l,l.message,HX.HTTP_STATUS_CODES.BAD_REQUEST)}oy(e,t,r);let i=new MX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;UX.isEmpty(u[t])?(f=xX.v4(),u[t]=f):f=u[t];let d=cy(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return ay(o,c,n,i,s)}a($X,"upsertRecords");async function ay(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||vi.getNextMonotonicTime(),GX(r,i),n}a(ay,"finalizeWrite");function cy(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(ev(r,!f,o),Number.isInteger(r[Hc])&&u[Hc]>r[Hc])return!1;f&&s.original_records.push(u);let d,p=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let S=r[h],g=e.dbis[h];if(g===void 0)continue;let R=u[h];if(typeof S=="function"){let A=S([[u]]);Array.isArray(A)&&(S=A[0][mo.FUNC_VAL],r[h]=S)}if(S===R)continue;let E=vi.getIndexedValues(R);if(E){tE&&g.prefetch(E.map(A=>({key:A,value:n})),rE);for(let A=0,O=E.length;A<O;A++)g.remove(E[A],n)}if(E=vi.getIndexedValues(S),E){tE&&g.prefetch(E.map(A=>({key:A,value:n})),rE);for(let A=0,O=E.length;A<O;A++)g.put(E[A],n)}}let _={...u,...r};c.put(n,_,_[Hc])},"do_put");return l?d=c.ifVersion(n,l.version,p):d=c.ifNoExists(n,p),d.then(_=>_?!0:cy(e,t,r,n,s,i,o))}a(cy,"updateUpsertRecord");function VX(e,t,r){if(vi.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(VX,"validateBasic");function ly(e,t,r,n){if(VX(e,t,r),!Array.isArray(n))throw n===void 0?new Error(a_.RECORDS_REQUIRED):new Error(a_.RECORDS_MUST_BE_ARRAY)}a(ly,"validateWrite");function rE(){}a(rE,"noop");tv.exports={insertRecords:kX,updateRecords:qX,upsertRecords:$X}});var Eo=w((bOe,KX)=>{KX.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 nE=w((OOe,rv)=>{var{common_validators:Ui}=Mi(),l_=ft(),c_="is required",er={database:{presence:!1,format:Ui.schema_format,length:Ui.schema_length},schema:{presence:!1,format:Ui.schema_format,length:Ui.schema_length},table:{presence:!0,format:Ui.schema_format,length:Ui.schema_length},attribute:{presence:!0,format:Ui.schema_format,length:Ui.schema_length},hash_attribute:{presence:!0,format:Ui.schema_format,length:Ui.schema_length}};function u_(e){for(let t in e)e[t]=e[t]===null||e[t]===void 0||typeof e[t]=="object"?e[t]:e[t].toString();return e}a(u_,"makeAttributesStrings");function YX(e){return e=u_(e),er.table.presence=!1,er.attribute.presence=!1,er.hash_attribute.presence=!1,l_.validateObject(e,er)}a(YX,"schema_object");function WX(e){return e=u_(e),er.table.presence={message:c_},er.attribute.presence=!1,er.hash_attribute.presence=!1,l_.validateObject(e,er)}a(WX,"table_object");function zX(e){return e=u_(e),er.table.presence={message:c_},er.attribute.presence=!1,l_.validateObject(e,er)}a(zX,"create_table_object");function jX(e){return e=u_(e),er.table.presence={message:c_},er.attribute.presence={message:c_},er.hash_attribute.presence=!1,l_.validateObject(e,er)}a(jX,"attribute_object");function QX(e){return e=u_(e),er.table.presence={message:c_},er.attribute.presence=!1,er.hash_attribute.presence=!1,l_.validateObject(e,er)}a(QX,"describe_table");function JX(e){if(e){if(!Array.isArray(e))throw new Error("residence must be a string array");if(e.length===0)throw new Error("residence cannot be an empty array");for(let t=0;t<e.length;t++)if(typeof e[t]!="string")throw new Error(`residence must be a string array, item '${e[t]}' is not a string`)}}a(JX,"validateTableResidence");rv.exports={schema_object:YX,create_table_object:zX,table_object:WX,attribute_object:jX,describe_table:QX,validateTableResidence:JX}});var sv=w((wOe,nv)=>{"use strict";var XX=require("uuid"),uy=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||XX.v4(),this.schema_table=`${this.schema}.${this.table}`}};nv.exports=uy});var sE=w((COe,iv)=>{"use strict";var ZX=sv(),dy=class extends ZX{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}};iv.exports=dy});var av=w((DOe,ov)=>{"use strict";ov.exports=t6;var e6="inserted";function t6(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===e6?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(t6,"returnObject")});var iE=w((vOe,dv)=>{"use strict";var r6=(H(),C(q)),fy=_t(),n6=kc(),{getSystemSchemaPath:s6,getSchemaPath:i6}=gt(),MOe=Eo(),o6=nE(),a6=sE(),c6=av(),{handleHDBError:cv,hdb_errors:uv}=pe(),lv=se(),{HTTP_STATUS_CODES:l6}=uv,u6="inserted";dv.exports=d6;async function d6(e){let t=o6.attribute_object(e);if(t)throw cv(new Error,t.message,uv.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&lv.checkGlobalSchemaTable(e.schema,e.table);if(r)throw cv(new Error,r,l6.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 a6(e.schema,e.table,e.attribute,e.id);try{let i=await fy.openEnvironment(i6(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}`);fy.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await fy.openEnvironment(s6(),r6.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await n6.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return c6(u6,c,{records:[s]},l)}catch(i){throw i}}a(d6,"lmdbCreateAttribute")});var d_=w((BOe,_v)=>{"use strict";var go=se(),fv=z(),xOe=HR(),{getDatabases:f6}=(Pe(),C(tt)),{ClientError:Fc}=pe();_v.exports=_6;function _6(e){if(go.isEmpty(e))throw new Fc("invalid update parameters defined.");if(go.isEmptyOrZeroLength(e.schema))throw new Fc("invalid schema specified.");if(go.isEmptyOrZeroLength(e.table))throw new Fc("invalid table specified.");if(!Array.isArray(e.records))throw new Fc("records must be an array");let t=f6()[e.schema]?.[e.table];if(go.isEmpty(t))throw new Fc(`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&&go.isEmptyOrZeroLength(o[r]))throw fv.error("a valid hash attribute must be provided with update record:",o),new Fc("a valid hash attribute must be provided with update record, check log for more info");if(!go.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 Fc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!go.isEmpty(o[r])&&o[r]!==""&&n.has(go.autoCast(o[r]))&&(o.skip=!0),n.add(go.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(_6,"insertUpdateValidate")});var hv=w((kOe,pv)=>{"use strict";var _y=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};pv.exports=_y});var gv=w((GOe,Ev)=>{"use strict";var py=_t(),p6=z(),mv=Bn().LMDB_ERRORS_ENUM;Ev.exports=h6;async function h6(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 py.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 py.closeEnvironment(global.lmdb_map[n]),await py.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){p6.error(t)}}a(h6,"cleanLMDBMap")});var Dv=w((VOe,Pv)=>{"use strict";var hy=require("recursive-iterator"),m6=require("alasql"),my=require("clone"),Sv=se(),{handleHDBError:Tv,hdb_errors:E6}=pe(),{HDB_ERROR_MSGS:Av,HTTP_STATUS_CODES:Rv}=E6,{getDatabases:g6}=(Pe(),C(tt)),S6=["DISTINCT_ARRAY"],yv=Symbol("validateTables"),Ey=Symbol("validateTable"),$Oe=Symbol("getAllColumns"),bv=Symbol("validateAllColumns"),oE=Symbol("findColumn"),Ov=Symbol("validateOrderBy"),f_=Symbol("validateSegment"),gy=Symbol("validateColumn"),Nv=Symbol("setColumnsForTable"),wv=Symbol("checkColumnsForAsterisk"),Iv=Symbol("validateGroupBy"),Cv=Symbol("hasColumns"),Sy=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[Ey](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Ey](t.table)})}}[Cv](){let t=!1,r=new hy(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Ey](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=g6();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=my(s);i.table=my(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 hy(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 m6.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[bv](){this[f_](this.statement.columns,!1),this[f_](this.statement.joins,!1),this[f_](this.statement.where,!1),this[Iv](this.statement.group,!1),this[f_](this.statement.order,!0)}[f_](t,r){if(!t)return;let n=new hy(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[gy](i)));return s}[Iv](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&S6.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=my(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[gy](t)}[gy](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=Sy});var Uv=w((YOe,vv)=>{"use strict";var Lv=require("lodash"),__=require("mathjs"),T6=require("jsonata"),Mv=se();vv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Lv.uniqWith(e,Lv.isEqual):e,"distinct_array"),searchJSON:A6,mad:p_.bind(null,__.mad),mean:p_.bind(null,__.mean),mode:p_.bind(null,__.mode),prod:p_.bind(null,__.prod),median:p_.bind(null,__.median)};function p_(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(p_,"aggregateFunction");function A6(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=T6(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(A6,"searchJSON")});var Bv=w((zOe,xv)=>{"use strict";var tr=require("moment"),Ty="YYYY-MM-DDTHH:mm:ss.SSSZZ";tr.suppressDeprecationWarnings=!0;xv.exports={current_date:a(()=>tr().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>tr().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return tr(e).utc().format("YYYY");case"month":return tr(e).utc().format("MM");case"day":return tr(e).utc().format("DD");case"hour":return tr(e).utc().format("HH");case"minute":return tr(e).utc().format("mm");case"second":return tr(e).utc().format("ss");case"millisecond":return tr(e).utc().format("SSS");default:break}},"extract"),date:a(e=>tr(e).utc().format(Ty),"date"),date_format:a((e,t)=>tr(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>tr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>tr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=tr(e).utc(),s=tr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>tr().utc().valueOf(),"now"),get_server_time:a(()=>tr().format(Ty),"get_server_time"),offset_utc:a((e,t)=>tr(e).utc().utcOffset(t).format(Ty),"offset_utc")}});var Gv=w((QOe,Fv)=>{"use strict";var R6=require("@turf/area"),y6=require("@turf/length"),b6=require("@turf/circle"),O6=require("@turf/difference"),N6=require("@turf/distance"),w6=require("@turf/boolean-contains"),I6=require("@turf/boolean-equal"),C6=require("@turf/boolean-disjoint"),P6=require("@turf/helpers"),Hv=(H(),C(q)),Ge=se(),So=z();Fv.exports={geoArea:D6,geoLength:L6,geoCircle:M6,geoDifference:v6,geoDistance:kv,geoNear:U6,geoContains:x6,geoEqual:B6,geoCrosses:H6,geoConvert:k6};function D6(e){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return R6.default(e)}catch(t){return So.trace(t,e),NaN}}a(D6,"geoArea");function L6(e,t){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return y6.default(e,{units:t||"kilometers"})}catch(r){return So.trace(r,e),NaN}}a(L6,"geoLength");function M6(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return b6.default(e,t,{units:r||"kilometers"})}catch(n){return So.trace(n,e,t),NaN}}a(M6,"geoCircle");function v6(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 O6(e,t)}catch(r){return So.trace(r,e,t),NaN}}a(v6,"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 N6.default(e,t,{units:r||"kilometers"})}catch(n){return So.trace(n,e,t),NaN}}a(kv,"geoDistance");function U6(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 So.trace(s,e,t),!1}}a(U6,"geoNear");function x6(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 w6.default(e,t)}catch(r){return So.trace(r,e,t),!1}}a(x6,"geoContains");function B6(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 I6.default(e,t)}catch(r){return So.trace(r,e,t),!1}}a(B6,"geoEqual");function H6(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!C6.default(e,t)}catch(r){return So.trace(r,e,t),!1}}a(H6,"geoCrosses");function k6(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)),P6[t](e,r)}a(k6,"geoConvert")});var aE=w((XOe,qv)=>{var Gc=Uv(),Kn=Bv(),xi=Gv();qv.exports=e=>{e.aggr.mad=e.aggr.MAD=Gc.mad,e.aggr.mean=e.aggr.MEAN=Gc.mean,e.aggr.mode=e.aggr.MODE=Gc.mode,e.aggr.prod=e.aggr.PROD=Gc.prod,e.aggr.median=e.aggr.MEDIAN=Gc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Gc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Gc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Kn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Kn.current_time,e.fn.extract=e.fn.EXTRACT=Kn.extract,e.fn.date=e.fn.DATE=Kn.date,e.fn.date_format=e.fn.DATE_FORMAT=Kn.date_format,e.fn.date_add=e.fn.DATE_ADD=Kn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Kn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Kn.date_diff,e.fn.now=e.fn.NOW=Kn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Kn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Kn.get_server_time,e.fn.getdate=e.fn.GETDATE=Kn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Kn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=xi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=xi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=xi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=xi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=xi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=xi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=xi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=xi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=xi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=xi.geoNear}});var Yv=w((ZOe,Kv)=>{"use strict";var h_=require("lodash"),Sn=require("alasql");Sn.options.cache=!1;var F6=aE(),$v=require("clone"),cE=require("recursive-iterator"),Ue=z(),We=se(),Nu=Yn(),G6=(H(),C(q)),{hdb_errors:q6}=pe(),{getDatabases:Vv}=(Pe(),C(tt)),$6="IS NULL",ei="There was a problem performing this search. Please check the logs and try again.";F6(Sn);var Ay=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(ei)}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(ei)}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(ei)}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(ei)}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(ei)}}_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=h_.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(We.isEmpty(this.statement.where)){Ue.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),!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 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(!We.isEmpty(G6.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&&h_.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($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(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($6)>-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=h_.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 Nu.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(ei)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async f=>{let d={...c};d.search_value=f;let p=await Nu.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(ei)}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 Nu.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(ei)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await Nu.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(ei)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof 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=h_.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=h_.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(ei)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let f in i)o.push(i[f][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await Nu.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(q6.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 Nu.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(ei)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Kv.exports=Ay});var Yr=w((tNe,Wv)=>{"use strict";var V6=Dv();Wv.exports={searchByConditions:Y6,searchByHash:W6,searchByValue:z6,search:j6};var Ry=Yn(),{transformReq:yy}=se(),K6=Yv();async function Y6(e){return yy(e),Ry.searchByConditions(e)}a(Y6,"searchByConditions");async function W6(e){yy(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of Ry.searchByHash(e))r&&t.push(r);return t}a(W6,"searchByHash");async function z6(e){yy(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of Ry.searchByValue(e))t.push(r);return t}a(z6,"searchByValue");function j6(e,t){try{let r=new V6(e);r.validate(),new K6(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(j6,"search")});var To=w((nNe,Jv)=>{"use strict";var m_=require("crypto"),Q6=ae(),{CONFIG_PARAMS:J6}=(H(),C(q)),jv="aes-256-cbc",X6=32,Z6=16,by=64,Qv=32,eZ=by+Qv,zv=new Map;Jv.exports={encrypt:tZ,decrypt:rZ,createNatsTableStreamName:nZ};function tZ(e){let t=m_.randomBytes(X6),r=m_.randomBytes(Z6),n=m_.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(tZ,"encrypt");function rZ(e){let t=e.substr(0,by),r=e.substr(by,Qv),n=e.substr(eZ,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=m_.createDecipheriv(jv,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(rZ,"decrypt");function nZ(e,t){let r=Q6.get(J6.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=zv.get(r);return n||(n=m_.createHash("md5").update(r).digest("hex"),zv.set(r,n)),n}a(nZ,"createNatsTableStreamName")});var Ao=w((oNe,eU)=>{"use strict";var iNe=Yr(),E_=z(),Xv=nE(),sZ=To(),lE=se(),{handleHDBError:uE,hdb_errors:iZ}=pe(),{HDB_ERROR_MSGS:dE,HTTP_STATUS_CODES:Oy}=iZ,Zv=ae();Zv.initSync();var{getDatabases:Ny}=(Pe(),C(tt)),oZ=require("fs-extra"),aZ=(H(),C(q));eU.exports={describeAll:cZ,describeTable:fE,describeSchema:lZ};async function cZ(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=Ny(),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){E_.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 E_.error("Got an error in describeAll"),E_.error(t),uE(new Error,dE.DESCRIBE_ALL_ERR)}}a(cZ,"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.describe_table(e);if(i)throw i;let c=Ny()[r];if(!c)throw uE(new Error,dE.SCHEMA_NOT_FOUND(e.schema),Oy.NOT_FOUND);let l=c[n];if(!l)throw uE(new Error,dE.TABLE_NOT_FOUND(e.schema,e.table),Oy.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 oZ.stat(l.primaryStore.env.path)).size}catch(_){E_.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(aZ.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(p.clustering_stream_name=sZ.createNatsTableStreamName(p.schema,p.name));try{let _=await l.getRecordCount({exactCount:e.exact_count==="true"});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(_){E_.warn(`unable to stat table dbi due to ${_}`)}return p}a(fE,"descTable");async function lZ(e){lE.transformReq(e);let t=Xv.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=Ny()[n];if(!i)throw uE(new Error,dE.SCHEMA_NOT_FOUND(e.schema),Oy.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(lZ,"describeSchema")});var ys=w((uNe,iU)=>{var uZ=Eo(),{callbackify:rU,promisify:dZ}=require("util"),{getDatabases:nU}=(Pe(),C(tt));iU.exports={setSchemaDataToGlobal:tU,getTableSchema:fZ,getSystemSchema:_Z,setSchemaDataToGlobalAsync:dZ(tU)};var sU=Ao(),cNe=rU(sU.describeAll),lNe=rU(sU.describeTable);function tU(e){global.hdb_schema=nU(),e&&e()}a(tU,"setSchemaDataToGlobal");function fZ(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(fZ,"getTableSchema");function _Z(){return uZ}a(_Z,"getSystemSchema")});var Iy=w((fNe,cU)=>{var pZ=ft(),wy=require("joi"),{hdb_table:hZ,hdb_database:oU}=Mi(),aU={schema:oU,database:oU,table:hZ},mZ={date:wy.date().iso().required()},EZ={timestamp:wy.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};cU.exports=function(e,t){let r=t==="timestamp"?{...aU,...EZ}:{...aU,...mZ},n=wy.object(r);return pZ.validateBySchema(e,n)}});var dU=w((_Ne,uU)=>{var gZ=ft(),Cy=require("joi"),{hdb_table:SZ,hdb_database:lU}=Mi(),TZ=Cy.object({schema:lU,database:lU,table:SZ,hash_values:Cy.array().required(),ids:Cy.array()});uU.exports=function(e){return gZ.validateBySchema(e,TZ)}});var My=w((pNe,fU)=>{"use strict";var Py=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}},Dy=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}},Ly=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};fU.exports={InsertObject:Py,NoSQLSeachObject:Dy,DeleteResponseObject:Ly}});var Vc=w((mNe,EU)=>{"use strict";var pU=Iy(),AZ=dU(),qc=se(),_U=require("moment"),hU=z(),{promisify:RZ,callbackify:yZ}=require("util"),$c=(H(),C(q)),bZ=ys(),vy=RZ(bZ.getTableSchema),Uy=Yn(),{DeleteResponseObject:OZ}=My(),{handleHDBError:Oa,hdb_errors:NZ}=pe(),{HDB_ERROR_MSGS:_E,HTTP_STATUS_CODES:Na}=NZ,wZ="records successfully deleted",IZ=yZ(mU);EU.exports={delete:IZ,deleteRecord:mU,deleteFilesBefore:CZ,deleteAuditLogsBefore:PZ};async function CZ(e){let t=pU(e,"date");if(t)throw Oa(t,t.message,Na.BAD_REQUEST,void 0,void 0,!0);if(qc.transformReq(e),!_U(e.date,_U.ISO_8601).isValid())throw Oa(new Error,_E.INVALID_DATE,Na.BAD_REQUEST,$c.LOG_LEVELS.ERROR,_E.INVALID_DATE,!0);let n=qc.checkSchemaTableExist(e.schema,e.table);if(n)throw Oa(new Error,n,Na.NOT_FOUND,$c.LOG_LEVELS.ERROR,n,!0);let s=await Uy.deleteRecordsBefore(e);if(await vy(e.schema,e.table),hU.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(CZ,"deleteFilesBefore");async function PZ(e){let t=pU(e,"timestamp");if(t)throw Oa(t,t.message,Na.BAD_REQUEST,void 0,void 0,!0);if(qc.transformReq(e),isNaN(e.timestamp))throw Oa(new Error,_E.INVALID_VALUE("Timestamp"),Na.BAD_REQUEST,$c.LOG_LEVELS.ERROR,_E.INVALID_VALUE("Timestamp"),!0);let r=qc.checkSchemaTableExist(e.schema,e.table);if(r)throw Oa(new Error,r,Na.NOT_FOUND,$c.LOG_LEVELS.ERROR,r,!0);let n=await Uy.deleteAuditLogsBefore(e);return await vy(e.schema,e.table),hU.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(PZ,"deleteAuditLogsBefore");async function mU(e){e.ids&&(e.hash_values=e.ids);let t=AZ(e);if(t)throw Oa(t,t.message,Na.BAD_REQUEST,void 0,void 0,!0);qc.transformReq(e);let r=qc.checkSchemaTableExist(e.schema,e.table);if(r)throw Oa(new Error,r,Na.NOT_FOUND,$c.LOG_LEVELS.ERROR,r,!0);try{await vy(e.schema,e.table);let n=await Uy.deleteRecords(e);return qc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${wZ}`),n}catch(n){if(n.message===$c.SEARCH_NOT_FOUND_MESSAGE){let s=new OZ;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 pE={};ve(pE,{HASH_FUNCTION:()=>T_,hash:()=>Hy,validate:()=>ky});function xy(e=S_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(g_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function Hy(e,t=T_[SU?.toUpperCase()]??"sha256"){return By[t](e)}function ky(e,t,r=T_[SU?.toUpperCase()]??"sha256"){return e?DZ[r](e,t):!1}var g_,wu,gU,SU,S_,TU,T_,By,DZ,hE=be(()=>{g_=M(require("node:crypto")),wu=M(require("argon2")),gU=M(ae());H();SU=(0,gU.get)(B.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),S_=16,TU=9,T_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(T_||{});a(xy,"generateSalt");By={md5:a((e,t=void 0)=>{t=t??xy(TU);let r=g_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??xy(S_);let r=g_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=xy(S_),r=await wu.hash(e,{type:wu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},DZ={md5:a((e,t)=>{let r=e.slice(0,TU);return e===By.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,S_);return e===By.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await wu.verify(e.slice(S_),t),"argon2id")};a(Hy,"hash");a(ky,"validate")});var RU=w((TNe,AU)=>{var Fy=ft(),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 LZ(e){return Wr.password.presence=!0,Wr.username.presence=!0,Wr.role.presence=!0,Wr.active.presence=!0,Fy.validateObject(e,Wr)}a(LZ,"addUserValidation");function MZ(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,Fy.validateObject(e,Wr)}a(MZ,"alterUserValidation");function vZ(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,Fy.validateObject(e,Wr)}a(vZ,"dropUserValidation");AU.exports={addUserValidation:LZ,alterUserValidation:MZ,dropUserValidation:vZ}});var Tt=w((yNe,bU)=>{"use strict";var{platform:RNe}=require("os"),UZ="nats-server.zip",Gy="nats-server",xZ=process.platform==="win32"?`${Gy}.exe`:Gy,BZ=/^[^\s.,*>]+$/,yU="__request__",HZ=a(e=>`${e}.${yU}`,"REQUEST_SUBJECT"),kZ={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},FZ={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},GZ={HUB:"hub.pid",LEAF:"leaf.pid"},qZ={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},$Z={SUCCESS:"success",ERROR:"error"},VZ={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},KZ={TXN:"txn",MSGID:"msgid"},Iu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},YZ={[Iu.ERR]:1,[Iu.WRN]:2,[Iu.INF]:3,[Iu.DBG]:4,[Iu.TRC]:5},WZ={debug:"-D",trace:"-DVV"};bU.exports={NATS_SERVER_ZIP:UZ,NATS_SERVER_NAME:Gy,NATS_BINARY_NAME:xZ,PID_FILES:GZ,NATS_CONFIG_FILES:FZ,SERVER_SUFFIX:qZ,NATS_TERM_CONSTRAINTS_RX:BZ,REQUEST_SUFFIX:yU,UPDATE_REMOTE_RESPONSE_STATUSES:$Z,CLUSTER_STATUS_STATUSES:VZ,REQUEST_SUBJECT:HZ,SUBJECT_PREFIXES:KZ,MSG_HEADERS:kZ,LOG_LEVELS:Iu,LOG_LEVEL_FLAGS:WZ,LOG_LEVEL_HIERARCHY:YZ}});var qy=w(OU=>{"use strict";var zZ={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
- `)},z6="certificate.pem",j6="privateKey.pem",Q6="caCertificate.pem",J6="natsCertificate.pem",X6="natsCaCertificate.pem",Tt={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},Z6={tls_certificate:Tt.SERVER,tls_certificateAuthority:Tt.CA,customFunctions_tls_certificate:Tt.SERVER,customFunctions_tls_certificateAuthority:Tt.CA,operationsApi_tls_certificate:Tt["OPERATIONS-API"],operationsApi_tls_certificateAuthority:Tt["OPERATIONS-CA"]},e8={[Tt.SERVER]:2,[Tt.DEFAULT]:1},t8={[Tt["OPERATIONS-API"]]:3,[Tt.SERVER]:2,[Tt.DEFAULT]:1},r8={[Tt["OPERATIONS-API"]]:3,[Tt.SERVER]:2,[Tt.DEFAULT]:1},n8={[Tt["OPERATIONS-CA"]]:3,[Tt.CA]:2,[Tt["DEFAULT-CA"]]:1},s8={[Tt["OPERATIONS-CA"]]:3,[Tt.CA]:2,[Tt["DEFAULT-CA"]]:1},i8={[Tt.CA]:2,[Tt["DEFAULT-CA"]]:1};Object.assign(yU,{CERTIFICATE_PEM_NAME:z6,PRIVATEKEY_PEM_NAME:j6,CA_PEM_NAME:Q6,CERT_NAME:Tt,CERT_CONFIG_NAME_MAP:Z6,CERT_PREFERENCE_APP:e8,CERT_PREFERENCE_OPS:t8,CERT_PREFERENCE_REP:r8,CA_CERT_PREFERENCE_REP:n8,CA_CERT_PREFERENCE_OPS:s8,CA_CERT_PREFERENCE_APP:i8,CERTIFICATE_VALUES:W6,NATS_CERTIFICATE_PEM_NAME:J6,NATS_CA_PEM_NAME:X6})});var $y=I((NNe,CU)=>{"use strict";var wU=require("fs-extra"),Se=require("joi"),o8=require("os"),{boolean:He,string:At,number:tr,array:Yc}=Se.types(),{totalmem:bU}=require("os"),Kc=require("path"),a8=Y(),qy=oe(),ONe=Gy(),OU=(B(),C(G)),c8=ut(),NU="log",l8="components",u8="Invalid logging.rotation.maxSize unit. Available units are G, M or K",d8="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",f8="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",_8="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",p8="rootPath config parameter is undefined",An=Se.alternatives([tr.min(0),At]).optional().empty(null),mE=Se.alternatives([Yc.items(At,{host:At.required(),port:An},{hostname:At.required(),port:An}).empty(null),Yc.items(At)]),Hi,IU=!1;CU.exports={configValidator:h8,routesValidator:A8,route_constraints:mE};function h8(e,t=!1){if(IU=t,Hi=e.rootPath,qy.isEmpty(Hi))throw p8;let r=He.optional(),n=tr.min(0).max(1e3).empty(null).default(T8),s=At.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(A_),i=At.optional().empty(null),o=At.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=Se.string().empty(null).default(A_),l=Se.custom(E8).empty(null).default(A_),u=e.clustering?.enabled,f=Se.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return u===!0?d=Se.object({enabled:r,hubServer:Se.object({cluster:Se.object({name:Se.required().empty(null),network:Se.object({port:An,routes:mE}).required()}).required(),leafNodes:Se.object({network:Se.object({port:An}).required()}).required(),network:Se.object({port:An}).required()}).required(),leafServer:Se.object({network:Se.object({port:An,routes:mE}).required(),streams:Se.object({maxAge:tr.min(120).allow(null).optional(),maxBytes:tr.min(1).allow(null).optional(),maxMsgs:tr.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:Se.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:He.optional(),databaseLevel:He.optional(),tls:Se.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.required(),verify:He.optional()}),user:At.optional().empty(null)}).optional():d=Se.object({enabled:r,tls:Se.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.optional()})}).optional(),Se.object({authentication:Se.alternatives(Se.object({authorizeLocal:He,cacheTTL:tr.required(),enableSessions:He,hashFunction:At.valid("md5","sha256","argon2id").optional().empty(null)}),He).optional(),analytics:Se.object({aggregatePeriod:tr}),replication:Se.object({hostname:Se.alternatives(At,tr).optional().empty(null),url:At.optional().empty(null),port:An,securePort:An,routes:Yc.optional().empty(null),databases:Se.alternatives(At,Yc),enableRootCAs:He.optional(),copyTablesToCatchUp:He.optional()}).optional(),componentsRoot:s.optional(),clustering:d,localStudio:Se.object({enabled:r}).required(),logging:Se.object({auditAuthEvents:Se.object({logFailed:He,logSuccessful:He}),file:He.required(),level:Se.valid("notify","fatal","error","warn","info","debug","trace"),rotation:Se.object({enabled:He.optional(),compress:He.optional(),interval:At.custom(S8).optional().empty(null),maxSize:At.custom(g8).optional().empty(null),path:At.optional().empty(null).default(A_)}).required(),root:s,stdStreams:He.required(),auditLog:He.required()}).required(),operationsApi:Se.object({network:Se.object({cors:He.optional(),corsAccessList:Yc.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:An,domainSocket:Se.optional().empty("hdb/operations-server").default(A_),securePort:An,timeout:tr.min(1).optional()}).optional(),tls:Se.alternatives([Se.array().items(f),f])}).required(),rootPath:At.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:Se.object({network:Se.object({port:An,securePort:An,mtls:Se.alternatives([He.optional(),Se.object({user:At.optional(),certificateAuthority:i,required:He.optional()})])}).required(),webSocket:He.optional(),requireAuthentication:He.optional()}),http:Se.object({compressionThreshold:tr.optional(),cors:He.optional(),corsAccessList:Yc.optional(),headersTimeout:tr.min(1).optional(),port:An,securePort:An,maxHeaderSize:tr.optional(),mtls:Se.alternatives([He.optional(),Se.object({user:At.optional(),certificateAuthority:i,required:He.optional()})]),threadRange:Se.alternatives([Yc.optional(),At.optional()])}).required(),threads:Se.alternatives(n.optional(),Se.object({count:n.optional(),debug:Se.alternatives(He.optional(),Se.object({startingPort:tr.min(1).optional(),host:At.optional(),waitForDebugger:He.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:Se.object({writeAsync:He.required(),overlappingSync:He.optional(),caching:He.optional(),compression:Se.alternatives([He.optional(),Se.object({dictionary:At.optional(),threshold:tr.optional()})]),compactOnStart:He.optional(),compactOnStartKeepBackup:He.optional(),noReadAhead:He.optional(),path:l,prefetchWrites:He.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:He.optional(),tls:Se.alternatives([Se.array().items(f),f])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(h8,"configValidator");function m8(e){return IU||wU.existsSync(e)?null:`Specified path ${e} does not exist.`}a(m8,"doesPathExist");function E8(e,t){Se.assert(e,At.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=m8(e);if(r)return t.message(r)}a(E8,"validatePath");function g8(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(u8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(f8):e}a(g8,"validateRotationMaxSize");function S8(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(d8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(_8):e}a(S8,"validateRotationInterval");function T8(e,t){let r=t.state.path.join("."),n=o8.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||bU();return i=Math.round(Math.min(i,bU())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),a8.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(T8,"setDefaultThreads");function A_(e,t){let r=t.state.path.join(".");if(!qy.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(qy.isEmpty(Hi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Kc.join(Hi,l8);case"logging.root":return Kc.join(Hi,NU);case"clustering.leafServer.streams.path":return Kc.join(Hi,"clustering","leaf");case"storage.path":let n=Kc.join(Hi,OU.LEGACY_DATABASES_DIR_NAME);return wU.existsSync(n)?n:Kc.join(Hi,OU.DATABASES_DIR_NAME);case"logging.rotation.path":return Kc.join(Hi,NU);case"operationsApi.network.domainSocket":return r==null?null:Kc.join(Hi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(A_,"setDefaultRoot");function A8(e){let t=Se.object({routes:mE});return c8.validateBySchema({routes:e},t)}a(A8,"routesValidator")});var Rt=I(FU=>{"use strict";var Os=(B(),C(G)),Er=oe(),rr=Y(),{configValidator:R8,routesValidator:PU}=$y(),jr=require("fs-extra"),LU=require("yaml"),jn=require("path"),y8=require("is-number"),MU=require("properties-reader"),b8=require("lodash"),{handleHDBError:O8}=pe(),{HTTP_STATUS_CODES:N8,HDB_ERROR_MSGS:Cu}=Hn(),{server:w8}=(Kr(),C(Tu)),{PACKAGE_ROOT:vU}=nt(),{DATABASES_PARAM_CONFIG:R_,CONFIG_PARAMS:zn,CONFIG_PARAM_MAP:ri}=Os,I8="Unable to get config value because config is uninitialized",C8="Config successfully initialized",P8="Error backing up config file",D8="Empty parameter sent to getConfigValue",UU=jn.join(vU,"config","yaml",Os.HDB_DEFAULT_CONFIG_FILE),L8=jn.join(vU,"config","yaml","defaultNatsConfig.yaml"),M8="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",DU={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,wt,gE;Object.assign(FU,{createConfigFile:v8,getDefaultConfig:U8,getConfigValue:BU,initConfig:SE,flattenConfig:Pu,updateConfigValue:HU,updateConfigObject:B8,getConfiguration:F8,setConfiguration:G8,readConfigFile:Wy,getClusteringRoutes:q8,initOldConfig:kU,getConfigFromFile:$8,getConfigFilePath:Wc,addConfig:V8,deleteConfigFromFile:K8,getConfigObj:Y8,resolvePath:Vy,getFlatConfigObj:W8});function Vy(e){if(e?.startsWith("~/"))return jn.join(Er.getHomeDir(),e.slice(1));let t=ce();return jn.resolve(t.getHdbBasePath(),e)}a(Vy,"resolvePath");function v8(e,t=!1){let r=Ia(UU);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=LU.parseDocument(jr.readFileSync(L8,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}EE=Pu(r.toJSON());let n;for(let c in e){let l=ri[c.toLowerCase()];if(l===zn.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=Ky(l,e[c]);l==="rootPath"&&f?.endsWith("/")&&(f=f.slice(0,-1));try{r.setIn([...u],f)}catch(d){rr.error(d)}}}n&&xU(r,n),Yy(r,t);let s=r.toJSON();wt=Pu(s);let i=r.getIn(["rootPath"]),o=jn.join(i,Os.HDB_CONFIG_FILE);if(jr.createFileSync(o),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);jr.writeFileSync(o,String(r)),rr.trace(`Config file written to ${o}`)}a(v8,"createConfigFile");function xU(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Er.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(R_.TABLES))for(let i in n[s][R_.TABLES])for(let o in n[s][R_.TABLES][i]){let c=n[s][R_.TABLES][i][o],l=[zn.DATABASES,s,R_.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=[zn.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(xU,"setSchemasConfig");function U8(e){if(EE===void 0){let r=Ia(UU);EE=Pu(r.toJSON())}let t=ri[e.toLowerCase()];if(t!==void 0)return EE[t.toLowerCase()]}a(U8,"getDefaultConfig");function BU(e){if(e==null){rr.info(D8);return}if(wt===void 0){rr.trace(I8);return}let t=ri[e.toLowerCase()];if(t!==void 0)return wt[t.toLowerCase()]}a(BU,"getConfigValue");function Wc(e=Er.getPropsFilePath()){let t=Er.getEnvCliRootPath();if(t)return Vy(jn.join(t,Os.HDB_CONFIG_FILE));let r=MU(e);return Vy(r.get(Os.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Wc,"getConfigFilePath");function SE(e=!1){if(wt===void 0||e){let t;if(!Er.noBootFile()){t=Er.getPropsFilePath();try{jr.accessSync(t,jr.constants.F_OK|jr.constants.R_OK)}catch(i){throw rr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Wc(t),n;if(r.includes("config/settings.js"))try{kU(r);return}catch(i){if(i.code!==Os.NODE_ERROR_CODES.ENOENT)throw i}try{n=Ia(r)}catch(i){if(i.code===Os.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}`)}x8(n,r),Yy(n);let s=n.toJSON();if(w8.config=s,wt=Pu(s),wt.logging_rotation_rotate)for(let i in DU)wt[i]&&rr.error(`Config ${DU[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);rr.trace(C8)}}a(SE,"initConfig");function x8(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],jn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],jn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n){if(rr.trace("Updating config file with missing config params"),e.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${e.errors}`);jr.writeFileSync(t,String(e))}}a(x8,"checkForUpdatedConfig");function Yy(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 Cu.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 Cu.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=R8(r,t);if(n.error)throw Cu.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(Yy,"validateConfig");function B8(e,t){wt===void 0&&(wt={});let r=ri[e.toLowerCase()];if(r===void 0){rr.trace(`Unable to update config object because config param '${e}' does not exist`);return}wt[r.toLowerCase()]=t}a(B8,"updateConfigObject");function HU(e,t,r=void 0,n=!1,s=!1,i=!1){wt===void 0&&SE();let o=BU(ri.hdb_root),c=jn.join(o,Os.HDB_CONFIG_FILE),l=Ia(c),u;if(r&&wt){let p=!1;for(let _ in r)if(r[_]!=wt[_.toLowerCase()]){p=!0;break}if(!p){rr.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===zn.DATABASES)u=t;else if(r===void 0){let p;if(i)p=e;else if(p=ri[e.toLowerCase()],p===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let _=p.split("_"),h=Ky(p,t);l.setIn([..._],h)}else for(let p in r){let _=ri[p.toLowerCase()];if(_===zn.HTTP_SECUREPORT&&r[p]===wt[zn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),_===zn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[p]===wt[zn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),_===zn.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=Os.LEGACY_CONFIG_PARAMS[p.toUpperCase()];S&&S.startsWith("customFunctions")&&l.hasIn(S.split("_"))&&(_=S,h=S.split("_"));let g=Ky(_,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(A){rr.error(A)}}}u&&xU(l,u),Yy(l);let f=l.getIn(["rootPath"]),d=jn.join(f,Os.HDB_CONFIG_FILE);if(n===!0&&H8(c,f),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);jr.writeFileSync(d,String(l)),s&&(wt=Pu(l.toJSON())),rr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(HU,"updateConfigValue");function H8(e,t){try{let r=jn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${Os.HDB_CONFIG_FILE}.bak`);jr.copySync(e,r),rr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){rr.error(P8),rr.error(r)}}a(H8,"backupConfigFile");var k8=["databases"];function Pu(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])&&!k8.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;!zn[l.toUpperCase()]&&ri[l]&&(s[ri[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Pu,"flattenConfig");function Ky(e,t){if(e===zn.CLUSTERING_NODENAME||e===zn.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(y8(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Er.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return Er.autoCast(t)}a(Ky,"castConfigValue");function F8(){let e=Er.getPropsFilePath(),t=Wc(e);return Ia(t).toJSON()}a(F8,"getConfiguration");async function G8(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return HU(void 0,void 0,s,!0),M8}catch(i){throw typeof i=="string"||i instanceof String?O8(i,i,N8.BAD_REQUEST,void 0,void 0,!0):i}}a(G8,"setConfiguration");function Wy(){let e=Er.getPropsFilePath();try{jr.accessSync(e,jr.constants.F_OK|jr.constants.R_OK)}catch(n){if(!Er.noBootFile())throw rr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Wc(e);return Ia(t).toJSON()}a(Wy,"readConfigFile");function Ia(e){return LU.parseDocument(jr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Ia,"parseYamlDoc");function q8(){let e=Wy(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Er.isEmptyOrZeroLength(t)?[]:t;let r=PU(t);if(r)throw Cu.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Er.isEmptyOrZeroLength(n)?[]:n;let s=PU(n);if(s)throw Cu.CONFIG_VALIDATION(s.message);if(!Er.isEmptyOrZeroLength(n)&&!Er.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Er.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Cu.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(q8,"getClusteringRoutes");function kU(e){let t=MU(e);wt={};for(let r in ri){let n=t.get(r.toUpperCase());if(Er.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ri[r].toLowerCase();s===zn.LOGGING_ROOT?wt[s]=jn.dirname(n):wt[s]=n}return wt}a(kU,"initOldConfig");function $8(e){let t=Wy();return b8.get(t,e.replaceAll("_","."))}a($8,"getConfigFromFile");async function V8(e,t){let r=Ia(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 jr.writeFile(Wc(),String(r))}a(V8,"addConfig");function K8(e){let t=Wc(Er.getPropsFilePath()),r=Ia(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=jn.join(n,Os.HDB_CONFIG_FILE);jr.writeFileSync(s,String(r))}a(K8,"deleteConfigFromFile");function Y8(){return gE||(SE(),gE)}a(Y8,"getConfigObj");function W8(){return wt||SE(),wt}a(W8,"getFlatConfigObj")});var Rn=I((PNe,Or)=>{"use strict";var $U="username is required",VU="nothing to update, must supply active, role or password to update",KU="password cannot be an empty string",YU="If role is specified, it cannot be empty.",WU="active must be true or false";Or.exports.addUser=r5;Or.exports.alterUser=n5;Or.exports.dropUser=i5;Or.exports.getSuperUser=u5;Or.exports.userInfo=o5;Or.exports.listUsers=AE;Or.exports.listUsersExternal=a5;Or.exports.setUsersWithRolesCache=zc;Or.exports.findAndValidateUser=rb;Or.exports.getClusterUser=d5;Or.exports.getUsersWithRolesCache=l5;Or.exports.USERNAME_REQUIRED=$U;Or.exports.ALTERUSER_NOTHING_TO_UPDATE=VU;Or.exports.EMPTY_PASSWORD=KU;Or.exports.EMPTY_ROLE=YU;Or.exports.ACTIVE_BOOLEAN=WU;var zU=yn(),z8=Vc(),y_=(hE(),C(pE)),jU=TU(),b_=Wr(),Xy=yo(),ki=oe(),QU=require("validate.js"),Zy=Y(),{promisify:j8}=require("util"),eb=To(),jy=(B(),C(G)),GU=St(),Q8=Rt(),J8=ce(),X8=Eo(),{hdb_errors:Z8,ClientError:ni}=pe(),{HTTP_STATUS_CODES:Ro,AUTHENTICATION_ERROR_MSGS:zy,HDB_ERROR_MSGS:Du}=Z8,{UserEventMsg:tb}=si(),Qy=require("lodash"),{server:TE}=(Kr(),C(Tu)),e5=Y();TE.getUser=(e,t)=>rb(e,t,t!=null);TE.authenticateUser=(e,t)=>rb(e,t);var JU={username:!0,active:!0,role:!0,password:!0},qU=new Map,t5=j8(z8.delete),Jy=J8.get(jy.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??y_.HASH_FUNCTION.SHA256,Fi;async function r5(e){let t=QU.cleanAttributes(e,JU),r=jU.addUserValidation(t);if(r)throw new ni(r.message);let n=await b_.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 ni(Du.ROLE_NAME_NOT_FOUND(t.role),Ro.NOT_FOUND);if(n.length>1)throw new ni(Du.DUP_ROLES_FOUND(t.role),Ro.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=eb.encrypt(t.password)),t.password=await y_.hash(t.password,Jy),t.hash_function=Jy,t.role=n[0].id;let s=await zU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(Zy.debug(s),await zc(),s.skipped_hashes.length===1)throw new ni(Du.USER_ALREADY_EXISTS(t.username),Ro.CONFLICT);return Xy.signalUserChange(new tb(process.pid)),`${t.username} successfully added`}a(r5,"addUser");async function n5(e){let t=QU.cleanAttributes(e,JU);if(ki.isEmptyOrZeroLength(t.username))throw new Error($U);if(ki.isEmptyOrZeroLength(t.password)&&ki.isEmptyOrZeroLength(t.role)&&ki.isEmptyOrZeroLength(t.active))throw new Error(VU);if(!ki.isEmpty(t.password)&&ki.isEmptyOrZeroLength(t.password.trim()))throw new Error(KU);if(!ki.isEmpty(t.active)&&!ki.isBoolean(t.active))throw new Error(WU);if(!ki.isEmpty(t.password)&&!ki.isEmptyOrZeroLength(t.password.trim())&&(s5(t.username)&&(t.hash=eb.encrypt(t.password)),t.password=await y_.hash(t.password,Jy)),t.role==="")throw new Error(YU);if(t.role){let n=await b_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ni(Du.ALTER_USER_ROLE_NOT_FOUND(t.role),Ro.NOT_FOUND);if(n.length>1)throw new ni(Du.DUP_ROLES_FOUND(t.role),Ro.CONFLICT);t.role=n[0].id}let r=await zU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await zc(),Xy.signalUserChange(new tb(process.pid)),r}a(n5,"alterUser");function s5(e){let t=!1,r=Fi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(s5,"isClusterUser");async function i5(e){let t=jU.dropUserValidation(e);if(t)throw new ni(t.message);if(Fi.get(e.username)===void 0)throw new ni(Du.USER_NOT_EXIST(e.username),Ro.NOT_FOUND);let r=await t5({table:"hdb_user",schema:"system",hash_values:[e.username]});return Zy.debug(r),await zc(),Xy.signalUserChange(new tb(process.pid)),`${e.username} successfully deleted`}a(i5,"dropUser");async function o5(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Qy.cloneDeep(e.hdb_user);let r=await b_.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(o5,"userInfo");async function a5(){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(a5,"listUsersExternal");async function AE(){let e=await b_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=Qy.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await b_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=Qy.cloneDeep(s),s.role=t[s.role],c5(s.role),n.set(s.username,s);return n}a(AE,"listUsers");function c5(e){if(!e){Zy.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(X8)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(c5,"appendSystemTablesToRole");async function zc(e=void 0){e?Fi=e:Fi=await AE()}a(zc,"setUsersWithRolesCache");async function l5(){return Fi||await zc(),Fi}a(l5,"getUsersWithRolesCache");async function rb(e,t,r=!0){Fi||await zc();let n=Fi.get(e);if(!n){if(!r)return{username:e};throw new ni(zy.GENERIC_AUTH_FAIL,Ro.UNAUTHORIZED)}if(n&&!n.active)throw new ni(zy.USER_INACTIVE,Ro.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(qU.get(t)===n.password)return s;{let i=y_.validate(n.password,t,n.hash_function||y_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)qU.set(t,n.password);else throw new ni(zy.GENERIC_AUTH_FAIL,Ro.UNAUTHORIZED)}}return s}a(rb,"findAndValidateUser");async function u5(){Fi||await zc();for(let[,e]of Fi)if(e.role.role==="super_user")return e}a(u5,"getSuperUser");async function d5(){let e=await AE(),t=Q8.getConfigFromFile(jy.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==jy.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=eb.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+GU.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+GU.SERVER_SUFFIX.ADMIN,r}a(d5,"getClusterUser");var XU=[];TE.invalidateUser=function(e){for(let t of XU)try{t(e)}catch(r){e5.error("Error invalidating user",r)}};TE.onInvalidatedUser=function(e){XU.push(e)}});var N_=I((vNe,r0)=>{"use strict";var jc=Y(),Qn=(B(),C(G)),f5=mv(),LNe=bs(),MNe=Ao(),_5=Rn(),{validateEvent:ZU}=si(),O_=Wn(),p5=require("process"),{resetDatabases:h5}=(Pe(),C(rt)),m5={[Qn.ITC_EVENT_TYPES.SCHEMA]:E5,[Qn.ITC_EVENT_TYPES.USER]:t0};async function E5(e){let t=ZU(e);if(t){jc.error(t);return}jc.trace("ITC schemaHandler received schema event:",e),await f5(e.message),await g5(e.message)}a(E5,"schemaHandler");async function g5(e){try{O_.resetReadTxn(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),O_.resetReadTxn(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),O_.resetReadTxn(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=h5();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){jc.error(t)}}a(g5,"syncSchemaMetadata");var e0=[];async function t0(e){try{try{O_.resetReadTxn(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),O_.resetReadTxn(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){jc.warn(r)}let t=ZU(e);if(t){jc.error(t);return}jc.trace(`ITC userHandler ${Qn.HDB_ITC_CLIENT_PREFIX}${p5.pid} received user event:`,e),await _5.setUsersWithRolesCache();for(let r of e0)r()}catch(t){jc.error(t)}}a(t0,"userHandler");t0.addListener=function(e){e0.push(e)};r0.exports=m5});var si=I((FNe,s0)=>{"use strict";var xNe=Y(),nb=oe(),S5=(B(),C(G)),{ITC_ERRORS:w_}=Hn(),{parentPort:BNe,threadId:T5,isMainThread:A5,workerData:HNe}=require("worker_threads"),{onMessageFromWorkers:R5,broadcast:kNe,broadcastWithAcknowledgement:y5}=tt();s0.exports={sendItcEvent:b5,validateEvent:n0,SchemaEventMsg:O5,UserEventMsg:N5};var RE;R5(async(e,t)=>{RE=RE||N_(),n0(e),RE[e.type]&&await RE[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function b5(e){return!A5&&e.message&&(e.message.originator=T5),y5(e)}a(b5,"sendItcEvent");function n0(e){if(typeof e!="object")return w_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||nb.isEmpty(e.type))return w_.MISSING_TYPE;if(!e.hasOwnProperty("message")||nb.isEmpty(e.message))return w_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||nb.isEmpty(e.message.originator))return w_.MISSING_ORIGIN;if(S5.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return w_.INVALID_EVENT(e.type)}a(n0,"validateEvent");function O5(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(O5,"SchemaEventMsg");function N5(e){this.originator=e}a(N5,"UserEventMsg")});var yo=I(($Ne,c0)=>{"use strict";var i0=(B(),C(G)),qNe=oe(),yE=Y(),o0=_v(),Lu,{sendItcEvent:a0}=si();function w5(e){try{yE.info("signalSchemaChange called with message:",e),Lu=Lu||N_();let t=new o0(i0.ITC_EVENT_TYPES.SCHEMA,e);return Lu.schema(t),a0(t)}catch(t){yE.error(t)}}a(w5,"signalSchemaChange");function I5(e){try{yE.trace("signalUserChange called with message:",e),Lu=Lu||N_();let t=new o0(i0.ITC_EVENT_TYPES.USER,e);return Lu.user(t),a0(t)}catch(t){yE.error(t)}}a(I5,"signalUserChange");c0.exports={signalSchemaChange:w5,signalUserChange:I5}});var bE=I((KNe,u0)=>{"use strict";var l0=oe(),C5=(B(),C(G)),P5=Y(),D5=iE(),L5=sE(),M5=yo(),{SchemaEventMsg:v5}=si(),U5="already exists in";u0.exports=x5;async function x5(e,t,r){if(l0.isEmptyOrZeroLength(r))return r;let n=[];l0.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 B5(e,t.schema,t.name,i)})),s}a(x5,"lmdbCheckForNewAttributes");async function B5(e,t,r,n){let s=new L5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await H5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(U5))P5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(B5,"createNewAttribute");async function H5(e){let t;return t=await D5(e),M5.signalSchemaChange(new v5(process.pid,C5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(H5,"createAttribute")});var Mu=I((WNe,d0)=>{"use strict";var sb=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}};d0.exports=sb});var _0=I((jNe,f0)=>{"use strict";var k5=Mu(),F5=(B(),C(G)).OPERATIONS_ENUM,ib=class extends k5{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(F5.INSERT,r,n,s,i),this.records=t}};f0.exports=ib});var h0=I((JNe,p0)=>{"use strict";var G5=Mu(),q5=(B(),C(G)).OPERATIONS_ENUM,ob=class extends G5{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(q5.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};p0.exports=ob});var E0=I((ZNe,m0)=>{"use strict";var $5=Mu(),V5=(B(),C(G)).OPERATIONS_ENUM,ab=class extends $5{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(V5.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};m0.exports=ab});var S0=I((twe,g0)=>{"use strict";var K5=Mu(),Y5=(B(),C(G)).OPERATIONS_ENUM,cb=class extends K5{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(Y5.DELETE,n,s,t,i),this.original_records=r}};g0.exports=cb});var I_=I((swe,y0)=>{"use strict";var nwe=require("path"),T0=dt(),W5=_0(),z5=h0(),j5=E0(),Q5=S0(),vu=vt(),A0=oe(),{CONFIG_PARAMS:J5}=(B(),C(G)),R0=ce();R0.initSync();var OE=(B(),C(G)).OPERATIONS_ENUM,{getTransactionAuditStorePath:X5}=Et();y0.exports=Z5;async function Z5(e,t){if(R0.get(J5.LOGGING_AUDITLOG)===!1)return;let r=X5(e.schema,e.table),n=await T0.openEnvironment(r,e.table,!0),s=e9(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){T0.initializeDBIs(n,vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,vu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),A0.isEmpty(s.user_name)||n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(Z5,"writeTransaction");function e9(e,t){let r=A0.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===OE.INSERT)return new W5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.UPDATE)return new z5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.UPSERT)return new j5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.DELETE)return new Q5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(e9,"createTransactionObject")});var lb=I((awe,b0)=>{"use strict";var t9=d_(),owe=vf(),C_=(B(),C(G)),r9=Uf(),n9=kc().insertRecords,s9=dt(),i9=Y(),o9=bE(),{getSchemaPath:a9}=Et(),c9=I_();b0.exports=l9;async function l9(e){try{let{schema_table:t,attributes:r}=t9(e);r9(e,r,t.hash_attribute),e.schema!==C_.SYSTEM_SCHEMA_NAME&&(r.includes(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await o9(e.hdb_auth_header,t,r),s=a9(e.schema,e.table),i=await s9.openEnvironment(s,e.table),o=await n9(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await c9(e,o)}catch(c){i9.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(l9,"lmdbCreateRecords")});var w0=I((lwe,N0)=>{"use strict";var O0=(B(),C(G)),u9=lb(),d9=vf(),f9=require("fs-extra"),{getSchemaPath:_9}=Et();N0.exports=p9;async function p9(e){let t=[{name:e.schema,createddate:Date.now()}],r=new d9(O0.SYSTEM_SCHEMA_NAME,O0.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await u9(r),await f9.mkdirp(_9(e.schema))}a(p9,"lmdbCreateSchema")});var C0=I((dwe,I0)=>{"use strict";var ub=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}};I0.exports=ub});var M0=I((mwe,L0)=>{"use strict";var P0=dt(),db=pn(),fb=Hn().LMDB_ERRORS_ENUM,h9=vt(),D0=Y(),_we=oe(),m9=require("lmdb"),E9=C0(),g9=(B(),C(G)),{OVERFLOW_MARKER:pwe,MAX_SEARCH_KEY_LENGTH:hwe}=h9,S9=g9.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function T9(e,t,r,n){if(db.validateEnv(e),t===void 0)throw new Error(fb.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(fb.IDS_REQUIRED):new Error(fb.IDS_MUST_BE_ITERABLE);try{let s=P0.listDBIs(e);P0.initializeDBIs(e,t,s);let i=new E9,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[S9]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,m9.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let g=0;g<s.length;g++){let A=s[g];if(!h.hasOwnProperty(A)||A===t)continue;let E=e.dbis[A],R=h[A];if(R!=null)try{let N=db.getIndexedValues(R);if(N)for(let v=0,k=N.length;v<k;v++)E.remove(N[v],o)}catch{D0.warn(`cannot delete from attribute: ${A}, ${R}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(h)}catch(h){D0.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=db.getNextMonotonicTime(),i}catch(s){throw s}}a(T9,"deleteRecords");L0.exports={deleteRecords:T9}});var P_=I((gwe,U0)=>{"use strict";var Uu=oe(),A9=M0(),R9=dt(),{getSchemaPath:y9}=Et(),b9=I_(),O9=Y();U0.exports=N9;async function N9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Uu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Uu.isEmptyOrZeroLength(e.hash_values)&&!Uu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Uu.isEmpty(l)||e.hash_values.push(l)}}if(Uu.isEmptyOrZeroLength(e.hash_values))return v0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Uu.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=y9(e.schema,e.table),i=await R9.openEnvironment(s,e.table),o=await A9.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await b9(e,o)}catch(c){O9.error(`unable to write transaction due to ${c.message}`)}return v0(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(N9,"lmdbDeleteRecords");function v0(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(v0,"createDeleteResponse")});var pb=I((Awe,x0)=>{"use strict";var w9=(B(),C(G)),Twe=pn();function _b(e,t){let r=Object.create(null);if(t.length===1&&w9.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(_b,"parseRow");function I9(e,t,r,n){let s=_b(r,e);n.push(s)}a(I9,"searchAll");function C9(e,t,r,n){let s=_b(r,e);n[t]=s}a(C9,"searchAllToMap");function P9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(P9,"iterateDBI");function Qc(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(Qc,"pushResults");function D9(e,t,r,n,s,i){t.toString().endsWith(e)&&Qc(t,r,n,s,i)}a(D9,"endsWith");function L9(e,t,r,n,s,i){t.toString().includes(e)&&Qc(t,r,n,s,i)}a(L9,"contains");function M9(e,t,r,n,s,i){t>e&&Qc(t,r,n,s,i)}a(M9,"greaterThanCompare");function v9(e,t,r,n,s,i){t>=e&&Qc(t,r,n,s,i)}a(v9,"greaterThanEqualCompare");function U9(e,t,r,n,s,i){t<e&&Qc(t,r,n,s,i)}a(U9,"lessThanCompare");function x9(e,t,r,n,s,i){t<=e&&Qc(t,r,n,s,i)}a(x9,"lessThanEqualCompare");x0.exports={parseRow:_b,searchAll:I9,searchAllToMap:C9,iterateDBI:P9,endsWith:D9,contains:L9,greaterThanCompare:M9,greaterThanEqualCompare:v9,lessThanCompare:U9,lessThanEqualCompare:x9,pushResults:Qc}});var xu=I((Nwe,$0)=>{"use strict";var Ca=dt(),ywe=Y(),Jn=pn(),NE=vt(),Kt=Hn().LMDB_ERRORS_ENUM,bwe=oe(),B9=(B(),C(G)),wE=pb(),{parseRow:H9}=wE,Owe=require("lmdb"),{OVERFLOW_MARKER:B0,MAX_SEARCH_KEY_LENGTH:k9}=NE;function H0(e,t,r,n=!1,s=void 0,i=void 0){return Jc(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(H0,"iterateFullIndex");function D_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Jc(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(R=>({value:R}))):d.getRange(E)})}a(D_,"iterateRangeBetween");function Jc(e,t,r,n){let s=e.database||e,i=Ca.openDBI(s,r);i[NE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Ca.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(Jc,"setupTransaction");function k0(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(B0)){if(!s)if(r)s=Ca.openDBI(e,r);else{let l=Ca.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=Ca.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(k0,"getOverflowCheck");function F9(e,t,r,n=!1,s=void 0,i=void 0){if(Jn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);return Jc(e,t,t,(o,c,l)=>(IE(r),r=L_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>H9(u.value,r))))}a(F9,"searchAll");function G9(e,t,r,n=!1,s=void 0,i=void 0){if(Jn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);IE(r),r=L_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of H0(e,t,t,n,s,i))o.set(c,wE.parseRow(l,r));return o}a(G9,"searchAllToMap");function q9(e,t,r=!1,n=void 0,s=void 0){if(Jn.validateEnv(e),t===void 0)throw new Error(Kt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=H0(e,void 0,t,r,n,s),c=o.transaction,l=k0(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(q9,"iterateDBI");function $9(e,t){if(Jn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);return Ca.statDBI(e,t).entryCount}a($9,"countAll");function V9(e,t,r,n,s=!1,i=void 0,o=void 0){return Pa(e,r,n),Jc(e,t,r,(c,l,u,f)=>(n=Jn.convertKeyValueToWrite(n),f===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(V9,"equals");function K9(e,t,r){return Pa(e,t,r),Ca.openDBI(e,t).getValuesCount(r)}a(K9,"count");function Y9(e,t,r,n,s=!1,i=void 0,o=void 0){return Pa(e,r,n),Jc(e,null,r,(c,l)=>{n=Jn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let f;if(s===!0){let d;for(let p of l.getKeys({transaction:c,start:n}))if(!p.startsWith(n)){d=p;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),f=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(p=>{let{key:_}=p;if(_!==d){if(_.toString().startsWith(n))return p;if(u===!0)return f.DONE}}),f.filter(p=>p)}else return f=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(u===!0)return f.DONE}),u?f:f.filter(d=>d)})}a(Y9,"startsWith");function W9(e,t,r,n,s=!1,i=void 0,o=void 0){return F0(e,t,r,n,s,i,o,!0)}a(W9,"endsWith");function F0(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Pa(e,r,n),Jc(e,null,r,(l,u,f,d)=>{let p=k0(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(B0)?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(F0,"contains");function z9(e,t,r,n,s=!1,i=void 0,o=void 0){Pa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),D_(e,t,r,n,l,s,i,o,!0,!1)}a(z9,"greaterThan");function j9(e,t,r,n,s=!1,i=void 0,o=void 0){Pa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),D_(e,t,r,n,l,s,i,o,!1,!1)}a(j9,"greaterThanEqual");function Q9(e,t,r,n,s=!1,i=void 0,o=void 0){Pa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),D_(e,t,r,l,n,s,i,o,!1,!0)}a(Q9,"lessThan");function J9(e,t,r,n,s=!1,i=void 0,o=void 0){Pa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),D_(e,t,r,l,n,s,i,o,!1,!1)}a(J9,"lessThanEqual");function X9(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Jn.validateEnv(e),r===void 0)throw new Error(Kt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Kt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Kt.END_VALUE_REQUIRED);if(n=Jn.convertKeyValueToWrite(n),s=Jn.convertKeyValueToWrite(s),n>s)throw new Error(Kt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return D_(e,t,r,n,s,i,o,c)}a(X9,"between");function Z9(e,t,r,n){Jn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);if(IE(r),r=L_(s,r),n===void 0)throw new Error(Kt.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(Z9,"searchByHash");function e7(e,t,r){Jn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Kt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(e7,"checkHashExists");function t7(e,t,r,n,s=[]){return q0(e,t,r,n,s),G0(e,t,r,n,s).map(i=>i[1])}a(t7,"batchSearchByHash");function r7(e,t,r,n,s=[]){q0(e,t,r,n,s);let i=new Map;for(let[o,c]of G0(e,t,r,n,s))i.set(o,c);return i}a(r7,"batchSearchByHashToMap");function G0(e,t,r,n,s=[]){return Jc(e,t,t,(i,o,c)=>{r=L_(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(G0,"batchHashSearch");function q0(e,t,r,n,s){if(Jn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);if(IE(r),n==null)throw new Error(Kt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Kt.IDS_MUST_BE_ITERABLE)}a(q0,"initializeBatchSearchByHash");function IE(e){if(!Array.isArray(e))throw e===void 0?new Error(Kt.FETCH_ATTRIBUTES_REQUIRED):new Error(Kt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(IE,"validateFetchAttributes");function Pa(e,t,r){if(Jn.validateEnv(e),t===void 0)throw new Error(Kt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Kt.SEARCH_VALUE_REQUIRED);if(r?.length>k9)throw new Error(Kt.SEARCH_VALUE_TOO_LARGE)}a(Pa,"validateComparisonFunctions");function L_(e,t){return t.length===1&&B9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Ca.listDBIs(e)),t}a(L_,"setGetWholeRowAttributes");$0.exports={searchAll:F9,searchAllToMap:G9,count:K9,countAll:$9,equals:V9,startsWith:Y9,endsWith:W9,contains:F0,searchByHash:Z9,setGetWholeRowAttributes:L_,batchSearchByHash:t7,batchSearchByHashToMap:r7,checkHashExists:e7,iterateDBI:q9,greaterThan:z9,greaterThanEqual:j9,lessThan:Q9,lessThanEqual:J9,between:X9}});var Bu=I((Iwe,z0)=>{var V0=require("lodash"),K0=ut(),ke=require("joi"),n7=oe(),{hdb_schema_table:M_,checkValidTable:Y0,hdb_table:W0,hdb_database:CE}=vi(),{handleHDBError:s7,hdb_errors:i7}=pe(),{getDatabases:o7}=(Pe(),C(rt)),{HTTP_STATUS_CODES:a7}=i7,c7=ke.object({database:CE,schema:CE,table:W0,search_attribute:M_,search_value:ke.any().required(),get_attributes:ke.array().min(1).items(ke.alternatives(M_,ke.object())).optional(),desc:ke.bool(),limit:ke.number().integer().min(1),offset:ke.number().integer().min(0)}),l7=ke.object({database:CE,schema:CE,table:W0,operator:ke.string().valid("and","or").default("and").lowercase(),offset:ke.number().integer().min(0),limit:ke.number().integer().min(1),get_attributes:ke.array().min(1).items(ke.alternatives(M_,ke.object())).optional(),sort:ke.object({attribute:ke.alternatives(M_,ke.array().min(1)),descending:ke.bool().optional()}).optional(),conditions:ke.array().min(1).items(ke.alternatives(ke.object({operator:ke.string().valid("and","or").default("and").lowercase(),conditions:ke.array()}),ke.object({search_attribute:ke.alternatives(M_,ke.array().min(1)),search_type:ke.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:ke.when("search_type",{switch:[{is:"equals",then:ke.any()},{is:"between",then:ke.array().items(ke.alternatives([ke.string(),ke.number()])).length(2)}],otherwise:ke.alternatives(ke.string(),ke.number())}).required()}))).required()});z0.exports=function(e,t){let r=null;switch(t){case"value":r=K0.validateBySchema(e,c7);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(Y0("database",e.schema)),i(Y0("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=K0.validateBySchema(e,l7);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=n7.checkGlobalSchemaTable(e.schema,e.table);if(s)return s7(new Error,s,a7.NOT_FOUND);let o=o7()[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=V0.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!V0.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 hb=I((Pwe,j0)=>{"use strict";var u7=dt(),d7=Bu(),{getSchemaPath:f7}=Et();j0.exports=_7;function _7(e){let t=d7(e,"hashes");if(t)throw t;let r=f7(e.schema,e.table);return u7.openEnvironment(r,e.table)}a(_7,"initialize")});var mb=I((Lwe,Q0)=>{"use strict";var p7=xu(),h7=hb();Q0.exports=m7;async function m7(e){let t=await h7(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return p7.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(m7,"lmdbGetDataByHash")});var Hu=I((vwe,J0)=>{"use strict";var Eb=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};J0.exports=Eb});var Z0=I((Bwe,X0)=>{"use strict";var xwe=Hu(),E7=xu(),g7=hb();X0.exports=S7;async function S7(e){let t=await g7(e),r=global.hdb_schema[e.schema][e.table];return E7.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(S7,"lmdbSearchByHash")});var ii=I((kwe,ex)=>{"use strict";var gb=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}};ex.exports=gb});var PE=I((Gwe,ox)=>{"use strict";var Qr=xu(),T7=dt(),A7=oe(),Fe=vt(),Xc=(B(),C(G)),R7=Eo(),tx=Hn().LMDB_ERRORS_ENUM,{getSchemaPath:y7}=Et(),bo=Xc.SEARCH_WILDCARDS;async function b7(e,t,r){let n;e.schema===Xc.SYSTEM_SCHEMA_NAME?n=R7[e.table]:n=global.hdb_schema[e.schema][e.table];let s=ix(e,n.hash_attribute,r,t);return nx(e,s,n.hash_attribute,r)}a(b7,"prepSearch");async function nx(e,t,r,n){let s=y7(e.schema,e.table),i=await T7.openEnvironment(s,e.table),o=sx(i,e,t,r),c=o.transaction||i;if([Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,Fe.SEARCH_TYPES.SEARCH_ALL,Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(O7(e,r)===!1){let f=e.search_attribute;if(f===r)return n?rx(o,()=>!0):o.map(p=>({[r]:p.key}));let d=a(p=>({[r]:p.value,[f]:p.key}),"toObject");return n?rx(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?Qr.batchSearchByHashToMap(c,r,e.get_attributes,u):Qr.batchSearchByHash(c,r,e.get_attributes,u)}a(nx,"executeSearch");function sx(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case Fe.SEARCH_TYPES.EQUALS:s=Qr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.CONTAINS:s=Qr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.ENDS_WITH:case Fe.SEARCH_TYPES._ENDS_WITH:s=Qr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.STARTS_WITH:case Fe.SEARCH_TYPES._STARTS_WITH:s=Qr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Qr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Qr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Fe.SEARCH_TYPES.SEARCH_ALL:return Qr.searchAll(e,n,t.get_attributes,o,c,l);case Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Qr.searchAllToMap(e,n,t.get_attributes,o,c,l);case Fe.SEARCH_TYPES.BETWEEN:s=Qr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case Fe.SEARCH_TYPES.GREATER_THAN:case Fe.SEARCH_TYPES._GREATER_THAN:s=Qr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.GREATER_THAN_EQUAL:case Fe.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Qr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.LESS_THAN:case Fe.SEARCH_TYPES._LESS_THAN:s=Qr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.LESS_THAN_EQUAL:case Fe.SEARCH_TYPES._LESS_THAN_EQUAL:s=Qr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(sx,"searchByType");function rx(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(rx,"createMapFromIterable");function O7(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(O7,"checkToFetchMore");function ix(e,t,r,n){if(A7.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),bo.indexOf(s)>-1)return r===!0?Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Fe.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(bo[0])<0&&s.indexOf(bo[1])<0)return c===!0?r===!0?Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:Fe.SEARCH_TYPES.EQUALS;if(bo.indexOf(i)>=0&&bo.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),Fe.SEARCH_TYPES.CONTAINS;if(bo.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Fe.SEARCH_TYPES.ENDS_WITH;if(bo.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),Fe.SEARCH_TYPES.STARTS_WITH;if(s.includes(bo[0])||s.includes(bo[1]))return Fe.SEARCH_TYPES.EQUALS;throw new Error(tx.UNKNOWN_SEARCH_TYPE)}else switch(n){case Xc.VALUE_SEARCH_COMPARATORS.BETWEEN:return Fe.SEARCH_TYPES.BETWEEN;case Xc.VALUE_SEARCH_COMPARATORS.GREATER:return Fe.SEARCH_TYPES.GREATER_THAN;case Xc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Fe.SEARCH_TYPES.GREATER_THAN_EQUAL;case Xc.VALUE_SEARCH_COMPARATORS.LESS:return Fe.SEARCH_TYPES.LESS_THAN;case Xc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Fe.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(tx.UNKNOWN_SEARCH_TYPE)}}a(ix,"createSearchTypeFromSearchObject");ox.exports={executeSearch:nx,createSearchTypeFromSearchObject:ix,prepSearch:b7,searchByType:sx}});var cx=I((Vwe,ax)=>{"use strict";var $we=ii(),N7=Bu(),w7=oe(),I7=(B(),C(G)),C7=PE();ax.exports=P7;function P7(e,t){if(!w7.isEmpty(t)&&I7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=N7(e,"value");if(n)throw n;return C7.prepSearch(e,t,!0)}a(P7,"lmdbGetDataByValue")});var v_=I((Wwe,lx)=>{"use strict";var Ywe=ii(),D7=Bu(),L7=oe(),M7=(B(),C(G)),v7=PE();lx.exports=U7;async function U7(e,t){if(!L7.isEmpty(t)&&M7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=D7(e,"value");if(n)throw n;return v7.prepSearch(e,t,!1)}a(U7,"lmdbSearchByValue")});var dx=I((Qwe,ux)=>{"use strict";var jwe=vt(),Sb=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}},Tb=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Ab=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};ux.exports={SearchByConditionsObject:Sb,SearchCondition:Tb,SortAttribute:Ab}});var mx=I((eIe,hx)=>{"use strict";var Xwe=dx().SearchByConditionsObject,x7=ii(),B7=Bu(),Rb=xu(),DE=vt(),{Resource:Zwe}=(ga(),C(mR)),px=PE(),H7=pb(),k7=require("lodash"),{getSchemaPath:F7}=Et(),fx=dt(),{handleHDBError:G7,hdb_errors:q7}=pe(),{HTTP_STATUS_CODES:$7}=q7,V7=1e8;hx.exports=K7;async function K7(e){let t=B7(e,"conditions");if(t)throw G7(t,t.message,$7.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=F7(e.schema,e.table),n=await fx.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)fx.openDBI(n,u.search_attribute);let i=k7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===DE.SEARCH_TYPES.EQUALS?u.estimated_count=Rb.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=V7}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await _x(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(px.filterByType),d=f.length,p=Rb.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(_=>H7.parseRow(_,p))}else{for(let d=1;d<i.length;d++){let p=i[d],_=await _x(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=Rb.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(K7,"lmdbSearchByConditions");async function _x(e,t,r,n){let s=new x7(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,px.searchByType(e,s,i,n).map(o=>o.value)}a(_x,"executeConditionSearch")});var U_=I((rIe,Ex)=>{"use strict";var Y7=(B(),C(G)).OPERATIONS_ENUM,yb=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=Y7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Ex.exports=yb});var bb=I((sIe,Ox)=>{"use strict";var Ax=ii(),Rx=U_(),yx=v_(),bx=P_(),bn=(B(),C(G)),gx=oe(),Sx=dt(),{getTransactionAuditStorePath:W7,getSchemaPath:z7}=Et(),Tx=Y();Ox.exports=j7;async function j7(e){try{if(gx.isEmpty(global.hdb_schema[e.schema])||gx.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await Q7(e),await J7(e);let t=z7(e.schema,e.table);try{await Sx.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Tx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=W7(e.schema,e.table);await Sx.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Tx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(j7,"lmdbDropTable");async function Q7(e){let t=new Ax(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 yx(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 Rx(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await bx(s)}a(Q7,"deleteAttributesFromSystem");async function J7(e){let t=new Ax(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 yx(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 Rx(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await bx(s)}catch(i){throw i}}a(J7,"dropTableFromSystem")});var wx=I((oIe,Nx)=>{"use strict";var X7=require("fs-extra"),Z7=ii(),eee=Hu(),tee=U_(),ree=bb(),nee=P_(),see=mb(),iee=v_(),Oo=(B(),C(G)),{getSchemaPath:oee}=Et(),{handleHDBError:aee,hdb_errors:cee}=pe(),{HDB_ERROR_MSGS:lee,HTTP_STATUS_CODES:uee}=cee;Nx.exports=dee;async function dee(e){let t;try{t=await fee(e.schema);let r=new Z7(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await iee(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await ree(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new tee(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await nee(s);let i=oee(t);await X7.remove(i)}catch(r){throw r}}a(dee,"lmdbDropSchema");async function fee(e){let t=new eee(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await see(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw aee(new Error,lee.SCHEMA_NOT_FOUND(e),uee.NOT_FOUND,void 0,void 0,!0);return n}a(fee,"validateDropSchema")});var x_=I((cIe,Ix)=>{"use strict";var Ob=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Ix.exports=Ob});var wb=I((dIe,Cx)=>{"use strict";var _ee=require("fs-extra"),LE=dt(),{getTransactionAuditStorePath:pee}=Et(),Nb=vt(),uIe=x_();Cx.exports=hee;async function hee(e){let t;try{let r=pee(e.schema,e.table);await _ee.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,Nb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),LE.createDBI(t,Nb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),LE.createDBI(t,Nb.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(hee,"createTransactionsAuditEnvironment")});var Lx=I((pIe,Dx)=>{"use strict";var Ib=(B(),C(G)),Px=dt(),mee=kc(),{getSystemSchemaPath:Eee,getSchemaPath:gee}=Et(),_Ie=Eo(),See=iE(),Cb=sE(),Tee=Y(),Aee=wb();Dx.exports=Ree;async function Ree(e,t){let r=gee(t.schema,t.table),n=new Cb(t.schema,t.table,Ib.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Cb(t.schema,t.table,Ib.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Cb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Px.createEnvironment(r,t.table),e!==void 0){let o=await Px.openEnvironment(Eee(),Ib.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await mee.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 Pb(n),await Pb(s),await Pb(i)}await Aee(t)}catch(o){throw o}}a(Ree,"lmdbCreateTable");async function Pb(e){try{await See(e)}catch(t){Tee.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Pb,"createAttribute")});var vx=I((mIe,Mx)=>{"use strict";var yee=d_(),bee=Uf(),Oee=bE(),B_=(B(),C(G)),Nee=kc().updateRecords,wee=dt(),{getSchemaPath:Iee}=Et(),Cee=I_(),Pee=Y();Mx.exports=Dee;async function Dee(e){try{let{schema_table:t,attributes:r}=yee(e);bee(e,r,t.hash_attribute),e.schema!==B_.SYSTEM_SCHEMA_NAME&&(r.includes(B_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(B_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(B_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(B_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await Oee(e.hdb_auth_header,t,r),s=Iee(e.schema,e.table),i=await wee.openEnvironment(s,e.table),o=await Nee(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await Cee(e,o)}catch(c){Pee.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(Dee,"lmdbUpdateRecords")});var xx=I((gIe,Ux)=>{"use strict";var Lee=(B(),C(G)).OPERATIONS_ENUM,Db=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Lee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Ux.exports=Db});var Hx=I((AIe,Bx)=>{"use strict";var TIe=xx(),Mee=d_(),vee=Uf(),Uee=bE(),H_=(B(),C(G)),xee=kc().upsertRecords,Bee=dt(),{getSchemaPath:Hee}=Et(),kee=I_(),Fee=Y(),{handleHDBError:Gee,hdb_errors:qee}=pe();Bx.exports=$ee;async function $ee(e){let t;try{t=Mee(e)}catch(l){throw Gee(l,l.message,qee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;vee(e,n,r.hash_attribute),e.schema!==H_.SYSTEM_SCHEMA_NAME&&(n.includes(H_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(H_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(H_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(H_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await Uee(e.hdb_auth_header,r,n),i=Hee(e.schema,e.table),o=await Bee.openEnvironment(i,e.table),c=await xee(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await kee(e,c)}catch(l){Fee.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($ee,"lmdbUpsertRecords")});var Fx=I((yIe,kx)=>{"use strict";var Lb=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};kx.exports=Lb});var qx=I((OIe,Gx)=>{"use strict";var Mb=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}};Gx.exports=Mb});var Kx=I((IIe,Vx)=>{"use strict";var vb=dt(),{getTransactionAuditStorePath:Vee}=Et(),wIe=Fx(),k_=vt(),Kee=oe(),$x=qx(),Yee=require("util").promisify,Wee=Yee(setTimeout),zee=1e4,jee=100;Vx.exports=Qee;async function Qee(e){let t=Vee(e.schema,e.table),r=await vb.openEnvironment(t,e.table,!0),n=vb.listDBIs(r);vb.initializeDBIs(r,k_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new $x;do s=await Jee(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 Wee(jee);while(s.transactions_deleted>0);return i}a(Qee,"deleteAuditLogsBefore");async function Jee(e,t){let r=new $x;try{let n=e.dbis[k_.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[k_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Kee.isEmpty(c)||(s=e.dbis[k_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[k_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>zee)break}return await s,r}catch(n){throw n}}a(Jee,"deleteTransactions")});var Wx=I((PIe,Yx)=>{"use strict";var Ub=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};Yx.exports=Ub});var jx=I((MIe,zx)=>{"use strict";var Xee=ii(),Zee=U_(),LIe=Wx(),Gi=(B(),C(G)),ete=oe(),xb=dt(),tte=Eo(),rte=v_(),nte=P_(),{getSchemaPath:ste}=Et();zx.exports=ite;async function ite(e,t=!0){let r;e.schema===Gi.SYSTEM_SCHEMA_NAME?r=tte[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await ate(e),s=ste(e.schema,e.table),i=await xb.openEnvironment(s,e.table);return t===!0&&await ote(e,i,r.hash_attribute),xb.dropDBI(i,e.attribute),n}a(ite,"lmdbDropAttribute");async function ote(e,t,r){let n=xb.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(ote,"removeAttributeFromAllObjects");async function ate(e){let t=new Xee(Gi.SYSTEM_SCHEMA_NAME,Gi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Gi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Gi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Gi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await rte(t)).filter(o=>o[Gi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(ete.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Gi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new Zee(Gi.SYSTEM_SCHEMA_NAME,Gi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return nte(i)}a(ate,"dropAttributeFromSystem")});var tB=I((xIe,eB)=>{"use strict";var Bb=dt(),ku=vt(),UIe=pn(),Hb=(B(),C(G)),Qx=oe(),{getTransactionAuditStorePath:cte}=Et(),lte=xu(),ME=Mu(),ute=Y();eB.exports=dte;async function dte(e){let t=cte(e.schema,e.table),r=await Bb.openEnvironment(t,e.table,!0),n=Bb.listDBIs(r);Bb.initializeDBIs(r,ku.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Hb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return Jx(r,e.search_values);case Hb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,_te(r,e.search_values,s);case Hb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return fte(r,e.search_values);default:return Jx(r)}}a(dte,"readAuditLog");function Jx(e,t=[0,Date.now()]){Qx.isEmpty(t[0])&&(t[0]=0),Qx.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[ku.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(Jx,"searchTransactionsByTimestamp");function fte(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[ku.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,Zx(e,i))}return Object.fromEntries(r)}a(fte,"searchTransactionsByUsername");function _te(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=lte.equals(e,ku.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ku.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=Zx(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);Xx(l,"records",r,f,o),Xx(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(_te,"searchTransactionsByHashValues");function Xx(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(Xx,"loopRecords");function Zx(e,t){let r=[];try{let n=e.dbis[ku.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){ute.warn(i)}return r}catch(n){throw n}}a(Zx,"batchSearchTransactions")});var nB=I((FIe,rB)=>{"use strict";var{getSchemaPath:HIe}=Et(),kIe=dt(),{database:pte}=(Pe(),C(rt));rB.exports={writeTransaction:hte};async function hte(e,t,r){return pte({database:e,table:t}).transaction(r)}a(hte,"writeTransaction")});var aB=I((qIe,oB)=>{"use strict";var{getSchemaPath:sB}=Et(),iB=dt();oB.exports={flush:mte,resetReadTxn:Ete};async function mte(e,t){return(await iB.openEnvironment(sB(e,t),t.toString())).flushed}a(mte,"flush");async function Ete(e,t){try{(await iB.openEnvironment(sB(e,t),t.toString())).resetReadTxn()}catch{}}a(Ete,"resetReadTxn")});var dB=I((VIe,uB)=>{"use strict";var{Readable:gte}=require("stream"),{getDatabases:Ste}=(Pe(),C(rt)),{readSync:Tte,openSync:Ate,createReadStream:cB}=require("fs"),{open:Rte}=require("lmdb"),lB=s_(),yte=i_(),{AUDIT_STORE_OPTIONS:bte}=(ho(),C(fB)),{INTERNAL_DBIS_NAME:Ote,AUDIT_STORE_NAME:Nte}=vt();uB.exports=Ite;var kb=32768,wte=100;async function Ite(e){let t=e.database||e.schema||"data",r=Ste()[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=Rte({noSync:!0,maxDbs:yte.MAX_DBS}),p,_=d.openDB(Ote,new lB(!1)),h=f.useReadTransaction(),S=0,g=a(async function(E,R){R.encoding="binary",R.encoder=void 0;let N=d.openDB(E,R),v=f.openDB(E,R);for(let{key:k,version:F,value:K}of v.getRange({start:null,transaction:h,versions:v.useVersions}))p=N.put(k,K,F),S++%wte===0&&(await new Promise(re=>setTimeout(re,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:E,value:R}of f.getRange({transaction:h,start:!1}))if(s.some(N=>E.startsWith?.(N+"/"))){_.put(E,R);let[,N]=E.split("/"),v=!N,k=new lB(!v,v);await g(E,k)}e.include_audit&&await g(Nte,{...bte}),await p;let A=cB(d.path);return A.headers=l(),A.on("close",()=>{h.done(),d.close()}),A}let o=r[Object.keys(r)[0]].primaryStore,c=Ate(o.path);return o.transaction(()=>{let u=Buffer.alloc(kb);Tte(c,u,0,kb),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=cB(null,{fd:c,start:kb}),p=new gte.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(Ite,"getBackup")});var hB=I((YIe,pB)=>{"use strict";var Cte=Y(),{handleHDBError:Pte}=pe(),Dte=bM(),Lte=iE(),Mte=lb(),vte=w0(),Ute=P_(),xte=mb(),Bte=Z0(),Hte=cx(),kte=v_(),Fte=mx(),Gte=wx(),qte=Lx(),$te=vx(),Vte=Hx(),Kte=Kx(),Yte=bb(),Wte=jx(),zte=tB(),jte=nB(),_B=aB(),Qte=dB(),Fb=class extends Dte{static{a(this,"LMDBBridge")}async searchByConditions(t){return Fte(t)}async getDataByHash(t){return await xte(t)}async searchByHash(t){return await Bte(t)}async getDataByValue(t,r){return await Hte(t,r)}async searchByValue(t){return await kte(t)}async createSchema(t){return await vte(t)}async dropSchema(t){return await Gte(t)}async createTable(t,r){return await qte(t,r)}async dropTable(t){return await Yte(t)}async createAttribute(t){return await Lte(t)}async createRecords(t){return await Mte(t)}async updateRecords(t){return await $te(t)}async upsertRecords(t){try{return await Vte(t)}catch(r){throw Pte(r,null,null,Cte.ERR,r)}}async deleteRecords(t){return await Ute(t)}async dropAttribute(t){return await Wte(t)}async deleteAuditLogsBefore(t){return await Kte(t)}async readAuditLog(t){return await zte(t)}writeTransaction(t,r,n){return jte.writeTransaction(t,r,n)}flush(t,r){return _B.flush(t,r)}resetReadTxn(t,r){return _B.resetReadTxn(t,r)}getBackup(t){return Qte(t)}};pB.exports=Fb});var qb={};ve(qb,{add:()=>vE,applyReverse:()=>mB,getRecordAtTime:()=>Gb,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 mB(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Jte[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=EB}}function Gb(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=Nt(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":mB(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===EB&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=Nt(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 Jte,EB,xE=be(()=>{ho();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)};Jte={add:vE};a(UE,"rebuildUpdateBefore");a(mB,"applyReverse");EB={};a(Gb,"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 Xn.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 Xn.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 Xn.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 Xn.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 Xn.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 Xn.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 Xn.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 Xn.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 Xn.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 Pi||d==null&&c.nullable!==!1))throw new Xn.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 Xn.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 _=$b(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 Xn.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,SB);break}o=c}while(o&&o!==SB)}function $b(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends F_{static{a(this,"TrackedObject")}},FE(r,t)),new r(e)):new F_(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=$b(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 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=qb[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)Xte.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[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(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 Xn,gB,SB,F_,Xte,Zc,HE,kE,Vb=be(()=>{Xn=M(pe());xE();As();a(On,"getChanges");a(FE,"assignTrackedAccessors");gB=Object.prototype,SB=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(gB[t])return gB[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=$b(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a($b,"trackObject");F_=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(F_,{});a(GE,"collapseData");Xte=Object.prototype.hasOwnProperty;a(el,"updateAndFreeze");a(BE,"hasChanges");Zc=Symbol.for("has-array-changes"),HE=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()}};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 wB={};ve(wB,{ResourceBridge:()=>Wb});function zb({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 AB(e,t){let r=qi(e),n=zb(e,r);if(!r)throw new oi.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;Ot(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 qi(e){let t=e.database||e.schema||ere,r=Je()[t];if(!r)throw(0,oi.handleHDBError)(new Error,Zte.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function RB(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*yB(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 bB,qE,oi,OB,Kb,Yb,NB,Zte,ere,tre,rre,TB,Wb,IB=be(()=>{"use strict";bB=M(hB()),qE=M(Bu()),oi=M(pe());Pe();OB=M(d_());B();Kb=M(yo()),Yb=M(si()),NB=M(oe());Oc();Vb();({HDB_ERROR_MSGS:Zte}=oi.hdb_errors),ere="data",tre=1e4,rre=10,Wb=class extends bB.default{static{a(this,"ResourceBridge")}constructor(t){super(t),TB=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,oi.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=qi(t);if(!n)throw new oi.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:zb(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 oi.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}]}lt({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await qi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=qi(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){qi(t).dropTable()}createSchema(t){return Fu({database:t.schema,table:null}),Kb.signalSchemaChange(new Yb.SchemaEventMsg(process.pid,$t.CREATE_SCHEMA,t.schema))}async dropSchema(t){await jb(t.schema),Kb.signalSchemaChange(new Yb.SchemaEventMsg(process.pid,$t.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,TB.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,OB.default)(t),s,i=Je()[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),Ot(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=Je()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Ot(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 RB(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Je()[t.schema][t.table];if(!r.createdTimeProperty)throw new oi.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,NB.async_set_timeout)(rre),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%tre===0&&await u();return l.length>0&&await u(),s?RB(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 AB(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of AB(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,qE.default)(t,"value");if(n)throw n;let s=qi(t);if(!s)throw new oi.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:zb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=qi(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){qi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return qi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=qi(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 yB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return yB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(zb,"getSelect");a(AB,"getRecords");a(qi,"getTable");a(RB,"createDeleteResponse");a(yB,"groupRecordsInHistory")});var Wn=I((iCe,CB)=>{"use strict";var{ResourceBridge:nre}=(IB(),C(wB)),sre=ce();sre.initSync();var $E;function ire(){return $E||($E=new nre,$E)}a(ire,"getBridge");CB.exports=ire()});var yn=I((aCe,MB)=>{"use strict";var KE=BR(),Lr=oe(),ore=require("util"),YE=Wn(),are=bs(),PB=Y(),{handleHDBError:tl,hdb_errors:cre}=pe(),{HTTP_STATUS_CODES:rl}=cre,lre=ore.promisify(are.getTableSchema),ure="updated",DB="inserted",LB="upserted";MB.exports={insert:fre,update:_re,upsert:pre,validation:dre,flush:hre};async function dre(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 lre(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 PB.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 PB.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(dre,"validation");async function fre(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=KE(e);if(t)throw tl(new Error,t.message,rl.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw tl(new Error,r,rl.BAD_REQUEST);let n=await YE.createRecords(e);return VE(DB,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(fre,"insertData");async function _re(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=KE(e);if(t)throw tl(new Error,t.message,rl.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw tl(new Error,r,rl.BAD_REQUEST);let n=await YE.updateRecords(e);return Lr.isEmpty(n.existing_rows)?VE(ure,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(_re,"updateData");async function pre(e){if(e.operation!=="upsert")throw tl(new Error,"invalid operation, must be upsert",rl.INTERNAL_SERVER_ERROR);let t=KE(e);if(t)throw tl(new Error,t.message,rl.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw tl(new Error,r,rl.BAD_REQUEST);let n=await YE.upsertRecords(e);return VE(LB,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(pre,"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===DB?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===LB?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(VE,"returnObject");function hre(e){return Lr.transformReq(e),YE.flush(e.schema,e.table)}a(hre,"flush")});var kB=I((lCe,HB)=>{var Gu=require("validate.js"),UB=ut(),qu=(B(),C(G)),{handleHDBError:mre,hdb_errors:Ere}=pe(),{HDB_ERROR_MSGS:Yt,HTTP_STATUS_CODES:gre}=Ere,Qb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Sre={STRUCTURE_USER:"structure_user"},vB=Object.values(qu.ROLE_TYPES_ENUM),Tre="attribute_permissions",Are="attribute_name",{PERMS_CRUD_ENUM:$u}=qu,Rre=[Tre,...Object.values($u)],xB=[$u.READ,$u.INSERT,$u.UPDATE],yre=[Are,...xB];function bre(e){let t=Qb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,BB(e,t)}a(bre,"addRoleValidation");function Ore(e){let t=Qb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,BB(e,t)}a(Ore,"alterRoleValidation");function Nre(e){let t=Qb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,UB.validateObject(e,t)}a(Nre,"dropRoleValidation");var wre=["operation","role","id","permission","hdb_user","hdb_auth_header","access"];function BB(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)wre.includes(n[o])||s.push(n[o]);s.length>0&&nr(Yt.INVALID_ROLE_JSON_KEYS(s),r);let i=UB.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{nr(o,r)}),e.permission){let o=Ire(e);o&&nr(o,r),vB.forEach(c=>{e.permission[c]&&!Gu.isBoolean(e.permission[c])&&nr(Yt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(vB.indexOf(o)<0){if(o===Sre.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(Yt.SCHEMA_NOT_FOUND(d),r)}continue}nr(Yt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){nr(Yt.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(Yt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{Rre.includes(f)||nr(Yt.INVALID_PERM_KEY(f),r,o,l)}),Object.values($u).forEach(f=>{Gu.isDefined(u[f])?Gu.isBoolean(u[f])||nr(Yt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):nr(Yt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){nr(Yt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){nr(Yt.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=>{!yre.includes(S)&&S!==$u.DELETE&&nr(Yt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!Gu.isDefined(_.attribute_name)){nr(Yt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=_.attribute_name;if(!f.includes(h)){nr(Yt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}xB.forEach(S=>{Gu.isDefined(_[S])?Gu.isBoolean(_[S])||nr(Yt.ATTR_PERM_NOT_BOOLEAN(S,h),r,o,l):nr(Yt.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(Yt.MISMATCHED_TABLE_ATTR_PERMS(p),r,o,l)}}}}return Cre(r)}a(BB,"customValidate");HB.exports={addRoleValidation:bre,alterRoleValidation:Ore,dropRoleValidation:Nre};function Ire(e){let{operation:t,permission:r}=e;if(t===qu.OPERATIONS_ENUM.ADD_ROLE||t===qu.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 Yt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?qu.ROLE_TYPES_ENUM.SUPER_USER:qu.ROLE_TYPES_ENUM.CLUSTER_USER;return Yt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(Ire,"validateNoSUPerms");function Cre(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Yt.ROLE_PERMS_ERROR,...e};return mre(new Error,n,gre.BAD_REQUEST)}else return null}a(Cre,"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 q_=I((fCe,$B)=>{"use strict";var FB=yn(),GB=Wr(),Pre=Vc(),Xb=kB(),Zb=yo(),dCe=require("uuid").v4,Dre=require("util"),WE=(B(),C(G)),Lre=oe(),eO=GB.searchByValue,Mre=GB.searchByHash,vre=Dre.promisify(Pre.delete),Ure=ii(),xre=Hu(),{hdb_errors:Bre,handleHDBError:nl}=pe(),{HDB_ERROR_MSGS:qB,HTTP_STATUS_CODES:G_}=Bre,{UserEventMsg:tO}=si();$B.exports={addRole:Hre,alterRole:kre,dropRole:Fre,listRoles:Gre};function Jb(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(Jb,"scrubRoleDetails");async function Hre(e){let t=Xb.addRoleValidation(e);if(t)throw t;e=Jb(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 eO(r)||[])}catch(i){throw nl(i)}if(n&&n.length>0)throw nl(new Error,qB.ROLE_ALREADY_EXISTS(e.role),G_.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 FB.insert(s),Zb.signalUserChange(new tO(process.pid)),e=Jb(e),e}a(Hre,"addRole");async function kre(e){let t=Xb.alterRoleValidation(e);if(t)throw t;e=Jb(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await FB.update(r)}catch(s){throw nl(s)}if(n&&n?.message==="updated 0 of 1 records")throw nl(new Error,"Invalid role id",G_.BAD_REQUEST,void 0,void 0,!0);return await Zb.signalUserChange(new tO(process.pid)),e}a(kre,"alterRole");async function Fre(e){let t=Xb.dropRoleValidation(e);if(t)throw nl(new Error,t,G_.BAD_REQUEST,void 0,void 0,!0);let r=new xre(WE.SYSTEM_SCHEMA_NAME,WE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await Mre(r));if(n.length===0)throw nl(new Error,qB.ROLE_NOT_FOUND,G_.NOT_FOUND,void 0,void 0,!0);let s=new Ure(WE.SYSTEM_SCHEMA_NAME,WE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await eO(s)),o=!1;if(Lre.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`,G_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await vre(c),Zb.signalUserChange(new tO(process.pid)),`${n[0].role} successfully deleted`}a(Fre,"dropRole");async function Gre(){return eO({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Gre,"listRoles")});var rO={};ve(rO,{start:()=>YB,startOnMainThread:()=>Vre});function YB({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,VB.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(qre.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 $re(i)}}}async function $re(e){let t=Je().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,KB.isEqual)(i,e)?void 0:(e.id=r.id,(0,zE.alterRole)(e))}return(0,zE.addRole)(e)}var zE,VB,KB,qre,Vre,WB=be(()=>{Pe();zE=M(q_()),VB=require("yaml"),KB=require("lodash"),qre=["super_user","cluster_user","structure_user"];a(YB,"start");a($re,"ensureRole");Vre=YB});async function jE(e){let t=(0,QB.pathToFileURL)(e).toString();return Kre?($_||($_=Yre(zre)),(await(await $_).import(t)).namespace):import(t)}async function Yre(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),$_=new Compartment({console,Math,Date,fetch:Wre,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,jB.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Vr,tables:Zn,databases:$e})}};let n=await(0,zB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),$_}function Wre(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 zre(){return{Resource:Vr,tables:Zn}}var zB,jB,QB,Kre,$_,nO=be(()=>{ga();Pe();zB=require("fs/promises"),jB=require("path"),QB=require("url"),Kre=!1;a(jE,"secureImport");a(Yre,"getCompartment");a(Wre,"secureOnlyFetch");a(zre,"getGlobalVars")});var iO={};ve(iO,{handleFile:()=>jre});async function jre(e,t,r,n){let s=new Map,i=await jE(r);c(i.default)&&n.set((0,sO.dirname)(t),i.default),o(i,(0,sO.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 sO,JB=be(()=>{nO();sO=require("path");a(jre,"handleFile")});var aO={};ve(aO,{start:()=>Qre});function Qre({resources:e}){e.set("login",oO),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var oO,XB=be(()=>{ga();a(Qre,"start");oO=class extends Vr{static{a(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:o}=r;return{data:await n.login(s,i)}}}});var j_={};ve(j_,{addAnalyticsListener:()=>z_,calculateCPUUtilization:()=>EH,diffResourceUsage:()=>gH,recordAction:()=>sr,recordActionBinary:()=>es,setAnalyticsEnabled:()=>Jre});function Jre(e){fH=e}function Xre(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 Zre(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(!fH)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=JE.get(i);o?Xre(e,o):Zre(i,e,t,r,n,s),QE||ene()}function es(e,t,r,n,s){sr(!!e,t,r,n,s)}function z_(e){hH.push(e)}function ene(){QE=performance.now(),setTimeout(async()=>{let e=performance.now()-QE;QE=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 mH){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 SH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:sl.threadId,byThread:!0,...n});for(let s of hH)s(t);JE=new Map,sl.parentPort?sl.parentPort.postMessage({type:pH,report:r}):RH({report:r})},_H).unref()}function XE(e,t,r){let n={id:(0,Y_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function EH(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function gH(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 tne(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),il.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function ZB(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getAuditSize(),o=dH.default.statSync(s.primaryStore.env.path).size,c=tne(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};XE(e,"database-size",u),il.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){il.warn?.("Error getting DB size metrics",s)}}function eH(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),il.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){il.warn?.("Error getting DB volumne metrics",s)}}async function rne(e,t=6e4){let r=lO(),n=TH(),s=new Promise(E=>{let R=performance.now();setImmediate(()=>{let N=performance.now();N-R>5e3&&il.warn?.("Unusually high event queue latency on the main thread of "+Math.round(N-R)+"ms"),R=performance.now()}),n.primaryStore.prefetch([1],()=>{let N=performance.now();N-R>5e3&&il.warn?.("Unusually high task queue latency on the main thread of "+Math.round(N-R)+"ms"),E(N-R)})}),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:R}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!R)continue;if(o){if(E>o+t)break}else o=E;f=E;let{metrics:N,threadId:v}=R;for(let k of N||[]){let{path:F,method:K,type:re,metric:ae,count:Z,total:se,distribution:W,threads:he,...Te}=k;Z||(Z=1);let Ce=ae+(F?"-"+F:"");K!==void 0&&(Ce+="-"+K),re!==void 0&&(Ce+="-"+re);let me=c.get(Ce);if(me){if(me.threads){let ct=me.threads[v];if(ct)me=ct;else{me.threads[v]={...Te};continue}}me.count||(me.count=1);let Xt=me.count;for(let ct in Te){let yr=Te[ct];typeof yr=="number"&&(me[ct]=(me[ct]*Xt+yr*Z)/(Xt+Z))}me.count+=Z,se>=0&&(me.total+=se,me.ratio=me.total/me.count)}else me={period:t,...k},delete me.distribution,c.set(Ce,me),me.byThread&&(me.threads=[],me.threads[v]={...Te},u.push(me));if(W){W=W.map(ct=>typeof ct=="number"?{value:ct,count:1}:ct);let Xt=l.get(Ce);Xt?Xt.push(...W):l.set(Ce,W)}}await SH()}for(let E of u){let{path:R,method:N,type:v,metric:k,count:F,total:K,distribution:re,threads:ae,...Z}=E;ae=ae.filter(se=>se);for(let se in Z){if(typeof E[se]!="number")continue;let W=0;for(let he of ae){let Te=he[se];typeof Te=="number"&&(W+=Te)}E[se]=W}E.count=ae.length,delete E.threads,delete E.byThread}for(let[E,R]of l){let N=c.get(E);R.sort((ct,yr)=>ct.value>yr.value?1:-1);let v=N.count-1,k=[],F=0,K=0,re;for(let ct of mH){let yr=v*ct;for(;F<yr;)re=R[K++],F+=re.count,K===1&&F--;let gs=R[K>1?K-2:0];re||(re=R[0]),k.push(re.value-(re.value-gs.value)*(F-yr)/re.count)}let[ae,Z,se,W,he,Te,Ce,me,Xt]=k;Object.assign(N,{p1:ae,p10:Z,p25:se,median:W,p75:he,p90:Te,p95:Ce,p99:me,p999:Xt})}let d;for(let[E,R]of c)R.id=(0,Y_.getNextMonotonicTime)(),R.time=f,n.primaryStore.put(R.id,R,{append:!0}).then(N=>{N||n.primaryStore.put(R.id,R)}),d=!0;let p=Date.now(),{idle:_,active:h}=performance.eventLoopUtilization();if(d||h*10>_){let E=(0,Y_.getNextMonotonicTime)(),R={id:E,metric:"main-thread-utilization",idle:_-tH,active:h-rH,taskQueueLatency:await s,time:p,...process.memoryUsage()};n.primaryStore.put(E,R,{append:!0}).then(N=>{N||n.primaryStore.put(E,R)})}tH=_,rH=h;let S=process.resourceUsage(),g=gH(V_,S);g.time=p,g.period=V_.time?p-V_.time:t,g.cpuUtilization=EH(V_,g.period),XE(n,"resource-usage",g),V_=g;let A=Je();ZB(n,A),ZB(n,{system:A.system}),eH(n,A),eH(n,{system:A.system})}async function nH(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function lO(){return sH||(sH=lt({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function TH(){return iH||(iH=lt({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function ine(){AH=!0;let e=(0,W_.get)(x.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await rne(_H,e),await nH(lO(),nne),await nH(TH(),sne)},Math.min(e/2,2147483647)).unref()}function RH(e,t){let r=e.report;r.threadId=t?.threadId||sl.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(oH+=n.mean*n.count);r.totalBytesProcessed=oH,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(aH.get(t))}),aH.set(t,t.performance.eventLoopUtilization())),r.id=(0,Y_.getNextMonotonicTime)(),lO().primaryStore.put(r.id,r),AH||ine(),one&&(yH=cne(r))}async function cne(e){if(await yH,!Da){let r=(0,K_.dirname)((0,lH.getLogFilePath)());try{Da=await(0,cO.open)((0,K_.join)(r,"analytics.log"),"r+")}catch{Da=await(0,cO.open)((0,K_.join)(r,"analytics.log"),"w+")}}let t=(await Da.stat()).size;if(t>ane){let r=Buffer.alloc(t);await Da.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Da.write(r,{position:0}),await Da.truncate(r.length),t=r.length}await Da.write(JSON.stringify(e)+`
21
- `,t)}var sl,cH,lH,uH,K_,cO,Y_,W_,dH,il,JE,fH,QE,_H,pH,hH,mH,tH,rH,V_,SH,nne,sne,sH,iH,AH,oH,aH,one,yH,Da,ane,$i=be(()=>{sl=require("worker_threads"),cH=M(tt());Pe();lH=M(Y()),uH=M(Ci()),K_=require("path"),cO=require("fs/promises"),Y_=M(pn()),W_=M(ce());B();Kr();dH=M(require("node:fs")),il=(0,uH.loggerWithTag)("analytics");(0,W_.initSync)();JE=new Map,fH=(0,W_.get)(x.ANALYTICS_AGGREGATEPERIOD)>-1;a(Jre,"setAnalyticsEnabled");a(Xre,"recordExistingAction");a(Zre,"recordNewAction");a(sr,"recordAction");We.recordAnalytics=sr;a(es,"recordActionBinary");QE=0,_H=1e3,pH="analytics-report",hH=[];a(z_,"addAnalyticsListener");mH=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(ene,"sendAnalytics");a(XE,"storeMetric");a(EH,"calculateCPUUtilization");a(gH,"diffResourceUsage");a(tne,"storeTableSizeMetrics");a(ZB,"storeDBSizeMetrics");a(eH,"storeVolumeMetrics");a(rne,"aggregation");tH=0,rH=0,V_={},SH=a(()=>new Promise(setImmediate),"rest");a(nH,"cleanup");nne=36e5,sne=31536e6;a(lO,"getRawAnalyticsTable");a(TH,"getAnalyticsTable");(0,cH.setChildListenerByType)(pH,RH);a(ine,"startScheduledTasks");oH=0,aH=new Map,one=!1;a(RH,"recordAnalytics");ane=1e6;a(cne,"logAnalytics")});var bH={};ve(bH,{Headers:()=>No,appendHeader:()=>ZE,mergeHeaders:()=>uO});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 uO(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new No(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 No,Q_=be(()=>{No=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(uO,"mergeHeaders")});function CH(e){let t={openapi:lne,info:{title:"HarperDB HTTP REST interface",version:IH.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:R,name:N,elements:v,relationship:k,definition:F}of o){if(k)R==="array"?u[N]={type:"array",items:{$ref:La+v.type}}:u[N]={$ref:La+R};else{let K=F??v?.definition;if(K){if(!t.components.schemas[K.type]){let re={};K.properties.forEach(ae=>{re[ae.name]=new pO(dO[ae.type],ae.type)}),t.components.schemas[K.type]=new wH(re)}R==="array"?u[N]={type:"array",items:{$ref:La+K.type}}:u[N]={$ref:La+K.type}}else R==="array"?v.type==="Any"||v.type=="ID"?u[N]={type:"array",items:{format:v.type}}:u[N]={type:"array",items:new pO(dO[v.type],v.type)}:R==="Any"||R=="ID"?u[N]={format:R}:u[N]=new pO(dO[R],R)}f.push(new hO(N,"query",u[N]))}let d=Object.keys(u),p=new hO(c,"path",{format:"ID"});p.required=!0,p.description="primary key of record";let _=new hO("property","path",{enum:d});_.required=!0,t.components.schemas[i]=new wH(u);let h=l.post!==Resource.prototype.post||l.update,S=typeof l.put=="function",g=typeof l.get=="function",A=typeof l.delete=="function",E="/"+s+"/";h&&(t.paths[E]={},t.paths[E].post=new une(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[E]||(t.paths[E]={}),t.paths[E].get=new fO(f,r,{200:new _O({$ref:La+i})},"search for records by the specified property name and value pairs")),A&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new NH(f,r,"delete all the records that match the provided query",{204:new OH})),E="/"+s+"/{"+c+"}",g&&(t.paths[E]={},t.paths[E].get=new fO([p],r,{200:new _O({$ref:La+i})},"retrieve a record by its primary key")),S&&(t.paths[E]||(t.paths[E]={}),t.paths[E].put=new dne([p],r,i,"create or update the record with the URL path that maps to the record's primary key")),A&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new NH([p],r,"delete a record with the given primary key",{204:new OH})),g&&_.schema.enum.length>0&&(E="/"+s+"/{"+c+"}.{property}",t.paths[E]={},t.paths[E].get=new fO([p,_],r,{200:new _O({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function une(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:La+e}}}},this.security=t,this.responses={200:{description:mO,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function fO(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function _O(e){this.description=mO,this.content={"application/json":{schema:e}}}function OH(){this.description="successfully processed request, no content returned to client"}function dne(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:La+r}}}},this.responses={200:{description:mO}}}function NH(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function wH(e){this.type="object",this.properties=e}function pO(e,t){this.type=e,this.format=t}function hO(e,t,r){this.name=e,this.in=t,this.schema=r}var IH,lne,dO,La,mO,PH=be(()=>{IH=M(nt()),lne="3.0.3",dO={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},La="#/components/schemas/",mO="successful operation";a(CH,"generateJsonApi");a(une,"Post");a(fO,"Get");a(_O,"Response200");a(OH,"Response204");a(dne,"Put");a(NH,"Delete");a(wH,"ResourceSchema");a(pO,"Type");a(hO,"Parameter")});var tg={};ve(tg,{parseHeaderValue:()=>gO,start:()=>pne});async function _ne(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 No;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==DH){let g=eg.getMatch(o,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Nc(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let A=gO(g);for(let E of A)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=gO(u).map(A=>(A.next?.name==="confirm"&&A.next.value>=0&&(e.replicatedConfirmation=+A.next.value),A.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 Ot(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=po(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new Vu.ClientError(g,400)}if(e.authorize=!0,o===DH&&s==="GET"){if(e?.user?.role?.permission?.super_user)return CH(eg);throw new Vu.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 Vu.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Vu.ServerError(`Method ${s} is not recognized`,501)}}),p=200,_;if(d==null)p=s==="GET"||s==="HEAD"?404:204,EO.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=uO(d.headers,i);return d.headers!==g&&(d.headers=g),d.data!==void 0&&(d.body=Qf(d.data,e,d)),d}else if(_=e.lastModified){fne[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),A=r["if-none-match"];A&&g==A?(d?.onDone&&d.onDone(),p=304,d=void 0):i.setIfNone("ETag",g),EO.lastModified&&i.setIfNone("Last-Modified",new Date(_).toUTCString())}e.createdResource&&(p=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:p,headers:i,body:void 0},S=d?.wasLoadedFromSource?.();return S!==void 0&&(h.wasCacheMiss=S,!S&&_&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||_))/1e3))),d!==void 0&&(h.body=Qf(d,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?Vi.warn(o):Vi.info(o):Vi.error(o),o.statusCode===405&&(o.method&&(o.message+=` to handle HTTP method ${o.method.toUpperCase()||""}`),o.allow&&(o.allow.push("trace","head","options"),i.setIfNone("Allow",o.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:o.statusCode||500,headers:i,body:void 0};return c.body=Qf(o.contentType?o:o.toString(),e,c),c}}function pne(e){EO=e,!LH&&(LH=!0,eg=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return _ne(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{J_++;let s=new kn;MH||(MH=!0,z_(l=>{J_>0&&l.push({metric:"ws-connections",connections:J_,byThread:!0})}));let i;t.on("error",l=>{i=!0,Vi.warn(l)});let o;t.on("message",a(function(u){o||(o=po(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_--,es(!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(es(!!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 Nc(u.relativeURL),d=u.Resource;c=(await Ot(r,()=>d.connect(f,s,r)))[Symbol.asyncIterator]();let _;for(;!(_=await c.next()).done;){let h=await ya(_.value,r);t.send(h),sr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?Vi.warn(l):Vi.info(l):Vi.error(l),t.close(hne[l.statusCode]||1011,l.toString())}t.close()},e))}function gO(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 Vi,Vu,Mr,fne,EO,DH,LH,eg,MH,J_,hne,vH=be(()=>{fo();$i();Vi=M(Y()),Vu=M(pe());Ff();_u();Oc();Q_();PH();Ff();Mr=new Uint8Array(8),fne=new Float64Array(Mr.buffer,0,1),EO={},DH="openapi";a(_ne,"http");J_=0;a(pne,"start");hne={401:3e3,403:3003};a(gO,"parseHeaderValue")});var SO=I((GCe,xH)=>{var{recordAction:rg,recordActionBinary:UH}=($i(),C(j_)),mne=require("fastify-plugin"),Ene=200;xH.exports=mne(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),UH(s.raw.statusCode<400,"success",u,d,f),UH(1,"response_"+s.raw.statusCode,u,d,f);let p=Ene;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 HH=I((qCe,BH)=>{var gne=ut(),Sne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};BH.exports=function(e){return gne.validateObject(e,Sne)}});var ng=I(($Ce,kH)=>{"use strict";var Tne=(B(),C(G)).OPERATIONS_ENUM,TO=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Tne.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};kH.exports=TO});var ep={};ve(ep,{createTokens:()=>Rne,getJWTRSAKeys:()=>cg,refreshOperationToken:()=>yne,validateOperationToken:()=>yO,validateRefreshToken:()=>lg});async function cg(){if(sg)return sg;try{let e=X_.default.join(Z_.default.getHdbBasePath(),YA),t=await ig.default.readFile(X_.default.join(e,bf.JWT_PASSPHRASE_NAME),"utf8"),r=await ig.default.readFile(X_.default.join(e,bf.JWT_PRIVATE_KEY_NAME),"utf8");return sg={publicKey:await ig.default.readFile(X_.default.join(e,bf.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},sg}catch(e){throw ag.default.error(e),new ai.ClientError(Yu.NO_ENCRYPTION_KEYS,Ku.INTERNAL_SERVER_ERROR)}}async function Rne(e){let t=(0,AO.validateBySchema)(e,Ki.default.object({username:Ki.default.string().optional(),password:Ki.default.string().optional(),role:Ki.default.string().optional(),expires_in:Ki.default.alternatives(Ki.default.string(),Ki.default.number()).optional()}));if(t)throw new ai.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,RO.findAndValidateUser)(e.username,e.password,d)}catch(d){throw ag.default.error(d),new ai.ClientError(Yu.INVALID_CREDENTIALS,Ku.UNAUTHORIZED)}if(!r)throw new ai.ClientError(Yu.INVALID_CREDENTIALS,Ku.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 Wu.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:e.expires_in??VH,algorithm:og,subject:"operation"}),l=await Wu.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:Ane,algorithm:og,subject:"refresh"}),u=By(l,"sha256");if((await(0,FH.update)(new GH.default(yf,du.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new ai.ClientError(Yu.REFRESH_TOKEN_SAVE_FAILED,Ku.INTERNAL_SERVER_ERROR);return qH.default.signalUserChange(new $H.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function yne(e){let t=(0,AO.validateBySchema)(e,Ki.default.object({refresh_token:Ki.default.string().required()}).required());if(t)throw new ai.ClientError(t.message);let{refresh_token:r}=e;await lg(r);let n=await cg(),s=await Wu.default.decode(r);return{operation_token:await Wu.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:VH,algorithm:og,subject:"operation"})}}async function yO(e){return KH(e,"operation")}async function lg(e){return KH(e,"refresh")}async function KH(e,t){try{let r=await cg(),n=await Wu.default.verify(e,r.publicKey,{algorithms:og,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,RO.findAndValidateUser)(n.username,void 0,!1);if(t==="refresh"&&!Hy(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw ag.default.warn(r),r?.name==="TokenExpiredError"?new ai.ClientError(Yu.TOKEN_EXPIRED,Ku.FORBIDDEN):new ai.ClientError(Yu.INVALID_TOKEN,Ku.UNAUTHORIZED)}}var Wu,ig,X_,Ki,AO,ai,ag,RO,FH,GH,qH,$H,Z_,Ku,Yu,VH,Ane,og,sg,zu=be(()=>{Wu=M(require("jsonwebtoken")),ig=M(require("fs-extra")),X_=M(require("node:path")),Ki=M(require("joi")),AO=M(ut());B();ai=M(pe()),ag=M(Y());hE();RO=M(Rn()),FH=M(yn()),GH=M(ng()),qH=M(yo()),$H=M(si()),Z_=M(ce()),{HTTP_STATUS_CODES:Ku,AUTHENTICATION_ERROR_MSGS:Yu}=ai.hdb_errors;Z_.default.initSync();VH=Z_.default.get(x.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",Ane=Z_.default.get(x.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",og="RS256";a(cg,"getJWTRSAKeys");a(Rne,"createTokens");a(yne,"refreshOperationToken");a(yO,"validateOperationToken");a(lg,"validateRefreshToken");a(KH,"validateToken")});var bO=I((zCe,zH)=>{"use strict";var bne=HH(),ju=require("passport"),One=require("passport-local").Strategy,Nne=require("passport-http").BasicStrategy,wne=require("util"),Ine=Rn(),WH=wne.callbackify(Ine.findAndValidateUser),WCe=Hn(),Cne=(B(),C(G)),YH=(zu(),C(ep));ju.use(new One(function(e,t,r){WH(e,t,r)}));ju.use(new Nne(function(e,t,r){WH(e,t,r)}));ju.serializeUser(function(e,t){t(null,e)});ju.deserializeUser(function(e,t){t(null,e)});function Pne(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===Cne.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?YH.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):YH.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(Pne,"authorize");function Dne(e,t){let r=bne(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(Dne,"checkPermissions");zH.exports={authorize:Pne,checkPermissions:Dne}});var ug=I((QCe,jH)=>{"use strict";var Lne=Wn();jH.exports={writeTransaction:Mne};function Mne(e,t,r){return Lne.writeTransaction(e,t,r)}a(Mne,"writeTransaction")});var ZH=I((ZCe,XH)=>{"use strict";var vne=Wr(),Une=bs(),QH=Y(),xne=yn(),XCe=ug(),Bne=require("clone"),NO=require("alasql"),Hne=aE(),JH=require("util"),kne=JH.promisify(Une.getTableSchema),Fne=JH.promisify(vne.search),Gne=(B(),C(G)),OO=oe();Hne(NO);XH.exports={update:$ne};var qne="There was a problem performing this update. Please check the logs and try again.";async function $ne({statement:e,hdb_user:t}){let r=await kne(e.table.databaseid,e.table.tableid),n=Vne(e.columns);OO.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=Bne(s),c=OO.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=NO.parse(l).statements[0],f=await Fne(u),d=Kne(n,f);return Yne(o,d,t)}a($ne,"update");function Vne(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=NO.compile(`SELECT ${r.expression.toString()} AS [${Gne.FUNC_VAL}] FROM ?`)}),t}catch(t){throw QH.error(t),new Error(qne)}}a(Vne,"createUpdateRecord");function Kne(e,t){return OO.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(Kne,"buildUpdateRecords");async function Yne(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await xne.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){QH.error(`Error delete new_attributes from update response: ${i}`)}return s}a(Yne,"updateRecords")});var tk=I((nPe,ek)=>{var Wne=require("alasql"),zne=Wr(),jne=Y(),Qne=Wn(),IO=require("util"),wO=oe(),Jne=(B(),C(G)),Xne=bs(),tPe=ug(),rPe=yn(),Zne="record",ese="successfully deleted",tse=IO.callbackify(ise),rse=IO.promisify(zne.search),nse=IO.promisify(Xne.getTableSchema);ek.exports={convertDelete:tse};function sse(e){return`${e.deleted_hashes.length} ${Zne}${e.deleted_hashes.length===1?"":"s"} ${ese}`}a(sse,"generateReturnMessage");async function ise({statement:e,hdb_user:t}){let r=await nse(e.table.databaseid,e.table.tableid);wO.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=wO.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=Wne.parse(o).statements[0],l={operation:Jne.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await rse(c);let u=await Qne.deleteRecords(l);return wO.isEmptyOrZeroLength(u.message)&&(u.message=sse(u)),delete u.txn_time,u}catch(u){throw jne.error(u),u.hdb_code?u.message:u}}a(ise,"convertDelete")});var ok=I((iPe,ik)=>{"use strict";var ose=Ao(),{hdb_errors:rk}=pe(),{getDatabases:nk}=(Pe(),C(rt));ik.exports={checkSchemaExists:sk,checkSchemaTableExists:ase,schema_describe:ose};async function sk(e){if(!nk()[e])return rk.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(sk,"checkSchemaExists");async function ase(e,t){let r=await sk(e);if(r)return r;if(!nk()[e][t])return rk.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(ase,"checkSchemaTableExists")});var MO=I((uPe,gk)=>{"use strict";var{decode:cse}=require("msgpackr"),{isMainThread:aPe,parentPort:cPe,threadId:lPe}=require("worker_threads"),_g=ir(),Qu=St(),DO=(B(),C(G)),Jr=Y(),PO=ce(),lse=(B(),C(G)),{onMessageByType:use}=tt(),uk=To(),{recordAction:ak,recordActionBinary:dse}=($i(),C(j_)),{publishToStream:fse}=_g,{ConsumerEvents:ck}=require("nats"),_se=Wr(),{promisify:pse}=require("util"),{decodeBlobsWithWrites:hse}=(As(),C(Fm)),dk=pse(setTimeout),pg=1e4,hg,fg,mse,Ese,fk,tp=new Map,Ju=new Map;gk.exports={initialize:_k,ingestConsumer:LO,setSubscription:gse,setIgnoreOrigin:Ase,getDatabaseSubscriptions:Tse,updateConsumer:pk};async function _k(){use(DO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await pk(n)}),fk=!0,Jr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await _g.getNATSReferences();hg=e,fg=e.info.server_name,mse=t,Ese=r}a(_k,"initialize");async function pk(e){if(e.status==="start"){let{js:t,jsm:r}=await hk(e.node_domain_name);LO(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=tp.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?.(),tp.set(e.stream_name+e.node_domain_name,"close")),Ju.get(e.node_domain_name)==="failed"&&Ju.set(e.node_domain_name,"close")}}a(pk,"updateConsumer");var mg=new Map;function gse(e,t,r){let n=mg.get(e);n||mg.set(e,n=new Map),n.set(t,r),fk||_k().then(Sse)}a(gse,"setSubscription");async function Sse(){let e=await _se.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 hk(r),!n))break;let{schema:o,table:c}=i,l=uk.createNatsTableStreamName(o,c);LO(l,n,s,r)}}}a(Sse,"accessConsumers");async function hk(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(Ju.get(e)==="close")break;Ju.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 dk(i)}return{js:t,jsm:r}}a(hk,"connectToRemoteJS");function Tse(){return mg}a(Tse,"getDatabaseSubscriptions");var mk;function Ase(e){mk=e}a(Ase,"setIgnoreOrigin");var Ek=100,lk=new Array(Ek),dg=0;async function LO(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(Ju.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 dk(f)}let c=!1,l;for(;!c;){if(tp.get(e+n)==="close"||Ju.get(n)==="close"){tp.delete(e+n),c=!0;continue}l=await i.consume({max_messages:PO.get(DO.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),tp.set(e+n,l);let u=!1;(async()=>{for await(let f of await l.status())if(f.type===ck.ConsumerDeleted&&(await l.close(),c=!0),f.type===ck.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 lk[dg],lk[dg]=Rse(f).catch(d=>{Jr.error(d)}),++dg>=Ek&&(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(LO,"ingestConsumer");async function Rse(e){let t;await hse(()=>{t=cse(e.data)}),ak(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=PO.get(DO.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&&!mk),dse(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:A,node_name:E}=p||{},R=mg.get(c)?.get(u);if(!R)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=h,R.send(t);else if(f.length===1&&!l)R.send({type:CO(o),value:f[0],id:d?.[0],expiresAt:_,timestamp:g,table:u,onCommit:h,user:A,nodeName:E});else{let v=f.map((k,F)=>({type:CO(o),value:k,expiresAt:_,id:d?.[F],table:u}));for(;l;)v.push({type:CO(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;R.send({type:"transaction",writes:v,table:u,timestamp:g,onCommit:h,user:A,nodeName:E})}PO.get(lse.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&fse(e.subject.split(".").slice(0,-1).join("."),uk.createNatsTableStreamName(c,u),e.headers,e.data),await S;let N=Date.now()-g;g&&ak(N,"replication-latency",e.subject,o,"ingest")}catch(o){Jr.error(o)}e.ack()}a(Rse,"messageProcessor");function CO(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(CO,"convertOperation")});var ir=I((EPe,Uk)=>{"use strict";var Nr=ce();Nr.initSync();var yse=require("fs-extra"),bse=require("semver"),sp=require("path"),{monotonicFactory:Ose}=require("ulidx"),Tk=Ose(),Nse=require("util"),Ak=require("child_process"),wse=Nse.promisify(Ak.exec),Ise=Ak.spawn,vr=St(),Ve=(B(),C(G)),{packageJson:Cse,PACKAGE_ROOT:Pse}=nt(),Eg=oe(),ci=Y(),gg=To(),Dse=ug(),rp=Rt(),{broadcast:Lse,onMessageByType:Mse,getWorkerIndex:vse}=tt(),{isMainThread:Rk}=require("worker_threads"),{Encoder:Use,decode:BO}=require("msgpackr"),yk=new Use,{isEmpty:ll}=Eg,bk=Rn(),fPe=48*36e11;Rk&&Mse(Ve.ITC_EVENT_TYPES.RESTART,()=>{Xr=void 0,cl=void 0});var{connect:xse,StorageType:Bse,RetentionPolicy:Hse,AckPolicy:HO,DeliverPolicy:kO,DiscardPolicy:kse,NatsConnection:_Pe,JetStreamManager:pPe,JetStreamClient:hPe,StringCodec:mPe,JSONCodec:Fse,createInbox:FO,headers:Gse,ErrorCode:Sk}=require("nats"),{recordAction:qse}=($i(),C(j_)),{encodeBlobsAsBuffers:$se}=(As(),C(Fm)),Ok=Fse(),Vse="clustering",Kse=Cse.engines[vr.NATS_SERVER_NAME],Yse=sp.join(Pse,"dependencies"),xO=sp.join(Yse,`${process.platform}-${process.arch}`,vr.NATS_BINARY_NAME),vO,UO,np,ol,al;Uk.exports={runCommand:Nk,checkNATSServerInstalled:Wse,createConnection:GO,getConnection:ip,getJetStreamManager:op,getJetStream:Ik,getNATSReferences:Yi,getServerList:jse,createLocalStream:qO,listStreams:Ck,deleteLocalStream:Qse,getServerConfig:Xu,listRemoteStreams:Jse,viewStream:Xse,viewStreamIterator:Zse,publishToStream:eie,request:nie,reloadNATS:$O,reloadNATSHub:sie,reloadNATSLeaf:iie,extractServerName:rie,requestErrorHandler:oie,createLocalTableStream:Mk,createTableStreams:lie,purgeTableStream:vk,purgeSchemaTableStreams:uie,getStreamInfo:die,updateLocalStreams:_ie,closeConnection:zse,getJsmServerName:Sg,addNatsMsgHeader:Pk,clearClientCache:wk,updateRemoteConsumer:aie,createConsumer:Dk,updateConsumerIterator:cie};async function Nk(e,t=void 0){let{stdout:r,stderr:n}=await wse(e,{cwd:t});if(n)throw new Error(n.replace(`
19
+ `)},jZ="certificate.pem",QZ="privateKey.pem",JZ="caCertificate.pem",XZ="natsCertificate.pem",ZZ="natsCaCertificate.pem",At={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},e8={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"]},t8={[At.SERVER]:2,[At.DEFAULT]:1},r8={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},n8={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},s8={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},i8={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},o8={[At.CA]:2,[At["DEFAULT-CA"]]:1};Object.assign(OU,{CERTIFICATE_PEM_NAME:jZ,PRIVATEKEY_PEM_NAME:QZ,CA_PEM_NAME:JZ,CERT_NAME:At,CERT_CONFIG_NAME_MAP:e8,CERT_PREFERENCE_APP:t8,CERT_PREFERENCE_OPS:r8,CERT_PREFERENCE_REP:n8,CA_CERT_PREFERENCE_REP:s8,CA_CERT_PREFERENCE_OPS:i8,CA_CERT_PREFERENCE_APP:o8,CERTIFICATE_VALUES:zZ,NATS_CERTIFICATE_PEM_NAME:XZ,NATS_CA_PEM_NAME:ZZ})});var Vy=w((wNe,DU)=>{"use strict";var CU=require("fs-extra"),Te=require("joi"),a8=require("os"),{boolean:Be,string:Rt,number:rr,array:Yc}=Te.types(),{totalmem:NU}=require("os"),Kc=require("path"),c8=z(),$y=se(),NNe=qy(),wU=(H(),C(q)),l8=ft(),IU="log",u8="components",d8="Invalid logging.rotation.maxSize unit. Available units are G, M or K",f8="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",_8="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",p8="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",h8="rootPath config parameter is undefined",Tn=Te.alternatives([rr.min(0),Rt]).optional().empty(null),mE=Te.alternatives([Yc.items(Rt,{host:Rt.required(),port:Tn},{hostname:Rt.required(),port:Tn}).empty(null),Yc.items(Rt)]),Bi,PU=!1;DU.exports={configValidator:m8,routesValidator:R8,route_constraints:mE};function m8(e,t=!1){if(PU=t,Bi=e.rootPath,$y.isEmpty(Bi))throw h8;let r=Be.optional(),n=rr.min(0).max(1e3).empty(null).default(A8),s=Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(A_),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(A_),l=Te.custom(g8).empty(null).default(A_),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:mE}).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:mE}).required(),streams:Te.object({maxAge:rr.min(120).allow(null).optional(),maxBytes:rr.min(1).allow(null).optional(),maxMsgs:rr.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:rr.required(),enableSessions:Be,hashFunction:Rt.valid("md5","sha256","argon2id").optional().empty(null)}),Be).optional(),analytics:Te.object({aggregatePeriod:rr}),replication:Te.object({hostname:Te.alternatives(Rt,rr).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(T8).optional().empty(null),maxSize:Rt.custom(S8).optional().empty(null),path:Rt.optional().empty(null).default(A_)}).required(),root:s,stdStreams:Be.required(),auditLog:Be.required()}).required(),operationsApi:Te.object({network:Te.object({cors:Be.optional(),corsAccessList:Yc.optional(),headersTimeout:rr.min(1).optional(),keepAliveTimeout:rr.min(1).optional(),port:Tn,domainSocket:Te.optional().empty("hdb/operations-server").default(A_),securePort:Tn,timeout:rr.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:rr.optional(),cors:Be.optional(),corsAccessList:Yc.optional(),headersTimeout:rr.min(1).optional(),port:Tn,securePort:Tn,maxHeaderSize:rr.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:rr.min(1).optional(),host:Rt.optional(),waitForDebugger:Be.optional()})),maxHeapMemory:rr.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:rr.optional()})]),compactOnStart:Be.optional(),compactOnStartKeepBackup:Be.optional(),noReadAhead:Be.optional(),path:l,prefetchWrites:Be.optional(),maxFreeSpaceToLoad:rr.optional(),maxFreeSpaceToRetain:rr.optional()}).required(),ignoreScripts:Be.optional(),tls:Te.alternatives([Te.array().items(f),f])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(m8,"configValidator");function E8(e){return PU||CU.existsSync(e)?null:`Specified path ${e} does not exist.`}a(E8,"doesPathExist");function g8(e,t){Te.assert(e,Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=E8(e);if(r)return t.message(r)}a(g8,"validatePath");function S8(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(d8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(_8):e}a(S8,"validateRotationMaxSize");function T8(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(f8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(p8):e}a(T8,"validateRotationInterval");function A8(e,t){let r=t.state.path.join("."),n=a8.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),c8.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(A8,"setDefaultThreads");function A_(e,t){let r=t.state.path.join(".");if(!$y.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if($y.isEmpty(Bi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Kc.join(Bi,u8);case"logging.root":return Kc.join(Bi,IU);case"clustering.leafServer.streams.path":return Kc.join(Bi,"clustering","leaf");case"storage.path":let n=Kc.join(Bi,wU.LEGACY_DATABASES_DIR_NAME);return CU.existsSync(n)?n:Kc.join(Bi,wU.DATABASES_DIR_NAME);case"logging.rotation.path":return Kc.join(Bi,IU);case"operationsApi.network.domainSocket":return r==null?null:Kc.join(Bi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(A_,"setDefaultRoot");function R8(e){let t=Te.object({routes:mE});return l8.validateBySchema({routes:e},t)}a(R8,"routesValidator")});var yt=w(qU=>{"use strict";var bs=(H(),C(q)),gr=se(),nr=z(),{configValidator:y8,routesValidator:LU}=Vy(),zr=require("fs-extra"),vU=require("yaml"),zn=require("path"),b8=require("is-number"),UU=require("properties-reader"),O8=require("lodash"),{handleHDBError:N8}=pe(),{HTTP_STATUS_CODES:w8,HDB_ERROR_MSGS:Cu}=Bn(),{server:I8}=(Vr(),C(Tu)),{PACKAGE_ROOT:xU}=st(),{DATABASES_PARAM_CONFIG:R_,CONFIG_PARAMS:Wn,CONFIG_PARAM_MAP:ti}=bs,C8="Unable to get config value because config is uninitialized",P8="Config successfully initialized",D8="Error backing up config file",L8="Empty parameter sent to getConfigValue",BU=zn.join(xU,"config","yaml",bs.HDB_DEFAULT_CONFIG_FILE),M8=zn.join(xU,"config","yaml","defaultNatsConfig.yaml"),v8="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"},EE,It,gE;Object.assign(qU,{createConfigFile:U8,getDefaultConfig:x8,getConfigValue:kU,initConfig:SE,flattenConfig:Pu,updateConfigValue:FU,updateConfigObject:H8,getConfiguration:G8,setConfiguration:q8,readConfigFile:zy,getClusteringRoutes:$8,initOldConfig:GU,getConfigFromFile:V8,getConfigFilePath:Wc,addConfig:K8,deleteConfigFromFile:Y8,getConfigObj:W8,resolvePath:Ky,getFlatConfigObj:z8});function Ky(e){if(e?.startsWith("~/"))return zn.join(gr.getHomeDir(),e.slice(1));let t=ae();return zn.resolve(t.getHdbBasePath(),e)}a(Ky,"resolvePath");function U8(e,t=!1){let r=wa(BU);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=vU.parseDocument(zr.readFileSync(M8,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}EE=Pu(r.toJSON());let n;for(let c in e){let l=ti[c.toLowerCase()];if(l===Wn.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=Yy(l,e[c]);l==="rootPath"&&f?.endsWith("/")&&(f=f.slice(0,-1));try{r.setIn([...u],f)}catch(d){nr.error(d)}}}n&&HU(r,n),Wy(r,t);let s=r.toJSON();It=Pu(s);let i=r.getIn(["rootPath"]),o=zn.join(i,bs.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)),nr.trace(`Config file written to ${o}`)}a(U8,"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(R_.TABLES))for(let i in n[s][R_.TABLES])for(let o in n[s][R_.TABLES][i]){let c=n[s][R_.TABLES][i][o],l=[Wn.DATABASES,s,R_.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=[Wn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){nr.error("Error parsing schemas CLI/env config arguments",n)}}a(HU,"setSchemasConfig");function x8(e){if(EE===void 0){let r=wa(BU);EE=Pu(r.toJSON())}let t=ti[e.toLowerCase()];if(t!==void 0)return EE[t.toLowerCase()]}a(x8,"getDefaultConfig");function kU(e){if(e==null){nr.info(L8);return}if(It===void 0){nr.trace(C8);return}let t=ti[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 Ky(zn.join(t,bs.HDB_CONFIG_FILE));let r=UU(e);return Ky(r.get(bs.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Wc,"getConfigFilePath");function SE(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 nr.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!==bs.NODE_ERROR_CODES.ENOENT)throw i}try{n=wa(r)}catch(i){if(i.code===bs.NODE_ERROR_CODES.ENOENT){nr.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 nr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}B8(n,r),Wy(n);let s=n.toJSON();if(I8.config=s,It=Pu(s),It.logging_rotation_rotate)for(let i in MU)It[i]&&nr.error(`Config ${MU[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);nr.trace(P8)}}a(SE,"initConfig");function B8(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],zn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],zn.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(nr.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(B8,"checkForUpdatedConfig");function Wy(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 Cu.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 Cu.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=y8(r,t);if(n.error)throw Cu.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(Wy,"validateConfig");function H8(e,t){It===void 0&&(It={});let r=ti[e.toLowerCase()];if(r===void 0){nr.trace(`Unable to update config object because config param '${e}' does not exist`);return}It[r.toLowerCase()]=t}a(H8,"updateConfigObject");function FU(e,t,r=void 0,n=!1,s=!1,i=!1){It===void 0&&SE();let o=kU(ti.hdb_root),c=zn.join(o,bs.HDB_CONFIG_FILE),l=wa(c),u;if(r&&It){let p=!1;for(let _ in r)if(r[_]!=It[_.toLowerCase()]){p=!0;break}if(!p){nr.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===Wn.DATABASES)u=t;else if(r===void 0){let p;if(i)p=e;else if(p=ti[e.toLowerCase()],p===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let _=p.split("_"),h=Yy(p,t);l.setIn([..._],h)}else for(let p in r){let _=ti[p.toLowerCase()];if(_===Wn.HTTP_SECUREPORT&&r[p]===It[Wn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),_===Wn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[p]===It[Wn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),_===Wn.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=bs.LEGACY_CONFIG_PARAMS[p.toUpperCase()];S&&S.startsWith("customFunctions")&&l.hasIn(S.split("_"))&&(_=S,h=S.split("_"));let g=Yy(_,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){nr.error(R)}}}u&&HU(l,u),Wy(l);let f=l.getIn(["rootPath"]),d=zn.join(f,bs.HDB_CONFIG_FILE);if(n===!0&&k8(c,f),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);zr.writeFileSync(d,String(l)),s&&(It=Pu(l.toJSON())),nr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(FU,"updateConfigValue");function k8(e,t){try{let r=zn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${bs.HDB_CONFIG_FILE}.bak`);zr.copySync(e,r),nr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){nr.error(D8),nr.error(r)}}a(k8,"backupConfigFile");var F8=["databases"];function Pu(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])&&!F8.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;!Wn[l.toUpperCase()]&&ti[l]&&(s[ti[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Pu,"flattenConfig");function Yy(e,t){if(e===Wn.CLUSTERING_NODENAME||e===Wn.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(b8(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(Yy,"castConfigValue");function G8(){let e=gr.getPropsFilePath(),t=Wc(e);return wa(t).toJSON()}a(G8,"getConfiguration");async function q8(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return FU(void 0,void 0,s,!0),v8}catch(i){throw typeof i=="string"||i instanceof String?N8(i,i,w8.BAD_REQUEST,void 0,void 0,!0):i}}a(q8,"setConfiguration");function zy(){let e=gr.getPropsFilePath();try{zr.accessSync(e,zr.constants.F_OK|zr.constants.R_OK)}catch(n){if(!gr.noBootFile())throw nr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Wc(e);return wa(t).toJSON()}a(zy,"readConfigFile");function wa(e){return vU.parseDocument(zr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(wa,"parseYamlDoc");function $8(){let e=zy(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=gr.isEmptyOrZeroLength(t)?[]:t;let r=LU(t);if(r)throw Cu.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=gr.isEmptyOrZeroLength(n)?[]:n;let s=LU(n);if(s)throw Cu.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 Cu.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a($8,"getClusteringRoutes");function GU(e){let t=UU(e);It={};for(let r in ti){let n=t.get(r.toUpperCase());if(gr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ti[r].toLowerCase();s===Wn.LOGGING_ROOT?It[s]=zn.dirname(n):It[s]=n}return It}a(GU,"initOldConfig");function V8(e){let t=zy();return O8.get(t,e.replaceAll("_","."))}a(V8,"getConfigFromFile");async function K8(e,t){let r=wa(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(K8,"addConfig");function Y8(e){let t=Wc(gr.getPropsFilePath()),r=wa(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=zn.join(n,bs.HDB_CONFIG_FILE);zr.writeFileSync(s,String(r))}a(Y8,"deleteConfigFromFile");function W8(){return gE||(SE(),gE)}a(W8,"getConfigObj");function z8(){return It||SE(),It}a(z8,"getFlatConfigObj")});var An=w((DNe,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=n5;Or.exports.alterUser=s5;Or.exports.dropUser=o5;Or.exports.getSuperUser=d5;Or.exports.userInfo=a5;Or.exports.listUsers=AE;Or.exports.listUsersExternal=c5;Or.exports.setUsersWithRolesCache=zc;Or.exports.findAndValidateUser=nb;Or.exports.getClusterUser=f5;Or.exports.getUsersWithRolesCache=u5;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 QU=Rn(),j8=Vc(),y_=(hE(),C(pE)),JU=RU(),b_=Yr(),Zy=yo(),Hi=se(),XU=require("validate.js"),eb=z(),{promisify:Q8}=require("util"),tb=To(),Qy=(H(),C(q)),$U=Tt(),J8=yt(),X8=ae(),Z8=Eo(),{hdb_errors:e5,ClientError:ri}=pe(),{HTTP_STATUS_CODES:Ro,AUTHENTICATION_ERROR_MSGS:jy,HDB_ERROR_MSGS:Du}=e5,{UserEventMsg:rb}=ni(),Jy=require("lodash"),{server:TE}=(Vr(),C(Tu)),t5=z();TE.getUser=(e,t)=>nb(e,t,t!=null);TE.authenticateUser=(e,t)=>nb(e,t);var ZU={username:!0,active:!0,role:!0,password:!0},VU=new Map,r5=Q8(j8.delete),Xy=X8.get(Qy.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??y_.HASH_FUNCTION.SHA256,ki;async function n5(e){let t=XU.cleanAttributes(e,ZU),r=JU.addUserValidation(t);if(r)throw new ri(r.message);let n=await b_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]});if(!n||n.length<1)throw new ri(Du.ROLE_NAME_NOT_FOUND(t.role),Ro.NOT_FOUND);if(n.length>1)throw new ri(Du.DUP_ROLES_FOUND(t.role),Ro.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=tb.encrypt(t.password)),t.password=await y_.hash(t.password,Xy),t.hash_function=Xy,t.role=n[0].id;let s=await QU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(eb.debug(s),await zc(),s.skipped_hashes.length===1)throw new ri(Du.USER_ALREADY_EXISTS(t.username),Ro.CONFLICT);return Zy.signalUserChange(new rb(process.pid)),`${t.username} successfully added`}a(n5,"addUser");async function s5(e){let t=XU.cleanAttributes(e,ZU);if(Hi.isEmptyOrZeroLength(t.username))throw new Error(KU);if(Hi.isEmptyOrZeroLength(t.password)&&Hi.isEmptyOrZeroLength(t.role)&&Hi.isEmptyOrZeroLength(t.active))throw new Error(YU);if(!Hi.isEmpty(t.password)&&Hi.isEmptyOrZeroLength(t.password.trim()))throw new Error(WU);if(!Hi.isEmpty(t.active)&&!Hi.isBoolean(t.active))throw new Error(jU);if(!Hi.isEmpty(t.password)&&!Hi.isEmptyOrZeroLength(t.password.trim())&&(i5(t.username)&&(t.hash=tb.encrypt(t.password)),t.password=await y_.hash(t.password,Xy)),t.role==="")throw new Error(zU);if(t.role){let n=await b_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ri(Du.ALTER_USER_ROLE_NOT_FOUND(t.role),Ro.NOT_FOUND);if(n.length>1)throw new ri(Du.DUP_ROLES_FOUND(t.role),Ro.CONFLICT);t.role=n[0].id}let r=await QU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await zc(),Zy.signalUserChange(new rb(process.pid)),r}a(s5,"alterUser");function i5(e){let t=!1,r=ki.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(i5,"isClusterUser");async function o5(e){let t=JU.dropUserValidation(e);if(t)throw new ri(t.message);if(ki.get(e.username)===void 0)throw new ri(Du.USER_NOT_EXIST(e.username),Ro.NOT_FOUND);let r=await r5({table:"hdb_user",schema:"system",hash_values:[e.username]});return eb.debug(r),await zc(),Zy.signalUserChange(new rb(process.pid)),`${e.username} successfully deleted`}a(o5,"dropUser");async function a5(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Jy.cloneDeep(e.hdb_user);let r=await b_.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(a5,"userInfo");async function c5(){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(c5,"listUsersExternal");async function AE(){let e=await b_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=Jy.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await b_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=Jy.cloneDeep(s),s.role=t[s.role],l5(s.role),n.set(s.username,s);return n}a(AE,"listUsers");function l5(e){if(!e){eb.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(l5,"appendSystemTablesToRole");async function zc(e=void 0){e?ki=e:ki=await AE()}a(zc,"setUsersWithRolesCache");async function u5(){return ki||await zc(),ki}a(u5,"getUsersWithRolesCache");async function nb(e,t,r=!0){ki||await zc();let n=ki.get(e);if(!n){if(!r)return{username:e};throw new ri(jy.GENERIC_AUTH_FAIL,Ro.UNAUTHORIZED)}if(n&&!n.active)throw new ri(jy.USER_INACTIVE,Ro.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=y_.validate(n.password,t,n.hash_function||y_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)VU.set(t,n.password);else throw new ri(jy.GENERIC_AUTH_FAIL,Ro.UNAUTHORIZED)}}return s}a(nb,"findAndValidateUser");async function d5(){ki||await zc();for(let[,e]of ki)if(e.role.role==="super_user")return e}a(d5,"getSuperUser");async function f5(){let e=await AE(),t=J8.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=tb.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(f5,"getClusterUser");var e0=[];TE.invalidateUser=function(e){for(let t of e0)try{t(e)}catch(r){t5.error("Error invalidating user",r)}};TE.onInvalidatedUser=function(e){e0.push(e)}});var N_=w((UNe,s0)=>{"use strict";var jc=z(),jn=(H(),C(q)),_5=gv(),MNe=ys(),vNe=Ao(),p5=An(),{validateEvent:t0}=ni(),O_=Yn(),h5=require("process"),{resetDatabases:m5}=(Pe(),C(tt)),E5={[jn.ITC_EVENT_TYPES.SCHEMA]:g5,[jn.ITC_EVENT_TYPES.USER]:n0};async function g5(e){let t=t0(e);if(t){jc.error(t);return}jc.trace("ITC schemaHandler received schema event:",e),await _5(e.message),await S5(e.message)}a(g5,"schemaHandler");async function S5(e){try{O_.resetReadTxn(jn.SYSTEM_SCHEMA_NAME,jn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),O_.resetReadTxn(jn.SYSTEM_SCHEMA_NAME,jn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),O_.resetReadTxn(jn.SYSTEM_SCHEMA_NAME,jn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=m5();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){jc.error(t)}}a(S5,"syncSchemaMetadata");var r0=[];async function n0(e){try{try{O_.resetReadTxn(jn.SYSTEM_SCHEMA_NAME,jn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),O_.resetReadTxn(jn.SYSTEM_SCHEMA_NAME,jn.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 ${jn.HDB_ITC_CLIENT_PREFIX}${h5.pid} received user event:`,e),await p5.setUsersWithRolesCache();for(let r of r0)r()}catch(t){jc.error(t)}}a(n0,"userHandler");n0.addListener=function(e){r0.push(e)};s0.exports=E5});var ni=w((GNe,o0)=>{"use strict";var BNe=z(),sb=se(),T5=(H(),C(q)),{ITC_ERRORS:w_}=Bn(),{parentPort:HNe,threadId:A5,isMainThread:R5,workerData:kNe}=require("worker_threads"),{onMessageFromWorkers:y5,broadcast:FNe,broadcastWithAcknowledgement:b5}=et();o0.exports={sendItcEvent:O5,validateEvent:i0,SchemaEventMsg:N5,UserEventMsg:w5};var RE;y5(async(e,t)=>{RE=RE||N_(),i0(e),RE[e.type]&&await RE[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function O5(e){return!R5&&e.message&&(e.message.originator=A5),b5(e)}a(O5,"sendItcEvent");function i0(e){if(typeof e!="object")return w_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||sb.isEmpty(e.type))return w_.MISSING_TYPE;if(!e.hasOwnProperty("message")||sb.isEmpty(e.message))return w_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||sb.isEmpty(e.message.originator))return w_.MISSING_ORIGIN;if(T5.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return w_.INVALID_EVENT(e.type)}a(i0,"validateEvent");function N5(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(N5,"SchemaEventMsg");function w5(e){this.originator=e}a(w5,"UserEventMsg")});var yo=w((VNe,u0)=>{"use strict";var a0=(H(),C(q)),$Ne=se(),yE=z(),c0=hv(),Lu,{sendItcEvent:l0}=ni();function I5(e){try{yE.info("signalSchemaChange called with message:",e),Lu=Lu||N_();let t=new c0(a0.ITC_EVENT_TYPES.SCHEMA,e);return Lu.schema(t),l0(t)}catch(t){yE.error(t)}}a(I5,"signalSchemaChange");function C5(e){try{yE.trace("signalUserChange called with message:",e),Lu=Lu||N_();let t=new c0(a0.ITC_EVENT_TYPES.USER,e);return Lu.user(t),l0(t)}catch(t){yE.error(t)}}a(C5,"signalUserChange");u0.exports={signalSchemaChange:I5,signalUserChange:C5}});var bE=w((YNe,f0)=>{"use strict";var d0=se(),P5=(H(),C(q)),D5=z(),L5=iE(),M5=sE(),v5=yo(),{SchemaEventMsg:U5}=ni(),x5="already exists in";f0.exports=B5;async function B5(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 H5(e,t.schema,t.name,i)})),s}a(B5,"lmdbCheckForNewAttributes");async function H5(e,t,r,n){let s=new M5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await k5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(x5))D5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(H5,"createNewAttribute");async function k5(e){let t;return t=await L5(e),v5.signalSchemaChange(new U5(process.pid,P5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(k5,"createAttribute")});var Mu=w((zNe,_0)=>{"use strict";var ib=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=ib});var h0=w((QNe,p0)=>{"use strict";var F5=Mu(),G5=(H(),C(q)).OPERATIONS_ENUM,ob=class extends F5{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(G5.INSERT,r,n,s,i),this.records=t}};p0.exports=ob});var E0=w((XNe,m0)=>{"use strict";var q5=Mu(),$5=(H(),C(q)).OPERATIONS_ENUM,ab=class extends q5{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super($5.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};m0.exports=ab});var S0=w((ewe,g0)=>{"use strict";var V5=Mu(),K5=(H(),C(q)).OPERATIONS_ENUM,cb=class extends V5{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(K5.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};g0.exports=cb});var A0=w((rwe,T0)=>{"use strict";var Y5=Mu(),W5=(H(),C(q)).OPERATIONS_ENUM,lb=class extends Y5{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(W5.DELETE,n,s,t,i),this.original_records=r}};T0.exports=lb});var I_=w((iwe,O0)=>{"use strict";var swe=require("path"),R0=_t(),z5=h0(),j5=E0(),Q5=S0(),J5=A0(),vu=vt(),y0=se(),{CONFIG_PARAMS:X5}=(H(),C(q)),b0=ae();b0.initSync();var OE=(H(),C(q)).OPERATIONS_ENUM,{getTransactionAuditStorePath:Z5}=gt();O0.exports=e9;async function e9(e,t){if(b0.get(X5.LOGGING_AUDITLOG)===!1)return;let r=Z5(e.schema,e.table),n=await R0.openEnvironment(r,e.table,!0),s=t9(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){R0.initializeDBIs(n,vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,vu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),y0.isEmpty(s.user_name)||n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(e9,"writeTransaction");function t9(e,t){let r=y0.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===OE.INSERT)return new z5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.UPDATE)return new j5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.UPSERT)return new Q5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.DELETE)return new J5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(t9,"createTransactionObject")});var ub=w((cwe,N0)=>{"use strict";var r9=d_(),awe=vf(),C_=(H(),C(q)),n9=Uf(),s9=kc().insertRecords,i9=_t(),o9=z(),a9=bE(),{getSchemaPath:c9}=gt(),l9=I_();N0.exports=u9;async function u9(e){try{let{schema_table:t,attributes:r}=r9(e);n9(e,r,t.hash_attribute),e.schema!==C_.SYSTEM_SCHEMA_NAME&&(r.includes(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await a9(e.hdb_auth_header,t,r),s=c9(e.schema,e.table),i=await i9.openEnvironment(s,e.table),o=await s9(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await l9(e,o)}catch(c){o9.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(u9,"lmdbCreateRecords")});var C0=w((uwe,I0)=>{"use strict";var w0=(H(),C(q)),d9=ub(),f9=vf(),_9=require("fs-extra"),{getSchemaPath:p9}=gt();I0.exports=h9;async function h9(e){let t=[{name:e.schema,createddate:Date.now()}],r=new f9(w0.SYSTEM_SCHEMA_NAME,w0.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await d9(r),await _9.mkdirp(p9(e.schema))}a(h9,"lmdbCreateSchema")});var D0=w((fwe,P0)=>{"use strict";var db=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=db});var U0=w((Ewe,v0)=>{"use strict";var L0=_t(),fb=_n(),_b=Bn().LMDB_ERRORS_ENUM,m9=vt(),M0=z(),pwe=se(),E9=require("lmdb"),g9=D0(),S9=(H(),C(q)),{OVERFLOW_MARKER:hwe,MAX_SEARCH_KEY_LENGTH:mwe}=m9,T9=S9.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function A9(e,t,r,n){if(fb.validateEnv(e),t===void 0)throw new Error(_b.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(_b.IDS_REQUIRED):new Error(_b.IDS_MUST_BE_ITERABLE);try{let s=L0.listDBIs(e);L0.initializeDBIs(e,t,s);let i=new g9,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[T9]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,E9.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let g=0;g<s.length;g++){let R=s[g];if(!h.hasOwnProperty(R)||R===t)continue;let E=e.dbis[R],A=h[R];if(A!=null)try{let O=fb.getIndexedValues(A);if(O)for(let v=0,F=O.length;v<F;v++)E.remove(O[v],o)}catch{M0.warn(`cannot delete from attribute: ${R}, ${A}:${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=fb.getNextMonotonicTime(),i}catch(s){throw s}}a(A9,"deleteRecords");v0.exports={deleteRecords:A9}});var P_=w((Swe,B0)=>{"use strict";var Uu=se(),R9=U0(),y9=_t(),{getSchemaPath:b9}=gt(),O9=I_(),N9=z();B0.exports=w9;async function w9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Uu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Uu.isEmptyOrZeroLength(e.hash_values)&&!Uu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Uu.isEmpty(l)||e.hash_values.push(l)}}if(Uu.isEmptyOrZeroLength(e.hash_values))return x0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Uu.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=b9(e.schema,e.table),i=await y9.openEnvironment(s,e.table),o=await R9.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await O9(e,o)}catch(c){N9.error(`unable to write transaction due to ${c.message}`)}return x0(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(w9,"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 hb=w((Rwe,H0)=>{"use strict";var I9=(H(),C(q)),Awe=_n();function pb(e,t){let r=Object.create(null);if(t.length===1&&I9.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(pb,"parseRow");function C9(e,t,r,n){let s=pb(r,e);n.push(s)}a(C9,"searchAll");function P9(e,t,r,n){let s=pb(r,e);n[t]=s}a(P9,"searchAllToMap");function D9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(D9,"iterateDBI");function Qc(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(Qc,"pushResults");function L9(e,t,r,n,s,i){t.toString().endsWith(e)&&Qc(t,r,n,s,i)}a(L9,"endsWith");function M9(e,t,r,n,s,i){t.toString().includes(e)&&Qc(t,r,n,s,i)}a(M9,"contains");function v9(e,t,r,n,s,i){t>e&&Qc(t,r,n,s,i)}a(v9,"greaterThanCompare");function U9(e,t,r,n,s,i){t>=e&&Qc(t,r,n,s,i)}a(U9,"greaterThanEqualCompare");function x9(e,t,r,n,s,i){t<e&&Qc(t,r,n,s,i)}a(x9,"lessThanCompare");function B9(e,t,r,n,s,i){t<=e&&Qc(t,r,n,s,i)}a(B9,"lessThanEqualCompare");H0.exports={parseRow:pb,searchAll:C9,searchAllToMap:P9,iterateDBI:D9,endsWith:L9,contains:M9,greaterThanCompare:v9,greaterThanEqualCompare:U9,lessThanCompare:x9,lessThanEqualCompare:B9,pushResults:Qc}});var xu=w((wwe,K0)=>{"use strict";var Ia=_t(),bwe=z(),Qn=_n(),NE=vt(),Yt=Bn().LMDB_ERRORS_ENUM,Owe=se(),H9=(H(),C(q)),wE=hb(),{parseRow:k9}=wE,Nwe=require("lmdb"),{OVERFLOW_MARKER:k0,MAX_SEARCH_KEY_LENGTH:F9}=NE;function F0(e,t,r,n=!1,s=void 0,i=void 0){return Jc(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 D_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Jc(e,t,r,(f,d,p,_)=>{let E={transaction:f,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return _===r?(E.values=!1,d.getRange(E).map(A=>({value:A}))):d.getRange(E)})}a(D_,"iterateRangeBetween");function Jc(e,t,r,n){let s=e.database||e,i=Ia.openDBI(s,r);i[NE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Ia.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(Jc,"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=Ia.openDBI(e,r);else{let l=Ia.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=Ia.openDBI(e,l[u]),!s[NE.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(G0,"getOverflowCheck");function G9(e,t,r,n=!1,s=void 0,i=void 0){if(Qn.validateEnv(e),t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);return Jc(e,t,t,(o,c,l)=>(IE(r),r=L_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>k9(u.value,r))))}a(G9,"searchAll");function q9(e,t,r,n=!1,s=void 0,i=void 0){if(Qn.validateEnv(e),t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);IE(r),r=L_(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,wE.parseRow(l,r));return o}a(q9,"searchAllToMap");function $9(e,t,r=!1,n=void 0,s=void 0){if(Qn.validateEnv(e),t===void 0)throw new Error(Yt.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($9,"iterateDBI");function V9(e,t){if(Qn.validateEnv(e),t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);return Ia.statDBI(e,t).entryCount}a(V9,"countAll");function K9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ca(e,r,n),Jc(e,t,r,(c,l,u,f)=>(n=Qn.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(K9,"equals");function Y9(e,t,r){return Ca(e,t,r),Ia.openDBI(e,t).getValuesCount(r)}a(Y9,"count");function W9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ca(e,r,n),Jc(e,null,r,(c,l)=>{n=Qn.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(W9,"startsWith");function z9(e,t,r,n,s=!1,i=void 0,o=void 0){return q0(e,t,r,n,s,i,o,!0)}a(z9,"endsWith");function q0(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Ca(e,r,n),Jc(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[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(q0,"contains");function j9(e,t,r,n,s=!1,i=void 0,o=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),D_(e,t,r,n,l,s,i,o,!0,!1)}a(j9,"greaterThan");function Q9(e,t,r,n,s=!1,i=void 0,o=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),D_(e,t,r,n,l,s,i,o,!1,!1)}a(Q9,"greaterThanEqual");function J9(e,t,r,n,s=!1,i=void 0,o=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),D_(e,t,r,l,n,s,i,o,!1,!0)}a(J9,"lessThan");function X9(e,t,r,n,s=!1,i=void 0,o=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),D_(e,t,r,l,n,s,i,o,!1,!1)}a(X9,"lessThanEqual");function Z9(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Qn.validateEnv(e),r===void 0)throw new Error(Yt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Yt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Yt.END_VALUE_REQUIRED);if(n=Qn.convertKeyValueToWrite(n),s=Qn.convertKeyValueToWrite(s),n>s)throw new Error(Yt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return D_(e,t,r,n,s,i,o,c)}a(Z9,"between");function e7(e,t,r,n){Qn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);if(IE(r),r=L_(s,r),n===void 0)throw new Error(Yt.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(e7,"searchByHash");function t7(e,t,r){Qn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Yt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(t7,"checkHashExists");function r7(e,t,r,n,s=[]){return V0(e,t,r,n,s),$0(e,t,r,n,s).map(i=>i[1])}a(r7,"batchSearchByHash");function n7(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(n7,"batchSearchByHashToMap");function $0(e,t,r,n,s=[]){return Jc(e,t,t,(i,o,c)=>{r=L_(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($0,"batchHashSearch");function V0(e,t,r,n,s){if(Qn.validateEnv(e),t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);if(IE(r),n==null)throw new Error(Yt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Yt.IDS_MUST_BE_ITERABLE)}a(V0,"initializeBatchSearchByHash");function IE(e){if(!Array.isArray(e))throw e===void 0?new Error(Yt.FETCH_ATTRIBUTES_REQUIRED):new Error(Yt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(IE,"validateFetchAttributes");function Ca(e,t,r){if(Qn.validateEnv(e),t===void 0)throw new Error(Yt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Yt.SEARCH_VALUE_REQUIRED);if(r?.length>F9)throw new Error(Yt.SEARCH_VALUE_TOO_LARGE)}a(Ca,"validateComparisonFunctions");function L_(e,t){return t.length===1&&H9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Ia.listDBIs(e)),t}a(L_,"setGetWholeRowAttributes");K0.exports={searchAll:G9,searchAllToMap:q9,count:Y9,countAll:V9,equals:K9,startsWith:W9,endsWith:z9,contains:q0,searchByHash:e7,setGetWholeRowAttributes:L_,batchSearchByHash:r7,batchSearchByHashToMap:n7,checkHashExists:t7,iterateDBI:$9,greaterThan:j9,greaterThanEqual:Q9,lessThan:J9,lessThanEqual:X9,between:Z9}});var Bu=w((Cwe,Q0)=>{var Y0=require("lodash"),W0=ft(),He=require("joi"),s7=se(),{hdb_schema_table:M_,checkValidTable:z0,hdb_table:j0,hdb_database:CE}=Mi(),{handleHDBError:i7,hdb_errors:o7}=pe(),{getDatabases:a7}=(Pe(),C(tt)),{HTTP_STATUS_CODES:c7}=o7,l7=He.object({database:CE,schema:CE,table:j0,search_attribute:M_,search_value:He.any().required(),get_attributes:He.array().min(1).items(He.alternatives(M_,He.object())).optional(),desc:He.bool(),limit:He.number().integer().min(1),offset:He.number().integer().min(0)}),u7=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(M_,He.object())).optional(),sort:He.object({attribute:He.alternatives(M_,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(M_,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=W0.validateBySchema(e,l7);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,u7);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=s7.checkGlobalSchemaTable(e.schema,e.table);if(s)return i7(new Error,s,c7.NOT_FOUND);let o=a7()[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 mb=w((Dwe,J0)=>{"use strict";var d7=_t(),f7=Bu(),{getSchemaPath:_7}=gt();J0.exports=p7;function p7(e){let t=f7(e,"hashes");if(t)throw t;let r=_7(e.schema,e.table);return d7.openEnvironment(r,e.table)}a(p7,"initialize")});var Eb=w((Mwe,X0)=>{"use strict";var h7=xu(),m7=mb();X0.exports=E7;async function E7(e){let t=await m7(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return h7.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(E7,"lmdbGetDataByHash")});var Hu=w((Uwe,Z0)=>{"use strict";var gb=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=gb});var tx=w((Hwe,ex)=>{"use strict";var Bwe=Hu(),g7=xu(),S7=mb();ex.exports=T7;async function T7(e){let t=await S7(e),r=global.hdb_schema[e.schema][e.table];return g7.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(T7,"lmdbSearchByHash")});var si=w((Fwe,rx)=>{"use strict";var Sb=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=Sb});var PE=w((qwe,cx)=>{"use strict";var jr=xu(),A7=_t(),R7=se(),ke=vt(),Xc=(H(),C(q)),y7=Eo(),nx=Bn().LMDB_ERRORS_ENUM,{getSchemaPath:b7}=gt(),bo=Xc.SEARCH_WILDCARDS;async function O7(e,t,r){let n;e.schema===Xc.SYSTEM_SCHEMA_NAME?n=y7[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(O7,"prepSearch");async function ix(e,t,r,n){let s=b7(e.schema,e.table),i=await A7.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(N7(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 N7(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(N7,"checkToFetchMore");function ax(e,t,r,n){if(R7.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),bo.indexOf(s)>-1)return r===!0?ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:ke.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(bo[0])<0&&s.indexOf(bo[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(bo.indexOf(i)>=0&&bo.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),ke.SEARCH_TYPES.CONTAINS;if(bo.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),ke.SEARCH_TYPES.ENDS_WITH;if(bo.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),ke.SEARCH_TYPES.STARTS_WITH;if(s.includes(bo[0])||s.includes(bo[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:O7,searchByType:ox}});var ux=w((Kwe,lx)=>{"use strict";var Vwe=si(),w7=Bu(),I7=se(),C7=(H(),C(q)),P7=PE();lx.exports=D7;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,!0)}a(D7,"lmdbGetDataByValue")});var v_=w((zwe,dx)=>{"use strict";var Wwe=si(),L7=Bu(),M7=se(),v7=(H(),C(q)),U7=PE();dx.exports=x7;async function x7(e,t){if(!M7.isEmpty(t)&&v7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=L7(e,"value");if(n)throw n;return U7.prepSearch(e,t,!1)}a(x7,"lmdbSearchByValue")});var _x=w((Jwe,fx)=>{"use strict";var Qwe=vt(),Tb=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}},Ab=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Rb=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};fx.exports={SearchByConditionsObject:Tb,SearchCondition:Ab,SortAttribute:Rb}});var gx=w((tIe,Ex)=>{"use strict";var Zwe=_x().SearchByConditionsObject,B7=si(),H7=Bu(),yb=xu(),DE=vt(),{Resource:eIe}=(ga(),C(mR)),mx=PE(),k7=hb(),F7=require("lodash"),{getSchemaPath:G7}=gt(),px=_t(),{handleHDBError:q7,hdb_errors:$7}=pe(),{HTTP_STATUS_CODES:V7}=$7,K7=1e8;Ex.exports=Y7;async function Y7(e){let t=H7(e,"conditions");if(t)throw q7(t,t.message,V7.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=G7(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=F7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===DE.SEARCH_TYPES.EQUALS?u.estimated_count=yb.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=K7}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=yb.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(_=>k7.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=yb.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(Y7,"lmdbSearchByConditions");async function hx(e,t,r,n){let s=new B7(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,mx.searchByType(e,s,i,n).map(o=>o.value)}a(hx,"executeConditionSearch")});var U_=w((nIe,Sx)=>{"use strict";var W7=(H(),C(q)).OPERATIONS_ENUM,bb=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=W7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Sx.exports=bb});var Ob=w((iIe,wx)=>{"use strict";var yx=si(),bx=U_(),Ox=v_(),Nx=P_(),yn=(H(),C(q)),Tx=se(),Ax=_t(),{getTransactionAuditStorePath:z7,getSchemaPath:j7}=gt(),Rx=z();wx.exports=Q7;async function Q7(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 J7(e),await X7(e);let t=j7(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=z7(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(Q7,"lmdbDropTable");async function J7(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(J7,"deleteAttributesFromSystem");async function X7(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(X7,"dropTableFromSystem")});var Cx=w((aIe,Ix)=>{"use strict";var Z7=require("fs-extra"),eee=si(),tee=Hu(),ree=U_(),nee=Ob(),see=P_(),iee=Eb(),oee=v_(),Oo=(H(),C(q)),{getSchemaPath:aee}=gt(),{handleHDBError:cee,hdb_errors:lee}=pe(),{HDB_ERROR_MSGS:uee,HTTP_STATUS_CODES:dee}=lee;Ix.exports=fee;async function fee(e){let t;try{t=await _ee(e.schema);let r=new eee(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await oee(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await nee(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new ree(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await see(s);let i=aee(t);await Z7.remove(i)}catch(r){throw r}}a(fee,"lmdbDropSchema");async function _ee(e){let t=new tee(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await iee(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw cee(new Error,uee.SCHEMA_NOT_FOUND(e),dee.NOT_FOUND,void 0,void 0,!0);return n}a(_ee,"validateDropSchema")});var x_=w((lIe,Px)=>{"use strict";var Nb=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Px.exports=Nb});var Ib=w((fIe,Dx)=>{"use strict";var pee=require("fs-extra"),LE=_t(),{getTransactionAuditStorePath:hee}=gt(),wb=vt(),dIe=x_();Dx.exports=mee;async function mee(e){let t;try{let r=hee(e.schema,e.table);await pee.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,wb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),LE.createDBI(t,wb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),LE.createDBI(t,wb.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(mee,"createTransactionsAuditEnvironment")});var vx=w((hIe,Mx)=>{"use strict";var Cb=(H(),C(q)),Lx=_t(),Eee=kc(),{getSystemSchemaPath:gee,getSchemaPath:See}=gt(),pIe=Eo(),Tee=iE(),Pb=sE(),Aee=z(),Ree=Ib();Mx.exports=yee;async function yee(e,t){let r=See(t.schema,t.table),n=new Pb(t.schema,t.table,Cb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Pb(t.schema,t.table,Cb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Pb(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(gee(),Cb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await Eee.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 Db(n),await Db(s),await Db(i)}await Ree(t)}catch(o){throw o}}a(yee,"lmdbCreateTable");async function Db(e){try{await Tee(e)}catch(t){Aee.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Db,"createAttribute")});var xx=w((EIe,Ux)=>{"use strict";var bee=d_(),Oee=Uf(),Nee=bE(),B_=(H(),C(q)),wee=kc().updateRecords,Iee=_t(),{getSchemaPath:Cee}=gt(),Pee=I_(),Dee=z();Ux.exports=Lee;async function Lee(e){try{let{schema_table:t,attributes:r}=bee(e);Oee(e,r,t.hash_attribute),e.schema!==B_.SYSTEM_SCHEMA_NAME&&(r.includes(B_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(B_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(B_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(B_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await Nee(e.hdb_auth_header,t,r),s=Cee(e.schema,e.table),i=await Iee.openEnvironment(s,e.table),o=await wee(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await Pee(e,o)}catch(c){Dee.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(Lee,"lmdbUpdateRecords")});var Hx=w((SIe,Bx)=>{"use strict";var Mee=(H(),C(q)).OPERATIONS_ENUM,Lb=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Mee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Bx.exports=Lb});var Fx=w((RIe,kx)=>{"use strict";var AIe=Hx(),vee=d_(),Uee=Uf(),xee=bE(),H_=(H(),C(q)),Bee=kc().upsertRecords,Hee=_t(),{getSchemaPath:kee}=gt(),Fee=I_(),Gee=z(),{handleHDBError:qee,hdb_errors:$ee}=pe();kx.exports=Vee;async function Vee(e){let t;try{t=vee(e)}catch(l){throw qee(l,l.message,$ee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;Uee(e,n,r.hash_attribute),e.schema!==H_.SYSTEM_SCHEMA_NAME&&(n.includes(H_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(H_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(H_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(H_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await xee(e.hdb_auth_header,r,n),i=kee(e.schema,e.table),o=await Hee.openEnvironment(i,e.table),c=await Bee(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await Fee(e,c)}catch(l){Gee.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(Vee,"lmdbUpsertRecords")});var qx=w((bIe,Gx)=>{"use strict";var Mb=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};Gx.exports=Mb});var Vx=w((NIe,$x)=>{"use strict";var vb=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=vb});var Wx=w((CIe,Yx)=>{"use strict";var Ub=_t(),{getTransactionAuditStorePath:Kee}=gt(),IIe=qx(),k_=vt(),Yee=se(),Kx=Vx(),Wee=require("util").promisify,zee=Wee(setTimeout),jee=1e4,Qee=100;Yx.exports=Jee;async function Jee(e){let t=Kee(e.schema,e.table),r=await Ub.openEnvironment(t,e.table,!0),n=Ub.listDBIs(r);Ub.initializeDBIs(r,k_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new Kx;do s=await Xee(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 zee(Qee);while(s.transactions_deleted>0);return i}a(Jee,"deleteAuditLogsBefore");async function Xee(e,t){let r=new Kx;try{let n=e.dbis[k_.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[k_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Yee.isEmpty(c)||(s=e.dbis[k_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[k_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>jee)break}return await s,r}catch(n){throw n}}a(Xee,"deleteTransactions")});var jx=w((DIe,zx)=>{"use strict";var xb=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};zx.exports=xb});var Jx=w((vIe,Qx)=>{"use strict";var Zee=si(),ete=U_(),MIe=jx(),Fi=(H(),C(q)),tte=se(),Bb=_t(),rte=Eo(),nte=v_(),ste=P_(),{getSchemaPath:ite}=gt();Qx.exports=ote;async function ote(e,t=!0){let r;e.schema===Fi.SYSTEM_SCHEMA_NAME?r=rte[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await cte(e),s=ite(e.schema,e.table),i=await Bb.openEnvironment(s,e.table);return t===!0&&await ate(e,i,r.hash_attribute),Bb.dropDBI(i,e.attribute),n}a(ote,"lmdbDropAttribute");async function ate(e,t,r){let n=Bb.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(ate,"removeAttributeFromAllObjects");async function cte(e){let t=new Zee(Fi.SYSTEM_SCHEMA_NAME,Fi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Fi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Fi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Fi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await nte(t)).filter(o=>o[Fi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(tte.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Fi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new ete(Fi.SYSTEM_SCHEMA_NAME,Fi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return ste(i)}a(cte,"dropAttributeFromSystem")});var nB=w((BIe,rB)=>{"use strict";var Hb=_t(),ku=vt(),xIe=_n(),kb=(H(),C(q)),Xx=se(),{getTransactionAuditStorePath:lte}=gt(),ute=xu(),ME=Mu(),dte=z();rB.exports=fte;async function fte(e){let t=lte(e.schema,e.table),r=await Hb.openEnvironment(t,e.table,!0),n=Hb.listDBIs(r);Hb.initializeDBIs(r,ku.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case kb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return Zx(r,e.search_values);case kb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,pte(r,e.search_values,s);case kb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return _te(r,e.search_values);default:return Zx(r)}}a(fte,"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[ku.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(Zx,"searchTransactionsByTimestamp");function _te(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[ku.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,tB(e,i))}return Object.fromEntries(r)}a(_te,"searchTransactionsByUsername");function pte(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=ute.equals(e,ku.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ku.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(pte,"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 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(eB,"loopRecords");function tB(e,t){let r=[];try{let n=e.dbis[ku.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){dte.warn(i)}return r}catch(n){throw n}}a(tB,"batchSearchTransactions")});var iB=w((GIe,sB)=>{"use strict";var{getSchemaPath:kIe}=gt(),FIe=_t(),{database:hte}=(Pe(),C(tt));sB.exports={writeTransaction:mte};async function mte(e,t,r){return hte({database:e,table:t}).transaction(r)}a(mte,"writeTransaction")});var lB=w(($Ie,cB)=>{"use strict";var{getSchemaPath:oB}=gt(),aB=_t();cB.exports={flush:Ete,resetReadTxn:gte};async function Ete(e,t){return(await aB.openEnvironment(oB(e,t),t.toString())).flushed}a(Ete,"flush");async function gte(e,t){try{(await aB.openEnvironment(oB(e,t),t.toString())).resetReadTxn()}catch{}}a(gte,"resetReadTxn")});var _B=w((KIe,fB)=>{"use strict";var{Readable:Ste}=require("stream"),{getDatabases:Tte}=(Pe(),C(tt)),{readSync:Ate,openSync:Rte,createReadStream:uB}=require("fs"),{open:yte}=require("lmdb"),dB=s_(),bte=i_(),{AUDIT_STORE_OPTIONS:Ote}=(ho(),C(pB)),{INTERNAL_DBIS_NAME:Nte,AUDIT_STORE_NAME:wte}=vt();fB.exports=Cte;var Fb=32768,Ite=100;async function Cte(e){let t=e.database||e.schema||"data",r=Tte()[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=yte({noSync:!0,maxDbs:bte.MAX_DBS}),p,_=d.openDB(Nte,new dB(!1)),h=f.useReadTransaction(),S=0,g=a(async function(E,A){A.encoding="binary",A.encoder=void 0;let O=d.openDB(E,A),v=f.openDB(E,A);for(let{key:F,version:G,value:Y}of v.getRange({start:null,transaction:h,versions:v.useVersions}))p=O.put(F,Y,G),S++%Ite===0&&(await new Promise(te=>setTimeout(te,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:E,value:A}of f.getRange({transaction:h,start:!1}))if(s.some(O=>E.startsWith?.(O+"/"))){_.put(E,A);let[,O]=E.split("/"),v=!O,F=new dB(!v,v);await g(E,F)}e.include_audit&&await g(wte,{...Ote}),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=Rte(o.path);return o.transaction(()=>{let u=Buffer.alloc(Fb);Ate(c,u,0,Fb),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=uB(null,{fd:c,start:Fb}),p=new Ste.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(Cte,"getBackup")});var EB=w((WIe,mB)=>{"use strict";var Pte=z(),{handleHDBError:Dte}=pe(),Lte=NM(),Mte=iE(),vte=ub(),Ute=C0(),xte=P_(),Bte=Eb(),Hte=tx(),kte=ux(),Fte=v_(),Gte=gx(),qte=Cx(),$te=vx(),Vte=xx(),Kte=Fx(),Yte=Wx(),Wte=Ob(),zte=Jx(),jte=nB(),Qte=iB(),hB=lB(),Jte=_B(),Gb=class extends Lte{static{a(this,"LMDBBridge")}async searchByConditions(t){return Gte(t)}async getDataByHash(t){return await Bte(t)}async searchByHash(t){return await Hte(t)}async getDataByValue(t,r){return await kte(t,r)}async searchByValue(t){return await Fte(t)}async createSchema(t){return await Ute(t)}async dropSchema(t){return await qte(t)}async createTable(t,r){return await $te(t,r)}async dropTable(t){return await Wte(t)}async createAttribute(t){return await Mte(t)}async createRecords(t){return await vte(t)}async updateRecords(t){return await Vte(t)}async upsertRecords(t){try{return await Kte(t)}catch(r){throw Dte(r,null,null,Pte.ERR,r)}}async deleteRecords(t){return await xte(t)}async dropAttribute(t){return await zte(t)}async deleteAuditLogsBefore(t){return await Yte(t)}async readAuditLog(t){return await jte(t)}writeTransaction(t,r,n){return Qte.writeTransaction(t,r,n)}flush(t,r){return hB.flush(t,r)}resetReadTxn(t,r){return hB.resetReadTxn(t,r)}getBackup(t){return Jte(t)}};mB.exports=Gb});var $b={};ve($b,{add:()=>vE,applyReverse:()=>gB,getRecordAtTime:()=>qb,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 gB(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Xte[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=SB}}function qb(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 Xte,SB,xE=be(()=>{ho();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)};Xte={add:vE};a(UE,"rebuildUpdateBefore");a(gB,"applyReverse");SB={};a(qb,"getRecordAtTime")});function bn(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}`);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 Ci||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 _=Vb(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 Vb(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends F_{static{a(this,"TrackedObject")}},FE(r,t)),new r(e)):new F_(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=Vb(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 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=$b[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)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[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(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,TB,AB,F_,Zte,Zc,HE,kE,Kb=be(()=>{Jn=M(pe());xE();Ts();a(bn,"getChanges");a(FE,"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=Vb(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(Vb,"trackObject");F_=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(F_,{});a(GE,"collapseData");Zte=Object.prototype.hasOwnProperty;a(el,"updateAndFreeze");a(BE,"hasChanges");Zc=Symbol.for("has-array-changes"),HE=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()}};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 CB={};ve(CB,{ResourceBridge:()=>zb});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=Gi(e),n=jb(e,r);if(!r)throw new ii.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},o;Nt(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],f;try{f=await r.get({id:u,lazy:s,select:n},i),f=f&&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 Gi(e){let t=e.database||e.schema||tre,r=Je()[t];if(!r)throw(0,ii.handleHDBError)(new Error,ere.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,qE,ii,wB,Yb,Wb,IB,ere,tre,rre,nre,RB,zb,PB=be(()=>{"use strict";NB=M(EB()),qE=M(Bu()),ii=M(pe());Pe();wB=M(d_());H();Yb=M(yo()),Wb=M(ni()),IB=M(se());Oc();Kb();({HDB_ERROR_MSGS:ere}=ii.hdb_errors),tre="data",rre=1e4,nre=10,zb=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,qE.default)(t,"conditions");if(r)throw(0,ii.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Gi(t);if(!n)throw new ii.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select: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 ii.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}dt({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await Gi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Gi(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){Gi(t).dropTable()}createSchema(t){return Fu({database:t.schema,table:null}),Yb.signalSchemaChange(new Wb.SchemaEventMsg(process.pid,Vt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Qb(t.schema),Yb.signalSchemaChange(new Wb.SchemaEventMsg(process.pid,Vt.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=Je()[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=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=Je()[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=Je()[t.schema][t.table];if(!r.createdTimeProperty)throw new ii.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator: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)(nre),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%rre===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,qE.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,qE.default)(t,"value");if(n)throw n;let s=Gi(t);if(!s)throw new ii.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===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=Gi(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){Gi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Gi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Gi(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(Gi,"getTable");a(bB,"createDeleteResponse");a(OB,"groupRecordsInHistory")});var Yn=w((oCe,DB)=>{"use strict";var{ResourceBridge:sre}=(PB(),C(CB)),ire=ae();ire.initSync();var $E;function ore(){return $E||($E=new sre,$E)}a(ore,"getBridge");DB.exports=ore()});var Rn=w((cCe,UB)=>{"use strict";var KE=HR(),Dr=se(),are=require("util"),YE=Yn(),cre=ys(),LB=z(),{handleHDBError:tl,hdb_errors:lre}=pe(),{HTTP_STATUS_CODES:rl}=lre,ure=are.promisify(cre.getTableSchema),dre="updated",MB="inserted",vB="upserted";UB.exports={insert:_re,update:pre,upsert:hre,validation:fre,flush:mre};async function fre(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 ure(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&&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(fre,"validation");async function _re(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=KE(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 YE.createRecords(e);return VE(MB,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(_re,"insertData");async function pre(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=KE(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 YE.updateRecords(e);return Dr.isEmpty(n.existing_rows)?VE(dre,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(pre,"updateData");async function hre(e){if(e.operation!=="upsert")throw tl(new Error,"invalid operation, must be upsert",rl.INTERNAL_SERVER_ERROR);let t=KE(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 YE.upsertRecords(e);return VE(vB,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(hre,"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===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(VE,"returnObject");function mre(e){return Dr.transformReq(e),YE.flush(e.schema,e.table)}a(mre,"flush")});var GB=w((uCe,FB)=>{var Gu=require("validate.js"),BB=ft(),qu=(H(),C(q)),{handleHDBError:Ere,hdb_errors:gre}=pe(),{HDB_ERROR_MSGS:Wt,HTTP_STATUS_CODES:Sre}=gre,Jb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Tre={STRUCTURE_USER:"structure_user"},xB=Object.values(qu.ROLE_TYPES_ENUM),Are="attribute_permissions",Rre="attribute_name",{PERMS_CRUD_ENUM:$u}=qu,yre=[Are,...Object.values($u)],HB=[$u.READ,$u.INSERT,$u.UPDATE],bre=[Rre,...HB];function Ore(e){let t=Jb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,kB(e,t)}a(Ore,"addRoleValidation");function Nre(e){let t=Jb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,kB(e,t)}a(Nre,"alterRoleValidation");function wre(e){let t=Jb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,BB.validateObject(e,t)}a(wre,"dropRoleValidation");var Ire=["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++)Ire.includes(n[o])||s.push(n[o]);s.length>0&&sr(Wt.INVALID_ROLE_JSON_KEYS(s),r);let i=BB.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{sr(o,r)}),e.permission){let o=Cre(e);o&&sr(o,r),xB.forEach(c=>{e.permission[c]&&!Gu.isBoolean(e.permission[c])&&sr(Wt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(xB.indexOf(o)<0){if(o===Tre.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]||sr(Wt.SCHEMA_NOT_FOUND(d),r)}continue}sr(Wt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){sr(Wt.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]){sr(Wt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{yre.includes(f)||sr(Wt.INVALID_PERM_KEY(f),r,o,l)}),Object.values($u).forEach(f=>{Gu.isDefined(u[f])?Gu.isBoolean(u[f])||sr(Wt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):sr(Wt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){sr(Wt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){sr(Wt.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=>{!bre.includes(S)&&S!==$u.DELETE&&sr(Wt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!Gu.isDefined(_.attribute_name)){sr(Wt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=_.attribute_name;if(!f.includes(h)){sr(Wt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}HB.forEach(S=>{Gu.isDefined(_[S])?Gu.isBoolean(_[S])||sr(Wt.ATTR_PERM_NOT_BOOLEAN(S,h),r,o,l):sr(Wt.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}`;sr(Wt.MISMATCHED_TABLE_ATTR_PERMS(p),r,o,l)}}}}return Pre(r)}a(kB,"customValidate");FB.exports={addRoleValidation:Ore,alterRoleValidation:Nre,dropRoleValidation:wre};function Cre(e){let{operation:t,permission:r}=e;if(t===qu.OPERATIONS_ENUM.ADD_ROLE||t===qu.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 Wt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?qu.ROLE_TYPES_ENUM.SUPER_USER:qu.ROLE_TYPES_ENUM.CLUSTER_USER;return Wt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(Cre,"validateNoSUPerms");function Pre(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Wt.ROLE_PERMS_ERROR,...e};return Ere(new Error,n,Sre.BAD_REQUEST)}else return null}a(Pre,"generateRolePermResponse");function sr(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(sr,"addPermError")});var q_=w((_Ce,KB)=>{"use strict";var qB=Rn(),$B=Yr(),Dre=Vc(),Zb=GB(),eO=yo(),fCe=require("uuid").v4,Lre=require("util"),WE=(H(),C(q)),Mre=se(),tO=$B.searchByValue,vre=$B.searchByHash,Ure=Lre.promisify(Dre.delete),xre=si(),Bre=Hu(),{hdb_errors:Hre,handleHDBError:nl}=pe(),{HDB_ERROR_MSGS:VB,HTTP_STATUS_CODES:G_}=Hre,{UserEventMsg:rO}=ni();KB.exports={addRole:kre,alterRole:Fre,dropRole:Gre,listRoles:qre};function Xb(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(Xb,"scrubRoleDetails");async function kre(e){let t=Zb.addRoleValidation(e);if(t)throw t;e=Xb(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 tO(r)||[])}catch(i){throw nl(i)}if(n&&n.length>0)throw nl(new Error,VB.ROLE_ALREADY_EXISTS(e.role),G_.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),eO.signalUserChange(new rO(process.pid)),e=Xb(e),e}a(kre,"addRole");async function Fre(e){let t=Zb.alterRoleValidation(e);if(t)throw t;e=Xb(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",G_.BAD_REQUEST,void 0,void 0,!0);return await eO.signalUserChange(new rO(process.pid)),e}a(Fre,"alterRole");async function Gre(e){let t=Zb.dropRoleValidation(e);if(t)throw nl(new Error,t,G_.BAD_REQUEST,void 0,void 0,!0);let r=new Bre(WE.SYSTEM_SCHEMA_NAME,WE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await vre(r));if(n.length===0)throw nl(new Error,VB.ROLE_NOT_FOUND,G_.NOT_FOUND,void 0,void 0,!0);let s=new xre(WE.SYSTEM_SCHEMA_NAME,WE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await tO(s)),o=!1;if(Mre.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`,G_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Ure(c),eO.signalUserChange(new rO(process.pid)),`${n[0].role} successfully deleted`}a(Gre,"dropRole");async function qre(){return tO({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(qre,"listRoles")});var nO={};ve(nO,{start:()=>zB,startOnMainThread:()=>Kre});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($re.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 Vre(i)}}}async function Vre(e){let t=Je().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,zE.alterRole)(e))}return(0,zE.addRole)(e)}var zE,YB,WB,$re,Kre,jB=be(()=>{Pe();zE=M(q_()),YB=require("yaml"),WB=require("lodash"),$re=["super_user","cluster_user","structure_user"];a(zB,"start");a(Vre,"ensureRole");Kre=zB});async function jE(e){let t=(0,XB.pathToFileURL)(e).toString();return Yre?($_||($_=Wre(jre)),(await(await $_).import(t)).namespace):import(t)}async function Wre(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),$_=new Compartment({console,Math,Date,fetch:zre,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,JB.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:Xn,databases:qe})}};let n=await(0,QB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),$_}function zre(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 jre(){return{Resource:$r,tables:Xn}}var QB,JB,XB,Yre,$_,sO=be(()=>{ga();Pe();QB=require("fs/promises"),JB=require("path"),XB=require("url"),Yre=!1;a(jE,"secureImport");a(Wre,"getCompartment");a(zre,"secureOnlyFetch");a(jre,"getGlobalVars")});var oO={};ve(oO,{handleFile:()=>Qre});async function Qre(e,t,r,n){let s=new Map,i=await jE(r);c(i.default)&&n.set((0,iO.dirname)(t),i.default),o(i,(0,iO.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 iO,ZB=be(()=>{sO();iO=require("path");a(Qre,"handleFile")});var cO={};ve(cO,{start:()=>Jre});function Jre({resources:e}){e.set("login",aO),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var aO,eH=be(()=>{ga();a(Jre,"start");aO=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 j_={};ve(j_,{addAnalyticsListener:()=>z_,calculateCPUUtilization:()=>SH,diffResourceUsage:()=>TH,recordAction:()=>ir,recordActionBinary:()=>Zn,setAnalyticsEnabled:()=>Xre});function Xre(e){pH=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 ene(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 ir(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?Zre(e,o):ene(i,e,t,r,n,s),QE||tne()}function Zn(e,t,r,n,s){ir(!!e,t,r,n,s)}function z_(e){EH.push(e)}function tne(){QE=performance.now(),setTimeout(async()=>{let e=performance.now()-QE;QE=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 XE(e,t,r){let n={id:(0,Y_.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 rne(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),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=rne(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};XE(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};XE(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 nne(e,t=6e4){let r=uO(),n=RH(),s=new Promise(E=>{let A=performance.now();setImmediate(()=>{let O=performance.now();O-A>5e3&&il.warn?.("Unusually high event queue latency on the main thread of "+Math.round(O-A)+"ms"),A=performance.now()}),n.primaryStore.prefetch([1],()=>{let O=performance.now();O-A>5e3&&il.warn?.("Unusually high task queue latency on the main thread of "+Math.round(O-A)+"ms"),E(O-A)})}),i;for(let E of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(E.value?.time){i=E.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],f;for(let{key:E,value:A}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!A)continue;if(o){if(E>o+t)break}else o=E;f=E;let{metrics:O,threadId:v}=A;for(let F of O||[]){let{path:G,method:Y,type:te,metric:ie,count:X,total:ne,distribution:Q,threads:he,...Re}=F;X||(X=1);let Ce=ie+(G?"-"+G:"");Y!==void 0&&(Ce+="-"+Y),te!==void 0&&(Ce+="-"+te);let me=c.get(Ce);if(me){if(me.threads){let lt=me.threads[v];if(lt)me=lt;else{me.threads[v]={...Re};continue}}me.count||(me.count=1);let Zt=me.count;for(let lt in Re){let yr=Re[lt];typeof yr=="number"&&(me[lt]=(me[lt]*Zt+yr*X)/(Zt+X))}me.count+=X,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(Q){Q=Q.map(lt=>typeof lt=="number"?{value:lt,count:1}:lt);let Zt=l.get(Ce);Zt?Zt.push(...Q):l.set(Ce,Q)}}await AH()}for(let E of u){let{path:A,method:O,type:v,metric:F,count:G,total:Y,distribution:te,threads:ie,...X}=E;ie=ie.filter(ne=>ne);for(let ne in X){if(typeof E[ne]!="number")continue;let Q=0;for(let he of ie){let Re=he[ne];typeof Re=="number"&&(Q+=Re)}E[ne]=Q}E.count=ie.length,delete E.threads,delete E.byThread}for(let[E,A]of l){let O=c.get(E);A.sort((lt,yr)=>lt.value>yr.value?1:-1);let v=O.count-1,F=[],G=0,Y=0,te;for(let lt of gH){let yr=v*lt;for(;G<yr;)te=A[Y++],G+=te.count,Y===1&&G--;let Es=A[Y>1?Y-2:0];te||(te=A[0]),F.push(te.value-(te.value-Es.value)*(G-yr)/te.count)}let[ie,X,ne,Q,he,Re,Ce,me,Zt]=F;Object.assign(O,{p1:ie,p10:X,p25:ne,median:Q,p75:he,p90:Re,p95:Ce,p99:me,p999:Zt})}let d;for(let[E,A]of c)A.id=(0,Y_.getNextMonotonicTime)(),A.time=f,n.primaryStore.put(A.id,A,{append:!0}).then(O=>{O||n.primaryStore.put(A.id,A)}),d=!0;let p=Date.now(),{idle:_,active:h}=performance.eventLoopUtilization();if(d||h*10>_){let E=(0,Y_.getNextMonotonicTime)(),A={id:E,metric:"main-thread-utilization",idle:_-nH,active:h-sH,taskQueueLatency:await s,time:p,...process.memoryUsage()};n.primaryStore.put(E,A,{append:!0}).then(O=>{O||n.primaryStore.put(E,A)})}nH=_,sH=h;let S=process.resourceUsage(),g=TH(V_,S);g.time=p,g.period=V_.time?p-V_.time:t,g.cpuUtilization=SH(V_,g.period),XE(n,"resource-usage",g),V_=g;let R=Je();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 uO(){return oH||(oH=dt({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function RH(){return aH||(aH=dt({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function one(){yH=!0;let e=(0,W_.get)(B.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await nne(hH,e),await iH(uO(),sne),await iH(RH(),ine)},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,Y_.getNextMonotonicTime)(),uO().primaryStore.put(r.id,r),yH||one(),ane&&(OH=lne(r))}async function lne(e){if(await OH,!Pa){let r=(0,K_.dirname)((0,dH.getLogFilePath)());try{Pa=await(0,lO.open)((0,K_.join)(r,"analytics.log"),"r+")}catch{Pa=await(0,lO.open)((0,K_.join)(r,"analytics.log"),"w+")}}let t=(await Pa.stat()).size;if(t>cne){let r=Buffer.alloc(t);await Pa.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Pa.write(r,{position:0}),await Pa.truncate(r.length),t=r.length}await Pa.write(JSON.stringify(e)+`
21
+ `,t)}var sl,uH,dH,fH,K_,lO,Y_,W_,_H,il,JE,pH,QE,hH,mH,EH,gH,nH,sH,V_,AH,sne,ine,oH,aH,yH,cH,lH,ane,OH,Pa,cne,qi=be(()=>{sl=require("worker_threads"),uH=M(et());Pe();dH=M(z()),fH=M(Ii()),K_=require("path"),lO=require("fs/promises"),Y_=M(_n()),W_=M(ae());H();Vr();_H=M(require("node:fs")),il=(0,fH.loggerWithTag)("analytics");(0,W_.initSync)();JE=new Map,pH=(0,W_.get)(B.ANALYTICS_AGGREGATEPERIOD)>-1;a(Xre,"setAnalyticsEnabled");a(Zre,"recordExistingAction");a(ene,"recordNewAction");a(ir,"recordAction");Ye.recordAnalytics=ir;a(Zn,"recordActionBinary");QE=0,hH=1e3,mH="analytics-report",EH=[];a(z_,"addAnalyticsListener");gH=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(tne,"sendAnalytics");a(XE,"storeMetric");a(SH,"calculateCPUUtilization");a(TH,"diffResourceUsage");a(rne,"storeTableSizeMetrics");a(tH,"storeDBSizeMetrics");a(rH,"storeVolumeMetrics");a(nne,"aggregation");nH=0,sH=0,V_={},AH=a(()=>new Promise(setImmediate),"rest");a(iH,"cleanup");sne=36e5,ine=31536e6;a(uO,"getRawAnalyticsTable");a(RH,"getAnalyticsTable");(0,uH.setChildListenerByType)(mH,bH);a(one,"startScheduledTasks");cH=0,lH=new Map,ane=!1;a(bH,"recordAnalytics");cne=1e6;a(lne,"logAnalytics")});var NH={};ve(NH,{Headers:()=>No,appendHeader:()=>ZE,mergeHeaders:()=>dO});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 dO(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new No(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 No,Q_=be(()=>{No=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(dO,"mergeHeaders")});function DH(e){let t={openapi:une,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:A,name:O,elements:v,relationship:F,definition:G}of o){if(F)A==="array"?u[O]={type:"array",items:{$ref:Da+v.type}}:u[O]={$ref:Da+A};else{let Y=G??v?.definition;if(Y){if(!t.components.schemas[Y.type]){let te={};Y.properties.forEach(ie=>{te[ie.name]=new hO(fO[ie.type],ie.type)}),t.components.schemas[Y.type]=new CH(te)}A==="array"?u[O]={type:"array",items:{$ref:Da+Y.type}}:u[O]={$ref:Da+Y.type}}else A==="array"?v.type==="Any"||v.type=="ID"?u[O]={type:"array",items:{format:v.type}}:u[O]={type:"array",items:new hO(fO[v.type],v.type)}:A==="Any"||A=="ID"?u[O]={format:A}:u[O]=new hO(fO[A],A)}f.push(new mO(O,"query",u[O]))}let d=Object.keys(u),p=new mO(c,"path",{format:"ID"});p.required=!0,p.description="primary key of record";let _=new mO("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 dne(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[E]||(t.paths[E]={}),t.paths[E].get=new _O(f,r,{200:new pO({$ref:Da+i})},"search for records by the specified property name and value pairs")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new 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 _O([p],r,{200:new pO({$ref:Da+i})},"retrieve a record by its primary key")),S&&(t.paths[E]||(t.paths[E]={}),t.paths[E].put=new fne([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 _O([p,_],r,{200:new pO({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function dne(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Da+e}}}},this.security=t,this.responses={200:{description:EO,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function _O(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function pO(e){this.description=EO,this.content={"application/json":{schema:e}}}function wH(){this.description="successfully processed request, no content returned to client"}function fne(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Da+r}}}},this.responses={200:{description:EO}}}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 hO(e,t){this.type=e,this.format=t}function mO(e,t,r){this.name=e,this.in=t,this.schema=r}var PH,une,fO,Da,EO,LH=be(()=>{PH=M(st()),une="3.0.3",fO={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Da="#/components/schemas/",EO="successful operation";a(DH,"generateJsonApi");a(dne,"Post");a(_O,"Get");a(pO,"Response200");a(wH,"Response204");a(fne,"Put");a(IH,"Delete");a(CH,"ResourceSchema");a(hO,"Type");a(mO,"Parameter")});var tg={};ve(tg,{parseHeaderValue:()=>SO,start:()=>hne});async function pne(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 No;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==MH){let g=eg.getMatch(o,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Nc(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let R=SO(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=SO(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=po(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new Vu.ClientError(g,400)}if(e.authorize=!0,o===MH&&s==="GET"){if(e?.user?.role?.permission?.super_user)return DH(eg);throw new Vu.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 Vu.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Vu.ServerError(`Method ${s} is not recognized`,501)}}),p=200,_;if(d==null)p=s==="GET"||s==="HEAD"?404:204,gO.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=dO(d.headers,i);return d.headers!==g&&(d.headers=g),d.data!==void 0&&(d.body=Qf(d.data,e,d)),d}else if(_=e.lastModified){_ne[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),gO.lastModified&&i.setIfNone("Last-Modified",new Date(_).toUTCString())}e.createdResource&&(p=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:p,headers:i,body:void 0},S=d?.wasLoadedFromSource?.();return S!==void 0&&(h.wasCacheMiss=S,!S&&_&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||_))/1e3))),d!==void 0&&(h.body=Qf(d,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?$i.warn(o):$i.info(o):$i.error(o),o.statusCode===405&&(o.method&&(o.message+=` to handle HTTP method ${o.method.toUpperCase()||""}`),o.allow&&(o.allow.push("trace","head","options"),i.setIfNone("Allow",o.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:o.statusCode||500,headers:i,body:void 0};return c.body=Qf(o.contentType?o:o.toString(),e,c),c}}function hne(e){gO=e,!vH&&(vH=!0,eg=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return pne(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{J_++;let s=new Hn;UH||(UH=!0,z_(l=>{J_>0&&l.push({metric:"ws-connections",connections:J_,byThread:!0})}));let i;t.on("error",l=>{i=!0,$i.warn(l)});let o;t.on("message",a(function(u){o||(o=po(r.requestedContentType??r.headers.asObject["content-type"],!1));let f=o(u);ir(u.length,"bytes-received",r.handlerPath,"message","ws"),s.push(f)},"message"));let c;t.on("close",()=>{J_--,Zn(!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(Zn(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,ir(h=>({count:h.count,total:J_}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let f=new Nc(u.relativeURL),d=u.Resource;c=(await Nt(r,()=>d.connect(f,s,r)))[Symbol.asyncIterator]();let _;for(;!(_=await c.next()).done;){let h=await Ra(_.value,r);t.send(h),ir(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?$i.warn(l):$i.info(l):$i.error(l),t.close(mne[l.statusCode]||1011,l.toString())}t.close()},e))}function SO(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 $i,Vu,Lr,_ne,gO,MH,vH,eg,UH,J_,mne,xH=be(()=>{uo();qi();$i=M(z()),Vu=M(pe());Ff();_u();Oc();Q_();LH();Ff();Lr=new Uint8Array(8),_ne=new Float64Array(Lr.buffer,0,1),gO={},MH="openapi";a(pne,"http");J_=0;a(hne,"start");mne={401:3e3,403:3003};a(SO,"parseHeaderValue")});var TO=w((qCe,HH)=>{var{recordAction:rg,recordActionBinary:BH}=(qi(),C(j_)),Ene=require("fastify-plugin"),gne=200;HH.exports=Ene(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),BH(s.raw.statusCode<400,"success",u,d,f),BH(1,"response_"+s.raw.statusCode,u,d,f);let p=gne;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 FH=w(($Ce,kH)=>{var Sne=ft(),Tne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};kH.exports=function(e){return Sne.validateObject(e,Tne)}});var ng=w((VCe,GH)=>{"use strict";var Ane=(H(),C(q)).OPERATIONS_ENUM,AO=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Ane.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};GH.exports=AO});var ep={};ve(ep,{createTokens:()=>yne,getJWTRSAKeys:()=>cg,refreshOperationToken:()=>bne,validateOperationToken:()=>bO,validateRefreshToken:()=>lg});async function cg(){if(sg)return sg;try{let e=X_.default.join(Z_.default.getHdbBasePath(),YA),t=await ig.default.readFile(X_.default.join(e,bf.JWT_PASSPHRASE_NAME),"utf8"),r=await ig.default.readFile(X_.default.join(e,bf.JWT_PRIVATE_KEY_NAME),"utf8");return sg={publicKey:await ig.default.readFile(X_.default.join(e,bf.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},sg}catch(e){throw ag.default.error(e),new oi.ClientError(Yu.NO_ENCRYPTION_KEYS,Ku.INTERNAL_SERVER_ERROR)}}async function yne(e){let t=(0,RO.validateBySchema)(e,Vi.default.object({username:Vi.default.string().optional(),password:Vi.default.string().optional(),role:Vi.default.string().optional(),expires_in:Vi.default.alternatives(Vi.default.string(),Vi.default.number()).optional()}));if(t)throw new oi.ClientError(t.message);let r;try{let d=e.bypass_auth!==!0;!e.username&&!e.password&&(e.username=e.hdb_user?.username,d=!1),r=await(0,yO.findAndValidateUser)(e.username,e.password,d)}catch(d){throw ag.default.error(d),new oi.ClientError(Yu.INVALID_CREDENTIALS,Ku.UNAUTHORIZED)}if(!r)throw new oi.ClientError(Yu.INVALID_CREDENTIALS,Ku.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 Wu.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:e.expires_in??YH,algorithm:og,subject:"operation"}),l=await Wu.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:Rne,algorithm:og,subject:"refresh"}),u=Hy(l,"sha256");if((await(0,qH.update)(new $H.default(yf,du.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new oi.ClientError(Yu.REFRESH_TOKEN_SAVE_FAILED,Ku.INTERNAL_SERVER_ERROR);return VH.default.signalUserChange(new KH.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function bne(e){let t=(0,RO.validateBySchema)(e,Vi.default.object({refresh_token:Vi.default.string().required()}).required());if(t)throw new oi.ClientError(t.message);let{refresh_token:r}=e;await lg(r);let n=await cg(),s=await Wu.default.decode(r);return{operation_token:await Wu.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:YH,algorithm:og,subject:"operation"})}}async function bO(e){return WH(e,"operation")}async function lg(e){return WH(e,"refresh")}async function WH(e,t){try{let r=await cg(),n=await Wu.default.verify(e,r.publicKey,{algorithms:og,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,yO.findAndValidateUser)(n.username,void 0,!1);if(t==="refresh"&&!ky(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw ag.default.warn(r),r?.name==="TokenExpiredError"?new oi.ClientError(Yu.TOKEN_EXPIRED,Ku.FORBIDDEN):new oi.ClientError(Yu.INVALID_TOKEN,Ku.UNAUTHORIZED)}}var Wu,ig,X_,Vi,RO,oi,ag,yO,qH,$H,VH,KH,Z_,Ku,Yu,YH,Rne,og,sg,zu=be(()=>{Wu=M(require("jsonwebtoken")),ig=M(require("fs-extra")),X_=M(require("node:path")),Vi=M(require("joi")),RO=M(ft());H();oi=M(pe()),ag=M(z());hE();yO=M(An()),qH=M(Rn()),$H=M(ng()),VH=M(yo()),KH=M(ni()),Z_=M(ae()),{HTTP_STATUS_CODES:Ku,AUTHENTICATION_ERROR_MSGS:Yu}=oi.hdb_errors;Z_.default.initSync();YH=Z_.default.get(B.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",Rne=Z_.default.get(B.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",og="RS256";a(cg,"getJWTRSAKeys");a(yne,"createTokens");a(bne,"refreshOperationToken");a(bO,"validateOperationToken");a(lg,"validateRefreshToken");a(WH,"validateToken")});var OO=w((jCe,QH)=>{"use strict";var One=FH(),ju=require("passport"),Nne=require("passport-local").Strategy,wne=require("passport-http").BasicStrategy,Ine=require("util"),Cne=An(),jH=Ine.callbackify(Cne.findAndValidateUser),zCe=Bn(),Pne=(H(),C(q)),zH=(zu(),C(ep));ju.use(new Nne(function(e,t,r){jH(e,t,r)}));ju.use(new wne(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 Dne(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===Pne.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(Dne,"authorize");function Lne(e,t){let r=One(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(Lne,"checkPermissions");QH.exports={authorize:Dne,checkPermissions:Lne}});var ug=w((JCe,JH)=>{"use strict";var Mne=Yn();JH.exports={writeTransaction:vne};function vne(e,t,r){return Mne.writeTransaction(e,t,r)}a(vne,"writeTransaction")});var tk=w((ePe,ek)=>{"use strict";var Une=Yr(),xne=ys(),XH=z(),Bne=Rn(),ZCe=ug(),Hne=require("clone"),wO=require("alasql"),kne=aE(),ZH=require("util"),Fne=ZH.promisify(xne.getTableSchema),Gne=ZH.promisify(Une.search),qne=(H(),C(q)),NO=se();kne(wO);ek.exports={update:Vne};var $ne="There was a problem performing this update. Please check the logs and try again.";async function Vne({statement:e,hdb_user:t}){let r=await Fne(e.table.databaseid,e.table.tableid),n=Kne(e.columns);NO.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=Hne(s),c=NO.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=wO.parse(l).statements[0],f=await Gne(u),d=Yne(n,f);return Wne(o,d,t)}a(Vne,"update");function Kne(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=wO.compile(`SELECT ${r.expression.toString()} AS [${qne.FUNC_VAL}] FROM ?`)}),t}catch(t){throw XH.error(t),new Error($ne)}}a(Kne,"createUpdateRecord");function Yne(e,t){return NO.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(Yne,"buildUpdateRecords");async function Wne(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await Bne.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(Wne,"updateRecords")});var nk=w((sPe,rk)=>{var zne=require("alasql"),jne=Yr(),Qne=z(),Jne=Yn(),CO=require("util"),IO=se(),Xne=(H(),C(q)),Zne=ys(),rPe=ug(),nPe=Rn(),ese="record",tse="successfully deleted",rse=CO.callbackify(ose),nse=CO.promisify(jne.search),sse=CO.promisify(Zne.getTableSchema);rk.exports={convertDelete:rse};function ise(e){return`${e.deleted_hashes.length} ${ese}${e.deleted_hashes.length===1?"":"s"} ${tse}`}a(ise,"generateReturnMessage");async function ose({statement:e,hdb_user:t}){let r=await sse(e.table.databaseid,e.table.tableid);IO.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=IO.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=zne.parse(o).statements[0],l={operation:Xne.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await nse(c);let u=await Jne.deleteRecords(l);return IO.isEmptyOrZeroLength(u.message)&&(u.message=ise(u)),delete u.txn_time,u}catch(u){throw Qne.error(u),u.hdb_code?u.message:u}}a(ose,"convertDelete")});var ck=w((oPe,ak)=>{"use strict";var ase=Ao(),{hdb_errors:sk}=pe(),{getDatabases:ik}=(Pe(),C(tt));ak.exports={checkSchemaExists:ok,checkSchemaTableExists:cse,schema_describe:ase};async function ok(e){if(!ik()[e])return sk.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(ok,"checkSchemaExists");async function cse(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(cse,"checkSchemaTableExists")});var vO=w((dPe,Tk)=>{"use strict";var{decode:lse}=require("msgpackr"),{isMainThread:cPe,parentPort:lPe,threadId:uPe}=require("worker_threads"),_g=or(),Qu=Tt(),LO=(H(),C(q)),Qr=z(),DO=ae(),use=(H(),C(q)),{onMessageByType:dse}=et(),fk=To(),{recordAction:lk,recordActionBinary:fse}=(qi(),C(j_)),{publishToStream:_se}=_g,{ConsumerEvents:uk}=require("nats"),pse=Yr(),{promisify:hse}=require("util"),{decodeBlobsWithWrites:mse}=(Ts(),C(Fm)),_k=hse(setTimeout),pg=1e4,hg,fg,Ese,gse,pk,tp=new Map,Ju=new Map;Tk.exports={initialize:hk,ingestConsumer:MO,setSubscription:Sse,setIgnoreOrigin:Rse,getDatabaseSubscriptions:Ase,updateConsumer:mk};async function hk(){dse(LO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await mk(n)}),pk=!0,Qr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await _g.getNATSReferences();hg=e,fg=e.info.server_name,Ese=t,gse=r}a(hk,"initialize");async function mk(e){if(e.status==="start"){let{js:t,jsm:r}=await Ek(e.node_domain_name);MO(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=tp.get(e.stream_name+e.node_domain_name);t&&(Qr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),tp.set(e.stream_name+e.node_domain_name,"close")),Ju.get(e.node_domain_name)==="failed"&&Ju.set(e.node_domain_name,"close")}}a(mk,"updateConsumer");var mg=new Map;function Sse(e,t,r){let n=mg.get(e);n||mg.set(e,n=new Map),n.set(t,r),pk||hk().then(Tse)}a(Sse,"setSubscription");async function Tse(){let e=await pse.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);MO(l,n,s,r)}}}a(Tse,"accessConsumers");async function Ek(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(Ju.get(e)==="close")break;Ju.set(e,"failed"),n%10===1&&Qr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<pg?n++*100:pg;await _k(i)}return{js:t,jsm:r}}a(Ek,"connectToRemoteJS");function Ase(){return mg}a(Ase,"getDatabaseSubscriptions");var gk;function Rse(e){gk=e}a(Rse,"setIgnoreOrigin");var Sk=100,dk=new Array(Sk),dg=0;async function MO(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),Qr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Ju.get(n)==="close")break;o%10===1&&Qr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(Qr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await _g.createConsumer(r,e,fg,new Date(Date.now()).toISOString()));let f=o++*100<pg?o++*100:pg;await _k(f)}let c=!1,l;for(;!c;){if(tp.get(e+n)==="close"||Ju.get(n)==="close"){tp.delete(e+n),c=!0;continue}l=await i.consume({max_messages:DO.get(LO.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),tp.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;Qr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(Qr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),u=!0)}})();try{for await(let f of l)await dk[dg],dk[dg]=yse(f).catch(d=>{Qr.error(d)}),++dg>=Sk&&(dg=0)}catch(f){f.message==="consumer deleted"?(Qr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):Qr.error("Error consuming clustering ingest, restarting consumer",f)}}}a(MO,"ingestConsumer");async function yse(e){let t;await mse(()=>{t=lse(e.data)}),lk(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),Qr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=DO.get(LO.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),fse(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;Qr.trace("processing message:",o,c,u,(f?"records: "+f.map(v=>v?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),Qr.trace(`messageProcessor nats msg id: ${e.headers.get(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||{},A=mg.get(c)?.get(u);if(!A)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=h,A.send(t);else if(f.length===1&&!l)A.send({type:PO(o),value:f[0],id:d?.[0],expiresAt:_,timestamp:g,table:u,onCommit:h,user:R,nodeName:E});else{let v=f.map((F,G)=>({type:PO(o),value:F,expiresAt:_,id:d?.[G],table:u}));for(;l;)v.push({type:PO(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;A.send({type:"transaction",writes:v,table:u,timestamp:g,onCommit:h,user:R,nodeName:E})}DO.get(use.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&_se(e.subject.split(".").slice(0,-1).join("."),fk.createNatsTableStreamName(c,u),e.headers,e.data),await S;let O=Date.now()-g;g&&lk(O,"replication-latency",e.subject,o,"ingest")}catch(o){Qr.error(o)}e.ack()}a(yse,"messageProcessor");function PO(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(PO,"convertOperation")});var or=w((gPe,Bk)=>{"use strict";var Nr=ae();Nr.initSync();var bse=require("fs-extra"),Ose=require("semver"),sp=require("path"),{monotonicFactory:Nse}=require("ulidx"),Rk=Nse(),wse=require("util"),yk=require("child_process"),Ise=wse.promisify(yk.exec),Cse=yk.spawn,Mr=Tt(),$e=(H(),C(q)),{packageJson:Pse,PACKAGE_ROOT:Dse}=st(),Eg=se(),ai=z(),gg=To(),Lse=ug(),rp=yt(),{broadcast:Mse,onMessageByType:vse,getWorkerIndex:Use}=et(),{isMainThread:bk}=require("worker_threads"),{Encoder:xse,decode:HO}=require("msgpackr"),Ok=new xse,{isEmpty:ll}=Eg,Nk=An(),_Pe=48*36e11;bk&&vse($e.ITC_EVENT_TYPES.RESTART,()=>{Jr=void 0,cl=void 0});var{connect:Bse,StorageType:Hse,RetentionPolicy:kse,AckPolicy:kO,DeliverPolicy:FO,DiscardPolicy:Fse,NatsConnection:pPe,JetStreamManager:hPe,JetStreamClient:mPe,StringCodec:EPe,JSONCodec:Gse,createInbox:GO,headers:qse,ErrorCode:Ak}=require("nats"),{recordAction:$se}=(qi(),C(j_)),{encodeBlobsAsBuffers:Vse}=(Ts(),C(Fm)),wk=Gse(),Kse="clustering",Yse=Pse.engines[Mr.NATS_SERVER_NAME],Wse=sp.join(Dse,"dependencies"),BO=sp.join(Wse,`${process.platform}-${process.arch}`,Mr.NATS_BINARY_NAME),UO,xO,np,ol,al;Bk.exports={runCommand:Ik,checkNATSServerInstalled:zse,createConnection:qO,getConnection:ip,getJetStreamManager:op,getJetStream:Pk,getNATSReferences:Ki,getServerList:Qse,createLocalStream:$O,listStreams:Dk,deleteLocalStream:Jse,getServerConfig:Xu,listRemoteStreams:Xse,viewStream:Zse,viewStreamIterator:eie,publishToStream:tie,request:sie,reloadNATS:VO,reloadNATSHub:iie,reloadNATSLeaf:oie,extractServerName:nie,requestErrorHandler:aie,createLocalTableStream:Uk,createTableStreams:uie,purgeTableStream:xk,purgeSchemaTableStreams:die,getStreamInfo:fie,updateLocalStreams:pie,closeConnection:jse,getJsmServerName:Sg,addNatsMsgHeader:Lk,clearClientCache:Ck,updateRemoteConsumer:cie,createConsumer:Mk,updateConsumerIterator:lie};async function Ik(e,t=void 0){let{stdout:r,stderr:n}=await Ise(e,{cwd:t});if(n)throw new Error(n.replace(`
22
22
  `,""));return r.replace(`
23
- `,"")}a(Nk,"runCommand");async function Wse(){try{await yse.access(xO)}catch{return!1}let e=await Nk(`${xO} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return bse.eq(t,Kse)}a(Wse,"checkNATSServerInstalled");async function GO(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await bk.getClusterUser();if(ll(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}ci.trace("create nats connection called");let i=await xse({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),ci.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&ci.error("Error with Nats client connection, connection closed",o),i===Xr&&wk()}),i}a(GO,"createConnection");function wk(){Xr=void 0,ol=void 0,al=void 0,cl=void 0}a(wk,"clearClientCache");async function zse(){Xr&&(await Xr.drain(),Xr=void 0,ol=void 0,al=void 0,cl=void 0)}a(zse,"closeConnection");var Xr,cl;async function ip(){return cl||(cl=GO(Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Xr=await cl),Xr||cl}a(ip,"getConnection");async function op(){if(ol)return ol;ll(Xr)&&await ip();let{domain:e}=Xu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ol=await Xr.jetstreamManager({domain:e,timeout:6e4}),ol}a(op,"getJetStreamManager");async function Ik(){if(al)return al;ll(Xr)&&await ip();let{domain:e}=Xu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return al=Xr.jetstream({domain:e,timeout:6e4}),al}a(Ik,"getJetStream");async function Yi(){let e=Xr||await ip(),t=ol||await op(),r=al||await Ik();return{connection:e,jsm:t,js:r}}a(Yi,"getNATSReferences");async function jse(e){let t=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await bk.getClusterUser(),s=await GO(t,r,n),i=FO(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let f of o){let d=Ok.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(jse,"getServerList");async function qO(e,t){let{jsm:r}=await Yi(),n=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Bse.File,retention:Hse.Limits,subjects:t,discard:kse.Old,max_msgs:s,max_bytes:i,max_age:n})}a(qO,"createLocalStream");async function Ck(){let{jsm:e}=await Yi(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(Ck,"listStreams");async function Qse(e){let{jsm:t}=await Yi();await t.streams.delete(e)}a(Qse,"deleteLocalStream");async function Jse(e){let{connection:t}=await Yi(),r=[],n=FO(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(Ok.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(Jse,"listRemoteStreams");async function Xse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Yi(),i=Tk(),o={durable_name:i,ack_policy:HO.Explicit};t&&(o.deliver_policy=kO.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=BO(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(Xse,"viewStream");async function*Zse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Yi(),i=Tk(),o={durable_name:i,ack_policy:HO.Explicit};t&&(o.deliver_policy=kO.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=BO(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(Zse,"viewStreamIterator");async function eie(e,t,r,n){ci.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=Pk(n,r);let{js:s}=await Yi(),i=await Sg(),o=`${e}.${i}`,c=await $se(()=>n instanceof Uint8Array?n:yk.encode(n));try{ci.trace(`publishToStream publishing to subject: ${o}`),qse(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 Lk(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){ci.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await qO(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(eie,"publishToStream");function Pk(e,t){t===void 0&&(t=Gse());let r=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(vr.MSG_HEADERS.ORIGIN)&&r&&t.append(vr.MSG_HEADERS.ORIGIN,r),t}a(Pk,"addNatsMsgHeader");function Xu(e){e=e.toLowerCase();let t=sp.join(Nr.get(Ve.CONFIG_PARAMS.ROOTPATH),Vse);if(e===Ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return ll(UO)&&(UO={port:rp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:rp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.HUB,config_file:vr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:sp.join(t,vr.PID_FILES.HUB),hdb_nats_path:t}),UO;if(e===Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return ll(vO)&&(vO={port:rp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:rp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.LEAF,config_file:vr.NATS_CONFIG_FILES.LEAF_SERVER,domain:rp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.LEAF,pid_file_path:sp.join(t,vr.PID_FILES.LEAF),hdb_nats_path:t}),vO;ci.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Xu,"getServerConfig");async function Dk(e,t,r,n){try{await e.consumers.add(t,{ack_policy:HO.Explicit,durable_name:r,deliver_policy:kO.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(Dk,"createConsumer");async function tie(e,t,r){await e.consumers.delete(t,r)}a(tie,"removeConsumer");function rie(e){return e.split(".")[1]}a(rie,"extractServerName");async function nie(e,t,r=6e4,n=FO()){if(!Eg.isObject(t))throw new Error("data param must be an object");let s=yk.encode(t),{connection:i}=await Yi(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return BO(c.data)}a(nie,"request");function $O(e){return new Promise(async(t,r)=>{let n=Ise(xO,["--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($O,"reloadNATS");async function sie(){let{pid_file_path:e}=Xu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await $O(e)}a(sie,"reloadNATSHub");async function iie(){let{pid_file_path:e}=Xu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await $O(e)}a(iie,"reloadNATSLeaf");function oie(e,t,r){let n;switch(e.code){case Sk.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case Sk.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(oie,"requestErrorHandler");async function aie(e,t){let r=t+vr.SERVER_SUFFIX.LEAF,{connection:n}=await Yi(),{jsm:s}=await hie(r),{schema:i,table:o}=e,c=gg.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await Lk(async()=>{if(e.subscribe===!0)await Dk(s,c,n.info.server_name,l);else try{await tie(s,c,n.info.server_name)}catch(u){ci.trace(u)}})}a(aie,"updateRemoteConsumer");async function cie(e,t,r,n){let s=gg.createNatsTableStreamName(e,t),i=r+vr.SERVER_SUFFIX.LEAF,o={type:Ve.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!Rk&&vse()<Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=MO();await c(o)}await Lse(o),n==="stop"&&await Eg.async_set_timeout(1e3)}a(cie,"updateConsumerIterator");function Lk(e){return Dse.writeTransaction(Ve.SYSTEM_SCHEMA_NAME,Ve.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(Lk,"exclusiveLock");async function Mk(e,t){let r=gg.createNatsTableStreamName(e,t),n=await Sg(),s=fie(e,t,n);await qO(r,[s])}a(Mk,"createLocalTableStream");async function lie(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await Mk(n,s)}}a(lie,"createTableStreams");async function vk(e,t,r=void 0){if(Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=gg.createNatsTableStreamName(e,t),{domain:s}=Xu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await ip()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")ci.warn(n);else throw n}}a(vk,"purgeTableStream");async function uie(e,t){if(Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await vk(e,t[r])}a(uie,"purgeSchemaTableStreams");async function die(e){return(await op()).streams.info(e)}a(die,"getStreamInfo");function fie(e,t,r){return`${vr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(fie,"createSubjectName");async function Sg(){if(np)return np;if(np=(await op())?.nc?.info?.server_name,np===void 0)throw new Error("Unable to get jetstream manager server name");return np}a(Sg,"getJsmServerName");async function _ie(){let e=await op(),t=await Sg(),r=await Ck();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=pie(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(".");ci.trace(`Updating stream subject name from: ${i} to: ${f}`),s.subjects[0]=f,await e.streams.update(s.name,s)}}a(_ie,"updateLocalStreams");function pie(e){let{config:t}=e,r=!1,n=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(pie,"updateStreamLimits");async function hie(e){let t,r;try{t=await Xr.jetstream({domain:e}),r=await Xr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw ci.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(hie,"connectToRemoteJS")});function VO(e){let t=e.get(Tg),r=t?(0,Zu.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:cp(e)??1,nodes:[]})})}i[n]=0,e.putSync(Tg,(0,Zu.pack)(r))}return r}function ap(e){return VO(e).remoteNameToId}function Bk(e,t){let r=VO(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,Zu.pack)(r)),s}function Ag(e,t){let r=VO(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,Zu.pack)(r))}return xk.trace?.("The remote node name map",e,n,s),s}var xk,Zu,Tg,KO=be(()=>{xk=M(Ci());ts();Zu=require("msgpackr"),Tg=Symbol.for("remote-ids");a(VO,"getIdMappingRecord");a(ap,"exportIdMapping");a(Bk,"remoteToLocalNodeId");a(Ag,"getIdOfRemoteNode")});var YO={};ve(YO,{commits_awaiting_replication:()=>td,getHDBNodeTable:()=>gr,getReplicationSharedStatus:()=>Rg,iterateRoutes:()=>up,shouldReplicateToNode:()=>lp,subscribeToNodeUpdates:()=>rd});function gr(){return Hk||(Hk=lt({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 rd(e){gr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;qk.debug?.("adding node",n,"on node",Xe()," on process",process.pid),server.nodes=server.nodes.filter(s=>s.name!==n),r.type==="put"&&n!==Xe()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r)),(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function lp(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&gr().primaryStore.get(Xe())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function mie(){rd(e=>{Ma({},(t,r)=>{let n=e.name,s=kk.get(n);if(s||kk.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 td.get(r)||[])u>l&&u<=c&&f();o.lastTime=c});o.lastTime=0,s.set(r,o)}})})}function*up(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=ed.default.get(x.REPLICATION_SECUREPORT)??(!ed.default.get(x.REPLICATION_PORT)&&ed.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||ed.default.get(x.REPLICATION_PORT)||ed.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){Fk.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}}}var Fk,Gk,ed,qk,Hk,kk,td,ul=be(()=>{Pe();ts();Am();Fk=require("worker_threads"),Gk=M(pe()),ed=M(ce());B();qk=M(Ci());server.nodes=[];a(gr,"getHDBNodeTable");a(Rg,"getReplicationSharedStatus");a(rd,"subscribeToNodeUpdates");a(lp,"shouldReplicateToNode");kk=new Map;EL((e,t,r)=>{if(r>server.nodes.length)throw new Gk.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);td||(td=new Map,mie());let n=td.get(e);return n||(n=[],td.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(mie,"startSubscriptionToReplications");a(up,"iterateRoutes")});var Yk={};ve(Yk,{connectedToNode:()=>dl,disconnectedFromNode:()=>id,ensureNode:()=>Io,requestClusterStatus:()=>Kk,startOnMainThread:()=>zO});async function zO(e){let t=0,r=Je();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,cp(l.auditStore));break}}}Wi.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes?.search([])||[])i.push(o);for(let o of up(e))try{let c=!o.subscriptions;if(c){let u=Xe();gr().primaryStore.get(u)===void 0&&await Io(u,{name:u,url:e.url??va(),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)}rd(s)});let n;function s(i,o=i?.name){let c=Xe()&&o===Xe()||va()&&i?.url===va();if(c){let d=!!i?.replicates;if(n!==void 0&&n!==d)for(let p of gr().search([]))p.replicates&&p.name!==o&&s(p,p.name);n=d}if(ot.trace("Setting up node replication for",i),!i){for(let[d,p]of wo){let _;for(let[h,{worker:S,nodes:g}]of p){let A=g[0];if(A&&A.name==o){_=!0;for(let[E,{worker:R}]of p)p.delete(E),ot.warn("Node was deleted, unsubscribing from node",o,E,d),R?.postMessage({type:"unsubscribe-from-node",node:o,database:E,url:d});break}}if(_){wo.get(d).iterator.remove(),wo.delete(d);return}}return}if(c)return;if(!i.url){ot.info(`Node ${i.name} is missing url`);return}let l=wo.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(ot.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 nd)if(i.url===p.url){nd.delete(d);break}nd.set(i.name,i)}let u=Je();if(l||(l=new Map,wo.set(i.url,l)),l.iterator=Ma(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]||(ot.warn(`Database ${p} not found for node ${i.name}, making a subscription anyway`),f(p,!1))}function f(d,p){ot.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:Xe(),start_time:yg.get(d),end_time:Date.now(),replicates:!0}),yg.delete(d));let g=lp(i,d),A=Wi.workers.filter(E=>E.name==="http");if(_?(h=_.worker,_.nodes=S):g&&(t=t%A.length,h=A[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):sd(E)},Eie);else{ot.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],gr().primaryStore.get(Xe())?.replicates),gr().primaryStore.get(Xe())?.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"),id=a(function(i){try{ot.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(nd.keys()),c=o.sort(),l=c.indexOf(i.name||li(i.url));if(l===-1){ot.warn("Disconnected node not found in node map",i.name,o);return}let u=wo.get(i.url),f=u?.get(i.database);if(!f){ot.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=nd.get(_);u=wo.get(h.url);let S=u?.get(i.database);if(!S){p=(p+1)%c.length;continue}let{worker:g,nodes:A}=S,E=!1;for(let R of f.nodes){if(A.some(N=>N.name===R.name)){ot.info(`Disconnected node is already failing over to ${_} for ${i.database}`);continue}A.push(R),E=!0}if(!E){ot.info(`Disconnected node ${i.name} has no nodes to fail over to ${_}`);return}f.redirectingTo=S,ot.info(`Failing over ${i.database} from ${i.name} to ${_}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:A}):sd({database:i.database,nodes:A});return}ot.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){ot.error("Error failing over node",o)}},"disconnectedFromNode"),dl=a(function(i){let o=wo.get(i.url),c=o?.get(i.database);if(!c){ot.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}):sd({database:i.database,nodes:u}))}},"connectedToNode"),(0,Wi.onMessageByType)("disconnected-from-node",id),(0,Wi.onMessageByType)("connected-to-node",dl),(0,Wi.onMessageByType)("request-cluster-status",Kk)}function Kk(e,t){let r=[];for(let[n,s]of nd)try{let i=wo.get(s.url);ot.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,WO.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){ot.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Io(e,t){let r=gr();e=e??li(t.url),t.name=e;try{if(t.ca){let s=new Vk.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){ot.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(ot.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!$k.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,WO.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])]}ot.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Wi,bg,ot,WO,$k,Vk,Eie,wo,id,dl,nd,yg,dp=be(()=>{Pe();Wi=M(tt());ts();bg=require("worker_threads");ul();ot=M(Y()),WO=require("lodash"),$k=M(ce());B();Vk=require("crypto"),Eie=200,wo=new Map,nd=new Map,yg=new Map;a(zO,"startOnMainThread");a(Kk,"requestClusterStatus");bg.parentPort&&(id=a(e=>{bg.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),dl=a(e=>{bg.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Wi.onMessageByType)("subscribe-to-node",e=>{sd(e)}),(0,Wi.onMessageByType)("unsubscribe-from-node",e=>{Og(e)}));a(Io,"ensureNode")});var rs=I(hF=>{"use strict";var or=require("path"),Nn=require("fs-extra"),od=require("node-forge"),Xk=require("net"),{generateKeyPair:QO,X509Certificate:Co,createPrivateKey:Zk}=require("crypto"),gie=require("util");QO=gie.promisify(QO);var yt=od.pki,ui=require("joi"),{v4:eF}=require("uuid"),{validateBySchema:eN}=ut(),ft=Y(),Ns=ce(),ws=(B(),C(G)),{CONFIG_PARAMS:ad}=ws,di=Gy(),{ClientError:xa}=pe(),Ng=require("node:tls"),{relative:tF,join:Sie}=require("node:path"),{CERT_PREFERENCE_APP:vPe,CERTIFICATE_VALUES:Wk}=di,Tie=da(),JO=Rt(),{table:Aie,getDatabases:Rie,databases:jO}=(Pe(),C(rt)),{getJWTRSAKeys:zk}=(zu(),C(ep));Object.assign(hF,{generateKeys:nN,updateConfigCert:lF,createCsr:Pie,signCertificate:Die,setCertTable:cd,loadCertificates:oF,reviewSelfSignedCert:iN,createTLSSelector:dF,listCertificates:_F,addCertificate:Bie,removeCertificate:kie,createNatsCerts:vie,generateCertsKeys:Mie,getReplicationCert:_p,getReplicationCertAuth:Cie,renewSelfSigned:Uie,hostnamesFromCert:pF,getKey:Fie});var{urlToNodeName:rF,getThisNodeUrl:yie,getThisNodeName:Ig,clearThisNodeName:bie}=(ts(),C(Po)),{readFileSync:Oie,watchFile:Nie,statSync:nF}=require("node:fs"),UPe=ce(),{getTicketKeys:wie,onMessageFromWorkers:Iie}=tt(),Ua=Y(),{isMainThread:sF}=require("worker_threads"),{TLSSocket:iF,createSecureContext:xPe}=require("node:tls"),tN=3650,fp=["127.0.0.1","localhost","::1"],rN=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];Iie(async e=>{e.type===ws.ITC_EVENT_TYPES.RESTART&&(Ns.initSync(!0),await iN())});var Ur;function Ha(){return Ur||(Ur=Rie().system.hdb_certificate,Ur||(Ur=Aie({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(Ha,"getCertTable");async function _p(){let e=dF("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 Co(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(_p,"getReplicationCert");async function Cie(){Ha();let e=(await _p()).options.cert,r=new Co(e).issuer.match(/CN=(.*)/)?.[1];return Ur.get(r)}a(Cie,"getReplicationCertAuth");var jk,Ba=new Map;function oF(){if(jk)return;jk=!0;let e=[{configKey:ad.TLS},{configKey:ad.OPERATIONSAPI_TLS}];Ha();let t=or.dirname(JO.getConfigFilePath()),r;for(let{configKey:n}of e){let s=JO.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&tF(Sie(t,"keys"),o);c&&Qk(o,l=>{Ba.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&sF){let f;Qk(u,d=>{if(Wk.cert===d)return;let p=i.hostname??i.hostnames??i.host??i.hosts;p&&!Array.isArray(p)&&(p=[p]);let _=uF(u),h=new Co(_),S;try{S=oN(h)}catch(R){ft.error("error extracting common name from certificate",R);return}if(S==null){ft.error("error extracting common name from certificate");return}if(h.checkIssued(new Co(Wk.cert)))return;let g=Ur.primaryStore.get(S),A=nF(u).mtimeMs,E=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&A<=E){A<E&&ft.info(`Certificate ${S} at ${u} is older (${new Date(A)}) 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:A,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(oF,"loadCertificates");function Qk(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&sF&&ft.warn(`Reloading ${r}:`,e),n=c,t(uF(e)))}catch(c){ft.error(`Error loading ${r}:`,e,c)}},"loadFile");Nn.existsSync(e)?s(nF(e)):ft.error(`${r} file not found:`,e),Nie(e,{persistent:!1},s)}a(Qk,"loadAndWatch");function XO(){let e=yie();if(e==null){let t=fp[0];return ft.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return rF(e)}a(XO,"getHost");function wg(){let e=Ig();if(e==null){let t=fp[0];return ft.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(wg,"getCommonName");async function Pie(){let e=await _p(),t=yt.certificateFromPem(e.options.cert),r=yt.privateKeyFromPem(e.options.key);ft.info("Creating CSR with cert named:",e.name);let n=yt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:wg()},...rN];ft.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:aF()}];return ft.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),od.pki.certificationRequestToPem(n)}a(Pie,"createCsr");function aF(){let e=fp.includes(wg())?fp:[...fp,wg()];return e.includes(XO())||e.push(XO()),[{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=>Xk.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(aF,"certExtensions");async function Die(e){let t={},r=or.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;Ha();for await(let f of Ur.search([]))if(f.is_authority&&!f.details.issuer.includes("HarperDB-Certificate-Authority")){if(Ba.has(f.private_key_name)){n=Ba.get(f.private_key_name),s=f;break}else if(f.private_key_name&&await Nn.exists(or.join(r,f.private_key_name))){n=Nn.readFile(or.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await ZO();s=f.ca,n=f.private_key}n=yt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=yt.certificateFromPem(s.certificate);ft.info("Signing CSR with cert named",s.name);let o=yt.certificationRequestFromPem(e.csr);try{o.verify()}catch(f){return ft.error(f),new Error("Error verifying CSR: "+f.message)}let c=od.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()+tN),ft.info("sign cert setting validity:",c.validity),ft.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),ft.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;ft.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,od.md.sha256.create()),t.certificate=yt.certificateToPem(c)}else ft.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(Die,"signCertificate");async function Lie(e,t){await cd({name:Ig(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await cd({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:yt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(Lie,"createCertificateTable");async function cd(e){let t=new Co(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},Ha(),await Ur.patch(e)}a(cd,"setCertTable");async function nN(){let e=await QO("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:yt.publicKeyFromPem(e.publicKey),private_key:yt.privateKeyFromPem(e.privateKey)}}a(nN,"generateKeys");async function sN(e,t,r){let n=yt.createCertificate();if(!t){let o=await _p();t=yt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+tN);let i=[{name:"commonName",value:wg()},...rN];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(aF()),n.sign(e,od.md.sha256.create()),yt.certificateToPem(n)}a(sN,"generateCertificates");async function ZO(){let e=await _F(),t;for(let r of e){if(!r.is_authority)continue;let n=await fF(r.private_key_name);if(r.private_key_name&&n&&new Co(r.certificate).checkPrivateKey(Zk(n))){ft.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;ft.trace("No CA found with matching private key")}a(ZO,"getCertAuthority");async function cF(e,t,r=!0){let n=yt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+tN);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${Ns.get(ad.REPLICATION_HOSTNAME)??rF(Ns.get(ad.REPLICATION_URL))??eF().split("-")[0]}`},...rN];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,od.md.sha256.create());let o=or.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME),c=or.join(o,di.PRIVATEKEY_PEM_NAME);return r&&await Nn.writeFile(c,yt.privateKeyToPem(e)),n}a(cF,"generateCertAuthority");async function Mie(){let{private_key:e,public_key:t}=await nN(),r=await cF(e,t),n=await sN(e,t,r);await Lie(n,r),lF()}a(Mie,"generateCertsKeys");async function vie(){let e=await sN(yt.privateKeyFromPem(di.CERTIFICATE_VALUES.key),void 0,yt.certificateFromPem(di.CERTIFICATE_VALUES.cert)),t=or.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME),r=or.join(t,di.NATS_CERTIFICATE_PEM_NAME);await Nn.exists(r)||await Nn.writeFile(r,e);let n=or.join(t,di.NATS_CA_PEM_NAME);await Nn.exists(n)||await Nn.writeFile(n,di.CERTIFICATE_VALUES.cert)}a(vie,"createNatsCerts");async function Uie(){Ha();for await(let e of Ur.search([{attribute:"is_self_signed",value:!0}]))await Ur.delete(e.name);await iN()}a(Uie,"renewSelfSigned");async function iN(){bie(),await oF(),Ha();let e=await ZO();if(!e){ft.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=Ns.get(ad.TLS_PRIVATEKEY),n=or.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME),s,i=tF(n,r);try{s=yt.privateKeyFromPem(await Nn.readFile(r))}catch(c){ft.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 nN(),await Nn.exists(or.join(n,di.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${eF().split("-")[0]}.pem`),await Nn.writeFile(or.join(n,i),yt.privateKeyToPem(s))}let o=await cF(s,yt.setRsaPublicKey(s.n,s.e),!1);await cd({name:o.subject.getField("CN").value,uses:["https"],certificate:yt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await _p()){let r=Ig();ft.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await ZO();let n=yt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await sN(yt.privateKeyFromPem(e.private_key),s,n);await cd({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(iN,"reviewSelfSignedCert");function lF(){let e=Tie(Object.keys(ws.CONFIG_PARAM_MAP),!0),t=or.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME),r=or.join(t,di.PRIVATEKEY_PEM_NAME),n=or.join(t,di.NATS_CERTIFICATE_PEM_NAME),s=or.join(t,di.NATS_CA_PEM_NAME),i=ws.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),JO.updateConfigValue(void 0,void 0,o,!1,!0)}a(lF,"updateConfigCert");function uF(e){return e.startsWith("-----BEGIN")?e:Oie(e,"utf8")}a(uF,"readPEM");var Jk=Ng.createSecureContext;Ng.createSecureContext=function(e){if(!e.cert||!e.key)return Jk(e);let t={...e};delete t.key,delete t.cert;let r=Jk(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var xie=iF.prototype._init;iF.prototype._init=function(e,t){xie.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 dF(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 jO.system.hdb_certificate.search([])){let p=d.certificate,_=new Co(p);d.is_authority&&(_.asString=p,fl.set(_.subject,p))}for await(let d of jO.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 fF(d.private_key_name),S=d.certificate,g=new Co(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 A={ciphers:d.ciphers,ticketKeys:wie(),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&&(A.sessionIdContext=o.sessionIdContext);let E=Ng.createSecureContext(A);E.name=d.name,E.options=A,E.quality=_,E.certificateAuthorities=Array.from(fl),E.certStart=S.toString().slice(0,100);let R=d.hostnames??pF(g);Array.isArray(R)||(R=[R]);let N;for(let v of R)if(v){v[0]==="*"&&(s=!0,v=v.slice(1)),v===XO()&&(_+=2),Xk.isIP(v)&&(N=!0);let k=r.get(v)?.quality??0;_>k&&r.set(v,E)}else Ua.error("No hostname found for certificate at",Ng.certificate);Ua.trace("Adding TLS",E.name,"for",o.ports||"client","cert named",d.name,"hostnames",R,"quality",_,"best quality",f),_>f&&(i.defaultContext=n=E,f=_,o&&(o.defaultContext=E))}catch(p){Ua.error("Error applying TLS for",d.name,p)}o?.secureContextsListeners.forEach(d=>d()),c(n)}catch(f){l(f)}}a(u,"updateTLS"),jO.system.hdb_certificate.subscribe({listener:a(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(o,c){Ua.info("TLS requested for",o||"(no SNI)");let l=o;for(;;){let f=r.get(l);if(f)return Ua.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?Ua.debug("No certificate found to match",o,"using the default certificate"):Ua.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.updatedContext&&(u=u.updatedContext):Ua.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(dF,"createTLSSelector");async function fF(e){let t=Ba.get(e);return!t&&e?await Nn.readFile(or.join(Ns.get(ad.ROOTPATH),ws.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(fF,"getPrivateKeyByName");async function _F(){Ha();let e=[];for await(let t of Ur.search([]))e.push(t);return e}a(_F,"listCertificates");async function Bie(e){let t=eN(e,ui.object({name:ui.string().required(),certificate:ui.string().required(),is_authority:ui.boolean().required(),private_key:ui.string(),hosts:ui.array(),uses:ui.array()}));if(t)throw new xa(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new Co(n),c=!1,l=!1,u;for(let[_,h]of Ba)!s&&!c&&o.checkPrivateKey(Zk(h))&&(c=!0,u=_),s&&s===h&&(l=!0,u=_);if(!i&&!s&&!c)throw new xa("A suitable private key was not found for this certificate");let f;if(!r){try{f=oN(o)}catch(_){ft.error(_)}if(f==null)throw new xa("Error extracting certificate common name, please provide a name parameter")}let d=Hie(r??f);s&&!c&&!l&&(await Nn.writeFile(or.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME,d+".pem"),s),Ba.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 cd(p),"Successfully added certificate: "+d}a(Bie,"addCertificate");function Hie(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(Hie,"sanitizeName");async function kie(e){let t=eN(e,ui.object({name:ui.string().required()}));if(t)throw new xa(t.message);let{name:r}=e;Ha();let n=await Ur.get(r);if(!n)throw new xa(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&&(ft.info("Removing private key named",s),await Nn.remove(or.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME,s)))}return await Ur.delete(r),"Successfully removed "+r}a(kie,"removeCertificate");function oN(e){return e.subject.match(/CN=(.*)/)?.[1]}a(oN,"extractCommonName");function pF(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):[oN(e)]}a(pF,"hostnamesFromCert");async function Fie(e){if(e.bypass_auth!==!0)throw new xa("Unauthorized","401");let t=eN(e,ui.object({name:ui.string().required()}));if(t)throw new xa(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await zk()).privateKey;if(r===".jwtPublic")return(await zk()).publicKey;if(Ba.get(r))return Ba.get(e.name);throw new xa("Key not found")}a(Fie,"getKey")});var vF={};ve(vF,{CONFIRMATION_STATUS_POSITION:()=>MF,NodeReplicationConnection:()=>pp,OPERATION_REQUEST:()=>dN,RECEIVED_TIME_POSITION:()=>_N,RECEIVED_VERSION_POSITION:()=>fN,SENDING_TIME_POSITION:()=>Mg,createWebSocket:()=>Ug,database_subscriptions:()=>Fa,replicateOverWS:()=>hp,table_update_listeners:()=>hN});async function Ug(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=Xe(),i;if(e.includes("wss://")){if(!cN){let l=(0,PF.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),cN=u.secureContexts}if(i=cN.get(s),i&&de.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,LF.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(c.secureContext=DF.createSecureContext({...i.options,ca:Array.from(pl)})),new IF.WebSocket(e,"harperdb-replication-v1",c)}function hp(e,t,r){let n=t.port||t.securePort,s=_l.pid%1e3+"-"+CF.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||Fa,d,p,_=!1,h=t.subscription;h?.then&&h.then(T=>h=T);let S=t.tables||u&&Je()[u];if(!r){de.error?.("No authorization provided"),dn(1008,"Unauthorized");return}let g=new Map,A=[],E=r.name;E&&t.connection&&(t.connection.nodeName=E);let R,N,v,k,F,K,re,ae=1e3,Z,se=0,W=0,he=0,Te=new Map,Ce=[],me=0,Xt;if(t.url){let T=a(()=>{F&&W===e._socket?.bytesRead&&he===e._socket?.bytesWritten?e.terminate():(F=performance.now(),e.ping(),W=e._socket?.bytesRead,he=e._socket?.bytesWritten)},"send_ping");v=setInterval(T,OF).unref(),T()}else ct();e._socket?.setMaxListeners(200);function ct(){clearTimeout(k),W=e._socket?.bytesRead,he=e._socket?.bytesWritten,k=setTimeout(()=>{W===e._socket?.bytesRead&&he===e._socket?.bytesWritten&&(de.warn?.(`Timeout waiting for ping from ${E}, terminating connection and reconnecting`),e.terminate())},OF*2).unref()}a(ct,"resetPingTimer");function yr(){return p||(p=Rg(d,u,E)),p}a(yr,"getSharedStatus"),u&&oa(u);let gs,Bn,su=[],iu=[],xA,BA=[],Dt=[],mf=[],jh=150,Qh=25,Ef=0,Jh=0,De=!1,gf,un,Ir,ou;e.on("message",T=>{se=performance.now();try{let O=T.dataView=new hl(T.buffer,T.byteOffset,T.byteLength);if(T[0]>127){let b=(0,je.decode)(T),[U,L,P]=b;switch(U){case EF:{if(L){if(E){if(E!==L){de.error?.(s,`Node name mismatch, expecting to connect to ${E}, but peer reported name as ${L}, disconnecting`),e.send((0,je.encode)([ld])),dn(1008,"Node name mismatch");return}}else if(E=L,t.connection?.tentativeNode){let ue=t.connection.tentativeNode;ue.name=E,t.connection.tentativeNode=null,Io(E,ue)}if(t.connection&&(t.connection.nodeName=E),de.debug?.(s,"received node name:",E,"db:",u),!u)try{oa(u=b[2]),u==="system"&&(gs=Ma(t,(ue,te)=>{cu(te)&&aa(te)}),e.on("close",()=>{gs?.remove()}))}catch(ue){de.warn?.(s,"Error setting database",ue),e.send((0,je.encode)([ld])),dn(1008,ue.message);return}Gr()}break}case yF:{de.debug?.(s,"Received table definitions for",L.map(ue=>ue.table));for(let ue of L){let te=b[2];ue.database=te;let fe;cu(te)&&(te==="system"?$e[te]?.[ue.table]||(fe=lN(ue,$e[te]?.[ue.table])):fe=lN(ue,$e[te]?.[ue.table]),d||(d=fe?.auditStore),S||(S=Je()?.[te]))}break}case ld:dn();break;case dN:try{let ue=r?.replicates||r?.subscribers||r?.name;server.operation(L,{user:r},!ue).then(te=>{Array.isArray(te)&&(te={results:te}),te.requestId=L.requestId,e.send((0,je.encode)([Pg,te]))},te=>{e.send((0,je.encode)([Pg,{requestId:L.requestId,error:te instanceof Error?te.toString():te}]))})}catch(ue){e.send((0,je.encode)([Pg,{requestId:L.requestId,error:ue instanceof Error?ue.toString():ue}]))}break;case Pg:let{resolve:H,reject:$}=g.get(L.requestId);L.error?$(new Error(L.error)):H(L),g.delete(L.requestId);break;case aN:let j=b[3];S||(u?de.error?.(s,"No tables found for",u):de.error?.(s,"Database name never received"));let Q=S[j];Q=lN({table:j,database:u,attributes:L.attributes,schemaDefined:L.schemaDefined},Q),su[P]={name:j,decoder:new je.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:L.typedStructs,structures:L.structures}),getEntry(ue){return Q.primaryStore.getEntry(ue)},rootStore:Q.primaryStore.rootStore};break;case gF:ou=d?Bk(L,d):new Map,xA=b[2],de.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${xA}`);break;case SF:let q=P;mf[q]=L;break;case RF:yr()[MF]=L,de.trace?.(s,"received and broadcasting committed update",L),yr().buffer.notify();break;case AF:R=L,h.send({type:"end_txn",localTime:R,remoteNodeIds:A});break;case Dg:{let ue=b[1],{fileId:te,size:fe,finished:ie,error:J}=ue,le=Te.get(te);de.debug?.("Received blob",te,"has stream",!!le,"connectedToBlob",!!le?.connectedToBlob,"length",b[2].length,"finished",ie),le||(le=new uN.PassThrough,le.expectedSize=fe,Te.set(te,le)),le.lastChunk=Date.now(),ie?(J?(le.on("error",()=>{}),le.destroy(new Error("Blob error: "+J))):le.end(b[2]),le.connectedToBlob&&Te.delete(te)):le.write(b[2]);break}case TF:{let ue=L,te;try{let fe=b[3],ie=iu[P]||(iu[P]=S[b[4]]);if(!ie)return de.warn?.("Unknown table id trying to handle record request",P);let J=ie.primaryStore.getBinaryFast(Symbol.for("structures")),le=J.length;if(le!==Jh){Jh=le;let Re=(0,je.decode)(J);e.send((0,je.encode)([aN,{typedStructs:Re.typed,structures:Re.named},P,ie.tableName]))}let ye=ie.primaryStore.getBinaryFast(fe);if(ye){let Re=ie.primaryStore.decoder.decode(ye,{valueAsBuffer:!0});te=(0,je.encode)([Cg,ue,{value:Re.value,expiresAt:Re.expiresAt,version:Re.version,residencyId:Re.residencyId,nodeId:Re.nodeId,user:Re.user}])}else te=(0,je.encode)([Cg,ue])}catch(fe){te=(0,je.encode)([Cg,ue,{error:fe.message}])}e.send(te);break}case Cg:{let{resolve:ue,reject:te,tableId:fe,key:ie}=g.get(b[1]),J=b[2];if(J?.error)te(new Error(J.error));else if(J){let le=su[fe].decoder.decode(J.value);J.value=le,J.key=ie,ue(J)}else ue();g.delete(b[1]);break}case mF:{Ir=L;let ue,te,fe=!1;if(h){if(u!==h.databaseName&&!h.then){de.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=f.get(u);if(de.debug?.(s,"received subscription request for",u,"at",Ir),!h){let Ae;h=new Promise(et=>{de.debug?.("Waiting for subscription to database "+u),Ae=et}),h.ready=Ae,Fa.set(u,h)}if(r.name)te=gr().subscribe(r.name),te.then(async Ae=>{ue=Ae;for await(let et of ue){let Lt=et.value;if(!(Lt?.replicates===!0||Lt?.replicates?.receives||Lt?.subscriptions?.some(pr=>(pr.database||pr.schema)===u&&pr.publish!==!1))){fe=!0,e.send((0,je.encode)([ld])),dn(1008,`Unauthorized database subscription to ${u}`);return}}},Ae=>{de.error?.(s,"Error subscribing to HDB nodes",Ae)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,je.encode)([ld])),dn(1008,`Unauthorized database subscription to ${u}`);return}if(un&&(de.debug?.(s,"stopping previous subscription",u),un.emit("close")),Ir.length===0)return;let ie=Ir[0],J=a(Ae=>{if(Ae&&(ie.replicateByDefault?!ie.tables.includes(Ae.tableName):ie.tables.includes(Ae.tableName)))return{table:Ae}},"tableToTableEntry"),le={txnTime:0},ye,Re,Be=1/0,it,Cr=a((Ae,et)=>{if(Ae.type==="end_txn"){le.txnTime&&(o[i]!==66&&de.error?.("Invalid encoding of message"),lu(9),lu(vg),z(it=et),qr()),i=c,le.txnTime=0;return}let Lt=Ae.nodeId,pr=Ae.tableId,qt=Re[pr];if(!qt&&(qt=Re[pr]=J(h.tableById[pr]),!qt))return de.debug?.("Not subscribed to table",pr);let $r=qt.table,Tc=$r.primaryStore,Mt=Tc.encoder;(Ae.extendedType&zm||!Mt.typedStructs)&&(Mt._mergeStructures(Mt.getStructures()),Mt.typedStructs&&(Mt.lastTypedStructuresLength=Mt.typedStructs.length));let Zh=ye[Lt];if(!(Zh&&Zh.startTime<et&&(!Zh.endTime||Zh.endTime>et)))return Lg&&de.trace?.(s,"skipping replication update",Ae.recordId,"to:",E,"from:",Lt,"subscribed:",ye),tD();Lg&&de.trace?.(s,"sending replication update",Ae.recordId,"to:",E,"from:",Lt,"subscribed:",ye);let HA=Ae.version;le.txnTime!==HA&&(le.txnTime&&(Lg&&de.trace?.(s,"new txn time, sending queued txn",le.txnTime),o[i]!==66&&de.error?.("Invalid encoding of message"),qr()),le.txnTime=HA,i=c,z(HA));let Ac=Ae.residencyId,kA=au(Ac,$r),em;if(kA&&!kA.includes(E)){let Rc=au(Ae.previousResidencyId,$r);if(Rc&&!Rc.includes(E)&&(Ae.type==="put"||Ae.type==="patch")||$r.getResidencyById)return tD();let Af=Ae.recordId;de.trace?.(s,"sending invalidation",Af,E,"from",Lt);let la=0;Ac&&(la|=xc),Ae.previousResidencyId&&(la|=Bc);let Ws,fn=null;for(let tm in $r.indices){if(!fn){if(Ws=Ae.getValue(Tc,!0),!Ws)break;fn={}}fn[tm]=Ws[tm]}em=bu(Ae.version,pr,Af,null,Lt,Ae.user,Ae.type==="put"||Ae.type==="patch"?"invalidate":Ae.type,Mt.encode(fn),la,Ac,Ae.previousResidencyId,Ae.expiresAt)}function tD(){de.trace?.(s,"skipping audit record",Ae.recordId),K||(K=setTimeout(()=>{K=null,(it||0)+bF/2<Be&&(Lg&&de.trace?.(s,"sending skipped sequence update",Be),e.send((0,je.encode)([AF,Be])))},bF).unref())}a(tD,"skipAuditRecord");let FA=Mt.typedStructs,GA=Mt.structures;if((FA?.length!=qt.typed_length||GA?.length!=qt.structure_length)&&(qt.typed_length=FA?.length,qt.structure_length=GA.length,de.debug?.(s,"send table struct",qt.typed_length,qt.structure_length),qt.sentName||(qt.sentName=!0),e.send((0,je.encode)([aN,{typedStructs:FA,structures:GA,attributes:$r.attributes,schemaDefined:$r.schemaDefined},pr,qt.table.tableName]))),Ac&&!Dt[Ac]&&(e.send((0,je.encode)([SF,kA,Ac])),Dt[Ac]=!0),em)lu(em.length),uu(em);else{let Rc=Ae.encoded;Ae.extendedType&$n&&IR(()=>Ae.getValue(Tc),async la=>{let Ws=Bm(la);try{let fn;me++;for await(let tm of la.stream()){if(fn&&(de.debug?.("Sending blob chunk",Ws,"length",fn.length),e.send((0,je.encode)([Dg,{fileId:Ws,size:la.size},fn]))),fn=tm,fe)return;e._socket.writableNeedDrain&&(de.debug?.("draining",Ws),await new Promise(SJ=>e._socket.once("drain",SJ)),de.debug?.("drained",Ws))}de.debug?.("Sending final blob chunk",Ws,"length",fn.length),e.send((0,je.encode)([Dg,{fileId:Ws,size:la.size,finished:!0},fn]))}catch(fn){de.debug?.("Error sending blob",fn),e.send((0,je.encode)([Dg,{fileId:Ws,finished:!0,error:fn.toString()},Buffer.alloc(0)]))}finally{me--,me<Qh&&Xt?.()}});let Af=Rc[0]===66?8:0;lu(Rc.length-Af),uu(Rc,Af),de.trace?.("wrote record",Ae.recordId,"length:",Rc.length)}},"sendAuditRecord"),qr=a(()=>{c-i>8?(e.send(o.subarray(i,c)),de.debug?.(s,"Sent message, size:",c-i)):de.debug?.(s,"skipping empty transaction")},"sendQueuedData");un=new pN.EventEmitter,un.once("close",()=>{fe=!0,ue?.end()});for(let{startTime:Ae}of Ir)Ae<Be&&(Be=Ae);(te||Promise.resolve()).then(async()=>{h=await h,d=h.auditStore,Re=h.tableById.map(J),ye=[];for(let{name:et,startTime:Lt,endTime:pr}of Ir){let qt=Ag(et,d);de.debug?.("subscription to",et,"using local id",qt,"starting",Lt),ye[qt]={startTime:Lt,endTime:pr}}aa(u),gs||(gs=ml(et=>{et.databaseName===u&&aa(u)}),Bn=mp(et=>{et===u&&(e.send((0,je.encode)([ld])),dn())}),e.on("close",()=>{gs?.remove(),Bn?.remove()})),e.send((0,je.encode)([gF,ap(h.auditStore),Ir.map(({name:et})=>et)]));let Ae=!0;do{isFinite(Be)||(de.warn?.("Invalid sequence id "+Be),dn(1008,"Invalid sequence id"+Be));let et;if(Ae&&!fe&&(Ae=!1,!(EN(d)<=Be)&&(wF.default.get(x.REPLICATION_COPYTABLESTOCATCHUP)??Gie)&&server.nodes[0]?.name===E)){de.info?.("Replicating all tables to",E);let pr=Be,qt=xg(d);for(let $r in S){if(!J($r))continue;let Tc=S[$r];for(let Mt of Tc.primaryStore.getRange({snapshot:!1})){if(fe)return;Mt.localTime>=Be&&(de.trace?.(s,"Copying record from",u,$r,Mt.key,Mt.localTime),pr=Math.max(Mt.localTime,pr),et=!0,yr()[Mg]=1,Cr({recordId:Mt.key,tableId:Tc.tableId,type:"put",getValue(){return Mt.value},encoded:Tc.primaryStore.getBinary(Mt.key),version:Mt.version,residencyId:Mt.residencyId,nodeId:qt,extendedType:Mt.metadataFlags},Mt.localTime))}}Be=pr}for(let{key:Lt,value:pr}of d.getRange({start:Be||1,exclusiveStart:!0,snapshot:!1})){if(fe)return;let qt=Nt(pr);de.debug?.("sending audit record",new Date(Lt)),yr()[Mg]=Lt,Be=Lt,Cr(qt,Lt),e._socket.writableNeedDrain?await new Promise($r=>{de.debug?.(`Waiting for remote node ${E} to allow more commits ${e._socket.writableNeedDrain?"due to network backlog":"due to requested flow directive"}`),e._socket.once("drain",$r)}):me>Qh?await new Promise($r=>{Xt=$r}):await new Promise(setImmediate),un.startTime=Lt,et=!0}et&&Cr({type:"end_txn"},Be),yr()[Mg]=0,await UF(d)}while(!fe)}).catch(Ae=>{de.error?.(s,"Error handling subscription to node",Ae),dn(1008,"Error handling subscription to node")});break}}return}O.position=8;let w=!0,y,D;do{yr();let b=O.readInt();if(b===9&&O.getUint8(O.position)==vg){O.position++,R=D=O.readFloat64(),p[fN]=R,p[_N]=Date.now(),de.trace?.("received remote sequence update",R,u);break}let U=O.position,L=Nt(T,U,U+b),P=su[L.tableId];P||de.error?.(`No table found with an id of ${L.tableId}`);let H;L.residencyId&&(H=mf[L.residencyId],de.trace?.(s,"received residency list",H,L.type,L.recordId));try{wR(()=>{y={table:P.name,id:L.recordId,type:L.type,nodeId:ou.get(L.nodeId),residencyList:H,timestamp:L.version,value:L.getValue(P),user:L.user,beginTxn:w,expiresAt:L.expiresAt}},$=>{let j=Bm($),Q=Te.get(j);de.debug?.("Received transaction with blob",j,"has stream",!!Q,"ended",!!Q?.writableEnded),Q?Q.writableEnded&&Te.delete(j):(Q=new uN.PassThrough,Te.set(j,Q)),Q.connectedToBlob=!0,Q.lastChunk=Date.now(),$.size===void 0&&Q.expectedSize&&($.size=Q.expectedSize);let q=createBlob(Q,$),ue=q.save({primaryStore:h.auditStore});return ue&&(ue.blobId=j,Ce.push(ue),ue.finally(()=>{de.debug?.(`Finished receiving blob stream ${j}`),Ce.splice(Ce.indexOf(ue),1)})),q})}catch($){throw $.message+="typed structures for current decoder"+JSON.stringify(P.decoder.typedStructs),$}w=!1,de.trace?.(s,"received replication message",L.type,"id",y.id,"version",new Date(L.version),"nodeId",y.nodeId),p[fN]=L.version,p[_N]=Date.now(),h.send(y),O.position=U+b}while(O.position<T.byteLength);Ef++,sr(T.byteLength,"bytes-received",`${E}.${u}.${y?.table||"unknown_table"}`,"replication","ingest"),Ef>jh&&!De&&(De=!0,e.pause(),de.debug?.(`Commit backlog causing replication back-pressure, requesting that ${E} pause replication`)),h.send({type:"end_txn",localTime:R,remoteNodeIds:A,async onCommit(){if(y){let b=Date.now()-y.timestamp;sr(b,"replication-latency",E+"."+u+"."+y.table,y.type,"ingest")}Ef--,De&&(De=!1,e.resume(),de.debug?.(`Replication resuming ${E}`)),Ce.length>0&&await Promise.all(Ce),de.trace?.("All blobs finished"),!N&&D&&(de.trace?.(s,"queuing confirmation of a commit at",D),setTimeout(()=>{e.send((0,je.encode)([RF,N])),de.trace?.(s,"sent confirmation of a commit at",N),N=null},qie)),N=D,de.debug?.("last sequence committed",new Date(D),u)}})}catch(O){de.error?.(s,"Error handling incoming replication message",O)}}),e.on("ping",ct),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-F,dl({name:E,database:u,url:t.url,latency:t.connection.latency})),F=null}),e.on("close",(T,O)=>{clearInterval(v),clearTimeout(k),clearInterval(re),un&&un.emit("close"),gf&&gf.end();for(let[w,{reject:y}]of g)y(new Error(`Connection closed ${O?.toString()} ${T}`));de.debug?.(s,"closed",T,O?.toString())});function Sf(){}a(Sf,"recordRemoteNodeSequence");function dn(T,O){e.isFinished=!0,e.close(T,O)}a(dn,"close");function Gr(){if(_||(_=!0,t.connection?.on("subscriptions-updated",Gr)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let T=new Map;try{for(let y of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let D of y.value.nodes||[])D.lastTxnTime>(T.get(D.id)??0)&&T.set(D.id,D.lastTxnTime)}catch(y){if(!y.message.includes("Can not re"))throw y}let O=t.connection?.nodeSubscriptions?.[0];A=[];let w=t.connection?.nodeSubscriptions.map((y,D)=>{let b=[],{replicateByDefault:U}=y;if(y.subscriptions){for(let $ of y.subscriptions)if($.subscribe&&($.schema||$.database)===u){let j=$.table;S?.[j]?.replicate!==!1&&b.push(j)}U=!1}else for(let $ in S)(U?S[$].replicate===!1:S[$].replicate)&&b.push($);let L=d&&Ag(y.name,d),P=h?.dbisDB?.get([Symbol.for("seq"),L])??1,H=Math.max(P?.seqId??1,(typeof y.start_time=="string"?new Date(y.start_time).getTime():y.start_time)??1);if(de.debug?.("Starting time recorded in db",y.name,L,u,P?.seqId,"start time:",H,new Date(H)),O!==y){let $=d&&Ag(O.name,d),j=h?.dbisDB?.get([Symbol.for("seq"),$])??1;for(let Q of j?.nodes||[])Q.name===y.name&&(H=Q.seqId,de.debug?.("Using sequence id from proxy node",O.name,H))}return A.push(L),T.get(L)>H&&(H=T.get(L),de.debug?.("Updating start time from more recent txn recorded",O.name,H)),{name:y.name,replicateByDefault:U,tables:b,startTime:H,endTime:y.end_time}});if(w)if(de.debug?.(s,"sending subscription request",w,h?.dbisDB?.path),clearTimeout(Z),w.length>0)e.send((0,je.encode)([mF,w]));else{let y=a(()=>{let D=performance.now();Z=setTimeout(()=>{se<=D?dn(1008,"No nodes to subscribe to"):y()},ae)},"schedule_close");y()}}a(Gr,"sendSubscriptionRequestUpdate");function au(T,O){if(!T)return;let w=BA[T];return w||(w=O.getResidencyRecord(T),BA[T]=w),w}a(au,"getResidence");function cu(T){return!(ka&&ka!="*"&&!ka[T]&&!ka.includes?.(T)&&!ka.some?.(O=>O.name===T))}a(cu,"checkDatabaseAccess");function oa(T){if(h=h||f.get(T),!cu(T))throw new Error(`Access to database "${T}" is not permitted`);h||de.warn?.(`No database named "${T}" was declared and registered`),d=h?.auditStore,S||(S=Je()?.[T]);let O=Xe();if(O===E)throw O?new Error("Should not connect to self",O):new Error("Node name not defined");return Xh(O,T),!0}a(oa,"setDatabase");function Xh(T,O){let w=Je()?.[O],y=[];for(let D in w){let b=w[D];y.push({table:D,schemaDefined:b.schemaDefined,attributes:b.attributes.map(U=>({name:U.name,type:U.type,isPrimaryKey:U.isPrimaryKey}))})}de.trace?.("Sending database info for node",T,"database name",O),e.send((0,je.encode)([EF,T,O,y]))}a(Xh,"sendNodeDBName");function aa(T){let O=Je()?.[T],w=[];for(let y in O){if(Ir&&!Ir.some(b=>b.replicateByDefault?!b.tables.includes(y):b.tables.includes(y)))continue;let D=O[y];w.push({table:y,schemaDefined:D.schemaDefined,attributes:D.attributes.map(b=>({name:b.name,type:b.type,isPrimaryKey:b.isPrimaryKey}))})}e.send((0,je.encode)([yF,w,T]))}a(aa,"sendDBSchema"),re=setInterval(()=>{for(let[T,O]of Te)O.lastChunk+3e4<Date.now()&&(de.warn?.(`Timeout waiting for blob stream to finish ${T} from ${E}`),Te.delete(T),O.end())},3e4).unref();let ca=1,Tf=[];return{end(){gf&&gf.end(),un&&un.emit("close")},getRecord(T){let O=ca++;return new Promise((w,y)=>{let D=[TF,O,T.table.tableId,T.id];Tf[T.table.tableId]||(D.push(T.table.tableName),Tf[T.table.tableId]=!0),e.send((0,je.encode)(D)),g.set(O,{tableId:T.table.tableId,key:T.id,resolve(b){let{table:U,entry:L}=T;w(b),b&&U._recordRelocate(L,b)},reject:y})})},sendOperation(T){let O=ca++;return T.requestId=O,e.send((0,je.encode)([dN,T])),new Promise((w,y)=>{g.set(O,{resolve:w,reject:y})})}};function lu(T){m(5),T<128?o[c++]=T:T<16384?(l.setUint16(c,T|32768),c+=2):T<1056964608?(l.setUint32(c,T|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,T),c+=5)}function uu(T,O=0,w=T.length){let y=w-O;m(y),T.copy(o,c,O,w),c+=y}function z(T){m(8),l.setFloat64(c,T),c+=8}function m(T){if(T+16>o.length-c){let O=Buffer.allocUnsafeSlow(c+T-i+65536>>10<<11);o.copy(O,0,i,c),c=c-i,i=0,o=O,l=new DataView(o.buffer,0,o.length)}}}function lN(e,t){let r=e.database??"data";if(r!=="data"&&!$e[r]){de.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?(de.debug?.("(Re)creating",e),lt({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var wF,je,IF,CF,de,pN,PF,DF,_l,LF,uN,mF,EF,gF,ld,SF,aN,TF,Cg,dN,Pg,AF,RF,yF,Dg,MF,fN,_N,Mg,Gie,hN,Fa,Lg,bF,qie,OF,cN,NF,pp,mN=be(()=>{Pe();ho();KO();gN();ts();wF=M(ce());B();Ou();je=require("msgpackr"),IF=require("ws"),CF=require("worker_threads"),de=M(Ci());dp();pN=require("events"),PF=M(rs()),DF=M(require("node:tls"));ul();_l=M(require("node:process")),LF=require("node:net");$i();As();uN=require("node:stream"),mF=129,EF=140,gF=141,ld=142,SF=130,aN=132,TF=133,Cg=134,dN=136,Pg=137,AF=143,RF=144,yF=145,Dg=146,MF=0,fN=1,_N=2,Mg=3,Gie=_l.env.HDB_LEADER_URL||_l.argv.includes("--HDB_LEADER_URL"),hN=new Map,Fa=new Map,Lg=!0,bF=300,qie=2,OF=3e4;a(Ug,"createWebSocket");NF=1e3,pp=class extends pN.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??li(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=NF;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;de.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${_l.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),de[this.isConnected?"info":"warn"]?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=NF,dl({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=hp(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"?(de.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"?de.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`):de.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(id({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();de.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(hp,"replicateOverWS");a(lN,"ensureTableIfChanged")});var Po={};ve(Po,{clearThisNodeName:()=>Qie,disableReplication:()=>Yie,enabled_databases:()=>ka,forEachReplicatedDatabase:()=>Ma,getThisNodeId:()=>xg,getThisNodeName:()=>Xe,getThisNodeUrl:()=>va,hostnameToUrl:()=>Fg,lastTimeInAuditStore:()=>cp,monitorNodeCAs:()=>$F,replicateOperation:()=>Xie,replication_certificate_authorities:()=>pl,sendOperationToNode:()=>gp,servers:()=>Vie,setReplicator:()=>KF,start:()=>Kie,startOnMainThread:()=>zO,subscribeToNode:()=>sd,unsubscribeFromNode:()=>Og,urlToNodeName:()=>li});function Kie(e){if(e.port||(e.port=Is.default.get(x.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=Is.default.get(x.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 up(e))t.set(li(n.url),n);Wie(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(),hp(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&ar.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&&ar.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=gr().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)){ar.warn("Revoked certificate used in attempt to connect to node",c.name,"certificate serial number",n.peerCertificate.serialNumber);return}else n.user=c;else ar.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:ar.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=kg.createSecureContext(l)}catch(c){ar.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),$F(s),Is.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function $F(e){let t=0;rd(r=>{r?.ca&&(pl.add(r.ca),pl.size!==t&&(t=pl.size,e?.()))})}function Yie(e=!0){qF=e}function Wie(e){qF||(Je(),ka=e.databases,Ma(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||Fa;for(let[s,i]of Ep){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];KF(r,s,e),hN.get(s)?.forEach(i=>i(s))}}))}function KF(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 VF extends Vr{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||Fa,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(ar.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new kn,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 _=zie(p,VF.subscription,e);_?.isConnected&&!u.has(_)&&(!f||_.latency<f.latency)&&(f=_)}if(!f)throw l||new FF.ServerError("No connection to any other nodes are available",502);let d={requestId:$ie++,table:t,entry:i,id:i.key};u.add(f);try{return await f.getRecord(d)}catch(p){if(f.isConnected)throw p;ar.warn("Error in load from node",Hg,p),l||(l=p)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function YF(e,t,r,n,s){let i=Ep.get(e);i||Ep.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new pp(e,t,r,n,s)),o.connect(),o.once("finished",()=>i.delete(r)),o}function zie(e,t,r){let n=xF.get(e)?.get(r);if(n)return n;let s=gr().primaryStore.get(e);return s?.url&&(n=YF(s.url,t,r,e,s.authorization),xF.set(e,Ep.get(s.url))),n}async function gp(e,t,r){r||(r={}),r.serverName=e.name;let n=await Ug(e.url,r),s=hp(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{ar.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function sd(e){try{GF.isMainThread&&ar.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=Fa.get(e.database);if(!t){let n;t=new Promise(s=>{ar.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,Fa.set(e.database,t)}let r=YF(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=>lp(n,e.database)),e.replicateByDefault)}catch(t){ar.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Og({name:e,url:t,database:r}){ar.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(gr().primaryStore.getRange({})));let n=Ep.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function jie(){if(SN!==void 0)return SN;let e=Is.default.get(x.OPERATIONSAPI_TLS_CERTIFICATE)||Is.default.get(x.TLS_CERTIFICATE);if(e)return SN=new HF.X509Certificate((0,kF.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function Xe(){return Hg||(Hg=Is.default.get("replication_hostname")??li(Is.default.get("replication_url"))??jie()??BF("operationsapi_network_secureport")??BF("operationsapi_network_port")??"127.0.0.1")}function Qie(){Hg=void 0}function BF(e){let t=Is.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function Bg(e){let t=Is.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function xg(e){return ap(e)?.[Xe()]}function va(){let e=Is.default.get("replication_url");return e||Fg(Xe())}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 li(e){if(e)return new URL(e).hostname}function Ma(e,t){for(let n of Object.getOwnPropertyNames($e))r(n);return mp(n=>{r(n)}),ml((n,s)=>{r(n.databaseName)});function r(n){let s=$e[n];ar.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):Jie(n)&&t(s,n,!1)}a(r,"forDatabase")}function Jie(e){let t=$e[e];for(let r in t)if(t[r].replicate)return!0}function cp(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function Xie(e){let t={message:""};if(e.replicated){e.replicated=!1,ar.trace?.("Replicating operation",e.operation,"to nodes",We.nodes.map(n=>n.name));let r=await Promise.allSettled(We.nodes.map(n=>gp(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 Is,ar,HF,kF,kg,FF,GF,qF,$ie,Vie,pl,ka,Ep,xF,SN,Hg,ts=be(()=>{Pe();ga();_u();mN();Kr();Is=M(ce()),ar=M(Y()),HF=require("crypto"),kF=require("fs");dp();ul();B();KO();kg=M(require("node:tls")),FF=M(pe()),GF=require("worker_threads"),$ie=1,Vie=[],pl=Is.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1?new Set(kg.rootCertificates):new Set;a(Kie,"start");a($F,"monitorNodeCAs");a(Yie,"disableReplication");a(Wie,"assignReplicationSource");a(KF,"setReplicator");Ep=new Map;a(YF,"getConnection");xF=new Map;a(zie,"getConnectionByName");a(gp,"sendOperationToNode");a(sd,"subscribeToNode");a(Og,"unsubscribeFromNode");a(jie,"getCommonNameFromCert");a(Xe,"getThisNodeName");a(Qie,"clearThisNodeName");Object.defineProperty(We,"hostname",{get(){return Xe()}});a(BF,"getHostFromListeningPort");a(Bg,"getPortFromListeningPort");a(xg,"getThisNodeId");We.replication={getThisNodeId:xg,exportIdMapping:ap};a(va,"getThisNodeUrl");a(Fg,"hostnameToUrl");a(li,"urlToNodeName");a(Ma,"forEachReplicatedDatabase");a(Jie,"hasExplicitlyReplicatedTable");a(cp,"lastTimeInAuditStore");a(Xie,"replicateOperation")});var Vg=I((lDe,JF)=>{"use strict";var ud=nE(),dd=ok(),Zie=Y(),eoe=require("uuid").v4,cDe=require("clone"),qg=yo(),fd=(B(),C(G)),toe=require("util"),Ga=Wn(),{handleHDBError:wn,hdb_errors:roe}=pe(),{HDB_ERROR_MSGS:Gg,HTTP_STATUS_CODES:In}=roe,{SchemaEventMsg:$g}=si(),WF=ir(),{getDatabases:noe}=(Pe(),C(rt)),{transformReq:_d}=oe(),{replicateOperation:zF}=(ts(),C(Po));JF.exports={createSchema:soe,createSchemaStructure:jF,createTable:ioe,createTableStructure:QF,createAttribute:uoe,dropSchema:ooe,dropTable:aoe,dropAttribute:coe,getBackup:doe};async function soe(e){let t=await jF(e);return qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema)),t}a(soe,"createSchema");async function jF(e){let t=ud.schema_object(e);if(t)throw wn(t,t.message,In.BAD_REQUEST,void 0,void 0,!0);if(_d(e),!await dd.checkSchemaExists(e.schema))throw wn(new Error,Gg.SCHEMA_EXISTS_ERR(e.schema),In.BAD_REQUEST,fd.LOG_LEVELS.ERROR,Gg.SCHEMA_EXISTS_ERR(e.schema),!0);return await Ga.createSchema(e),`database '${e.schema}' successfully created`}a(jF,"createSchemaStructure");async function ioe(e){return _d(e),e.hash_attribute=e.primary_key??e.hash_attribute,await QF(e)}a(ioe,"createTable");async function QF(e){let t=ud.create_table_object(e);if(t)throw wn(t,t.message,In.BAD_REQUEST,void 0,void 0,!0);if(ud.validateTableResidence(e.residence),!await dd.checkSchemaTableExists(e.schema,e.table))throw wn(new Error,Gg.TABLE_EXISTS_ERR(e.schema,e.table),In.BAD_REQUEST,fd.LOG_LEVELS.ERROR,Gg.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:eoe(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await Ga.createTable(n,e);else throw wn(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",In.BAD_REQUEST);else await Ga.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(QF,"createTableStructure");async function ooe(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=ud.schema_object(e),n=t??r;if(n)throw wn(n,n.message,In.BAD_REQUEST,void 0,void 0,!0);_d(e);let s=await dd.checkSchemaExists(e.schema);if(s)throw wn(new Error,s,In.NOT_FOUND,fd.LOG_LEVELS.ERROR,s,!0);let i=await dd.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);await Ga.dropSchema(e),qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema)),await WF.purgeSchemaTableStreams(e.schema,o);let c=await zF(e);return c.message=`successfully deleted '${e.schema}'`,c}a(ooe,"dropSchema");async function aoe(e){let t=ud.table_object(e);if(t)throw wn(t,t.message,In.BAD_REQUEST,void 0,void 0,!0);_d(e);let r=await dd.checkSchemaTableExists(e.schema,e.table);if(r)throw wn(new Error,r,In.NOT_FOUND,fd.LOG_LEVELS.ERROR,r,!0);await Ga.dropTable(e),await WF.purgeTableStream(e.schema,e.table);let n=await zF(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(aoe,"dropTable");async function coe(e){let t=ud.attribute_object(e);if(t)throw wn(t,t.message,In.BAD_REQUEST,void 0,void 0,!0);_d(e);let r=await dd.checkSchemaTableExists(e.schema,e.table);if(r)throw wn(new Error,r,In.NOT_FOUND,fd.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw wn(new Error,"You cannot drop a hash attribute",In.BAD_REQUEST,void 0,void 0,!0);if(fd.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw wn(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,In.BAD_REQUEST,void 0,void 0,!0);try{return await Ga.dropAttribute(e),loe(e),qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw Zie.error(`Got an error deleting attribute ${toe.inspect(e)}.`),n}}a(coe,"dropAttribute");function loe(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(loe,"dropAttributeFromGlobal");async function uoe(e){_d(e);let t=noe()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw wn(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,In.BAD_REQUEST,void 0,void 0,!0);return await Ga.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(uoe,"createAttribute");function doe(e){return Ga.getBackup(e)}a(doe,"getBackup")});var ZF=I((dDe,XF)=>{"use strict";var{OPERATIONS_ENUM:foe}=(B(),C(G)),TN=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=foe.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};XF.exports=TN});var AN=I((pDe,sG)=>{"use strict";var _oe=Wn(),_De=ZF(),Kg=oe(),Yg=(B(),C(G)),poe=ce(),{handleHDBError:eG,hdb_errors:hoe}=pe(),{HDB_ERROR_MSGS:tG,HTTP_STATUS_CODES:rG}=hoe,moe=Object.values(Yg.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),nG="To use this operation audit log must be enabled in harperdb-config.yaml";sG.exports=Eoe;async function Eoe(e){if(Kg.isEmpty(e.schema))throw new Error(tG.SCHEMA_REQUIRED_ERR);if(Kg.isEmpty(e.table))throw new Error(tG.TABLE_REQUIRED_ERR);if(!poe.get(Yg.CONFIG_PARAMS.LOGGING_AUDITLOG))throw eG(new Error,nG,rG.BAD_REQUEST,Yg.LOG_LEVELS.ERROR,nG,!0);let t=Kg.checkSchemaTableExist(e.schema,e.table);if(t)throw eG(new Error,t,rG.NOT_FOUND,Yg.LOG_LEVELS.ERROR,t,!0);if(!Kg.isEmpty(e.search_type)&&moe.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await _oe.readAuditLog(e)}a(Eoe,"readAuditLog")});var oG=I((mDe,iG)=>{"use strict";var{OPERATIONS_ENUM:goe}=(B(),C(G)),RN=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=goe.GET_BACKUP,this.schema=t,this.table=r}};iG.exports=RN});var lG=I((TDe,cG)=>{"use strict";var Soe=Wn(),gDe=oG(),yN=oe(),Toe=(B(),C(G)),SDe=ce(),{handleHDBError:Aoe,hdb_errors:Roe}=pe(),{HDB_ERROR_MSGS:aG,HTTP_STATUS_CODES:yoe}=Roe;cG.exports=boe;async function boe(e){if(yN.isEmpty(e.schema))throw new Error(aG.SCHEMA_REQUIRED_ERR);if(yN.isEmpty(e.table))throw new Error(aG.TABLE_REQUIRED_ERR);let t=yN.checkSchemaTableExist(e.schema,e.table);if(t)throw Aoe(new Error,t,yoe.NOT_FOUND,Toe.LOG_LEVELS.ERROR,t,!0);return await Soe.getBackup(read_audit_log_object)}a(boe,"getBackup")});var _G=I((RDe,fG)=>{"use strict";var Ooe=ce(),qa=require("joi"),Noe=ut(),uG=require("moment"),woe=require("fs-extra"),bN=require("path"),Ioe=require("lodash"),Sp=(B(),C(G)),{LOG_LEVELS:El}=(B(),C(G)),Coe="YYYY-MM-DD hh:mm:ss",Poe=bN.resolve(__dirname,"../logs");fG.exports=function(e){return Noe.validateBySchema(e,Doe)};var Doe=qa.object({from:qa.custom(dG),until:qa.custom(dG),level:qa.valid(El.NOTIFY,El.FATAL,El.ERROR,El.WARN,El.INFO,El.DEBUG,El.TRACE),order:qa.valid("asc","desc"),limit:qa.number().min(1),start:qa.number().min(0),log_name:qa.custom(Loe)});function dG(e,t){if(uG(e,uG.ISO_8601).format(Coe)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(dG,"validateDatetime");function Loe(e,t){if(Ioe.invert(Sp.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=Ooe.get(Sp.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Sp.LOG_NAMES.HDB:e,i=s===Sp.LOG_NAMES.INSTALL?bN.join(Poe,Sp.LOG_NAMES.INSTALL):bN.join(n,s);return woe.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Loe,"validateReadLogPath")});var NN=I((bDe,hG)=>{"use strict";var Wg=(B(),C(G)),Moe=Y(),voe=ce(),Uoe=_G(),ON=require("path"),pG=require("fs-extra"),{once:xoe}=require("events"),{handleHDBError:Boe,hdb_errors:Hoe}=pe(),{PACKAGE_ROOT:koe}=nt(),Foe=ON.join(koe,"logs"),Goe=1e3,qoe=200;hG.exports=$oe;async function $oe(e){let t=Uoe(e);if(t)throw Boe(t,t.message,Hoe.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=voe.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?ON.join(Foe,Wg.LOG_NAMES.INSTALL):ON.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?Goe: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(pG.statSync(s).size-(h+5)*qoe,0));let g=pG.createReadStream(s,{start:S});g.on("error",k=>{Moe.error(k)});let A=0,E=[],R="",N;g.on("data",k=>{let F=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;k=R+k;let K=0,re;for(;(re=F.exec(k))&&!g.destroyed;){N&&(N.message=k.slice(K,re.index),v(N));let[ae,Z,se]=re,W=se.split("] ["),he=W[0],Te=W[1];W.splice(0,2),N={timestamp:Z,thread:he,level:Te,tags:W,message:""},K=re.index+ae.length}R=k.slice(K)}),g.on("end",k=>{g.destroyed||N&&(N.message=R.trim(),v(N))}),g.resume();function v(k){let F,K,re;switch(!0){case(i&&c&&u):F=new Date(k.timestamp),K=new Date(l),re=new Date(f),k.level===o&&F>=K&&F<=re&&A<_?A++:k.level===o&&F>=K&&F<=re&&($a(k,p,E),A++,A===h&&g.destroy());break;case(i&&c):F=new Date(k.timestamp),K=new Date(l),k.level===o&&F>=K&&A<_?A++:k.level===o&&F>=K&&($a(k,p,E),A++,A===h&&g.destroy());break;case(i&&u):F=new Date(k.timestamp),re=new Date(f),k.level===o&&F<=re&&A<_?A++:k.level===o&&F<=re&&($a(k,p,E),A++,A===h&&g.destroy());break;case(c&&u):F=new Date(k.timestamp),K=new Date(l),re=new Date(f),F>=K&&F<=re&&A<_?A++:F>=K&&F<=re&&($a(k,p,E),A++,A===h&&g.destroy());break;case i:k.level===o&&A<_?A++:k.level===o&&($a(k,p,E),A++,A===h&&g.destroy());break;case c:F=new Date(k.timestamp),K=new Date(l),F>=K&&A<_?A++:F>=K&&A>=_&&($a(k,p,E),A++,A===h&&g.destroy());break;case u:F=new Date(k.timestamp),re=new Date(f),F<=re&&A<_?A++:F<=re&&A>=_&&($a(k,p,E),A++,A===h&&g.destroy());break;default:A<_?A++:($a(k,p,E),A++,A===h&&g.destroy())}}return a(v,"onLogMessage"),await xoe(g,"close"),E}a($oe,"readLog");function $a(e,t,r){t==="desc"?Voe(e,r):t==="asc"?Koe(e,r):r.push(e)}a($a,"pushLineToResult");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,"insertDescending");function Koe(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(Koe,"insertAscending")});var zg=I((PDe,SG)=>{"use strict";var wN=require("joi"),{string:pd,boolean:mG,date:Yoe}=wN.types(),Woe=ut(),{validateSchemaExists:NDe,validateTableExists:wDe,validateSchemaName:IDe}=vi(),zoe=(B(),C(G)),joe=St(),EG=ce();EG.initSync();var CDe=pd.invalid(EG.get(zoe.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(joe.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),gG={operation:pd.valid("add_node","update_node","set_node_replication"),node_name:pd.optional(),subscriptions:wN.array().items({table:pd.optional(),schema:pd.optional(),database:pd.optional(),subscribe:mG.required(),publish:mG.required().custom(Joe),start_time:Yoe.iso()})};function Qoe(e){return Woe.validateBySchema(e,wN.object(gG))}a(Qoe,"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");SG.exports={addUpdateNodeValidator:Qoe,validation_schema:gG}});var hd=I((LDe,TG)=>{"use strict";var IN=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},CN=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};TG.exports={Node:IN,NodeSubscription:CN}});var RG=I((vDe,AG)=>{"use strict";var Xoe=(B(),C(G)).OPERATIONS_ENUM,PN=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Xoe.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};AG.exports=PN});var Tp=I((xDe,yG)=>{"use strict";var DN=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},LN=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)}};yG.exports={RemotePayloadObject:DN,RemotePayloadSubscription:LN}});var OG=I((HDe,bG)=>{"use strict";var MN=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}};bG.exports=MN});var wG=I((VDe,NG)=>{"use strict";var Zoe=OG(),FDe=vt(),GDe=dt(),eae=Y(),{getSchemaPath:qDe,getTransactionAuditStorePath:$De}=Et(),{getDatabases:tae}=(Pe(),C(rt));NG.exports=rae;async function rae(e){let t=new Zoe;try{let r=tae()[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){eae.warn(`unable to stat table dbi due to ${r}`)}return t}a(rae,"lmdbGetTableSize")});var CG=I((YDe,IG)=>{"use strict";var vN=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}};IG.exports=vN});var Do=I((XDe,MG)=>{"use strict";var nae=require("fs-extra"),sae=require("path"),Zr=require("systeminformation"),Va=Y(),PG=ir(),zDe=St(),md=(B(),C(G)),iae=wG(),oae=Ao(),{getThreadInfo:DG}=tt(),Ap=ce();Ap.initSync();var aae=CG(),{openEnvironment:jDe}=dt(),{getSchemaPath:QDe}=Et(),{database:JDe,databases:UN}=(Pe(),C(rt)),jg;MG.exports={getHDBProcessInfo:kN,getNetworkInfo:GN,getDiskInfo:FN,getMemoryInfo:HN,getCPUInfo:BN,getTimeInfo:xN,getSystemInformation:qN,systemInformation:cae,getTableSize:$N,getMetrics:VN};function xN(){return Zr.time()}a(xN,"getTimeInfo");async function BN(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...f}=await Zr.cpu();f.cpu_speed=await Zr.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:p,raw_currentload_irq:_,raw_currentload_nice:h,raw_currentload_system:S,raw_currentload_user:g,cpus:A,...E}=await Zr.currentLoad();return E.cpus=[],A.forEach(R=>{let{raw_load:N,raw_load_idle:v,raw_load_irq:k,raw_load_nice:F,raw_load_system:K,raw_load_user:re,...ae}=R;E.cpus.push(ae)}),f.current_load=E,f}catch(e){return Va.error(`error in getCPUInfo: ${e}`),{}}}a(BN,"getCPUInfo");async function HN(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Zr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return Va.error(`error in getMemoryInfo: ${e}`),{}}}a(HN,"getMemoryInfo");async function kN(){let e={core:[],clustering:[]};try{let t=await Zr.processes(),r;try{r=Number.parseInt(await nae.readFile(sae.join(Ap.get(md.CONFIG_PARAMS.ROOTPATH),md.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===md.NODE_ERROR_CODES.ENOENT)Va.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 Va.error(`error in getHDBProcessInfo: ${t}`),e}}a(kN,"getHDBProcessInfo");async function FN(){let e={};try{if(!Ap.get(md.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Zr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Zr.fsStats();return e.read_write=u,e.size=await Zr.fsSize(),e}catch(t){return Va.error(`error in getDiskInfo: ${t}`),e}}a(FN,"getDiskInfo");async function GN(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return Ap.get(md.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Zr.networkInterfaceDefault(),e.latency=await Zr.inetChecksite("google.com"),(await Zr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:f,carrier_changes:d,...p}=n;e.interfaces.push(p)}),(await Zr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return Va.error(`error in getNetworkInfo: ${t}`),e}}a(GN,"getNetworkInfo");async function qN(){if(jg!==void 0)return jg;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Zr.osInfo();e=c;let l=await Zr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,jg=e,jg}catch(t){return Va.error(`error in getSystemInformation: ${t}`),e}}a(qN,"getSystemInformation");async function $N(){let e=[],t=await oae.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await iae(n));return e}a($N,"getTableSize");async function VN(){let e={};for(let t in UN){let r=e[t]={},n=r.tables={};for(let s in UN[t])try{let i=UN[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){Va.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(VN,"getMetrics");async function LG(){if(Ap.get(md.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await PG.getNATSReferences(),t=await PG.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(LG,"getNatsStreamInfo");async function cae(e){let t=new aae;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await qN(),t.time=xN(),t.cpu=await BN(),t.memory=await HN(),t.disk=await FN(),t.network=await GN(),t.harperdb_processes=await kN(),t.table_size=await $N(),t.metrics=await VN(),t.threads=await DG(),t.replication=await LG(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await qN();break;case"time":t.time=xN();break;case"cpu":t.cpu=await BN();break;case"memory":t.memory=await HN();break;case"disk":t.disk=await FN();break;case"network":t.network=await GN();break;case"harperdb_processes":t.harperdb_processes=await kN();break;case"table_size":t.table_size=await $N();break;case"database_metrics":case"metrics":t.metrics=await VN();break;case"threads":t.threads=await DG();break;case"replication":t.replication=await LG();break;default:break}return t}a(cae,"systemInformation")});var Lo=I((rLe,BG)=>{"use strict";var lae=yn(),KN=oe(),uae=require("util"),gl=(B(),C(G)),vG=ce();vG.initSync();var dae=bO(),UG=Wr(),{Node:eLe,NodeSubscription:tLe}=hd(),fae=Hu(),_ae=RG(),{RemotePayloadObject:pae,RemotePayloadSubscription:hae}=Tp(),{handleHDBError:mae,hdb_errors:Eae}=pe(),{HTTP_STATUS_CODES:gae,HDB_ERROR_MSGS:Sae}=Eae,Tae=ii(),Aae=Do(),{packageJson:Rae}=nt(),{getDatabases:yae}=(Pe(),C(rt)),bae=uae.promisify(dae.authorize),Oae=UG.searchByHash,Nae=UG.searchByValue;BG.exports={authHeaderToUser:wae,isEmpty:Iae,getNodeRecord:Cae,upsertNodeRecord:Pae,buildNodePayloads:Dae,checkClusteringEnabled:Lae,getAllNodeRecords:Mae,getSystemInfo:vae,reverseSubscription:xG};async function wae(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await bae(t,null),e}a(wae,"authHeaderToUser");function Iae(e){return e==null}a(Iae,"isEmpty");async function Cae(e){let t=new fae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Oae(t)}a(Cae,"getNodeRecord");async function Pae(e){let t=new _ae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return lae.upsert(t)}a(Pae,"upsertNodeRecord");function xG(e){if(KN.isEmpty(e.subscribe)||KN.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(xG,"reverseSubscription");function Dae(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=KN.getTableHashAttribute(l,u),{subscribe:d,publish:p}=xG(c),_=yae()[l]?.[u],h=new hae(l,u,f,p,d,c.start_time,_.schemaDefined?_.attributes:void 0);s.push(h)}return new pae(r,t,s,n)}a(Dae,"buildNodePayloads");function Lae(){if(!vG.get(gl.CONFIG_PARAMS.CLUSTERING_ENABLED))throw mae(new Error,Sae.CLUSTERING_NOT_ENABLED,gae.BAD_REQUEST,void 0,void 0,!0)}a(Lae,"checkClusteringEnabled");async function Mae(){let e=new Tae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Nae(e))}a(Mae,"getAllNodeRecords");async function vae(){let e=await Aae.getSystemInformation();return{hdb_version:Rae.version,node_version:e.node_version,platform:e.platform}}a(vae,"getSystemInfo")});var YN=I((sLe,KG)=>{"use strict";var Qg=ir(),HG=oe(),kG=St(),FG=(B(),C(G)),Jg=Y(),GG=Vg(),Uae=x_(),{RemotePayloadObject:xae}=Tp(),{handleHDBError:qG,hdb_errors:Bae}=pe(),{HTTP_STATUS_CODES:$G}=Bae,{NodeSubscription:VG}=hd();KG.exports=Hae;async function Hae(e,t){let r;try{r=await Qg.request(`${t}.${kG.REQUEST_SUFFIX}`,new xae(FG.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),Jg.trace("Response from remote describe all request:",r)}catch(o){Jg.error(`addNode received error from describe all request to remote node: ${o}`);let c=Qg.requestErrorHandler(o,"add_node",t);throw qG(new Error,c,$G.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===kG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw qG(new Error,o,$G.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===FG.SYSTEM_SCHEMA_NAME){await Qg.createLocalTableStream(l,c);let h=new VG(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let u=HG.doesSchemaExist(l),f=n[l]!==void 0,d=c?HG.doesTableExist(l,c):!0,p=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!f||!d&&!p){s.push(o);continue}if(!u&&f&&(Jg.trace(`addNode creating schema: ${l}`),await GG.createSchema({operation:"create_schema",schema:l})),!d&&p){Jg.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Uae(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await GG.createTable(h)}await Qg.createLocalTableStream(l,c);let _=new VG(l,c,o.publish,o.subscribe);_.start_time=o.start_time,i.push(_)}return{added:i,skipped:s}}a(Hae,"reviewSubscriptions")});var Tl={};ve(Tl,{addNodeBack:()=>$ae,removeNodeBack:()=>Vae,setNode:()=>qae});async function qae(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=li(t)):t=Fg(r);let n=(0,WG.validateBySchema)(e,Gae);if(n)throw(0,Mo.handleHDBError)(n,n.message,Fae.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new Mo.ClientError("url or hostname is required for remove_node operation");let _=r,h=gr(),S=await h.get(_);if(!S)throw new Mo.ClientError(_+" does not exist");try{await gp({url:S.url},{operation:$t.REMOVE_NODE_BACK,name:S?.subscriptions?.length>0?Xe():_},void 0)}catch(g){ns.warn(`Error removing node from target node ${_}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,g)}return await h.delete(_),`Successfully removed '${_}' from cluster`}if(!t)throw new Mo.ClientError("url required for this operation");let s=va();if(s==null)throw new Mo.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,Cs.getReplicationCert)();let _=await(0,Cs.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,Cs.createCsr)(),ns.info("Sending CSR to target node:",t)):_&&(c=_.certificate,ns.info("Sending CA named",_.name,"to target node",t))}let l={operation:$t.ADD_NODE_BACK,hostname:(0,zG.get)(x.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(YG):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let _=YG(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 gp({url:t},l,e)}catch(_){_.message=`Error returned from ${t}: `+_.message,ns.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&&(ns.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,Cs.setCertTable)({name:kae.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,Cs.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),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 Io(Xe(),_)}await Io(u?u.nodeName:d.name??li(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 $ae(e){ns.trace("addNodeBack received request:",e);let t=await(0,Cs.signCertificate)(e),r;e.csr?(r=t.signingCA,ns.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,ns.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,Cs.getReplicationCertAuth)();if(n.replicates){let i={url:va(),ca:s?.certificate,replicates:!0,subscriptions:null};e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await Io(Xe(),i)}return await Io(e.hostname,n),t.nodeName=Xe(),t.usingCA=s?.certificate,ns.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Vae(e){ns.trace("removeNodeBack received request:",e),await gr().delete(e.name)}function YG(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var Cs,WG,Sl,zG,ns,Mo,kae,Fae,Gae,Al=be(()=>{Cs=M(rs()),WG=M(ut()),Sl=M(require("joi")),zG=M(ce());B();dp();ul();ts();ns=M(Y()),Mo=M(pe()),{pki:kae}=require("node-forge"),{HTTP_STATUS_CODES:Fae}=Mo.hdb_errors,Gae=Sl.default.object({hostname:Sl.default.string(),verify_tls:Sl.default.boolean(),replicates:Sl.default.boolean(),subscriptions:Sl.default.array(),revoked_certificates:Sl.default.array()});a(qae,"setNode");a($ae,"addNodeBack");a(Vae,"removeNodeBack");a(YG,"reverseSubscription")});var Ed=I((_Le,QG)=>{"use strict";var{handleHDBError:Xg,hdb_errors:Kae}=pe(),{HTTP_STATUS_CODES:Zg}=Kae,{addUpdateNodeValidator:Yae}=zg(),eS=Y(),tS=(B(),C(G)),jG=St(),Wae=oe(),Rp=ir(),yp=Lo(),WN=ce(),zae=YN(),{Node:jae,NodeSubscription:Qae}=hd(),{broadcast:Jae}=tt(),{setNode:Xae}=(Al(),C(Tl)),dLe=ce(),fLe=(B(),C(G)),Zae="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",ece="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",tce=WN.get(tS.CONFIG_PARAMS.CLUSTERING_NODENAME);QG.exports=rce;async function rce(e,t=!1){if(eS.trace("addNode called with:",e),WN.get(tS.CONFIG_PARAMS.REPLICATION_URL)||WN.get(tS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Xae(e);yp.checkClusteringEnabled();let r=Yae(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(!Wae.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 zae(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=Zae,o;let c=yp.buildNodePayloads(s,tce,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 Qae(_.schema,_.table,_.publish,_.subscribe))}eS.trace("addNode sending remote payload:",c);let u;try{u=await Rp.request(`${n}.${jG.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===jG.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 jae(n,l,u.system_info);return await yp.upsertNodeRecord(f),Jae({type:"nats_update"}),i.length>0?o.message=ece:o.message=`Successfully added '${n}' to manifest`,o}a(rce,"addNode")});var JN=I((mLe,XG)=>{"use strict";var{handleHDBError:zN,hdb_errors:nce}=pe(),{HTTP_STATUS_CODES:jN}=nce,{addUpdateNodeValidator:sce}=zg(),bp=Y(),rS=(B(),C(G)),JG=St(),hLe=oe(),Op=ir(),Np=Lo(),QN=ce(),{cloneDeep:ice}=require("lodash"),oce=YN(),{Node:ace,NodeSubscription:cce}=hd(),{broadcast:lce}=tt(),{setNode:uce}=(Al(),C(Tl)),dce="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",fce="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",_ce=QN.get(rS.CONFIG_PARAMS.CLUSTERING_NODENAME);XG.exports=pce;async function pce(e){if(bp.trace("updateNode called with:",e),QN.get(rS.CONFIG_PARAMS.REPLICATION_URL)??QN.get(rS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return uce(e);Np.checkClusteringEnabled();let t=sce(e);if(t)throw zN(t,t.message,jN.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Np.getNodeRecord(r);s.length>0&&(n=ice(s));let{added:i,skipped:o}=await oce(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=dce,c;let l=Np.buildNodePayloads(i,_ce,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}.${JG.REQUEST_SUFFIX}`,l)}catch(f){bp.error(`updateNode received error from request: ${f}`);let d=Op.requestErrorHandler(f,"update_node",r);throw zN(new Error,d,jN.INTERNAL_SERVER_ERROR,"error",d)}if(u.status===JG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let f=`Error returned from remote node ${r}: ${u.message}`;throw zN(new Error,f,jN.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 ace(r,[],u.system_info)]),await hce(n[0],i,u.system_info),o.length>0?c.message=fce:c.message=`Successfully updated '${r}'`,c}a(pce,"updateNode");async function hce(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 cce(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Np.upsertNodeRecord(n),lce({type:"nats_update"})}a(hce,"updateNodeTable")});var nq=I((gLe,rq)=>{"use strict";var tq=require("joi"),{string:ZG}=tq.types(),mce=ut(),eq=(B(),C(G)),Ece=ce(),gce=St();rq.exports=Sce;function Sce(e){let t=ZG.invalid(Ece.get(eq.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(gce.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=tq.object({operation:ZG.valid(eq.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return mce.validateBySchema(e,r)}a(Sce,"removeNodeValidator")});var nS=I((TLe,cq)=>{"use strict";var{handleHDBError:sq,hdb_errors:Tce}=pe(),{HTTP_STATUS_CODES:iq}=Tce,Ace=nq(),wp=Y(),oq=Lo(),Rce=oe(),gd=(B(),C(G)),aq=St(),XN=ir(),ZN=ce(),{RemotePayloadObject:yce}=Tp(),{NodeSubscription:bce}=hd(),Oce=U_(),Nce=Vc(),{broadcast:wce}=tt(),{setNode:Ice}=(Al(),C(Tl)),Cce=ZN.get(gd.CONFIG_PARAMS.CLUSTERING_NODENAME);cq.exports=Pce;async function Pce(e){if(wp.trace("removeNode called with:",e),ZN.get(gd.CONFIG_PARAMS.REPLICATION_URL)??ZN.get(gd.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Ice(e);oq.checkClusteringEnabled();let t=Ace(e);if(t)throw sq(t,t.message,iq.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await oq.getNodeRecord(r);if(Rce.isEmptyOrZeroLength(n))throw sq(new Error,`Node '${r}' was not found.`,iq.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new yce(gd.OPERATIONS_ENUM.REMOVE_NODE,Cce,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let f=n.subscriptions[l];f.subscribe===!0&&await XN.updateConsumerIterator(f.schema,f.table,r,"stop");try{await XN.updateRemoteConsumer(new bce(f.schema,f.table,!1,!1),r)}catch(d){wp.error(d)}}try{i=await XN.request(`${r}.${aq.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 Oce(gd.SYSTEM_SCHEMA_NAME,gd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Nce.deleteRecord(c),wce({type:"nats_update"}),i?.status===aq.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(Pce,"removeNode")});var dq=I((RLe,uq)=>{"use strict";var lq=require("joi"),{string:Dce,array:Lce}=lq.types(),Mce=ut(),vce=zg();uq.exports=Uce;function Uce(e){let t=lq.object({operation:Dce.valid("configure_cluster").required(),connections:Lce.items(vce.validation_schema).required()});return Mce.validateBySchema(e,t)}a(Uce,"configureClusterValidator")});var ew=I((bLe,mq)=>{"use strict";var fq=(B(),C(G)),sS=Y(),xce=oe(),Bce=ce(),Hce=nS(),kce=Ed(),Fce=Lo(),Gce=dq(),{handleHDBError:_q,hdb_errors:qce}=pe(),{HTTP_STATUS_CODES:pq}=qce,$ce="Configure cluster complete.",Vce="Failed to configure the cluster. Check the logs for more details.",Kce="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";mq.exports=Yce;async function Yce(e){sS.trace("configure cluster called with:",e);let t=Gce(e);if(t)throw _q(t,t.message,pq.BAD_REQUEST,void 0,void 0,!0);let r=await Fce.getAllNodeRecords(),n=[];if(Bce.get(fq.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let f=0,d=r.length;f<d;f++){let p=await hq(Hce,{operation:fq.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 hq(kce,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(xce.isEmptyOrZeroLength(o))return{message:$ce,connections:c};if(l)return{message:Kce,failed_nodes:o,connections:c};throw _q(new Error,Vce,pq.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Yce,"configureCluster");async function hq(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(hq,"functionWrapper")});var Tq=I((NLe,Sq)=>{"use strict";var Ip=require("joi"),Wce=ut(),{validateSchemaExists:Eq,validateTableExists:zce,validateSchemaName:gq}=vi(),jce=Ip.object({operation:Ip.string().valid("purge_stream"),schema:Ip.string().custom(Eq).custom(gq).optional(),database:Ip.string().custom(Eq).custom(gq).optional(),table:Ip.string().custom(zce).required()});function Qce(e){return Wce.validateBySchema(e,jce)}a(Qce,"purgeStreamValidator");Sq.exports=Qce});var tw=I((ILe,Aq)=>{"use strict";var{handleHDBError:Jce,hdb_errors:Xce}=pe(),{HTTP_STATUS_CODES:Zce}=Xce,ele=Tq(),tle=ir(),rle=Lo();Aq.exports=nle;async function nle(e){e.schema=e.schema??e.database;let t=ele(e);if(t)throw Jce(t,t.message,Zce.BAD_REQUEST,void 0,void 0,!0);rle.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await tle.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(nle,"purgeStream")});var aS=I((PLe,Iq)=>{"use strict";var nw=Lo(),sle=ir(),oS=ce(),Sd=(B(),C(G)),Rl=St(),ile=oe(),rw=Y(),{RemotePayloadObject:ole}=Tp(),{ErrorCode:Rq}=require("nats"),{parentPort:yq}=require("worker_threads"),{onMessageByType:ale}=tt(),{getThisNodeName:cle}=(ts(),C(Po)),{requestClusterStatus:lle}=(dp(),C(Yk)),{getReplicationSharedStatus:ule}=(ul(),C(YO)),{CONFIRMATION_STATUS_POSITION:dle,RECEIVED_VERSION_POSITION:fle,RECEIVED_TIME_POSITION:_le,SENDING_TIME_POSITION:ple}=(mN(),C(vF)),bq=oS.get(Sd.CONFIG_PARAMS.CLUSTERING_ENABLED),Oq=oS.get(Sd.CONFIG_PARAMS.CLUSTERING_NODENAME);Iq.exports={clusterStatus:hle,buildNodeStatus:wq};var Nq;ale("cluster-status",async e=>{Nq(e)});async function hle(){if(oS.get(Sd.CONFIG_PARAMS.REPLICATION_URL)||oS.get(Sd.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;if(yq){yq.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{Nq=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=ule(l,c,i);o.lastCommitConfirmed=iS(u[dle]),o.lastReceivedRemoteTime=iS(u[fle]),o.lastReceivedLocalTime=iS(u[_le]),o.sendingMessage=iS(u[ple])}}}else n=lle();return n.node_name=cle(),n.is_enabled=!0,n}let e={node_name:Oq,is_enabled:bq,connections:[]};if(!bq)return e;let t=await nw.getAllNodeRecords();if(ile.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(wq(t[n],e.connections));return await Promise.allSettled(r),e}a(hle,"clusterStatus");function iS(e){return e?e===1?"Copying":new Date(e).toUTCString():void 0}a(iS,"asDate");async function wq(e,t){let r=e.name,n=new ole(Sd.OPERATIONS_ENUM.CLUSTER_STATUS,Oq,void 0,await nw.getSystemInfo()),s,i,o=Rl.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await sle.request(Rl.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Rl.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Rl.CLUSTER_STATUS_STATUSES.CLOSED,rw.error(`Error getting node status from ${r} `,s))}catch(l){rw.warn(`Error getting node status from ${r}`,l),l.code===Rq.NoResponders?o=Rl.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===Rq.Timeout?o=Rl.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Rl.CLUSTER_STATUS_STATUSES.CLOSED}let c=new mle(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!==Sd.PRE_4_0_0_VERSION&&await nw.upsertNodeRecord(l)}catch(l){rw.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(wq,"buildNodeStatus");function mle(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(mle,"NodeStatusObject")});var lS=I((LLe,Cq)=>{"use strict";var{handleHDBError:Ele,hdb_errors:gle}=pe(),{HTTP_STATUS_CODES:Sle}=gle,Tle=ir(),Ale=Lo(),sw=oe(),cS=require("joi"),Rle=ut(),yle=2e3,ble=cS.object({timeout:cS.number().min(1),connected_nodes:cS.boolean(),routes:cS.boolean()});Cq.exports=Ole;async function Ole(e){Ale.checkClusteringEnabled();let t=Rle.validateBySchema(e,ble);if(t)throw Ele(t,t.message,Sle.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||sw.autoCastBoolean(n),o=s===void 0||sw.autoCastBoolean(s),c={nodes:[]},l=await Tle.getServerList(r??yle),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:sw.autoCast(S.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(Ole,"clusterNetwork")});var Mq=I((vLe,Lq)=>{"use strict";var iw=require("joi"),Pq=ut(),{route_constraints:Dq}=$y();Lq.exports={setRoutesValidator:Nle,deleteRoutesValidator:wle};function Nle(e){let t=iw.object({server:iw.valid("hub","leaf"),routes:Dq.required()});return Pq.validateBySchema(e,t)}a(Nle,"setRoutesValidator");function wle(e){let t=iw.object({routes:Dq.required()});return Pq.validateBySchema(e,t)}a(wle,"deleteRoutesValidator")});var uS=I((xLe,Fq)=>{"use strict";var vo=Rt(),ow=oe(),Ps=(B(),C(G)),Td=ce(),vq=Mq(),{handleHDBError:Uq,hdb_errors:Ile}=pe(),{HTTP_STATUS_CODES:xq}=Ile,Bq="cluster routes successfully set",Hq="cluster routes successfully deleted";Fq.exports={setRoutes:Ple,getRoutes:Dle,deleteRoutes:Lle};function Cle(e){let t=vo.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=ow.autoCast(l.port);let u=r.some(d=>d.host===l.host&&d.port===l.port),f=n.some(d=>d.host===l.host&&d.port===l.port);u||f?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?vo.updateConfigValue(Ps.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):vo.updateConfigValue(Ps.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:Bq,set:i,skipped:s}}a(Cle,"setRoutesNats");function Ple(e){let t=vq.setRoutesValidator(e);if(t)throw Uq(t,t.message,xq.BAD_REQUEST,void 0,void 0,!0);if(Td.get(Ps.CONFIG_PARAMS.CLUSTERING_ENABLED))return Cle(e);let r=[],n=[],s=Td.get(Ps.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{kq(s,i)?n.push(i):(s.push(i),r.push(i))}),vo.updateConfigValue(Ps.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:Bq,set:r,skipped:n}}a(Ple,"setRoutes");function kq(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(kq,"existsInArray");function Dle(){if(Td.get(Ps.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=vo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Td.get(Ps.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Dle,"getRoutes");function Lle(e){let t=vq.deleteRoutesValidator(e);if(t)throw Uq(t,t.message,xq.BAD_REQUEST,void 0,void 0,!0);if(Td.get(Ps.CONFIG_PARAMS.CLUSTERING_ENABLED))return Mle(e);let r=[],n=[],s=Td.get(Ps.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{kq(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),vo.updateConfigValue(Ps.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Hq,deleted:r,skipped:n}}a(Lle,"deleteRoutes");function Mle(e){let t=vo.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let f=e.routes[l],d=!1;for(let p=0,_=r.length;p<_;p++){let h=r[p];if(f.host===h.host&&f.port===h.port){r.splice(p,1),d=!0,o=!0,s.push(f);break}}if(!d){let p=!0;for(let _=0,h=n.length;_<h;_++){let S=n[_];if(f.host===S.host&&f.port===S.port){n.splice(_,1),c=!0,p=!1,s.push(f);break}}p&&i.push(f)}}return o&&(r=ow.isEmptyOrZeroLength(r)?null:r,vo.updateConfigValue(Ps.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=ow.isEmptyOrZeroLength(n)?null:n,vo.updateConfigValue(Ps.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Hq,deleted:s,skipped:i}}a(Mle,"deleteRoutesNats")});var qq=I((HLe,Gq)=>{"use strict";var Cp=require("alasql"),yl=require("recursive-iterator"),fi=Y(),vle=oe(),Pp=(B(),C(G)),aw=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,xle(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=Ule(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 Ule(e){return e.filter(t=>t[Pp.PERMS_CRUD_ENUM.READ])}a(Ule,"filterReadRestrictedAttrs");function xle(e,t,r,n,s){Ble(e,t,r,n,s)}a(xle,"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 Ble(e,t,r,n,s){if(!e){fi.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Cp.yy.Insert?Gle(e,t,r):e instanceof Cp.yy.Select?Hle(e,t,r,n,s):e instanceof Cp.yy.Update?kle(e,t,r):e instanceof Cp.yy.Delete?Fle(e,t,r):fi.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(Ble,"getRecordAttributesAST");function Hle(e,t,r,n,s){if(!e){fi.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(vle.isEmptyOrZeroLength(i)){fi.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 yl(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{fi.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 yl(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{fi.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 yl(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{fi.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 yl(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{fi.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(Hle,"getSelectAttributes");function kle(e,t,r){if(!e){fi.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new yl(e.columns),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&cw(e.table.tableid,s,i.columnid,t,r)}a(kle,"getUpdateAttributes");function Fle(e,t,r){if(!e){fi.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new yl(e.where),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&cw(e.table.tableid,s,i.columnid,t,r)}a(Fle,"getDeleteAttributes");function Gle(e,t,r){if(!e){fi.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new yl(e.columns),s=e.into.databaseid;Dp(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&cw(e.into.tableid,s,i.columnid,t,r)}a(Gle,"getInsertAttributes");function cw(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(cw,"pushAttribute");Gq.exports=aw});var Vq=I((FLe,$q)=>{"use strict";var dS=(B(),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}},lw=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}};$q.exports={BaseLicense:fS,ExtendedLicense:lw}});var yd=I((qLe,Qq)=>{"use strict";var Rd=require("fs-extra"),_S=(hE(),C(pE)),Yq=require("crypto"),qle=require("moment"),$le=require("uuid").v4,en=Y(),dw=require("path"),Vle=oe(),bl=(B(),C(G)),{totalmem:Kq}=require("os"),Kle=Vq().ExtendedLicense,Ad="invalid license key format",Yle="061183",Wle="mofi25",zle="aes-256-cbc",jle=16,Qle=32,Wq=ce(),{resolvePath:zq}=Rt();Wq.initSync();var uw;Qq.exports={validateLicense:jq,generateFingerPrint:Xle,licenseSearch:pw,getLicense:tue,checkMemoryLimit:rue};function fw(){return dw.join(Wq.getHdbBasePath(),bl.LICENSE_KEY_DIR_NAME,bl.LICENSE_FILE_NAME)}a(fw,"getLicenseDirPath");function Jle(){let e=fw();return zq(dw.join(e,bl.LICENSE_FILE_NAME))}a(Jle,"getLicenseFilePath");function _w(){let e=fw();return zq(dw.join(e,bl.REG_KEY_FILE_NAME))}a(_w,"getFingerPrintFilePath");async function Xle(){let e=_w();try{return await Rd.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await Zle();throw en.error(`Error writing fingerprint file to ${e}`),en.error(t),new Error("There was an error generating the fingerprint")}}a(Xle,"generateFingerPrint");async function Zle(){let e=$le(),t=_S.hash(e,_S.HASH_FUNCTION.MD5),r=_w();try{await Rd.mkdirp(fw()),await Rd.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw en.error(`Error writing fingerprint file to ${r}`),en.error(n),new Error("There was an error generating the fingerprint")}return t}a(Zle,"writeFingerprint");function jq(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:bl.RAM_ALLOCATION_ENUM.DEFAULT,version:bl.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return en.error("empty license key passed to validate."),r;let n=_w(),s=!1;try{s=Rd.statSync(n)}catch(i){en.error(i)}if(s){let i;try{i=Rd.readFileSync(n,"utf8")}catch{en.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(Wle),c=o[1];c=Buffer.concat([Buffer.from(c)],jle);let l=Buffer.concat([Buffer.from(i)],Qle),u=Yq.createDecipheriv(zle,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 _=eue(o[0],i);if(_)f=_;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Ad),en.error(Ad),new Error(Ad)}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(Ad),en.error(Ad),new Error(Ad)}else r.exp_date=f;r.exp_date<qle().valueOf()&&(r.valid_date=!1),_S.validate(o[1],`${Yle}${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||en.error("Invalid licence"),r}a(jq,"validateLicense");function eue(e,t){try{let r=Yq.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{en.warn("Check old license failed")}}a(eue,"checkOldLicense");function pw(){let e=new Kle,t=[];try{t=Rd.readFileSync(Jle(),"utf-8").split(`\r
25
- `)}catch(r){r.code==="ENOENT"?en.debug("no license file found"):en.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(Vle.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=jq(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){en.error("There was an error parsing the license string."),en.error(s),e.ram_allocation=bl.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return uw=e,e}a(pw,"licenseSearch");async function tue(){return uw||await pw(),uw}a(tue,"getLicense");function rue(){let e=pw().ram_allocation,t=process.constrainedMemory?.()||Kq();if(t=Math.round(Math.min(t,Kq())/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(rue,"checkMemoryLimit")});var hS=I((VLe,e$)=>{var pS=yd(),Jq=require("chalk"),ss=Y(),Xq=require("prompt"),{promisify:nue}=require("util"),hw=(B(),C(G)),sue=require("fs-extra"),iue=require("path"),oue=oe(),{packageJson:aue}=nt(),Zq=ce();Zq.initSync();var cue=require("moment"),lue=nue(Xq.get),uue=iue.join(Zq.getHdbBasePath(),hw.LICENSE_KEY_DIR_NAME,hw.LICENSE_FILE_NAME,hw.LICENSE_FILE_NAME);e$.exports={getFingerprint:fue,setLicense:due,parseLicense:mw,register:_ue,getRegistrationInfo:hue};async function due(e){if(e&&e.key&&e.company){try{ss.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await mw(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw ss.error(r),ss.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(due,"setLicense");async function fue(){let e={};try{e=await pS.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw ss.error(r),ss.error(t),new Error(r)}return e}a(fue,"getFingerprint");async function mw(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");ss.info("Validating license input...");let r=pS.validateLicense(e,t);if(ss.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(ss.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(ss.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{ss.info("writing license to disk"),await sue.writeFile(uue,JSON.stringify({license_key:e,company:t}))}catch(n){throw ss.error("Failed to write License"),n}return"Registration successful."}a(mw,"parseLicense");async function _ue(){let e=await pue();return mw(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(_ue,"register");async function pue(){let e=await pS.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:Jq.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:Jq.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{Xq.start()}catch(n){ss.error(n)}let r;try{r=await lue(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(pue,"promptForRegistration");async function hue(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await pS.getLicense()}catch(r){throw ss.error(`There was an error when searching licenses due to: ${r.message}`),r}if(oue.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=aue.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=cue.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(hue,"getRegistrationInfo")});var r$=I((YLe,t$)=>{"use strict";var mue=St(),Ew=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+mue.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"}};t$.exports=Ew});var i$=I((zLe,s$)=>{"use strict";var n$=St(),gw=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+n$.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+n$.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"}};s$.exports=gw});var a$=I((QLe,o$)=>{"use strict";var Sw=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};o$.exports=Sw});var l$=I((XLe,c$)=>{"use strict";var Eue=St(),Tw=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+Eue.SERVER_SUFFIX.ADMIN,this.password=r}};c$.exports=Tw});var SS=I((eMe,f$)=>{"use strict";var Ol=require("path"),Nl=require("fs-extra"),gue=r$(),Sue=i$(),Tue=a$(),Aue=l$(),Aw=Rn(),Od=oe(),Cn=Rt(),ES=(B(),C(G)),Lp=St(),{CONFIG_PARAMS:Wt}=ES,Nd=Y(),Mp=ce(),u$=To(),Rw=ir(),Rue=rs(),bd="clustering",yue=1e4,d$=50;f$.exports={generateNatsConfig:Oue,removeNatsConfig:Nue,getHubConfigPath:bue};function bue(){let e=Mp.get(Wt.ROOTPATH);return Ol.join(e,bd,Lp.NATS_CONFIG_FILES.HUB_SERVER)}a(bue,"getHubConfigPath");async function Oue(e=!1,t=void 0){let r=Mp.get(Wt.ROOTPATH);Nl.ensureDirSync(Ol.join(r,"clustering","leaf")),Mp.initSync();let n=Cn.getConfigFromFile(Wt.CLUSTERING_TLS_CERT_AUTH),s=Cn.getConfigFromFile(Wt.CLUSTERING_TLS_PRIVATEKEY),i=Cn.getConfigFromFile(Wt.CLUSTERING_TLS_CERTIFICATE);!await Nl.exists(i)&&!await Nl.exists(!n)&&await Rue.createNatsCerts();let o=Ol.join(r,bd,Lp.PID_FILES.HUB),c=Ol.join(r,bd,Lp.PID_FILES.LEAF),l=Cn.getConfigFromFile(Wt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=Ol.join(r,bd,Lp.NATS_CONFIG_FILES.HUB_SERVER),f=Ol.join(r,bd,Lp.NATS_CONFIG_FILES.LEAF_SERVER),d=Cn.getConfigFromFile(Wt.CLUSTERING_TLS_INSECURE),p=Cn.getConfigFromFile(Wt.CLUSTERING_TLS_VERIFY),_=Cn.getConfigFromFile(Wt.CLUSTERING_NODENAME),h=Cn.getConfigFromFile(Wt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Rw.checkNATSServerInstalled()||gS("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await Aw.listUsers(),g=Cn.getConfigFromFile(Wt.CLUSTERING_USER),A=await Aw.getClusterUser();(Od.isEmpty(A)||A.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(Wt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await mS(Wt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await mS(Wt.CLUSTERING_HUBSERVER_NETWORK_PORT),await mS(Wt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let E=[],R=[];for(let[ae,Z]of S.entries())Z.role?.role===ES.ROLE_TYPES_ENUM.CLUSTER_USER&&Z.active&&(E.push(new Aue(Z.username,u$.decrypt(Z.hash))),R.push(new Tue(Z.username,u$.decrypt(Z.hash))));let N=[],{hub_routes:v}=Cn.getClusteringRoutes();if(!Od.isEmptyOrZeroLength(v))for(let ae of v)N.push(`tls://${A.sys_name_encoded}:${A.uri_encoded_d_hash}@${ae.host}:${ae.port}`);let k=new gue(Cn.getConfigFromFile(Wt.CLUSTERING_HUBSERVER_NETWORK_PORT),_,o,i,s,n,d,p,h,Cn.getConfigFromFile(Wt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Cn.getConfigFromFile(Wt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),N,E,R);n==null&&(delete k.tls.ca_file,delete k.leafnodes.tls.ca_file),t=Od.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===ES.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Nl.writeJson(u,k),Nd.trace(`Hub server config written to ${u}`));let F=`tls://${A.sys_name_encoded}:${A.uri_encoded_d_hash}@0.0.0.0:${h}`,K=`tls://${A.uri_encoded_name}:${A.uri_encoded_d_hash}@0.0.0.0:${h}`,re=new Sue(Cn.getConfigFromFile(Wt.CLUSTERING_LEAFSERVER_NETWORK_PORT),_,c,l,[F],[K],E,R,i,s,n,d);n==null&&delete re.tls.ca_file,(t===void 0||t===ES.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Nl.writeJson(f,re),Nd.trace(`Leaf server config written to ${f}`))}a(Oue,"generateNatsConfig");async function mS(e){let t=Mp.get(e);return Od.isEmpty(t)&&gS(`port undefined for '${e}'`),await Od.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}`;Nd.error(t),console.error(t),process.exit(1)}a(gS,"generateNatsConfigError");async function Nue(e){let{port:t,config_file:r}=Rw.getServerConfig(e),{username:n,decrypt_hash:s}=await Aw.getClusterUser(),i=0,o=2e3;for(;i<d$;){try{let f=await Rw.createConnection(t,n,s,!1);if(f.protocol.connected===!0){f.close();break}}catch(f){Nd.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${f}`)}if(i++,i>=d$)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&&Nd.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Od.async_set_timeout(u)}let c="0".repeat(yue),l=Ol.join(Mp.get(Wt.ROOTPATH),bd,r);await Nl.writeFile(l,c),await Nl.remove(l),Nd.notify(e,"started.")}a(Nue,"removeNatsConfig")});var g$=I((rMe,E$)=>{"use strict";var is=ce(),wue=yd(),Ge=(B(),C(G)),vp=St(),Uo=require("path"),{PACKAGE_ROOT:AS}=nt(),_$=ce(),TS=oe(),wd="/dev/null",Iue=Uo.join(AS,"launchServiceScripts"),p$=Uo.join(AS,"utility/scripts"),Cue=Uo.join(p$,Ge.HDB_RESTART_SCRIPT),h$=Uo.resolve(AS,"dependencies",`${process.platform}-${process.arch}`,vp.NATS_BINARY_NAME);function m$(){let t=wue.licenseSearch().ram_allocation||Ge.RAM_ALLOCATION_ENUM.DEFAULT,r=Ge.MEM_SETTING_KEY+t,n={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return TS.noBootFile()&&(n[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=TS.getEnvCliRootPath()),{name:Ge.PROCESS_DESCRIPTORS.HDB,script:Ge.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:AS}}a(m$,"generateMainServerConfig");var Pue=9930;function Due(){is.initSync(!0);let e=is.get(Ge.CONFIG_PARAMS.ROOTPATH),t=Uo.join(e,"clustering",vp.NATS_CONFIG_FILES.HUB_SERVER),r=Uo.join(is.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=_$.get(Ge.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=vp.LOG_LEVEL_FLAGS[is.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Pue?"-"+n:""),script:h$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return is.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=wd,i.error_file=wd),i}a(Due,"generateNatsHubServerConfig");var Lue=9940;function Mue(){is.initSync(!0);let e=is.get(Ge.CONFIG_PARAMS.ROOTPATH),t=Uo.join(e,"clustering",vp.NATS_CONFIG_FILES.LEAF_SERVER),r=Uo.join(is.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=_$.get(Ge.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=vp.LOG_LEVEL_FLAGS[is.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Lue?"-"+n:""),script:h$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return is.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=wd,i.error_file=wd),i}a(Mue,"generateNatsLeafServerConfig");function vue(){is.initSync();let e=Uo.join(is.get(Ge.CONFIG_PARAMS.LOGGING_ROOT),Ge.LOG_NAMES.HDB),t={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Ge.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Iue,autorestart:!1};return is.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=wd,t.error_file=wd),t}a(vue,"generateClusteringUpgradeV4ServiceConfig");function Uue(){let e={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.RESTART_HDB};return TS.noBootFile()&&(e[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=TS.getEnvCliRootPath()),{...{name:Ge.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:p$},script:Cue}}a(Uue,"generateRestart");function xue(){return{apps:[m$()]}}a(xue,"generateAllServiceConfigs");E$.exports={generateAllServiceConfigs:xue,generateMainServerConfig:m$,generateRestart:Uue,generateNatsHubServerConfig:Due,generateNatsLeafServerConfig:Mue,generateClusteringUpgradeV4ServiceConfig:vue}});var Id=I((iMe,L$)=>{"use strict";var Ze=(B(),C(G)),Bue=oe(),Bo=SS(),RS=ir(),xo=St(),Ka=g$(),yS=ce(),wl=Y(),Hue=Lo(),{startWorker:S$,onMessageFromWorkers:kue}=tt(),Fue=Do(),sMe=require("util"),Gue=require("child_process"),que=require("fs"),{execFile:$ue}=Gue,Ke;L$.exports={enterPM2Mode:Vue,start:Ya,stop:yw,reload:A$,restart:R$,list:bw,describe:O$,connect:Ho,kill:jue,startAllServices:Que,startService:Ow,getUniqueServicesList:N$,restartAllServices:Jue,isServiceRegistered:w$,reloadStopStart:I$,restartHdb:b$,deleteProcess:Wue,startClusteringProcesses:P$,startClusteringThreads:D$,isHdbRestartRunning:zue,isClusteringRunning:Zue,stopClustering:Xue,reloadClustering:ede,expectedRestartOfChildren:y$};var Up=!1;kue(e=>{e.type==="restart"&&yS.initSync(!0)});function Vue(){Up=!0}a(Vue,"enterPM2Mode");function Ho(){return Ke||(Ke=require("pm2")),new Promise((e,t)=>{Ke.connect((r,n)=>{r&&t(r),e(n)})})}a(Ho,"connect");var tn,Kue=10,T$;function Ya(e,t=!1){if(Up)return Yue(e);let r=$ue(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=tn.indexOf(r);o>-1&&tn.splice(o,1),!T$&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Kue&&(que.existsSync(Bo.getHubConfigPath())?Ya(e):(await Bo.generateNatsConfig(!0),Ya(e),await new Promise(c=>setTimeout(c,3e3)),await Bo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Bo.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&&xo.LOG_LEVEL_HIERARCHY[o]>=xo.LOG_LEVEL_HIERARCHY[f||"info"]){let _=f===xo.LOG_LEVELS.ERR||f===xo.LOG_LEVELS.WRN?wl.OUTPUTS.STDERR:wl.OUTPUTS.STDOUT;wl.logCustomLevel(f||"info",_,n,i.slice(u,l.index).trim())}let[d,p]=l;u=l.index+d.length,f=xo.LOG_LEVELS[p]}if(xo.LOG_LEVEL_HIERARCHY[o]>=xo.LOG_LEVEL_HIERARCHY[f||"info"]){let d=f===xo.LOG_LEVELS.ERR||f===xo.LOG_LEVELS.WRN?wl.OUTPUTS.STDERR:wl.OUTPUTS.STDOUT;wl.logCustomLevel(f||"info",d,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!tn&&(tn=[],!t)){let i=a(()=>{T$=!0,tn&&(tn.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}tn.push(r)}a(Ya,"start");function Yue(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.start(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(Yue,"startWithPM2");function yw(e){if(!Up){for(let t of tn||[])t.name===e&&(tn.splice(tn.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.stop(e,async(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.delete(e,(i,o)=>{i&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(o)})})})}a(yw,"stop");function A$(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.reload(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(A$,"reload");function R$(e){if(!Up){y$();for(let t of tn||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.restart(e,(n,s)=>{Ke.disconnect(),t(s)})})}a(R$,"restart");function y$(){for(let e of tn||[])e.config&&(e.config.restarts=0)}a(y$,"expectedRestartOfChildren");function Wue(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.delete(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(Wue,"deleteProcess");async function b$(){await Ya(Ka.generateRestart())}a(b$,"restartHdb");async function zue(){let e=await bw();for(let t in e)if(e[t].name===Ze.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(zue,"isHdbRestartRunning");function bw(){return new Promise(async(e,t)=>{try{await Ho()}catch(r){t(r)}Ke.list((r,n)=>{r&&(Ke.disconnect(),t(r)),Ke.disconnect(),e(n)})})}a(bw,"list");function O$(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.describe(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(O$,"describe");function jue(){if(!Up){for(let e of tn||[])e.kill();tn=[];return}return new Promise(async(e,t)=>{try{await Ho()}catch(r){t(r)}Ke.killDaemon((r,n)=>{r&&(Ke.disconnect(),t(r)),Ke.disconnect(),e(n)})})}a(jue,"kill");async function Que(){try{await P$(),await D$(),await Ya(Ka.generateAllServiceConfigs())}catch(e){throw Ke?.disconnect(),e}}a(Que,"startAllServices");async function Ow(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case Ze.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ka.generateMainServerConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ka.generateNatsIngestServiceConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ka.generateNatsReplyServiceConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ka.generateNatsHubServerConfig(),await Ya(r,t),await Bo.removeNatsConfig(e);return;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ka.generateNatsLeafServerConfig(),await Ya(r,t),await Bo.removeNatsConfig(e);return;case Ze.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 Ke?.disconnect(),r}}a(Ow,"startService");async function N$(){try{let e=await bw(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Ke?.disconnect(),e}}a(N$,"getUniqueServicesList");async function Jue(e=[]){try{let t=!1,r=await N$();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 R$(o))}t&&await I$(Ze.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ke?.disconnect(),t}}a(Jue,"restartAllServices");async function w$(e){if(tn?.find(r=>r.name===e))return!0;let t=await Fue.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(w$,"isServiceRegistered");async function I$(e){let t=yS.get(Ze.CONFIG_PARAMS.THREADS_COUNT)??yS.get(Ze.CONFIG_PARAMS.THREADS),r=await O$(e),n=Bue.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await yw(e),await Ow(e)):e===Ze.PROCESS_DESCRIPTORS.HDB?await b$():await A$(e)}a(I$,"reloadStopStart");var C$;async function P$(e=!1){for(let t in Ze.CLUSTERING_PROCESSES){let r=Ze.CLUSTERING_PROCESSES[t];await Ow(r,e)}}a(P$,"startClusteringProcesses");async function D$(){C$=S$(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 Hue.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===Ze.PRE_4_0_0_VERSION){wl.info("Starting clustering upgrade 4.0.0 process"),S$(Ze.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(D$,"startClusteringThreads");async function Xue(){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 C$.terminate();else{let t=Ze.CLUSTERING_PROCESSES[e];await yw(t)}}a(Xue,"stopClustering");async function Zue(){for(let e in Ze.CLUSTERING_PROCESSES){let t=Ze.CLUSTERING_PROCESSES[e];if(await w$(t)===!1)return!1}return!0}a(Zue,"isClusteringRunning");async function ede(){await Bo.generateNatsConfig(!0),await RS.reloadNATSHub(),await RS.reloadNATSLeaf(),await Bo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await Bo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(ede,"reloadClustering")});var NS={};ve(NS,{compactOnStart:()=>tde,copyDb:()=>H$});async function tde(){Wa.notify("Running compact on start"),console.log("Running compact on start");let e=(0,Nw.get)(x.ROOTPATH),t=new Map,r=Je();(0,ww.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,bS.join)(e,"backup",n+".mdb"),o=(0,bS.join)(e,yc,n+"-copy.mdb"),c=0;try{c=await M$(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 H$(n,o),console.log("Backing up",n,"to",i),await(0,Il.move)(s,i,{overwrite:!0})}try{Cd()}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,Il.move)(i,s,{overwrite:!0}),await(0,Il.remove)((0,bS.join)(e,yc,`${n}-copy.mdb-lock`));try{Cd()}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,ww.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,Il.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Cd(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await M$(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(Ik,"runCommand");async function zse(){try{await bse.access(BO)}catch{return!1}let e=await Ik(`${BO} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Ose.eq(t,Yse)}a(zse,"checkNATSServerInstalled");async function qO(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}ai.trace("create nats connection called");let i=await Bse({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(),ai.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&ai.error("Error with Nats client connection, connection closed",o),i===Jr&&Ck()}),i}a(qO,"createConnection");function Ck(){Jr=void 0,ol=void 0,al=void 0,cl=void 0}a(Ck,"clearClientCache");async function jse(){Jr&&(await Jr.drain(),Jr=void 0,ol=void 0,al=void 0,cl=void 0)}a(jse,"closeConnection");var Jr,cl;async function ip(){return cl||(cl=qO(Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Jr=await cl),Jr||cl}a(ip,"getConnection");async function op(){if(ol)return ol;ll(Jr)&&await ip();let{domain:e}=Xu($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ol=await Jr.jetstreamManager({domain:e,timeout:6e4}),ol}a(op,"getJetStreamManager");async function Pk(){if(al)return al;ll(Jr)&&await ip();let{domain:e}=Xu($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return al=Jr.jetstream({domain:e,timeout:6e4}),al}a(Pk,"getJetStream");async function Ki(){let e=Jr||await ip(),t=ol||await op(),r=al||await Pk();return{connection:e,jsm:t,js:r}}a(Ki,"getNATSReferences");async function Qse(e){let t=Nr.get($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await Nk.getClusterUser(),s=await qO(t,r,n),i=GO(),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 Eg.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(Qse,"getServerList");async function $O(e,t){let{jsm:r}=await Ki(),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:Hse.File,retention:kse.Limits,subjects:t,discard:Fse.Old,max_msgs:s,max_bytes:i,max_age:n})}a($O,"createLocalStream");async function Dk(){let{jsm:e}=await Ki(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(Dk,"listStreams");async function Jse(e){let{jsm:t}=await Ki();await t.streams.delete(e)}a(Jse,"deleteLocalStream");async function Xse(e){let{connection:t}=await Ki(),r=[],n=GO(),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(Xse,"listRemoteStreams");async function Zse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ki(),i=Rk(),o={durable_name:i,ack_policy:kO.Explicit};t&&(o.deliver_policy=FO.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=HO(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(Zse,"viewStream");async function*eie(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ki(),i=Rk(),o={durable_name:i,ack_policy:kO.Explicit};t&&(o.deliver_policy=FO.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=HO(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(eie,"viewStreamIterator");async function tie(e,t,r,n){ai.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=Lk(n,r);let{js:s}=await Ki(),i=await Sg(),o=`${e}.${i}`,c=await Vse(()=>n instanceof Uint8Array?n:Ok.encode(n));try{ai.trace(`publishToStream publishing to subject: ${o}`),$se(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"){ai.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await $O(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(tie,"publishToStream");function Lk(e,t){t===void 0&&(t=qse());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 Xu(e){e=e.toLowerCase();let t=sp.join(Nr.get($e.CONFIG_PARAMS.ROOTPATH),Kse);if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return ll(xO)&&(xO={port:rp.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:rp.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+Mr.SERVER_SUFFIX.HUB,config_file:Mr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:sp.join(t,Mr.PID_FILES.HUB),hdb_nats_path:t}),xO;if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return ll(UO)&&(UO={port:rp.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:rp.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+Mr.SERVER_SUFFIX.LEAF,config_file:Mr.NATS_CONFIG_FILES.LEAF_SERVER,domain:rp.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+Mr.SERVER_SUFFIX.LEAF,pid_file_path:sp.join(t,Mr.PID_FILES.LEAF),hdb_nats_path:t}),UO;ai.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Xu,"getServerConfig");async function Mk(e,t,r,n){try{await e.consumers.add(t,{ack_policy:kO.Explicit,durable_name:r,deliver_policy:FO.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(Mk,"createConsumer");async function rie(e,t,r){await e.consumers.delete(t,r)}a(rie,"removeConsumer");function nie(e){return e.split(".")[1]}a(nie,"extractServerName");async function sie(e,t,r=6e4,n=GO()){if(!Eg.isObject(t))throw new Error("data param must be an object");let s=Ok.encode(t),{connection:i}=await Ki(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return HO(c.data)}a(sie,"request");function VO(e){return new Promise(async(t,r)=>{let n=Cse(BO,["--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(VO,"reloadNATS");async function iie(){let{pid_file_path:e}=Xu($e.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await VO(e)}a(iie,"reloadNATSHub");async function oie(){let{pid_file_path:e}=Xu($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await VO(e)}a(oie,"reloadNATSLeaf");function aie(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(aie,"requestErrorHandler");async function cie(e,t){let r=t+Mr.SERVER_SUFFIX.LEAF,{connection:n}=await Ki(),{jsm:s}=await mie(r),{schema:i,table:o}=e,c=gg.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 rie(s,c,n.info.server_name)}catch(u){ai.trace(u)}})}a(cie,"updateRemoteConsumer");async function lie(e,t,r,n){let s=gg.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&&Use()<Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=vO();await c(o)}await Mse(o),n==="stop"&&await Eg.async_set_timeout(1e3)}a(lie,"updateConsumerIterator");function vk(e){return Lse.writeTransaction($e.SYSTEM_SCHEMA_NAME,$e.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(vk,"exclusiveLock");async function Uk(e,t){let r=gg.createNatsTableStreamName(e,t),n=await Sg(),s=_ie(e,t,n);await $O(r,[s])}a(Uk,"createLocalTableStream");async function uie(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(uie,"createTableStreams");async function xk(e,t,r=void 0){if(Nr.get($e.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=gg.createNatsTableStreamName(e,t),{domain:s}=Xu($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await ip()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")ai.warn(n);else throw n}}a(xk,"purgeTableStream");async function die(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(die,"purgeSchemaTableStreams");async function fie(e){return(await op()).streams.info(e)}a(fie,"getStreamInfo");function _ie(e,t,r){return`${Mr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(_ie,"createSubjectName");async function Sg(){if(np)return np;if(np=(await op())?.nc?.info?.server_name,np===void 0)throw new Error("Unable to get jetstream manager server name");return np}a(Sg,"getJsmServerName");async function pie(){let e=await op(),t=await Sg(),r=await Dk();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=hie(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let f=u.join(".");ai.trace(`Updating stream subject name from: ${i} to: ${f}`),s.subjects[0]=f,await e.streams.update(s.name,s)}}a(pie,"updateLocalStreams");function hie(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(hie,"updateStreamLimits");async function mie(e){let t,r;try{t=await Jr.jetstream({domain:e}),r=await Jr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw ai.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(mie,"connectToRemoteJS")});function KO(e){let t=e.get(Tg),r=t?(0,Zu.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:cp(e)??1,nodes:[]})})}i[n]=0,e.putSync(Tg,(0,Zu.pack)(r))}return r}function ap(e){return KO(e).remoteNameToId}function kk(e,t){let r=KO(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,Zu.pack)(r)),s}function Ag(e,t){let r=KO(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,Zu.pack)(r))}return Hk.trace?.("The remote node name map",e,n,s),s}var Hk,Zu,Tg,YO=be(()=>{Hk=M(Ii());es();Zu=require("msgpackr"),Tg=Symbol.for("remote-ids");a(KO,"getIdMappingRecord");a(ap,"exportIdMapping");a(kk,"remoteToLocalNodeId");a(Ag,"getIdOfRemoteNode")});var WO={};ve(WO,{commits_awaiting_replication:()=>td,getHDBNodeTable:()=>ar,getReplicationSharedStatus:()=>Rg,iterateRoutes:()=>up,shouldReplicateToNode:()=>lp,subscribeToNodeUpdates:()=>rd});function ar(){return Fk||(Fk=dt({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"revoked_certificates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function Rg(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(32),n&&{callback:n}))}function rd(e){ar().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 ar().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 lp(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&ar().primaryStore.get(Xe())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function Eie(){rd(e=>{La({},(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=Rg(i,r,n,()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:f}of td.get(r)||[])u>l&&u<=c&&f();o.lastTime=c});o.lastTime=0,s.set(r,o)}})})}function*up(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=ed.default.get(B.REPLICATION_SECUREPORT)??(!ed.default.get(B.REPLICATION_PORT)&&ed.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||ed.default.get(B.REPLICATION_PORT)||ed.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,ed,Vk,Fk,Gk,td,ul=be(()=>{Pe();es();Am();qk=require("worker_threads"),$k=M(pe()),ed=M(ae());H();Vk=M(Ii());server.nodes=[];a(ar,"getHDBNodeTable");a(Rg,"getReplicationSharedStatus");a(rd,"subscribeToNodeUpdates");a(lp,"shouldReplicateToNode");Gk=new Map;SL((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})`);td||(td=new Map,Eie());let n=td.get(e);return n||(n=[],td.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(Eie,"startSubscriptionToReplications");a(up,"iterateRoutes")});var zk={};ve(zk,{connectedToNode:()=>dl,disconnectedFromNode:()=>id,ensureNode:()=>Io,requestClusterStatus:()=>Wk,startOnMainThread:()=>jO});async function jO(e){let t=0,r=Je();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,cp(l.auditStore));break}}}Yi.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes?.search([])||[])i.push(o);for(let o of up(e))try{let c=!o.subscriptions;if(c){let u=Xe();ar().primaryStore.get(u)===void 0&&await Io(u,{name:u,url:e.url??Ma(),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)}rd(s)});let n;function s(i,o=i?.name){let c=Xe()&&o===Xe()||Ma()&&i?.url===Ma();if(c){let d=!!i?.replicates;if(n!==void 0&&n!==d)for(let p of ar().search([]))p.replicates&&p.name!==o&&s(p,p.name);n=d}if(ot.trace("Setting up node replication for",i),!i){for(let[d,p]of wo){let _;for(let[h,{worker:S,nodes:g}]of p){let R=g[0];if(R&&R.name==o){_=!0;for(let[E,{worker:A}]of p)p.delete(E),ot.warn("Node was deleted, unsubscribing from node",o,E,d),A?.postMessage({type:"unsubscribe-from-node",node:o,database:E,url:d});break}}if(_){wo.get(d).iterator.remove(),wo.delete(d);return}}return}if(c)return;if(!i.url){ot.info(`Node ${i.name} is missing url`);return}let l=wo.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(ot.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 nd)if(i.url===p.url){nd.delete(d);break}nd.set(i.name,i)}let u=Je();if(l||(l=new Map,wo.set(i.url,l)),l.iterator=La(e,(d,p,_)=>{_?f(p,!0):f(p,!1)}),i.subscriptions)for(let d of i.subscriptions){let p=d.database||d.schema;u[p]||(ot.warn(`Database ${p} not found for node ${i.name}, making a subscription anyway`),f(p,!1))}function f(d,p){ot.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:Xe(),start_time:yg.get(d),end_time:Date.now(),replicates:!0}),yg.delete(d));let g=lp(i,d),R=Yi.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):sd(E)},gie);else{ot.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],ar().primaryStore.get(Xe())?.replicates),ar().primaryStore.get(Xe())?.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"),id=a(function(i){try{ot.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(nd.keys()),c=o.sort(),l=c.indexOf(i.name||ci(i.url));if(l===-1){ot.warn("Disconnected node not found in node map",i.name,o);return}let u=wo.get(i.url),f=u?.get(i.database);if(!f){ot.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=nd.get(_);u=wo.get(h.url);let S=u?.get(i.database);if(!S){p=(p+1)%c.length;continue}let{worker:g,nodes:R}=S,E=!1;for(let A of f.nodes){if(R.some(O=>O.name===A.name)){ot.info(`Disconnected node is already failing over to ${_} for ${i.database}`);continue}R.push(A),E=!0}if(!E){ot.info(`Disconnected node ${i.name} has no nodes to fail over to ${_}`);return}f.redirectingTo=S,ot.info(`Failing over ${i.database} from ${i.name} to ${_}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:R}):sd({database:i.database,nodes:R});return}ot.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){ot.error("Error failing over node",o)}},"disconnectedFromNode"),dl=a(function(i){let o=wo.get(i.url),c=o?.get(i.database);if(!c){ot.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}):sd({database:i.database,nodes:u}))}},"connectedToNode"),(0,Yi.onMessageByType)("disconnected-from-node",id),(0,Yi.onMessageByType)("connected-to-node",dl),(0,Yi.onMessageByType)("request-cluster-status",Wk)}function Wk(e,t){let r=[];for(let[n,s]of nd)try{let i=wo.get(s.url);ot.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,zO.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){ot.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Io(e,t){let r=ar();e=e??ci(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){ot.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(ot.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,zO.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])]}ot.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Yi,bg,ot,zO,Kk,Yk,gie,wo,id,dl,nd,yg,dp=be(()=>{Pe();Yi=M(et());es();bg=require("worker_threads");ul();ot=M(z()),zO=require("lodash"),Kk=M(ae());H();Yk=require("crypto"),gie=200,wo=new Map,nd=new Map,yg=new Map;a(jO,"startOnMainThread");a(Wk,"requestClusterStatus");bg.parentPort&&(id=a(e=>{bg.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),dl=a(e=>{bg.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Yi.onMessageByType)("subscribe-to-node",e=>{sd(e)}),(0,Yi.onMessageByType)("unsubscribe-from-node",e=>{Og(e)}));a(Io,"ensureNode")});var ts=w(EF=>{"use strict";var cr=require("path"),On=require("fs-extra"),od=require("node-forge"),eF=require("net"),{generateKeyPair:JO,X509Certificate:Co,createPrivateKey:tF}=require("crypto"),Sie=require("util");JO=Sie.promisify(JO);var bt=od.pki,li=require("joi"),{v4:rF}=require("uuid"),{validateBySchema:tN}=ft(),pt=z(),Os=ae(),Ns=(H(),C(q)),{CONFIG_PARAMS:ad}=Ns,ui=qy(),{ClientError:Ua}=pe(),Ng=require("node:tls"),{relative:nF,join:Tie}=require("node:path"),{CERT_PREFERENCE_APP:UPe,CERTIFICATE_VALUES:jk}=ui,Aie=da(),XO=yt(),{table:Rie,getDatabases:yie,databases:QO}=(Pe(),C(tt)),{getJWTRSAKeys:Qk}=(zu(),C(ep));Object.assign(EF,{generateKeys:sN,updateConfigCert:dF,createCsr:Die,signCertificate:Lie,setCertTable:cd,loadCertificates:cF,reviewSelfSignedCert:oN,createTLSSelector:_F,listCertificates:hF,addCertificate:Hie,removeCertificate:Fie,createNatsCerts:Uie,generateCertsKeys:vie,getReplicationCert:_p,getReplicationCertAuth:Pie,renewSelfSigned:xie,hostnamesFromCert:mF,getKey:Gie});var{urlToNodeName:sF,getThisNodeUrl:bie,getThisNodeName:Ig,clearThisNodeName:Oie}=(es(),C(Po)),{readFileSync:Nie,watchFile:wie,statSync:iF}=require("node:fs"),xPe=ae(),{getTicketKeys:Iie,onMessageFromWorkers:Cie}=et(),va=z(),{isMainThread:oF}=require("worker_threads"),{TLSSocket:aF,createSecureContext:BPe}=require("node:tls"),rN=3650,fp=["127.0.0.1","localhost","::1"],nN=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];Cie(async e=>{e.type===Ns.ITC_EVENT_TYPES.RESTART&&(Os.initSync(!0),await oN())});var vr;function Ba(){return vr||(vr=yie().system.hdb_certificate,vr||(vr=Rie({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(Ba,"getCertTable");async function _p(){let e=_F("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 Co(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(_p,"getReplicationCert");async function Pie(){Ba();let e=(await _p()).options.cert,r=new Co(e).issuer.match(/CN=(.*)/)?.[1];return vr.get(r)}a(Pie,"getReplicationCertAuth");var Jk,xa=new Map;function cF(){if(Jk)return;Jk=!0;let e=[{configKey:ad.TLS},{configKey:ad.OPERATIONSAPI_TLS}];Ba();let t=cr.dirname(XO.getConfigFilePath()),r;for(let{configKey:n}of e){let s=XO.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&nF(Tie(t,"keys"),o);c&&Xk(o,l=>{xa.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 Co(_),S;try{S=aN(h)}catch(A){pt.error("error extracting common name from certificate",A);return}if(S==null){pt.error("error extracting common name from certificate");return}if(h.checkIssued(new Co(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),wie(e,{persistent:!1},s)}a(Xk,"loadAndWatch");function ZO(){let e=bie();if(e==null){let t=fp[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return sF(e)}a(ZO,"getHost");function wg(){let e=Ig();if(e==null){let t=fp[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(wg,"getCommonName");async function Die(){let e=await _p(),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()},...nN];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),od.pki.certificationRequestToPem(n)}a(Die,"createCsr");function lF(){let e=fp.includes(wg())?fp:[...fp,wg()];return e.includes(ZO())||e.push(ZO()),[{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 Lie(e){let t={},r=cr.join(Os.getHdbBasePath(),Ns.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;Ba();for await(let f of vr.search([]))if(f.is_authority&&!f.details.issuer.includes("HarperDB-Certificate-Authority")){if(xa.has(f.private_key_name)){n=xa.get(f.private_key_name),s=f;break}else if(f.private_key_name&&await On.exists(cr.join(r,f.private_key_name))){n=On.readFile(cr.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await eN();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=od.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()+rN),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,od.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(Lie,"signCertificate");async function Mie(e,t){await cd({name:Ig(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await cd({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(Mie,"createCertificateTable");async function cd(e){let t=new Co(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},Ba(),await vr.patch(e)}a(cd,"setCertTable");async function sN(){let e=await JO("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(sN,"generateKeys");async function iN(e,t,r){let n=bt.createCertificate();if(!t){let o=await _p();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()+rN);let i=[{name:"commonName",value:wg()},...nN];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(lF()),n.sign(e,od.md.sha256.create()),bt.certificateToPem(n)}a(iN,"generateCertificates");async function eN(){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 Co(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(eN,"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()+rN);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${Os.get(ad.REPLICATION_HOSTNAME)??sF(Os.get(ad.REPLICATION_URL))??rF().split("-")[0]}`},...nN];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,od.md.sha256.create());let o=cr.join(Os.getHdbBasePath(),Ns.LICENSE_KEY_DIR_NAME),c=cr.join(o,ui.PRIVATEKEY_PEM_NAME);return r&&await On.writeFile(c,bt.privateKeyToPem(e)),n}a(uF,"generateCertAuthority");async function vie(){let{private_key:e,public_key:t}=await sN(),r=await uF(e,t),n=await iN(e,t,r);await Mie(n,r),dF()}a(vie,"generateCertsKeys");async function Uie(){let e=await iN(bt.privateKeyFromPem(ui.CERTIFICATE_VALUES.key),void 0,bt.certificateFromPem(ui.CERTIFICATE_VALUES.cert)),t=cr.join(Os.getHdbBasePath(),Ns.LICENSE_KEY_DIR_NAME),r=cr.join(t,ui.NATS_CERTIFICATE_PEM_NAME);await On.exists(r)||await On.writeFile(r,e);let n=cr.join(t,ui.NATS_CA_PEM_NAME);await On.exists(n)||await On.writeFile(n,ui.CERTIFICATE_VALUES.cert)}a(Uie,"createNatsCerts");async function xie(){Ba();for await(let e of vr.search([{attribute:"is_self_signed",value:!0}]))await vr.delete(e.name);await oN()}a(xie,"renewSelfSigned");async function oN(){Oie(),await cF(),Ba();let e=await eN();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=Os.get(ad.TLS_PRIVATEKEY),n=cr.join(Os.getHdbBasePath(),Ns.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 sN(),await On.exists(cr.join(n,ui.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${rF().split("-")[0]}.pem`),await On.writeFile(cr.join(n,i),bt.privateKeyToPem(s))}let o=await uF(s,bt.setRsaPublicKey(s.n,s.e),!1);await cd({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 _p()){let r=Ig();pt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await eN();let n=bt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await iN(bt.privateKeyFromPem(e.private_key),s,n);await cd({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(oN,"reviewSelfSignedCert");function dF(){let e=Aie(Object.keys(Ns.CONFIG_PARAM_MAP),!0),t=cr.join(Os.getHdbBasePath(),Ns.LICENSE_KEY_DIR_NAME),r=cr.join(t,ui.PRIVATEKEY_PEM_NAME),n=cr.join(t,ui.NATS_CERTIFICATE_PEM_NAME),s=cr.join(t,ui.NATS_CA_PEM_NAME),i=Ns.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),XO.updateConfigValue(void 0,void 0,o,!1,!0)}a(dF,"updateConfigCert");function fF(e){return e.startsWith("-----BEGIN")?e:Nie(e,"utf8")}a(fF,"readPEM");var Zk=Ng.createSecureContext;Ng.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 Bie=aF.prototype._init;aF.prototype._init=function(e,t){Bie.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 Co(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 Co(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:Iie(),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=Ng.createSecureContext(R);E.name=d.name,E.options=R,E.quality=_,E.certificateAuthorities=Array.from(fl),E.certStart=S.toString().slice(0,100);let A=d.hostnames??mF(g);Array.isArray(A)||(A=[A]);let O;for(let v of A)if(v){v[0]==="*"&&(s=!0,v=v.slice(1)),v===ZO()&&(_+=2),eF.isIP(v)&&(O=!0);let F=r.get(v)?.quality??0;_>F&&r.set(v,E)}else va.error("No hostname found for certificate at",Ng.certificate);va.trace("Adding TLS",E.name,"for",o.ports||"client","cert named",d.name,"hostnames",A,"quality",_,"best quality",f),_>f&&(i.defaultContext=n=E,f=_,o&&(o.defaultContext=E))}catch(p){va.error("Error applying TLS for",d.name,p)}o?.secureContextsListeners.forEach(d=>d()),c(n)}catch(f){l(f)}}a(u,"updateTLS"),QO.system.hdb_certificate.subscribe({listener:a(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(o,c){va.info("TLS requested for",o||"(no SNI)");let l=o;for(;;){let f=r.get(l);if(f)return va.debug("Found certificate for",o,f.certStart),f.updatedContext&&(f=f.updatedContext),c(null,f);if(s&&l){let d=l.indexOf(".",1);d<0?l="":l=l.slice(d)}else break}o?va.debug("No certificate found to match",o,"using the default certificate"):va.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.updatedContext&&(u=u.updatedContext):va.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(_F,"createTLSSelector");async function pF(e){let t=xa.get(e);return!t&&e?await On.readFile(cr.join(Os.get(ad.ROOTPATH),Ns.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(pF,"getPrivateKeyByName");async function hF(){Ba();let e=[];for await(let t of vr.search([]))e.push(t);return e}a(hF,"listCertificates");async function Hie(e){let t=tN(e,li.object({name:li.string().required(),certificate:li.string().required(),is_authority:li.boolean().required(),private_key:li.string(),hosts:li.array(),uses:li.array()}));if(t)throw new Ua(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new Co(n),c=!1,l=!1,u;for(let[_,h]of xa)!s&&!c&&o.checkPrivateKey(tF(h))&&(c=!0,u=_),s&&s===h&&(l=!0,u=_);if(!i&&!s&&!c)throw new Ua("A suitable private key was not found for this certificate");let f;if(!r){try{f=aN(o)}catch(_){pt.error(_)}if(f==null)throw new Ua("Error extracting certificate common name, please provide a name parameter")}let d=kie(r??f);s&&!c&&!l&&(await On.writeFile(cr.join(Os.getHdbBasePath(),Ns.LICENSE_KEY_DIR_NAME,d+".pem"),s),xa.set(d,s));let p={name:r??f,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(p.private_key_name=u??d+".pem"),await cd(p),"Successfully added certificate: "+d}a(Hie,"addCertificate");function kie(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(kie,"sanitizeName");async function Fie(e){let t=tN(e,li.object({name:li.string().required()}));if(t)throw new Ua(t.message);let{name:r}=e;Ba();let n=await vr.get(r);if(!n)throw new Ua(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(cr.join(Os.getHdbBasePath(),Ns.LICENSE_KEY_DIR_NAME,s)))}return await vr.delete(r),"Successfully removed "+r}a(Fie,"removeCertificate");function aN(e){return e.subject.match(/CN=(.*)/)?.[1]}a(aN,"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):[aN(e)]}a(mF,"hostnamesFromCert");async function Gie(e){if(e.bypass_auth!==!0)throw new Ua("Unauthorized","401");let t=tN(e,li.object({name:li.string().required()}));if(t)throw new Ua(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await Qk()).privateKey;if(r===".jwtPublic")return(await Qk()).publicKey;if(xa.get(r))return xa.get(e.name);throw new Ua("Key not found")}a(Gie,"getKey")});var xF={};ve(xF,{CONFIRMATION_STATUS_POSITION:()=>UF,NodeReplicationConnection:()=>pp,OPERATION_REQUEST:()=>fN,RECEIVED_TIME_POSITION:()=>pN,RECEIVED_VERSION_POSITION:()=>_N,SENDING_TIME_POSITION:()=>Mg,createWebSocket:()=>Ug,database_subscriptions:()=>ka,replicateOverWS:()=>hp,table_update_listeners:()=>mN});async function Ug(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=Xe(),i;if(e.includes("wss://")){if(!lN){let l=(0,LF.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),lN=u.secureContexts}if(i=lN.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 hp(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||ka,d,p,_=!1,h=t.subscription;h?.then&&h.then(m=>h=m);let S=t.tables||u&&Je()[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 A,O,v,F,G,Y,te,ie=1e3,X,ne=0,Q=0,he=0,Re=new Map,Ce=[],me=0,Zt;if(t.url){let m=a(()=>{G&&Q===e._socket?.bytesRead&&he===e._socket?.bytesWritten?e.terminate():(G=performance.now(),e.ping(),Q=e._socket?.bytesRead,he=e._socket?.bytesWritten)},"send_ping");v=setInterval(m,wF).unref(),m()}else lt();e._socket?.setMaxListeners(200);function lt(){clearTimeout(F),Q=e._socket?.bytesRead,he=e._socket?.bytesWritten,F=setTimeout(()=>{Q===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(lt,"resetPingTimer");function yr(){return p||(p=Rg(d,u,E)),p}a(yr,"getSharedStatus"),u&&oa(u);let Es,xn,nu=[],su=[],xA,BA=[],Lt=[],mf=[],jh=150,Qh=25,Ef=0,Jh=0,De=!1,gf,ln,Ir,iu;e.on("message",m=>{ne=performance.now();try{let T=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)([ld])),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,Io(E,U)}if(t.connection&&(t.connection.nodeName=E),le.debug?.(s,"received node name:",E,"db:",u),!u)try{oa(u=P[2]),u==="system"&&(Es=La(t,(U,ue)=>{au(ue)&&aa(ue)}),e.on("close",()=>{Es?.remove()}))}catch(U){le.warn?.(s,"Error setting database",U),e.send((0,ze.encode)([ld])),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=uN(U,qe[ue]?.[U.table])):ce=uN(U,qe[ue]?.[U.table]),d||(d=ce?.auditStore),S||(S=Je()?.[ue]))}break}case ld:un();break;case fN: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)([Pg,ue]))},ue=>{e.send((0,ze.encode)([Pg,{requestId:L.requestId,error:ue instanceof Error?ue.toString():ue}]))})}catch(U){e.send((0,ze.encode)([Pg,{requestId:L.requestId,error:U instanceof Error?U.toString():U}]))}break;case Pg:let{resolve:D,reject:x}=g.get(L.requestId);L.error?x(new Error(L.error)):D(L),g.delete(L.requestId);break;case cN:let $=P[3];S||(u?le.error?.(s,"No tables found for",u):le.error?.(s,"Database name never received"));let j=S[$];j=uN({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,xA=P[2],le.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${xA}`);break;case AF:let oe=k;mf[oe]=L;break;case bF:yr()[UF]=L,le.trace?.(s,"received and broadcasting committed update",L),yr().buffer.notify();break;case yF:A=L,h.send({type:"end_txn",localTime:A,remoteNodeIds:R});break;case Dg:{let U=P[1],{fileId:ue,size:ce,finished:fe,error:ee}=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 dN.PassThrough,W.expectedSize=ce,Re.set(ue,W)),W.lastChunk=Date.now(),fe?(ee?(W.on("error",()=>{}),W.destroy(new Error("Blob error: "+ee))):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 ee=fe.primaryStore.getBinaryFast(Symbol.for("structures")),W=ee.length;if(W!==Jh){Jh=W;let Ae=(0,ze.decode)(ee);e.send((0,ze.encode)([cN,{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)([Cg,U,{value:Ae.value,expiresAt:Ae.expiresAt,version:Ae.version,residencyId:Ae.residencyId,nodeId:Ae.nodeId,user:Ae.user}])}else ue=(0,ze.encode)([Cg,U])}catch(ce){ue=(0,ze.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]),ee=P[2];if(ee?.error)ue(new Error(ee.error));else if(ee){let W=nu[ce].decoder.decode(ee.value);ee.value=W,ee.key=fe,U(ee)}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(Qe=>{le.debug?.("Waiting for subscription to database "+u),Ee=Qe}),h.ready=Ee,ka.set(u,h)}if(r.name)ue=ar().subscribe(r.name),ue.then(async Ee=>{U=Ee;for await(let Qe of U){let nt=Qe.value;if(!(nt?.replicates===!0||nt?.replicates?.receives||nt?.subscriptions?.some(qt=>(qt.database||qt.schema)===u&&qt.publish!==!1))){ce=!0,e.send((0,ze.encode)([ld])),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)([ld])),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],ee=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,ut,rt=a((Ee,Qe)=>{if(Ee.type==="end_txn"){W.txnTime&&(o[i]!==66&&le.error?.("Invalid encoding of message"),cu(9),cu(vg),uu(ut=Qe),Gr()),i=c,W.txnTime=0;return}let nt=Ee.nodeId,qt=Ee.tableId,$t=Ae[qt];if(!$t&&($t=Ae[qt]=ee(h.tableById[qt]),!$t))return le.debug?.("Not subscribed to table",qt);let qr=$t.table,Tc=qr.primaryStore,Mt=Tc.encoder;(Ee.extendedType&zm||!Mt.typedStructs)&&(Mt._mergeStructures(Mt.getStructures()),Mt.typedStructs&&(Mt.lastTypedStructuresLength=Mt.typedStructs.length));let Zh=_e[nt];if(!(Zh&&Zh.startTime<Qe&&(!Zh.endTime||Zh.endTime>Qe)))return Lg&&le.trace?.(s,"skipping replication update",Ee.recordId,"to:",E,"from:",nt,"subscribed:",_e),nD();Lg&&le.trace?.(s,"sending replication update",Ee.recordId,"to:",E,"from:",nt,"subscribed:",_e);let HA=Ee.version;W.txnTime!==HA&&(W.txnTime&&(Lg&&le.trace?.(s,"new txn time, sending queued txn",W.txnTime),o[i]!==66&&le.error?.("Invalid encoding of message"),Gr()),W.txnTime=HA,i=c,uu(HA));let Ac=Ee.residencyId,kA=ou(Ac,qr),em;if(kA&&!kA.includes(E)){let Rc=ou(Ee.previousResidencyId,qr);if(Rc&&!Rc.includes(E)&&(Ee.type==="put"||Ee.type==="patch")||qr.getResidencyById)return nD();let Af=Ee.recordId;le.trace?.(s,"sending invalidation",Af,E,"from",nt);let la=0;Ac&&(la|=xc),Ee.previousResidencyId&&(la|=Bc);let Ys,dn=null;for(let tm in qr.indices){if(!dn){if(Ys=Ee.getValue(Tc,!0),!Ys)break;dn={}}dn[tm]=Ys[tm]}em=bu(Ee.version,qt,Af,null,nt,Ee.user,Ee.type==="put"||Ee.type==="patch"?"invalidate":Ee.type,Mt.encode(dn),la,Ac,Ee.previousResidencyId,Ee.expiresAt)}function nD(){le.trace?.(s,"skipping audit record",Ee.recordId),Y||(Y=setTimeout(()=>{Y=null,(ut||0)+NF/2<ye&&(Lg&&le.trace?.(s,"sending skipped sequence update",ye),e.send((0,ze.encode)([yF,ye])))},NF).unref())}a(nD,"skipAuditRecord");let FA=Mt.typedStructs,GA=Mt.structures;if((FA?.length!=$t.typed_length||GA?.length!=$t.structure_length)&&($t.typed_length=FA?.length,$t.structure_length=GA.length,le.debug?.(s,"send table struct",$t.typed_length,$t.structure_length),$t.sentName||($t.sentName=!0),e.send((0,ze.encode)([cN,{typedStructs:FA,structures:GA,attributes:qr.attributes,schemaDefined:qr.schemaDefined},qt,$t.table.tableName]))),Ac&&!Lt[Ac]&&(e.send((0,ze.encode)([AF,kA,Ac])),Lt[Ac]=!0),em)cu(em.length),lu(em);else{let Rc=Ee.encoded;Ee.extendedType&qn&&IR(()=>Ee.getValue(Tc),async la=>{let Ys=Bm(la);try{let dn;me++;for await(let tm of la.stream()){if(dn&&(le.debug?.("Sending blob chunk",Ys,"length",dn.length),e.send((0,ze.encode)([Dg,{fileId:Ys,size:la.size},dn]))),dn=tm,ce)return;e._socket.writableNeedDrain&&(le.debug?.("draining",Ys),await new Promise(TJ=>e._socket.once("drain",TJ)),le.debug?.("drained",Ys))}le.debug?.("Sending final blob chunk",Ys,"length",dn.length),e.send((0,ze.encode)([Dg,{fileId:Ys,size:la.size,finished:!0},dn]))}catch(dn){le.debug?.("Error sending blob",dn),e.send((0,ze.encode)([Dg,{fileId:Ys,finished:!0,error:dn.toString()},Buffer.alloc(0)]))}finally{me--,me<Qh&&Zt?.()}});let Af=Rc[0]===66?8:0;cu(Rc.length-Af),lu(Rc,Af),le.trace?.("wrote record",Ee.recordId,"length:",Rc.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 hN.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(ee),_e=[];for(let{name:Qe,startTime:nt,endTime:qt}of Ir){let $t=Ag(Qe,d);le.debug?.("subscription to",Qe,"using local id",$t,"starting",nt),_e[$t]={startTime:nt,endTime:qt}}aa(u),Es||(Es=ml(Qe=>{Qe.databaseName===u&&aa(u)}),xn=mp(Qe=>{Qe===u&&(e.send((0,ze.encode)([ld])),un())}),e.on("close",()=>{Es?.remove(),xn?.remove()})),e.send((0,ze.encode)([TF,ap(h.auditStore),Ir.map(({name:Qe})=>Qe)]));let Ee=!0;do{isFinite(ye)||(le.warn?.("Invalid sequence id "+ye),un(1008,"Invalid sequence id"+ye));let Qe;if(Ee&&!ce&&(Ee=!1,!(gN(d)<=ye)&&(CF.default.get(B.REPLICATION_COPYTABLESTOCATCHUP)??qie)&&server.nodes[0]?.name===E)){le.info?.("Replicating all tables to",E);let qt=ye,$t=xg(d);for(let qr in S){if(!ee(qr))continue;let Tc=S[qr];for(let Mt of Tc.primaryStore.getRange({snapshot:!1})){if(ce)return;Mt.localTime>=ye&&(le.trace?.(s,"Copying record from",u,qr,Mt.key,Mt.localTime),qt=Math.max(Mt.localTime,qt),Qe=!0,yr()[Mg]=1,rt({recordId:Mt.key,tableId:Tc.tableId,type:"put",getValue(){return Mt.value},encoded:Tc.primaryStore.getBinary(Mt.key),version:Mt.version,residencyId:Mt.residencyId,nodeId:$t,extendedType:Mt.metadataFlags},Mt.localTime))}}ye=qt}for(let{key:nt,value:qt}of d.getRange({start:ye||1,exclusiveStart:!0,snapshot:!1})){if(ce)return;let $t=wt(qt);le.debug?.("sending audit record",new Date(nt)),yr()[Mg]=nt,ye=nt,rt($t,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>Qh?await new Promise(qr=>{Zt=qr}):await new Promise(setImmediate),ln.startTime=nt,Qe=!0}Qe&&rt({type:"end_txn"},ye),yr()[Mg]=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}T.position=8;let I=!0,y,b;do{yr();let P=T.readInt();if(P===9&&T.getUint8(T.position)==vg){T.position++,A=b=T.readFloat64(),p[_N]=A,p[pN]=Date.now(),le.trace?.("received remote sequence update",A,u);break}let N=T.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=mf[L.residencyId],le.trace?.(s,"received residency list",D,L.type,L.recordId));try{wR(()=>{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 dN.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[_N]=L.version,p[pN]=Date.now(),h.send(y),T.position=N+P}while(T.position<m.byteLength);Ef++,ir(m.byteLength,"bytes-received",`${E}.${u}.${y?.table||"unknown_table"}`,"replication","ingest"),Ef>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:A,remoteNodeIds:R,async onCommit(){if(y){let P=Date.now()-y.timestamp;ir(P,"replication-latency",E+"."+u+"."+y.table,y.type,"ingest")}Ef--,De&&(De=!1,e.resume(),le.debug?.(`Replication resuming ${E}`)),Ce.length>0&&await Promise.all(Ce),le.trace?.("All blobs finished"),!O&&b&&(le.trace?.(s,"queuing confirmation of a commit at",b),setTimeout(()=>{e.send((0,ze.encode)([bF,O])),le.trace?.(s,"sent confirmation of a commit at",O),O=null},$ie)),O=b,le.debug?.("last sequence committed",new Date(b),u)}})}catch(T){le.error?.(s,"Error handling incoming replication message",T)}}),e.on("ping",lt),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-G,dl({name:E,database:u,url:t.url,latency:t.connection.latency})),G=null}),e.on("close",(m,T)=>{clearInterval(v),clearTimeout(F),clearInterval(te),ln&&ln.emit("close"),gf&&gf.end();for(let[I,{reject:y}]of g)y(new Error(`Connection closed ${T?.toString()} ${m}`));le.debug?.(s,"closed",m,T?.toString())});function Sf(){}a(Sf,"recordRemoteNodeSequence");function un(m,T){e.isFinished=!0,e.close(m,T)}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 b of y.value.nodes||[])b.lastTxnTime>(m.get(b.id)??0)&&m.set(b.id,b.lastTxnTime)}catch(y){if(!y.message.includes("Can not re"))throw y}let T=t.connection?.nodeSubscriptions?.[0];R=[];let I=t.connection?.nodeSubscriptions.map((y,b)=>{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&&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)),T!==y){let x=d&&Ag(T.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",T.name,D))}return R.push(L),m.get(L)>D&&(D=m.get(L),le.debug?.("Updating start time from more recent txn recorded",T.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(X),I.length>0)e.send((0,ze.encode)([gF,I]));else{let y=a(()=>{let b=performance.now();X=setTimeout(()=>{ne<=b?un(1008,"No nodes to subscribe to"):y()},ie)},"schedule_close");y()}}a(Fr,"sendSubscriptionRequestUpdate");function ou(m,T){if(!m)return;let I=BA[m];return I||(I=T.getResidencyRecord(m),BA[m]=I),I}a(ou,"getResidence");function au(m){return!(Ha&&Ha!="*"&&!Ha[m]&&!Ha.includes?.(m)&&!Ha.some?.(T=>T.name===m))}a(au,"checkDatabaseAccess");function oa(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=Je()?.[m]);let T=Xe();if(T===E)throw T?new Error("Should not connect to self",T):new Error("Node name not defined");return Xh(T,m),!0}a(oa,"setDatabase");function Xh(m,T){let I=Je()?.[T],y=[];for(let b in I){let P=I[b];y.push({table:b,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",T),e.send((0,ze.encode)([SF,m,T,y]))}a(Xh,"sendNodeDBName");function aa(m){let T=Je()?.[m],I=[];for(let y in T){if(Ir&&!Ir.some(P=>P.replicateByDefault?!P.tables.includes(y):P.tables.includes(y)))continue;let b=T[y];I.push({table:y,schemaDefined:b.schemaDefined,attributes:b.attributes.map(P=>({name:P.name,type:P.type,isPrimaryKey:P.isPrimaryKey}))})}e.send((0,ze.encode)([OF,I,m]))}a(aa,"sendDBSchema"),te=setInterval(()=>{for(let[m,T]of Re)T.lastChunk+3e4<Date.now()&&(le.warn?.(`Timeout waiting for blob stream to finish ${m} from ${E}`),Re.delete(m),T.end())},3e4).unref();let ca=1,Tf=[];return{end(){gf&&gf.end(),ln&&ln.emit("close")},getRecord(m){let T=ca++;return new Promise((I,y)=>{let b=[RF,T,m.table.tableId,m.id];Tf[m.table.tableId]||(b.push(m.table.tableName),Tf[m.table.tableId]=!0),e.send((0,ze.encode)(b)),g.set(T,{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 T=ca++;return m.requestId=T,e.send((0,ze.encode)([fN,m])),new Promise((I,y)=>{g.set(T,{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,T=0,I=m.length){let y=I-T;K(y),m.copy(o,c,T,I),c+=y}function uu(m){K(8),l.setFloat64(c,m),c+=8}function K(m){if(m+16>o.length-c){let T=Buffer.allocUnsafeSlow(c+m-i+65536>>10<<11);o.copy(T,0,i,c),c=c-i,i=0,o=T,l=new DataView(o.buffer,0,o.length)}}}function uN(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),dt({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var CF,ze,PF,DF,le,hN,LF,MF,_l,vF,dN,gF,SF,TF,ld,AF,cN,RF,Cg,fN,Pg,yF,bF,OF,Dg,UF,_N,pN,Mg,qie,mN,ka,Lg,NF,$ie,wF,lN,IF,pp,EN=be(()=>{Pe();ho();YO();SN();es();CF=M(ae());H();Ou();ze=require("msgpackr"),PF=require("ws"),DF=require("worker_threads"),le=M(Ii());dp();hN=require("events"),LF=M(ts()),MF=M(require("node:tls"));ul();_l=M(require("node:process")),vF=require("node:net");qi();Ts();dN=require("node:stream"),gF=129,SF=140,TF=141,ld=142,AF=130,cN=132,RF=133,Cg=134,fN=136,Pg=137,yF=143,bF=144,OF=145,Dg=146,UF=0,_N=1,pN=2,Mg=3,qie=_l.env.HDB_LEADER_URL||_l.argv.includes("--HDB_LEADER_URL"),mN=new Map,ka=new Map,Lg=!0,NF=300,$ie=2,wF=3e4;a(Ug,"createWebSocket");IF=1e3,pp=class extends hN.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??ci(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=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 Ug(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=hp(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&&(id({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(hp,"replicateOverWS");a(uN,"ensureTableIfChanged")});var Po={};ve(Po,{clearThisNodeName:()=>Jie,disableReplication:()=>Wie,enabled_databases:()=>Ha,forEachReplicatedDatabase:()=>La,getThisNodeId:()=>xg,getThisNodeName:()=>Xe,getThisNodeUrl:()=>Ma,hostnameToUrl:()=>Fg,lastTimeInAuditStore:()=>cp,monitorNodeCAs:()=>KF,replicateOperation:()=>Zie,replication_certificate_authorities:()=>pl,sendOperationToNode:()=>gp,servers:()=>Kie,setReplicator:()=>WF,start:()=>Yie,startOnMainThread:()=>jO,subscribeToNode:()=>sd,unsubscribeFromNode:()=>Og,urlToNodeName:()=>ci});function Yie(e){if(e.port||(e.port=ws.default.get(B.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=ws.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 up(e))t.set(ci(n.url),n);zie(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(),hp(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&lr.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&&lr.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=ar().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)){lr.warn("Revoked certificate used in attempt to connect to node",c.name,"certificate serial number",n.peerCertificate.serialNumber);return}else n.user=c;else lr.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:lr.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=kg.createSecureContext(l)}catch(c){lr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),KF(s),ws.default.get(B.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function KF(e){let t=0;rd(r=>{r?.ca&&(pl.add(r.ca),pl.size!==t&&(t=pl.size,e?.()))})}function Wie(e=!0){VF=e}function zie(e){VF||(Je(),Ha=e.databases,La(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||ka;for(let[s,i]of Ep){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),mN.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||ka,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(lr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new Hn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let f;for(let p of c){let _=jie(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:Vie++,table:t,entry:i,id:i.key};u.add(f);try{return await f.getRecord(d)}catch(p){if(f.isConnected)throw p;lr.warn("Error in load from node",Hg,p),l||(l=p)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function zF(e,t,r,n,s){let i=Ep.get(e);i||Ep.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new pp(e,t,r,n,s)),o.connect(),o.once("finished",()=>i.delete(r)),o}function jie(e,t,r){let n=HF.get(e)?.get(r);if(n)return n;let s=ar().primaryStore.get(e);return s?.url&&(n=zF(s.url,t,r,e,s.authorization),HF.set(e,Ep.get(s.url))),n}async function gp(e,t,r){r||(r={}),r.serverName=e.name;let n=await Ug(e.url,r),s=hp(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{lr.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function sd(e){try{$F.isMainThread&&lr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=ka.get(e.database);if(!t){let n;t=new Promise(s=>{lr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,ka.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=>lp(n,e.database)),e.replicateByDefault)}catch(t){lr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Og({name:e,url:t,database:r}){lr.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(ar().primaryStore.getRange({})));let n=Ep.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function Qie(){if(TN!==void 0)return TN;let e=ws.default.get(B.OPERATIONSAPI_TLS_CERTIFICATE)||ws.default.get(B.TLS_CERTIFICATE);if(e)return TN=new FF.X509Certificate((0,GF.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function Xe(){return Hg||(Hg=ws.default.get("replication_hostname")??ci(ws.default.get("replication_url"))??Qie()??kF("operationsapi_network_secureport")??kF("operationsapi_network_port")??"127.0.0.1")}function Jie(){Hg=void 0}function kF(e){let t=ws.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function Bg(e){let t=ws.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function xg(e){return ap(e)?.[Xe()]}function Ma(){let e=ws.default.get("replication_url");return e||Fg(Xe())}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 ci(e){if(e)return new URL(e).hostname}function La(e,t){for(let n of Object.getOwnPropertyNames(qe))r(n);return mp(n=>{r(n)}),ml((n,s)=>{r(n.databaseName)});function r(n){let s=qe[n];lr.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):Xie(n)&&t(s,n,!1)}a(r,"forDatabase")}function Xie(e){let t=qe[e];for(let r in t)if(t[r].replicate)return!0}function cp(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,lr.trace?.("Replicating operation",e.operation,"to nodes",Ye.nodes.map(n=>n.name));let r=await Promise.allSettled(Ye.nodes.map(n=>gp(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 ws,lr,FF,GF,kg,qF,$F,VF,Vie,Kie,pl,Ha,Ep,HF,TN,Hg,es=be(()=>{Pe();ga();_u();EN();Vr();ws=M(ae()),lr=M(z()),FF=require("crypto"),GF=require("fs");dp();ul();H();YO();kg=M(require("node:tls")),qF=M(pe()),$F=require("worker_threads"),Vie=1,Kie=[],pl=ws.default.get(B.REPLICATION_ENABLEROOTCAS)!==!1?new Set(kg.rootCertificates):new Set;a(Yie,"start");a(KF,"monitorNodeCAs");a(Wie,"disableReplication");a(zie,"assignReplicationSource");a(WF,"setReplicator");Ep=new Map;a(zF,"getConnection");HF=new Map;a(jie,"getConnectionByName");a(gp,"sendOperationToNode");a(sd,"subscribeToNode");a(Og,"unsubscribeFromNode");a(Qie,"getCommonNameFromCert");a(Xe,"getThisNodeName");a(Jie,"clearThisNodeName");Object.defineProperty(Ye,"hostname",{get(){return Xe()}});a(kF,"getHostFromListeningPort");a(Bg,"getPortFromListeningPort");a(xg,"getThisNodeId");Ye.replication={getThisNodeId:xg,exportIdMapping:ap};a(Ma,"getThisNodeUrl");a(Fg,"hostnameToUrl");a(ci,"urlToNodeName");a(La,"forEachReplicatedDatabase");a(Xie,"hasExplicitlyReplicatedTable");a(cp,"lastTimeInAuditStore");a(Zie,"replicateOperation")});var Vg=w((uDe,ZF)=>{"use strict";var ud=nE(),dd=ck(),eoe=z(),toe=require("uuid").v4,lDe=require("clone"),qg=yo(),fd=(H(),C(q)),roe=require("util"),Fa=Yn(),{handleHDBError:Nn,hdb_errors:noe}=pe(),{HDB_ERROR_MSGS:Gg,HTTP_STATUS_CODES:wn}=noe,{SchemaEventMsg:$g}=ni(),jF=or(),{getDatabases:soe}=(Pe(),C(tt)),{transformReq:_d}=se(),{replicateOperation:QF}=(es(),C(Po));ZF.exports={createSchema:ioe,createSchemaStructure:JF,createTable:ooe,createTableStructure:XF,createAttribute:doe,dropSchema:aoe,dropTable:coe,dropAttribute:loe,getBackup:foe};async function ioe(e){let t=await JF(e);return qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema)),t}a(ioe,"createSchema");async function JF(e){let t=ud.schema_object(e);if(t)throw Nn(t,t.message,wn.BAD_REQUEST,void 0,void 0,!0);if(_d(e),!await dd.checkSchemaExists(e.schema))throw Nn(new Error,Gg.SCHEMA_EXISTS_ERR(e.schema),wn.BAD_REQUEST,fd.LOG_LEVELS.ERROR,Gg.SCHEMA_EXISTS_ERR(e.schema),!0);return await Fa.createSchema(e),`database '${e.schema}' successfully created`}a(JF,"createSchemaStructure");async function ooe(e){return _d(e),e.hash_attribute=e.primary_key??e.hash_attribute,await XF(e)}a(ooe,"createTable");async function XF(e){let t=ud.create_table_object(e);if(t)throw Nn(t,t.message,wn.BAD_REQUEST,void 0,void 0,!0);if(ud.validateTableResidence(e.residence),!await dd.checkSchemaTableExists(e.schema,e.table))throw Nn(new Error,Gg.TABLE_EXISTS_ERR(e.schema,e.table),wn.BAD_REQUEST,fd.LOG_LEVELS.ERROR,Gg.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:toe(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await Fa.createTable(n,e);else throw Nn(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",wn.BAD_REQUEST);else await Fa.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(XF,"createTableStructure");async function aoe(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=ud.schema_object(e),n=t??r;if(n)throw Nn(n,n.message,wn.BAD_REQUEST,void 0,void 0,!0);_d(e);let s=await dd.checkSchemaExists(e.schema);if(s)throw Nn(new Error,s,wn.NOT_FOUND,fd.LOG_LEVELS.ERROR,s,!0);let i=await dd.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);await Fa.dropSchema(e),qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema)),await jF.purgeSchemaTableStreams(e.schema,o);let c=await QF(e);return c.message=`successfully deleted '${e.schema}'`,c}a(aoe,"dropSchema");async function coe(e){let t=ud.table_object(e);if(t)throw Nn(t,t.message,wn.BAD_REQUEST,void 0,void 0,!0);_d(e);let r=await dd.checkSchemaTableExists(e.schema,e.table);if(r)throw Nn(new Error,r,wn.NOT_FOUND,fd.LOG_LEVELS.ERROR,r,!0);await Fa.dropTable(e),await jF.purgeTableStream(e.schema,e.table);let n=await QF(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(coe,"dropTable");async function loe(e){let t=ud.attribute_object(e);if(t)throw Nn(t,t.message,wn.BAD_REQUEST,void 0,void 0,!0);_d(e);let r=await dd.checkSchemaTableExists(e.schema,e.table);if(r)throw Nn(new Error,r,wn.NOT_FOUND,fd.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Nn(new Error,"You cannot drop a hash attribute",wn.BAD_REQUEST,void 0,void 0,!0);if(fd.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Nn(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,wn.BAD_REQUEST,void 0,void 0,!0);try{return await Fa.dropAttribute(e),uoe(e),qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw eoe.error(`Got an error deleting attribute ${roe.inspect(e)}.`),n}}a(loe,"dropAttribute");function uoe(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(uoe,"dropAttributeFromGlobal");async function doe(e){_d(e);let t=soe()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Nn(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,wn.BAD_REQUEST,void 0,void 0,!0);return await Fa.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(doe,"createAttribute");function foe(e){return Fa.getBackup(e)}a(foe,"getBackup")});var tG=w((fDe,eG)=>{"use strict";var{OPERATIONS_ENUM:_oe}=(H(),C(q)),AN=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=_oe.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};eG.exports=AN});var RN=w((hDe,oG)=>{"use strict";var poe=Yn(),pDe=tG(),Kg=se(),Yg=(H(),C(q)),hoe=ae(),{handleHDBError:rG,hdb_errors:moe}=pe(),{HDB_ERROR_MSGS:nG,HTTP_STATUS_CODES:sG}=moe,Eoe=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=goe;async function goe(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(!hoe.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)&&Eoe.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await poe.readAuditLog(e)}a(goe,"readAuditLog")});var cG=w((EDe,aG)=>{"use strict";var{OPERATIONS_ENUM:Soe}=(H(),C(q)),yN=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Soe.GET_BACKUP,this.schema=t,this.table=r}};aG.exports=yN});var dG=w((ADe,uG)=>{"use strict";var Toe=Yn(),SDe=cG(),bN=se(),Aoe=(H(),C(q)),TDe=ae(),{handleHDBError:Roe,hdb_errors:yoe}=pe(),{HDB_ERROR_MSGS:lG,HTTP_STATUS_CODES:boe}=yoe;uG.exports=Ooe;async function Ooe(e){if(bN.isEmpty(e.schema))throw new Error(lG.SCHEMA_REQUIRED_ERR);if(bN.isEmpty(e.table))throw new Error(lG.TABLE_REQUIRED_ERR);let t=bN.checkSchemaTableExist(e.schema,e.table);if(t)throw Roe(new Error,t,boe.NOT_FOUND,Aoe.LOG_LEVELS.ERROR,t,!0);return await Toe.getBackup(read_audit_log_object)}a(Ooe,"getBackup")});var hG=w((yDe,pG)=>{"use strict";var Noe=ae(),Ga=require("joi"),woe=ft(),fG=require("moment"),Ioe=require("fs-extra"),ON=require("path"),Coe=require("lodash"),Sp=(H(),C(q)),{LOG_LEVELS:El}=(H(),C(q)),Poe="YYYY-MM-DD hh:mm:ss",Doe=ON.resolve(__dirname,"../logs");pG.exports=function(e){return woe.validateBySchema(e,Loe)};var Loe=Ga.object({from:Ga.custom(_G),until:Ga.custom(_G),level:Ga.valid(El.NOTIFY,El.FATAL,El.ERROR,El.WARN,El.INFO,El.DEBUG,El.TRACE),order:Ga.valid("asc","desc"),limit:Ga.number().min(1),start:Ga.number().min(0),log_name:Ga.custom(Moe)});function _G(e,t){if(fG(e,fG.ISO_8601).format(Poe)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(_G,"validateDatetime");function Moe(e,t){if(Coe.invert(Sp.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=Noe.get(Sp.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Sp.LOG_NAMES.HDB:e,i=s===Sp.LOG_NAMES.INSTALL?ON.join(Doe,Sp.LOG_NAMES.INSTALL):ON.join(n,s);return Ioe.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Moe,"validateReadLogPath")});var wN=w((ODe,EG)=>{"use strict";var Wg=(H(),C(q)),voe=z(),Uoe=ae(),xoe=hG(),NN=require("path"),mG=require("fs-extra"),{once:Boe}=require("events"),{handleHDBError:Hoe,hdb_errors:koe}=pe(),{PACKAGE_ROOT:Foe}=st(),Goe=NN.join(Foe,"logs"),qoe=1e3,$oe=200;EG.exports=Voe;async function Voe(e){let t=xoe(e);if(t)throw Hoe(t,t.message,koe.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=Uoe.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?NN.join(Goe,Wg.LOG_NAMES.INSTALL):NN.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?qoe: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)*$oe,0));let g=mG.createReadStream(s,{start:S});g.on("error",F=>{voe.error(F)});let R=0,E=[],A="",O;g.on("data",F=>{let G=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;F=A+F;let Y=0,te;for(;(te=G.exec(F))&&!g.destroyed;){O&&(O.message=F.slice(Y,te.index),v(O));let[ie,X,ne]=te,Q=ne.split("] ["),he=Q[0],Re=Q[1];Q.splice(0,2),O={timestamp:X,thread:he,level:Re,tags:Q,message:""},Y=te.index+ie.length}A=F.slice(Y)}),g.on("end",F=>{g.destroyed||O&&(O.message=A.trim(),v(O))}),g.resume();function v(F){let G,Y,te;switch(!0){case(i&&c&&u):G=new Date(F.timestamp),Y=new Date(l),te=new Date(f),F.level===o&&G>=Y&&G<=te&&R<_?R++:F.level===o&&G>=Y&&G<=te&&(qa(F,p,E),R++,R===h&&g.destroy());break;case(i&&c):G=new Date(F.timestamp),Y=new Date(l),F.level===o&&G>=Y&&R<_?R++:F.level===o&&G>=Y&&(qa(F,p,E),R++,R===h&&g.destroy());break;case(i&&u):G=new Date(F.timestamp),te=new Date(f),F.level===o&&G<=te&&R<_?R++:F.level===o&&G<=te&&(qa(F,p,E),R++,R===h&&g.destroy());break;case(c&&u):G=new Date(F.timestamp),Y=new Date(l),te=new Date(f),G>=Y&&G<=te&&R<_?R++:G>=Y&&G<=te&&(qa(F,p,E),R++,R===h&&g.destroy());break;case i:F.level===o&&R<_?R++:F.level===o&&(qa(F,p,E),R++,R===h&&g.destroy());break;case c:G=new Date(F.timestamp),Y=new Date(l),G>=Y&&R<_?R++:G>=Y&&R>=_&&(qa(F,p,E),R++,R===h&&g.destroy());break;case u:G=new Date(F.timestamp),te=new Date(f),G<=te&&R<_?R++:G<=te&&R>=_&&(qa(F,p,E),R++,R===h&&g.destroy());break;default:R<_?R++:(qa(F,p,E),R++,R===h&&g.destroy())}}return a(v,"onLogMessage"),await Boe(g,"close"),E}a(Voe,"readLog");function qa(e,t,r){t==="desc"?Koe(e,r):t==="asc"?Yoe(e,r):r.push(e)}a(qa,"pushLineToResult");function Koe(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(Koe,"insertDescending");function Yoe(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(Yoe,"insertAscending")});var zg=w((DDe,AG)=>{"use strict";var IN=require("joi"),{string:pd,boolean:gG,date:Woe}=IN.types(),zoe=ft(),{validateSchemaExists:wDe,validateTableExists:IDe,validateSchemaName:CDe}=Mi(),joe=(H(),C(q)),Qoe=Tt(),SG=ae();SG.initSync();var PDe=pd.invalid(SG.get(joe.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(Qoe.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:pd.valid("add_node","update_node","set_node_replication"),node_name:pd.optional(),subscriptions:IN.array().items({table:pd.optional(),schema:pd.optional(),database:pd.optional(),subscribe:gG.required(),publish:gG.required().custom(Xoe),start_time:Woe.iso()})};function Joe(e){return zoe.validateBySchema(e,IN.object(TG))}a(Joe,"addUpdateNodeValidator");function Xoe(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(Xoe,"checkForFalsy");AG.exports={addUpdateNodeValidator:Joe,validation_schema:TG}});var hd=w((MDe,RG)=>{"use strict";var CN=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},PN=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:CN,NodeSubscription:PN}});var bG=w((UDe,yG)=>{"use strict";var Zoe=(H(),C(q)).OPERATIONS_ENUM,DN=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Zoe.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};yG.exports=DN});var Tp=w((BDe,OG)=>{"use strict";var LN=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},MN=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:LN,RemotePayloadSubscription:MN}});var wG=w((kDe,NG)=>{"use strict";var vN=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=vN});var CG=w((KDe,IG)=>{"use strict";var eae=wG(),GDe=vt(),qDe=_t(),tae=z(),{getSchemaPath:$De,getTransactionAuditStorePath:VDe}=gt(),{getDatabases:rae}=(Pe(),C(tt));IG.exports=nae;async function nae(e){let t=new eae;try{let r=rae()[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){tae.warn(`unable to stat table dbi due to ${r}`)}return t}a(nae,"lmdbGetTableSize")});var DG=w((WDe,PG)=>{"use strict";var UN=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=UN});var Do=w((ZDe,UG)=>{"use strict";var sae=require("fs-extra"),iae=require("path"),Xr=require("systeminformation"),$a=z(),LG=or(),jDe=Tt(),md=(H(),C(q)),oae=CG(),aae=Ao(),{getThreadInfo:MG}=et(),Ap=ae();Ap.initSync();var cae=DG(),{openEnvironment:QDe}=_t(),{getSchemaPath:JDe}=gt(),{database:XDe,databases:xN}=(Pe(),C(tt)),jg;UG.exports={getHDBProcessInfo:FN,getNetworkInfo:qN,getDiskInfo:GN,getMemoryInfo:kN,getCPUInfo:HN,getTimeInfo:BN,getSystemInformation:$N,systemInformation:lae,getTableSize:VN,getMetrics:KN};function BN(){return Xr.time()}a(BN,"getTimeInfo");async function HN(){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(A=>{let{raw_load:O,raw_load_idle:v,raw_load_irq:F,raw_load_nice:G,raw_load_system:Y,raw_load_user:te,...ie}=A;E.cpus.push(ie)}),f.current_load=E,f}catch(e){return $a.error(`error in getCPUInfo: ${e}`),{}}}a(HN,"getCPUInfo");async function kN(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Xr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return $a.error(`error in getMemoryInfo: ${e}`),{}}}a(kN,"getMemoryInfo");async function FN(){let e={core:[],clustering:[]};try{let t=await Xr.processes(),r;try{r=Number.parseInt(await sae.readFile(iae.join(Ap.get(md.CONFIG_PARAMS.ROOTPATH),md.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===md.NODE_ERROR_CODES.ENOENT)$a.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return $a.error(`error in getHDBProcessInfo: ${t}`),e}}a(FN,"getHDBProcessInfo");async function GN(){let e={};try{if(!Ap.get(md.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 $a.error(`error in getDiskInfo: ${t}`),e}}a(GN,"getDiskInfo");async function qN(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return Ap.get(md.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 $a.error(`error in getNetworkInfo: ${t}`),e}}a(qN,"getNetworkInfo");async function $N(){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 $a.error(`error in getSystemInformation: ${t}`),e}}a($N,"getSystemInformation");async function VN(){let e=[],t=await aae.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await oae(n));return e}a(VN,"getTableSize");async function KN(){let e={};for(let t in xN){let r=e[t]={},n=r.tables={};for(let s in xN[t])try{let i=xN[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,f,d]=l.trim().split(" ");return{pid:u,thread:f,txnid:d}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}}let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){$a.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(KN,"getMetrics");async function vG(){if(Ap.get(md.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 lae(e){let t=new cae;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await $N(),t.time=BN(),t.cpu=await HN(),t.memory=await kN(),t.disk=await GN(),t.network=await qN(),t.harperdb_processes=await FN(),t.table_size=await VN(),t.metrics=await KN(),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 $N();break;case"time":t.time=BN();break;case"cpu":t.cpu=await HN();break;case"memory":t.memory=await kN();break;case"disk":t.disk=await GN();break;case"network":t.network=await qN();break;case"harperdb_processes":t.harperdb_processes=await FN();break;case"table_size":t.table_size=await VN();break;case"database_metrics":case"metrics":t.metrics=await KN();break;case"threads":t.threads=await MG();break;case"replication":t.replication=await vG();break;default:break}return t}a(lae,"systemInformation")});var Lo=w((nLe,kG)=>{"use strict";var uae=Rn(),YN=se(),dae=require("util"),gl=(H(),C(q)),xG=ae();xG.initSync();var fae=OO(),BG=Yr(),{Node:tLe,NodeSubscription:rLe}=hd(),_ae=Hu(),pae=bG(),{RemotePayloadObject:hae,RemotePayloadSubscription:mae}=Tp(),{handleHDBError:Eae,hdb_errors:gae}=pe(),{HTTP_STATUS_CODES:Sae,HDB_ERROR_MSGS:Tae}=gae,Aae=si(),Rae=Do(),{packageJson:yae}=st(),{getDatabases:bae}=(Pe(),C(tt)),Oae=dae.promisify(fae.authorize),Nae=BG.searchByHash,wae=BG.searchByValue;kG.exports={authHeaderToUser:Iae,isEmpty:Cae,getNodeRecord:Pae,upsertNodeRecord:Dae,buildNodePayloads:Lae,checkClusteringEnabled:Mae,getAllNodeRecords:vae,getSystemInfo:Uae,reverseSubscription:HG};async function Iae(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Oae(t,null),e}a(Iae,"authHeaderToUser");function Cae(e){return e==null}a(Cae,"isEmpty");async function Pae(e){let t=new _ae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Nae(t)}a(Pae,"getNodeRecord");async function Dae(e){let t=new pae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return uae.upsert(t)}a(Dae,"upsertNodeRecord");function HG(e){if(YN.isEmpty(e.subscribe)||YN.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 Lae(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=YN.getTableHashAttribute(l,u),{subscribe:d,publish:p}=HG(c),_=bae()[l]?.[u],h=new mae(l,u,f,p,d,c.start_time,_.schemaDefined?_.attributes:void 0);s.push(h)}return new hae(r,t,s,n)}a(Lae,"buildNodePayloads");function Mae(){if(!xG.get(gl.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Eae(new Error,Tae.CLUSTERING_NOT_ENABLED,Sae.BAD_REQUEST,void 0,void 0,!0)}a(Mae,"checkClusteringEnabled");async function vae(){let e=new Aae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await wae(e))}a(vae,"getAllNodeRecords");async function Uae(){let e=await Rae.getSystemInformation();return{hdb_version:yae.version,node_version:e.node_version,platform:e.platform}}a(Uae,"getSystemInfo")});var WN=w((iLe,WG)=>{"use strict";var Qg=or(),FG=se(),GG=Tt(),qG=(H(),C(q)),Jg=z(),$G=Vg(),xae=x_(),{RemotePayloadObject:Bae}=Tp(),{handleHDBError:VG,hdb_errors:Hae}=pe(),{HTTP_STATUS_CODES:KG}=Hae,{NodeSubscription:YG}=hd();WG.exports=kae;async function kae(e,t){let r;try{r=await Qg.request(`${t}.${GG.REQUEST_SUFFIX}`,new Bae(qG.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),Jg.trace("Response from remote describe all request:",r)}catch(o){Jg.error(`addNode received error from describe all request to remote node: ${o}`);let c=Qg.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 Qg.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&&(Jg.trace(`addNode creating schema: ${l}`),await $G.createSchema({operation:"create_schema",schema:l})),!d&&p){Jg.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new xae(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await $G.createTable(h)}await Qg.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(kae,"reviewSubscriptions")});var Sl={};ve(Sl,{addNodeBack:()=>Vae,removeNodeBack:()=>Kae,setNode:()=>$ae});async function $ae(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=ci(t)):t=Fg(r);let n=(0,jG.validateBySchema)(e,qae);if(n)throw(0,Mo.handleHDBError)(n,n.message,Gae.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new Mo.ClientError("url or hostname is required for remove_node operation");let _=r,h=ar(),S=await h.get(_);if(!S)throw new Mo.ClientError(_+" does not exist");try{await gp({url:S.url},{operation:Vt.REMOVE_NODE_BACK,name:S?.subscriptions?.length>0?Xe():_},void 0)}catch(g){rs.warn(`Error removing node from target node ${_}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,g)}return await h.delete(_),`Successfully removed '${_}' from cluster`}if(!t)throw new Mo.ClientError("url required for this operation");let s=Ma();if(s==null)throw new Mo.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,Is.getReplicationCert)();let _=await(0,Is.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,Is.createCsr)(),rs.info("Sending CSR to target node:",t)):_&&(c=_.certificate,rs.info("Sending CA named",_.name,"to target node",t))}let l={operation:Vt.ADD_NODE_BACK,hostname:(0,QG.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 gp({url:t},l,e)}catch(_){_.message=`Error returned from ${t}: `+_.message,rs.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&&(rs.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,Is.setCertTable)({name:Fae.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,Is.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 Io(Xe(),_)}await Io(u?u.nodeName:d.name??ci(t),d);let p;return e.operation==="update_node"?p=`Successfully updated '${t}'`:p=`Successfully added '${t}' to cluster`,f&&(p+=" but there was an error updating target node: "+f.message),p}async function Vae(e){rs.trace("addNodeBack received request:",e);let t=await(0,Is.signCertificate)(e),r;e.csr?(r=t.signingCA,rs.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,rs.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,Is.getReplicationCertAuth)();if(n.replicates){let i={url:Ma(),ca:s?.certificate,replicates:!0,subscriptions:null};e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await Io(Xe(),i)}return await Io(e.hostname,n),t.nodeName=Xe(),t.usingCA=s?.certificate,rs.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Kae(e){rs.trace("removeNodeBack received request:",e),await ar().delete(e.name)}function zG(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var Is,jG,Va,QG,rs,Mo,Fae,Gae,qae,Tl=be(()=>{Is=M(ts()),jG=M(ft()),Va=M(require("joi")),QG=M(ae());H();dp();ul();es();rs=M(z()),Mo=M(pe()),{pki:Fae}=require("node-forge"),{HTTP_STATUS_CODES:Gae}=Mo.hdb_errors,qae=Va.default.object({hostname:Va.default.string(),verify_tls:Va.default.boolean(),replicates:Va.default.boolean(),subscriptions:Va.default.array(),revoked_certificates:Va.default.array(),shard:Va.default.number()});a($ae,"setNode");a(Vae,"addNodeBack");a(Kae,"removeNodeBack");a(zG,"reverseSubscription")});var Ed=w((pLe,XG)=>{"use strict";var{handleHDBError:Xg,hdb_errors:Yae}=pe(),{HTTP_STATUS_CODES:Zg}=Yae,{addUpdateNodeValidator:Wae}=zg(),eS=z(),tS=(H(),C(q)),JG=Tt(),zae=se(),Rp=or(),yp=Lo(),zN=ae(),jae=WN(),{Node:Qae,NodeSubscription:Jae}=hd(),{broadcast:Xae}=et(),{setNode:Zae}=(Tl(),C(Sl)),fLe=ae(),_Le=(H(),C(q)),ece="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",tce="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",rce=zN.get(tS.CONFIG_PARAMS.CLUSTERING_NODENAME);XG.exports=nce;async function nce(e,t=!1){if(eS.trace("addNode called with:",e),zN.get(tS.CONFIG_PARAMS.REPLICATION_URL)||zN.get(tS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Zae(e);yp.checkClusteringEnabled();let r=Wae(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(!zae.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 jae(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=ece,o;let c=yp.buildNodePayloads(s,rce,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}.${JG.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===JG.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 Qae(n,l,u.system_info);return await yp.upsertNodeRecord(f),Xae({type:"nats_update"}),i.length>0?o.message=tce:o.message=`Successfully added '${n}' to manifest`,o}a(nce,"addNode")});var XN=w((ELe,eq)=>{"use strict";var{handleHDBError:jN,hdb_errors:sce}=pe(),{HTTP_STATUS_CODES:QN}=sce,{addUpdateNodeValidator:ice}=zg(),bp=z(),rS=(H(),C(q)),ZG=Tt(),mLe=se(),Op=or(),Np=Lo(),JN=ae(),{cloneDeep:oce}=require("lodash"),ace=WN(),{Node:cce,NodeSubscription:lce}=hd(),{broadcast:uce}=et(),{setNode:dce}=(Tl(),C(Sl)),fce="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",_ce="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",pce=JN.get(rS.CONFIG_PARAMS.CLUSTERING_NODENAME);eq.exports=hce;async function hce(e){if(bp.trace("updateNode called with:",e),JN.get(rS.CONFIG_PARAMS.REPLICATION_URL)??JN.get(rS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return dce(e);Np.checkClusteringEnabled();let t=ice(e);if(t)throw jN(t,t.message,QN.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Np.getNodeRecord(r);s.length>0&&(n=oce(s));let{added:i,skipped:o}=await ace(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=fce,c;let l=Np.buildNodePayloads(i,pce,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 jN(new Error,d,QN.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 jN(new Error,f,QN.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 cce(r,[],u.system_info)]),await mce(n[0],i,u.system_info),o.length>0?c.message=_ce:c.message=`Successfully updated '${r}'`,c}a(hce,"updateNode");async function mce(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 lce(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Np.upsertNodeRecord(n),uce({type:"nats_update"})}a(mce,"updateNodeTable")});var iq=w((SLe,sq)=>{"use strict";var nq=require("joi"),{string:tq}=nq.types(),Ece=ft(),rq=(H(),C(q)),gce=ae(),Sce=Tt();sq.exports=Tce;function Tce(e){let t=tq.invalid(gce.get(rq.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Sce.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 Ece.validateBySchema(e,r)}a(Tce,"removeNodeValidator")});var nS=w((ALe,uq)=>{"use strict";var{handleHDBError:oq,hdb_errors:Ace}=pe(),{HTTP_STATUS_CODES:aq}=Ace,Rce=iq(),wp=z(),cq=Lo(),yce=se(),gd=(H(),C(q)),lq=Tt(),ZN=or(),ew=ae(),{RemotePayloadObject:bce}=Tp(),{NodeSubscription:Oce}=hd(),Nce=U_(),wce=Vc(),{broadcast:Ice}=et(),{setNode:Cce}=(Tl(),C(Sl)),Pce=ew.get(gd.CONFIG_PARAMS.CLUSTERING_NODENAME);uq.exports=Dce;async function Dce(e){if(wp.trace("removeNode called with:",e),ew.get(gd.CONFIG_PARAMS.REPLICATION_URL)??ew.get(gd.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Cce(e);cq.checkClusteringEnabled();let t=Rce(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(yce.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 bce(gd.OPERATIONS_ENUM.REMOVE_NODE,Pce,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let f=n.subscriptions[l];f.subscribe===!0&&await ZN.updateConsumerIterator(f.schema,f.table,r,"stop");try{await ZN.updateRemoteConsumer(new Oce(f.schema,f.table,!1,!1),r)}catch(d){wp.error(d)}}try{i=await ZN.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 Nce(gd.SYSTEM_SCHEMA_NAME,gd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await wce.deleteRecord(c),Ice({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(Dce,"removeNode")});var _q=w((yLe,fq)=>{"use strict";var dq=require("joi"),{string:Lce,array:Mce}=dq.types(),vce=ft(),Uce=zg();fq.exports=xce;function xce(e){let t=dq.object({operation:Lce.valid("configure_cluster").required(),connections:Mce.items(Uce.validation_schema).required()});return vce.validateBySchema(e,t)}a(xce,"configureClusterValidator")});var tw=w((OLe,gq)=>{"use strict";var pq=(H(),C(q)),sS=z(),Bce=se(),Hce=ae(),kce=nS(),Fce=Ed(),Gce=Lo(),qce=_q(),{handleHDBError:hq,hdb_errors:$ce}=pe(),{HTTP_STATUS_CODES:mq}=$ce,Vce="Configure cluster complete.",Kce="Failed to configure the cluster. Check the logs for more details.",Yce="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";gq.exports=Wce;async function Wce(e){sS.trace("configure cluster called with:",e);let t=qce(e);if(t)throw hq(t,t.message,mq.BAD_REQUEST,void 0,void 0,!0);let r=await Gce.getAllNodeRecords(),n=[];if(Hce.get(pq.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let f=0,d=r.length;f<d;f++){let p=await Eq(kce,{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(Fce,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(Bce.isEmptyOrZeroLength(o))return{message:Vce,connections:c};if(l)return{message:Yce,failed_nodes:o,connections:c};throw hq(new Error,Kce,mq.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Wce,"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((wLe,Aq)=>{"use strict";var Ip=require("joi"),zce=ft(),{validateSchemaExists:Sq,validateTableExists:jce,validateSchemaName:Tq}=Mi(),Qce=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(jce).required()});function Jce(e){return zce.validateBySchema(e,Qce)}a(Jce,"purgeStreamValidator");Aq.exports=Jce});var rw=w((CLe,yq)=>{"use strict";var{handleHDBError:Xce,hdb_errors:Zce}=pe(),{HTTP_STATUS_CODES:ele}=Zce,tle=Rq(),rle=or(),nle=Lo();yq.exports=sle;async function sle(e){e.schema=e.schema??e.database;let t=tle(e);if(t)throw Xce(t,t.message,ele.BAD_REQUEST,void 0,void 0,!0);nle.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await rle.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(sle,"purgeStream")});var aS=w((DLe,Pq)=>{"use strict";var sw=Lo(),ile=or(),oS=ae(),Sd=(H(),C(q)),Al=Tt(),ole=se(),nw=z(),{RemotePayloadObject:ale}=Tp(),{ErrorCode:bq}=require("nats"),{parentPort:Oq}=require("worker_threads"),{onMessageByType:cle}=et(),{getThisNodeName:lle}=(es(),C(Po)),{requestClusterStatus:ule}=(dp(),C(zk)),{getReplicationSharedStatus:dle}=(ul(),C(WO)),{CONFIRMATION_STATUS_POSITION:fle,RECEIVED_VERSION_POSITION:_le,RECEIVED_TIME_POSITION:ple,SENDING_TIME_POSITION:hle}=(EN(),C(xF)),Nq=oS.get(Sd.CONFIG_PARAMS.CLUSTERING_ENABLED),wq=oS.get(Sd.CONFIG_PARAMS.CLUSTERING_NODENAME);Pq.exports={clusterStatus:mle,buildNodeStatus:Cq};var Iq;cle("cluster-status",async e=>{Iq(e)});async function mle(){if(oS.get(Sd.CONFIG_PARAMS.REPLICATION_URL)||oS.get(Sd.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=dle(l,c,i);o.lastCommitConfirmed=iS(u[fle]),o.lastReceivedRemoteTime=iS(u[_le]),o.lastReceivedLocalTime=iS(u[ple]),o.sendingMessage=iS(u[hle])}}}else n=ule();return n.node_name=lle(),n.is_enabled=!0,n}let e={node_name:wq,is_enabled:Nq,connections:[]};if(!Nq)return e;let t=await sw.getAllNodeRecords();if(ole.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(mle,"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 ale(Sd.OPERATIONS_ENUM.CLUSTER_STATUS,wq,void 0,await sw.getSystemInfo()),s,i,o=Al.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await ile.request(Al.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Al.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Al.CLUSTER_STATUS_STATUSES.CLOSED,nw.error(`Error getting node status from ${r} `,s))}catch(l){nw.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 Ele(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!==Sd.PRE_4_0_0_VERSION&&await sw.upsertNodeRecord(l)}catch(l){nw.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(Cq,"buildNodeStatus");function Ele(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(Ele,"NodeStatusObject")});var lS=w((MLe,Dq)=>{"use strict";var{handleHDBError:gle,hdb_errors:Sle}=pe(),{HTTP_STATUS_CODES:Tle}=Sle,Ale=or(),Rle=Lo(),iw=se(),cS=require("joi"),yle=ft(),ble=2e3,Ole=cS.object({timeout:cS.number().min(1),connected_nodes:cS.boolean(),routes:cS.boolean()});Dq.exports=Nle;async function Nle(e){Rle.checkClusteringEnabled();let t=yle.validateBySchema(e,Ole);if(t)throw gle(t,t.message,Tle.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||iw.autoCastBoolean(n),o=s===void 0||iw.autoCastBoolean(s),c={nodes:[]},l=await Ale.getServerList(r??ble),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:iw.autoCast(S.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(Nle,"clusterNetwork")});var Uq=w((ULe,vq)=>{"use strict";var ow=require("joi"),Lq=ft(),{route_constraints:Mq}=Vy();vq.exports={setRoutesValidator:wle,deleteRoutesValidator:Ile};function wle(e){let t=ow.object({server:ow.valid("hub","leaf"),routes:Mq.required()});return Lq.validateBySchema(e,t)}a(wle,"setRoutesValidator");function Ile(e){let t=ow.object({routes:Mq.required()});return Lq.validateBySchema(e,t)}a(Ile,"deleteRoutesValidator")});var uS=w((BLe,qq)=>{"use strict";var vo=yt(),aw=se(),Cs=(H(),C(q)),Td=ae(),xq=Uq(),{handleHDBError:Bq,hdb_errors:Cle}=pe(),{HTTP_STATUS_CODES:Hq}=Cle,kq="cluster routes successfully set",Fq="cluster routes successfully deleted";qq.exports={setRoutes:Dle,getRoutes:Lle,deleteRoutes:Mle};function Ple(e){let t=vo.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=aw.autoCast(l.port);let u=r.some(d=>d.host===l.host&&d.port===l.port),f=n.some(d=>d.host===l.host&&d.port===l.port);u||f?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?vo.updateConfigValue(Cs.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):vo.updateConfigValue(Cs.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:kq,set:i,skipped:s}}a(Ple,"setRoutesNats");function Dle(e){let t=xq.setRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(Td.get(Cs.CONFIG_PARAMS.CLUSTERING_ENABLED))return Ple(e);let r=[],n=[],s=Td.get(Cs.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Gq(s,i)?n.push(i):(s.push(i),r.push(i))}),vo.updateConfigValue(Cs.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:kq,set:r,skipped:n}}a(Dle,"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 Lle(){if(Td.get(Cs.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=vo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Td.get(Cs.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Lle,"getRoutes");function Mle(e){let t=xq.deleteRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(Td.get(Cs.CONFIG_PARAMS.CLUSTERING_ENABLED))return vle(e);let r=[],n=[],s=Td.get(Cs.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Gq(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),vo.updateConfigValue(Cs.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Fq,deleted:r,skipped:n}}a(Mle,"deleteRoutes");function vle(e){let t=vo.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let f=e.routes[l],d=!1;for(let p=0,_=r.length;p<_;p++){let h=r[p];if(f.host===h.host&&f.port===h.port){r.splice(p,1),d=!0,o=!0,s.push(f);break}}if(!d){let p=!0;for(let _=0,h=n.length;_<h;_++){let S=n[_];if(f.host===S.host&&f.port===S.port){n.splice(_,1),c=!0,p=!1,s.push(f);break}}p&&i.push(f)}}return o&&(r=aw.isEmptyOrZeroLength(r)?null:r,vo.updateConfigValue(Cs.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=aw.isEmptyOrZeroLength(n)?null:n,vo.updateConfigValue(Cs.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Fq,deleted:s,skipped:i}}a(vle,"deleteRoutesNats")});var Vq=w((kLe,$q)=>{"use strict";var Cp=require("alasql"),Rl=require("recursive-iterator"),di=z(),Ule=se(),Pp=(H(),C(q)),cw=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,Ble(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=xle(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 xle(e){return e.filter(t=>t[Pp.PERMS_CRUD_ENUM.READ])}a(xle,"filterReadRestrictedAttrs");function Ble(e,t,r,n,s){Hle(e,t,r,n,s)}a(Ble,"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 Hle(e,t,r,n,s){if(!e){di.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Cp.yy.Insert?qle(e,t,r):e instanceof Cp.yy.Select?kle(e,t,r,n,s):e instanceof Cp.yy.Update?Fle(e,t,r):e instanceof Cp.yy.Delete?Gle(e,t,r):di.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(Hle,"getRecordAttributesAST");function kle(e,t,r,n,s){if(!e){di.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Ule.isEmptyOrZeroLength(i)){di.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{di.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new 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{di.info(`table specified as ${f} not found.`);continue}t.get(i).get(f).indexOf(u.columnid)<0&&t.get(i).get(f).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new 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{di.info(`table specified as ${f} not found.`);continue}t.get(d).get(f).indexOf(u.columnid)<0&&t.get(d).get(f).push(u.columnid)}}),e.order){let c=new 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{di.info(`table specified as ${u} not found.`);return}t.get(f).get(u).indexOf(l.columnid)<0&&t.get(f).get(u).push(l.columnid)}}}a(kle,"getSelectAttributes");function Fle(e,t,r){if(!e){di.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&&lw(e.table.tableid,s,i.columnid,t,r)}a(Fle,"getUpdateAttributes");function Gle(e,t,r){if(!e){di.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&&lw(e.table.tableid,s,i.columnid,t,r)}a(Gle,"getDeleteAttributes");function qle(e,t,r){if(!e){di.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&&lw(e.into.tableid,s,i.columnid,t,r)}a(qle,"getInsertAttributes");function lw(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(lw,"pushAttribute");$q.exports=cw});var Yq=w((GLe,Kq)=>{"use strict";var dS=(H(),C(q)),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}},uw=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:uw}});var yd=w(($Le,Xq)=>{"use strict";var Rd=require("fs-extra"),_S=(hE(),C(pE)),zq=require("crypto"),$le=require("moment"),Vle=require("uuid").v4,Zr=z(),fw=require("path"),Kle=se(),yl=(H(),C(q)),{totalmem:Wq}=require("os"),Yle=Yq().ExtendedLicense,Ad="invalid license key format",Wle="061183",zle="mofi25",jle="aes-256-cbc",Qle=16,Jle=32,jq=ae(),{resolvePath:Qq}=yt();jq.initSync();var dw;Xq.exports={validateLicense:Jq,generateFingerPrint:Zle,licenseSearch:hw,getLicense:rue,checkMemoryLimit:nue};function _w(){return fw.join(jq.getHdbBasePath(),yl.LICENSE_KEY_DIR_NAME,yl.LICENSE_FILE_NAME)}a(_w,"getLicenseDirPath");function Xle(){let e=_w();return Qq(fw.join(e,yl.LICENSE_FILE_NAME))}a(Xle,"getLicenseFilePath");function pw(){let e=_w();return Qq(fw.join(e,yl.REG_KEY_FILE_NAME))}a(pw,"getFingerPrintFilePath");async function Zle(){let e=pw();try{return await Rd.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await eue();throw Zr.error(`Error writing fingerprint file to ${e}`),Zr.error(t),new Error("There was an error generating the fingerprint")}}a(Zle,"generateFingerPrint");async function eue(){let e=Vle(),t=_S.hash(e,_S.HASH_FUNCTION.MD5),r=pw();try{await Rd.mkdirp(_w()),await Rd.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(eue,"writeFingerprint");function Jq(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=pw(),s=!1;try{s=Rd.statSync(n)}catch(i){Zr.error(i)}if(s){let i;try{i=Rd.readFileSync(n,"utf8")}catch{Zr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(zle),c=o[1];c=Buffer.concat([Buffer.from(c)],Qle);let l=Buffer.concat([Buffer.from(i)],Jle),u=zq.createDecipheriv(jle,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 _=tue(o[0],i);if(_)f=_;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Ad),Zr.error(Ad),new Error(Ad)}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(Ad),Zr.error(Ad),new Error(Ad)}else r.exp_date=f;r.exp_date<$le().valueOf()&&(r.valid_date=!1),_S.validate(o[1],`${Wle}${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(Jq,"validateLicense");function tue(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(tue,"checkOldLicense");function hw(){let e=new Yle,t=[];try{t=Rd.readFileSync(Xle(),"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(Kle.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=Jq(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 dw=e,e}a(hw,"licenseSearch");async function rue(){return dw||await hw(),dw}a(rue,"getLicense");function nue(){let e=hw().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(nue,"checkMemoryLimit")});var hS=w((KLe,r$)=>{var pS=yd(),Zq=require("chalk"),ns=z(),e$=require("prompt"),{promisify:sue}=require("util"),mw=(H(),C(q)),iue=require("fs-extra"),oue=require("path"),aue=se(),{packageJson:cue}=st(),t$=ae();t$.initSync();var lue=require("moment"),uue=sue(e$.get),due=oue.join(t$.getHdbBasePath(),mw.LICENSE_KEY_DIR_NAME,mw.LICENSE_FILE_NAME,mw.LICENSE_FILE_NAME);r$.exports={getFingerprint:_ue,setLicense:fue,parseLicense:Ew,register:pue,getRegistrationInfo:mue};async function fue(e){if(e&&e.key&&e.company){try{ns.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await Ew(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw ns.error(r),ns.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(fue,"setLicense");async function _ue(){let e={};try{e=await pS.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw ns.error(r),ns.error(t),new Error(r)}return e}a(_ue,"getFingerprint");async function Ew(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");ns.info("Validating license input...");let r=pS.validateLicense(e,t);if(ns.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(ns.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(ns.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{ns.info("writing license to disk"),await iue.writeFile(due,JSON.stringify({license_key:e,company:t}))}catch(n){throw ns.error("Failed to write License"),n}return"Registration successful."}a(Ew,"parseLicense");async function pue(){let e=await hue();return Ew(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(pue,"register");async function hue(){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){ns.error(n)}let r;try{r=await uue(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(hue,"promptForRegistration");async function mue(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await pS.getLicense()}catch(r){throw ns.error(`There was an error when searching licenses due to: ${r.message}`),r}if(aue.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=cue.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=lue.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(mue,"getRegistrationInfo")});var s$=w((WLe,n$)=>{"use strict";var Eue=Tt(),gw=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+Eue.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=gw});var a$=w((jLe,o$)=>{"use strict";var i$=Tt(),Sw=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=Sw});var l$=w((JLe,c$)=>{"use strict";var Tw=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};c$.exports=Tw});var d$=w((ZLe,u$)=>{"use strict";var gue=Tt(),Aw=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+gue.SERVER_SUFFIX.ADMIN,this.password=r}};u$.exports=Aw});var SS=w((tMe,p$)=>{"use strict";var bl=require("path"),Ol=require("fs-extra"),Sue=s$(),Tue=a$(),Aue=l$(),Rue=d$(),Rw=An(),Od=se(),In=yt(),ES=(H(),C(q)),Lp=Tt(),{CONFIG_PARAMS:zt}=ES,Nd=z(),Mp=ae(),f$=To(),yw=or(),yue=ts(),bd="clustering",bue=1e4,_$=50;p$.exports={generateNatsConfig:Nue,removeNatsConfig:wue,getHubConfigPath:Oue};function Oue(){let e=Mp.get(zt.ROOTPATH);return bl.join(e,bd,Lp.NATS_CONFIG_FILES.HUB_SERVER)}a(Oue,"getHubConfigPath");async function Nue(e=!1,t=void 0){let r=Mp.get(zt.ROOTPATH);Ol.ensureDirSync(bl.join(r,"clustering","leaf")),Mp.initSync();let n=In.getConfigFromFile(zt.CLUSTERING_TLS_CERT_AUTH),s=In.getConfigFromFile(zt.CLUSTERING_TLS_PRIVATEKEY),i=In.getConfigFromFile(zt.CLUSTERING_TLS_CERTIFICATE);!await Ol.exists(i)&&!await Ol.exists(!n)&&await yue.createNatsCerts();let o=bl.join(r,bd,Lp.PID_FILES.HUB),c=bl.join(r,bd,Lp.PID_FILES.LEAF),l=In.getConfigFromFile(zt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=bl.join(r,bd,Lp.NATS_CONFIG_FILES.HUB_SERVER),f=bl.join(r,bd,Lp.NATS_CONFIG_FILES.LEAF_SERVER),d=In.getConfigFromFile(zt.CLUSTERING_TLS_INSECURE),p=In.getConfigFromFile(zt.CLUSTERING_TLS_VERIFY),_=In.getConfigFromFile(zt.CLUSTERING_NODENAME),h=In.getConfigFromFile(zt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await yw.checkNATSServerInstalled()||gS("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await Rw.listUsers(),g=In.getConfigFromFile(zt.CLUSTERING_USER),R=await Rw.getClusterUser();(Od.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(zt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await mS(zt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await mS(zt.CLUSTERING_HUBSERVER_NETWORK_PORT),await mS(zt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let E=[],A=[];for(let[ie,X]of S.entries())X.role?.role===ES.ROLE_TYPES_ENUM.CLUSTER_USER&&X.active&&(E.push(new Rue(X.username,f$.decrypt(X.hash))),A.push(new Aue(X.username,f$.decrypt(X.hash))));let O=[],{hub_routes:v}=In.getClusteringRoutes();if(!Od.isEmptyOrZeroLength(v))for(let ie of v)O.push(`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@${ie.host}:${ie.port}`);let F=new Sue(In.getConfigFromFile(zt.CLUSTERING_HUBSERVER_NETWORK_PORT),_,o,i,s,n,d,p,h,In.getConfigFromFile(zt.CLUSTERING_HUBSERVER_CLUSTER_NAME),In.getConfigFromFile(zt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),O,E,A);n==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=Od.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===ES.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Ol.writeJson(u,F),Nd.trace(`Hub server config written to ${u}`));let G=`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}`,te=new Tue(In.getConfigFromFile(zt.CLUSTERING_LEAFSERVER_NETWORK_PORT),_,c,l,[G],[Y],E,A,i,s,n,d);n==null&&delete te.tls.ca_file,(t===void 0||t===ES.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Ol.writeJson(f,te),Nd.trace(`Leaf server config written to ${f}`))}a(Nue,"generateNatsConfig");async function mS(e){let t=Mp.get(e);return Od.isEmpty(t)&&gS(`port undefined for '${e}'`),await Od.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}`;Nd.error(t),console.error(t),process.exit(1)}a(gS,"generateNatsConfigError");async function wue(e){let{port:t,config_file:r}=yw.getServerConfig(e),{username:n,decrypt_hash:s}=await Rw.getClusterUser(),i=0,o=2e3;for(;i<_$;){try{let f=await yw.createConnection(t,n,s,!1);if(f.protocol.connected===!0){f.close();break}}catch(f){Nd.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&&Nd.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Od.async_set_timeout(u)}let c="0".repeat(bue),l=bl.join(Mp.get(zt.ROOTPATH),bd,r);await Ol.writeFile(l,c),await Ol.remove(l),Nd.notify(e,"started.")}a(wue,"removeNatsConfig")});var T$=w((nMe,S$)=>{"use strict";var ss=ae(),Iue=yd(),Fe=(H(),C(q)),vp=Tt(),Uo=require("path"),{PACKAGE_ROOT:AS}=st(),h$=ae(),TS=se(),wd="/dev/null",Cue=Uo.join(AS,"launchServiceScripts"),m$=Uo.join(AS,"utility/scripts"),Pue=Uo.join(m$,Fe.HDB_RESTART_SCRIPT),E$=Uo.resolve(AS,"dependencies",`${process.platform}-${process.arch}`,vp.NATS_BINARY_NAME);function g$(){let t=Iue.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 Due=9930;function Lue(){ss.initSync(!0);let e=ss.get(Fe.CONFIG_PARAMS.ROOTPATH),t=Uo.join(e,"clustering",vp.NATS_CONFIG_FILES.HUB_SERVER),r=Uo.join(ss.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[ss.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(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_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return ss.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=wd,i.error_file=wd),i}a(Lue,"generateNatsHubServerConfig");var Mue=9940;function vue(){ss.initSync(!0);let e=ss.get(Fe.CONFIG_PARAMS.ROOTPATH),t=Uo.join(e,"clustering",vp.NATS_CONFIG_FILES.LEAF_SERVER),r=Uo.join(ss.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[ss.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Mue?"-"+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 ss.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=wd,i.error_file=wd),i}a(vue,"generateNatsLeafServerConfig");function Uue(){ss.initSync();let e=Uo.join(ss.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:Cue,autorestart:!1};return ss.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=wd,t.error_file=wd),t}a(Uue,"generateClusteringUpgradeV4ServiceConfig");function xue(){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:Pue}}a(xue,"generateRestart");function Bue(){return{apps:[g$()]}}a(Bue,"generateAllServiceConfigs");S$.exports={generateAllServiceConfigs:Bue,generateMainServerConfig:g$,generateRestart:xue,generateNatsHubServerConfig:Lue,generateNatsLeafServerConfig:vue,generateClusteringUpgradeV4ServiceConfig:Uue}});var Id=w((oMe,v$)=>{"use strict";var Ze=(H(),C(q)),Hue=se(),Bo=SS(),RS=or(),xo=Tt(),Ka=T$(),yS=ae(),Nl=z(),kue=Lo(),{startWorker:A$,onMessageFromWorkers:Fue}=et(),Gue=Do(),iMe=require("util"),que=require("child_process"),$ue=require("fs"),{execFile:Vue}=que,Ve;v$.exports={enterPM2Mode:Kue,start:Ya,stop:bw,reload:y$,restart:b$,list:Ow,describe:w$,connect:Ho,kill:Que,startAllServices:Jue,startService:Nw,getUniqueServicesList:I$,restartAllServices:Xue,isServiceRegistered:C$,reloadStopStart:P$,restartHdb:N$,deleteProcess:zue,startClusteringProcesses:L$,startClusteringThreads:M$,isHdbRestartRunning:jue,isClusteringRunning:ede,stopClustering:Zue,reloadClustering:tde,expectedRestartOfChildren:O$};var Up=!1;Fue(e=>{e.type==="restart"&&yS.initSync(!0)});function Kue(){Up=!0}a(Kue,"enterPM2Mode");function Ho(){return Ve||(Ve=require("pm2")),new Promise((e,t)=>{Ve.connect((r,n)=>{r&&t(r),e(n)})})}a(Ho,"connect");var en,Yue=10,R$;function Ya(e,t=!1){if(Up)return Wue(e);let r=Vue(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<Yue&&($ue.existsSync(Bo.getHubConfigPath())?Ya(e):(await Bo.generateNatsConfig(!0),Ya(e),await new Promise(c=>setTimeout(c,3e3)),await Bo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Bo.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&&xo.LOG_LEVEL_HIERARCHY[o]>=xo.LOG_LEVEL_HIERARCHY[f||"info"]){let _=f===xo.LOG_LEVELS.ERR||f===xo.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=xo.LOG_LEVELS[p]}if(xo.LOG_LEVEL_HIERARCHY[o]>=xo.LOG_LEVEL_HIERARCHY[f||"info"]){let d=f===xo.LOG_LEVELS.ERR||f===xo.LOG_LEVELS.WRN?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(Ya,"start");function Wue(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ve.start(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(Wue,"startWithPM2");function bw(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 Ho()}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(bw,"stop");function y$(e){return new Promise(async(t,r)=>{try{await Ho()}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 Ho()}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 zue(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ve.delete(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(zue,"deleteProcess");async function N$(){await Ya(Ka.generateRestart())}a(N$,"restartHdb");async function jue(){let e=await Ow();for(let t in e)if(e[t].name===Ze.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(jue,"isHdbRestartRunning");function Ow(){return new Promise(async(e,t)=>{try{await Ho()}catch(r){t(r)}Ve.list((r,n)=>{r&&(Ve.disconnect(),t(r)),Ve.disconnect(),e(n)})})}a(Ow,"list");function w$(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ve.describe(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(w$,"describe");function Que(){if(!Up){for(let e of en||[])e.kill();en=[];return}return new Promise(async(e,t)=>{try{await Ho()}catch(r){t(r)}Ve.killDaemon((r,n)=>{r&&(Ve.disconnect(),t(r)),Ve.disconnect(),e(n)})})}a(Que,"kill");async function Jue(){try{await L$(),await M$(),await Ya(Ka.generateAllServiceConfigs())}catch(e){throw Ve?.disconnect(),e}}a(Jue,"startAllServices");async function Nw(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case Ze.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ka.generateMainServerConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ka.generateNatsIngestServiceConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ka.generateNatsReplyServiceConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ka.generateNatsHubServerConfig(),await Ya(r,t),await Bo.removeNatsConfig(e);return;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ka.generateNatsLeafServerConfig(),await Ya(r,t),await Bo.removeNatsConfig(e);return;case Ze.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(Nw,"startService");async function I$(){try{let e=await Ow(),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 Xue(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(Xue,"restartAllServices");async function C$(e){if(en?.find(r=>r.name===e))return!0;let t=await Gue.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=Hue.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await bw(e),await Nw(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 Nw(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 kue.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 Zue(){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 bw(t)}}a(Zue,"stopClustering");async function ede(){for(let e in Ze.CLUSTERING_PROCESSES){let t=Ze.CLUSTERING_PROCESSES[e];if(await C$(t)===!1)return!1}return!0}a(ede,"isClusteringRunning");async function tde(){await Bo.generateNatsConfig(!0),await RS.reloadNATSHub(),await RS.reloadNATSLeaf(),await Bo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await Bo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(tde,"reloadClustering")});var NS={};ve(NS,{compactOnStart:()=>rde,copyDb:()=>F$});async function rde(){Wa.notify("Running compact on start"),console.log("Running compact on start");let e=(0,ww.get)(B.ROOTPATH),t=new Map,r=Je();(0,Iw.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,yc,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,wl.move)(s,i,{overwrite:!0})}try{Cd()}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,wl.move)(i,s,{overwrite:!0}),await(0,wl.remove)((0,bS.join)(e,yc,`${n}-copy.mdb-lock`));try{Cd()}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,Iw.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 Cd(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await U$(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
26
26
  Total record count before compaction: ${i}, total after: ${c}.
27
- Database backup has not been removed and can be found here: ${s}`;Wa.error(l),console.error(l)}(0,Nw.get)(x.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,Il.remove)(s))}}async function M$(e){let t=await(0,B$.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function H$(e,t){console.log("copyDb start");let r=Je()[e],n;for(let d in r){n=r[d].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,v$.open)(new U$.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 A=new x$.default(!h,h);A.encoding="binary",A.compression=S;let E=n.openDB(p,A);E.decoder=null,E.decoderCopies=!1,E.encoding="binary",A.compression=g;let R=o.openDB(p,A);R.encoder=null,console.log("copying",p,"from",e,"to",t),await d(E,R,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,A=0,E=1e7,R=null;for(;E-- >0;)try{for(let N of p.getKeys({start:R,transaction:S}))try{R=N;let{value:v,version:k}=p.getEntry(N,{transaction:S});l=_.put(N,v,h?k:void 0),g++,S.openTimer&&(S.openTimer=0),A+=(N?.length||10)+v.length,u++>5e3&&(await l,console.log("copied",g,"entries",A,"bytes"),u=0)}catch(v){console.error("Error copying record",typeof N=="symbol"?"symbol":N,"from",e,"to",t,v)}console.log("finish copying, copied",g,"entries",A,"bytes");return}catch{if(typeof R=="string"){if(R==="z")return console.error("Reached end of dbi",R,"for",e,"to",t);R=R.slice(0,-2)+"z"}else if(typeof R=="number")R++;else return console.error("Unknown key type",R,"for",e,"to",t)}}a(d,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{f.done(),o.close()}}var v$,bS,Il,Nw,U$,x$,OS,B$,ww,Wa,wS=be(()=>{Pe();v$=require("lmdb"),bS=require("path"),Il=require("fs-extra"),Nw=M(ce()),U$=M(i_()),x$=M(s_()),OS=M(vt());B();ho();B$=M(Ao()),ww=M(Rt()),Wa=M(Y());a(tde,"compactOnStart");a(M$,"getTotalDBRecordCount");a(H$,"copyDb")});var za=I((pMe,K$)=>{"use strict";var rde=require("minimist"),{isMainThread:Cw,parentPort:Hp,threadId:dMe}=require("worker_threads"),st=(B(),C(G)),zi=Y(),Pw=oe(),PS=SS(),CS=ir(),fMe=St(),q$=Rt(),_i=Id(),k$=Do(),{compactOnStart:nde}=(wS(),C(NS)),sde=da(),{restartWorkers:DS,onMessageByType:ide}=tt(),{handleHDBError:ode,hdb_errors:ade}=pe(),{HTTP_STATUS_CODES:cde}=ade,kp=ce(),{sendOperationToNode:F$,getThisNodeName:lde,monitorNodeCAs:ude}=(ts(),C(Po)),{getHDBNodeTable:_Me}=(ul(),C(YO));kp.initSync();var Bp=`Restarting HarperDB. This may take up to ${st.RESTART_TIMEOUT_MS/1e3} seconds.`,dde="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",G$="Clustering is not enabled so cannot be restarted",fde="Invalid service",Pd,Ds;K$.exports={restart:$$,restartService:Dw};Cw&&ide(st.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await Dw({service:e.workerType}):$$({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function $$(e){Ds=Object.keys(e).length===0,Pd=await _i.isServiceRegistered(st.PROCESS_DESCRIPTORS.HDB);let t=rde(process.argv);if(t.service){await Dw(t);return}if(Ds&&!Pd){console.error(dde);return}if(Ds&&console.log(Bp),Pd){_i.enterPM2Mode(),zi.notify(Bp);let r=sde(Object.keys(st.CONFIG_PARAM_MAP),!0);return Pw.isEmptyOrZeroLength(Object.keys(r))||q$.updateConfigValue(void 0,void 0,r,!0,!0),_de(),Bp}return Cw?(zi.notify(Bp),kp.get(st.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await nde(),setTimeout(()=>{DS()},50)):Hp.postMessage({type:st.ITC_EVENT_TYPES.RESTART}),Bp}a($$,"restart");async function Dw(e){let{service:t}=e;if(st.HDB_PROCESS_SERVICES[t]===void 0)throw ode(new Error,fde,cde.BAD_REQUEST,void 0,void 0,!0);if(_i.expectedRestartOfChildren(),Pd=await _i.isServiceRegistered(st.PROCESS_DESCRIPTORS.HDB),!Cw){e.replicated&&ude(),Hp.postMessage({type:st.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===lde())continue;let{job_id:i}=await F$(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 F$(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 st.HDB_PROCESS_SERVICES.clustering:if(!kp.get(st.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=G$;break}Ds&&console.log("Restarting clustering"),zi.notify("Restarting clustering"),await V$();break;case st.HDB_PROCESS_SERVICES.clustering_config:case st.HDB_PROCESS_SERVICES["clustering config"]:if(!kp.get(st.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=G$;break}Ds&&console.log("Restarting clustering_config"),zi.notify("Restarting clustering_config"),await _i.reloadClustering();break;case"custom_functions":case"custom functions":case st.HDB_PROCESS_SERVICES.harperdb:case st.HDB_PROCESS_SERVICES.http_workers:case st.HDB_PROCESS_SERVICES.http:if(Ds&&!Pd){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}Ds&&console.log("Restarting http_workers"),zi.notify("Restarting http_workers"),Ds?await _i.restart(st.PROCESS_DESCRIPTORS.HDB):await DS("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(zi.error(r),Ds&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(Dw,"restartService");async function _de(){await V$(),await _i.restart(st.PROCESS_DESCRIPTORS.HDB),await Pw.async_set_timeout(2e3),kp.get(st.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await Iw(),Ds&&(await CS.closeConnection(),process.exit(0))}a(_de,"restartPM2Mode");async function V$(){if(!q$.getConfigFromFile(st.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await k$.getHDBProcessInfo()).clustering.length===0)zi.trace("Clustering not running, restart will start clustering services"),await PS.generateNatsConfig(!0),await _i.startClusteringProcesses(),await _i.startClusteringThreads(),await Iw(),Ds&&await CS.closeConnection();else{await PS.generateNatsConfig(!0),Pd?(zi.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await _i.restart(st.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await _i.restart(st.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await k$.getHDBProcessInfo()).clustering.forEach(s=>{zi.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await Pw.async_set_timeout(3e3),await Iw(),await CS.updateLocalStreams(),Ds&&await CS.closeConnection(),zi.trace("Restart clustering restarting ingest and reply service threads");let t=DS(st.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=DS(st.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(V$,"restartClustering");async function Iw(){await PS.removeNatsConfig(st.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await PS.removeNatsConfig(st.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(Iw,"removeNatsConfig")});var rV=I((EMe,tV)=>{"use strict";var mMe=require("lodash"),Pn=(B(),C(G)),{handleHDBError:Y$,hdb_errors:pde}=pe(),{HDB_ERROR_MSGS:hde,HTTP_STATUS_CODES:mde}=pde,Lw=Y();tV.exports={getRolePermissions:gde};var Cl=Object.create(null),Ede=a(e=>({key:e,perms:{}}),"perms_template_obj"),Q$=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),J$=a((e=!1,t=!1,r=!1,n=!1)=>({[Pn.PERMS_CRUD_ENUM.READ]:e,[Pn.PERMS_CRUD_ENUM.INSERT]:t,[Pn.PERMS_CRUD_ENUM.UPDATE]:r,[Pn.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),Mw=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...J$(t,r,n,s)}),"table_perms_template"),W$=a((e,t=J$())=>({attribute_name:e,describe:eV(t),[Fp]:t[Fp],[vw]:t[vw],[Uw]:t[Uw]}),"attr_perms_template"),z$=a((e,t=!1)=>({attribute_name:e,describe:t,[Fp]:t}),"timestamp_attr_perms_template"),{READ:Fp,INSERT:vw,UPDATE:Uw}=Pn.PERMS_CRUD_ENUM,X$=Object.values(Pn.PERMS_CRUD_ENUM),Z$=[Fp,vw,Uw];function gde(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[Pn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Cl[t]&&Cl[t].key===n)return Cl[t].perms;let s=Sde(e,r);return Cl[t]?Cl[t].key=n:Cl[t]=Ede(n),Cl[t].perms=s,s}catch(r){if(!e[Pn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Pn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Pn.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 Lw.error(n),Lw.debug(r),Y$(new Error,hde.OUTDATED_PERMS_TRANSLATION_ERROR,mde.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
28
- ${r.stack}`;throw Lw.error(n),Y$(new Error)}}}a(gde,"getRolePermissions");function Sde(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[Pn.SYSTEM_SCHEMA_NAME]=n[Pn.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]=Tde(t[i]);return}r[i]=Q$(),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=Ade(c,l);r[i].describe||X$.forEach(f=>{u[f]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=Mw()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=Mw()})}),r}a(Sde,"translateRolePermissions");function Tde(e){let t=Q$(!0);return Object.keys(e).forEach(r=>{t.tables[r]=Mw(!0,!0,!0,!0,!0)}),t}a(Tde,"createStructureUserPermissions");function Ade(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 Pn.TIME_STAMP_NAMES.includes(d)&&(p=z$(d,f[Fp])),u[d]=p,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=W$(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let f=i[u];f.describe=eV(f),s.attribute_permissions.push(f),c||Rde(f,l)}else if(u!==o){let f;Pn.TIME_STAMP_NAMES.includes(u)?f=z$(u):f=W$(u),s.attribute_permissions.push(f)}}),c||s.attribute_permissions.push(l),s.describe=j$(s),s}else return e.describe=j$(e),e}a(Ade,"getTableAttrPerms");function j$(e){return X$.filter(t=>e[t]).length>0}a(j$,"getSchemaTableDescribePerm");function eV(e){return Z$.filter(t=>e[t]).length>0}a(eV,"getAttributeDescribePerm");function Rde(e,t){Z$.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(Rde,"checkForHashPerms")});var Gp={};ve(Gp,{authentication:()=>lV,bypassAuth:()=>Cde,login:()=>Dde,logout:()=>Lde,start:()=>Pde});function Cde(){cV=!0}async function lV(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let _=e.isOperationsServer?Nde?Ode:[]:bde?yde:[];if(_.includes(i)||_.includes("*")){if(e.method==="OPTIONS"){let h=os.get(x.HTTP_CORSACCESSCONTROLALLOWHEADERS)??"Accept, Content-Type, Authorization",S=new No([["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 nV.get(l);break}e.session=u||(u={})}let f=a((_,h,S)=>{let g=new Dd.AuthAuditLog(_,h,ua.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);g.auth_strategy=S,l&&(g.session_id=l),r.referer&&(g.referer=r.referer),r.origin&&(g.origin=r.origin),h===zs.SUCCESS?xw.notify(g):xw.error(g)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&xw.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(_,zs.SUCCESS,"mTLS")):(0,Dd.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=Pl.get(n),!d){let _=n.indexOf(" "),h=n.slice(0,_),S=n.slice(_+1),g,A;try{switch(h){case"Basic":let E=atob(S),R=E.indexOf(":");g=E.slice(0,R),A=E.slice(R+1),d=g||A?await We.getUser(g,A,e):null;break;case"Bearer":try{d=await yO(S)}catch(N){if(N.message==="invalid token")try{return await lg(S),c({status:-1})}catch{throw N}}break}}catch(E){return Ide&&(Pl.get(S)||(Pl.set(S,S),f(g,zs.FAILURE,h))),c({status:401,body:ya({error:E.message},e)})}Pl.set(n,d),wde&&f(d.username,zs.SUCCESS,h)}e.user=d}else u?.user?e.user=await We.getUser(u.user,null,e):(cV&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,iV.getSuperUser)());LS&&(e.session.update=function(_){if(!l){l=(0,oV.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,nV.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")&&Ii.loginPath?(p.status=302,p.headers.set("Location",Ii.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 No);for(let d=0;d<u;){let p=o[d++];f.set(p,o[d++])}}return o=null,l}a(c,"applyResponseHeaders")}function Pde({server:e,port:t,securePort:r}){e.http(lV,t||r?{port:t,securePort:r}:{port:"all"}),sV||(sV=!0,setInterval(()=>{Pl=new Map},os.get(x.AUTHENTICATION_CACHETTL)).unref(),aV.user.addListener(()=>{Pl=new Map}))}async function Dde(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 Lde(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var iV,oV,os,Dd,aV,xw,yde,bde,Ode,Nde,nV,LS,cV,wde,Ide,Pl,sV,MS=be(()=>{iV=M(Rn());Kr();Su();zu();Pe();oV=require("uuid"),os=M(ce());B();Dd=M(Y()),aV=M(N_());Q_();fo();xw=(0,Dd.loggerWithTag)("auth-event");os.initSync();yde=os.get(x.HTTP_CORSACCESSLIST),bde=os.get(x.HTTP_CORS),Ode=os.get(x.OPERATIONSAPI_NETWORK_CORSACCESSLIST),Nde=os.get(x.OPERATIONSAPI_NETWORK_CORS),nV=lt({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),LS=os.get(x.AUTHENTICATION_ENABLESESSIONS)??!0,cV=process.env.AUTHENTICATION_AUTHORIZELOCAL??os.get(x.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,wde=os.get(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,Ide=os.get(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Pl=new Map;We.onInvalidatedUser(()=>{Pl=new Map});a(Cde,"bypassAuth");a(lV,"authentication");a(Pde,"start");a(Dde,"login");a(Lde,"logout")});var mV=I((wMe,hV)=>{"use strict";var Ne=require("joi"),uV=require("fs-extra"),dV=require("path"),as=ut(),fV=ce(),_V=(B(),C(G)),pV=Y(),{hdb_errors:Mde}=pe(),{HDB_ERROR_MSGS:rn}=Mde,ko=/^[a-zA-Z0-9-_]+$/,vde=/^[a-zA-Z0-9-_]+$/;hV.exports={getDropCustomFunctionValidator:xde,setCustomFunctionValidator:Bde,addComponentValidator:Gde,dropCustomFunctionProjectValidator:qde,packageComponentValidator:$de,deployComponentValidator:Vde,setComponentFileValidator:Hde,getComponentFileValidator:Fde,dropComponentFileValidator:kde,addSSHKeyValidator:Kde,updateSSHKeyValidator:Yde,deleteSSHKeyValidator:Wde,setSSHKnownHostsValidator:zde};function vS(e,t,r){try{let n=fV.get(_V.CONFIG_PARAMS.COMPONENTSROOT),s=dV.join(n,t);return uV.existsSync(s)?e?t:r.message(rn.PROJECT_EXISTS):e?r.message(rn.NO_PROJECT):t}catch(n){return pV.error(n),r.message(rn.VALIDATION_ERR)}}a(vS,"checkProjectExists");function qp(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(qp,"checkFilePath");function Ude(e,t,r,n){try{let s=fV.get(_V.CONFIG_PARAMS.COMPONENTSROOT),i=dV.join(s,e,t,r+".js");return uV.existsSync(i)?r:n.message(rn.NO_FILE)}catch(s){return pV.error(s),n.message(rn.VALIDATION_ERR)}}a(Ude,"checkFileExists");function xde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(vS.bind(null,!0)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().pattern(ko).custom(Ude.bind(null,e.project,e.type)).custom(qp).required().messages({"string.pattern.base":rn.BAD_FILE_NAME})});return as.validateBySchema(e,t)}a(xde,"getDropCustomFunctionValidator");function Bde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(vS.bind(null,!0)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().custom(qp).required(),function_content:Ne.string().required()});return as.validateBySchema(e,t)}a(Bde,"setCustomFunctionValidator");function Hde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.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 as.validateBySchema(e,t)}a(Hde,"setComponentFileValidator");function kde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),file:Ne.string().custom(qp).optional()});return as.validateBySchema(e,t)}a(kde,"dropComponentFileValidator");function Fde(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 as.validateBySchema(e,t)}a(Fde,"getComponentFileValidator");function Gde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(vS.bind(null,!1)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME})});return as.validateBySchema(e,t)}a(Gde,"addComponentValidator");function qde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(vS.bind(null,!0)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME})});return as.validateBySchema(e,t)}a(qde,"dropCustomFunctionProjectValidator");function $de(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),skip_node_modules:Ne.boolean(),skip_symlinks:Ne.boolean()});return as.validateBySchema(e,t)}a($de,"packageComponentValidator");function Vde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),package:Ne.string().optional(),restart:Ne.alternatives().try(Ne.boolean(),Ne.string().valid("rolling")).optional()});return as.validateBySchema(e,t)}a(Vde,"deployComponentValidator");function Kde(e){let t=Ne.object({name:Ne.string().pattern(vde).required().messages({"string.pattern.base":rn.BAD_SSH_KEY_NAME}),key:Ne.string().required(),host:Ne.string().required(),hostname:Ne.string().required(),known_hosts:Ne.string().optional()});return as.validateBySchema(e,t)}a(Kde,"addSSHKeyValidator");function Yde(e){let t=Ne.object({name:Ne.string().required(),key:Ne.string().required()});return as.validateBySchema(e,t)}a(Yde,"updateSSHKeyValidator");function Wde(e){let t=Ne.object({name:Ne.string().required()});return as.validateBySchema(e,t)}a(Wde,"deleteSSHKeyValidator");function zde(e){let t=Ne.object({known_hosts:Ne.string().required()});return as.validateBySchema(e,t)}a(zde,"setSSHKnownHostsValidator")});var Kp=I((CMe,RV)=>{"use strict";var US=require("joi"),ja=require("path"),Ld=require("fs-extra"),{exec:jde}=require("child_process"),Qde=require("util"),EV=Qde.promisify(jde),Md=(B(),C(G)),{PACKAGE_ROOT:Jde}=nt(),{handleHDBError:$p,hdb_errors:Xde}=pe(),{HTTP_STATUS_CODES:Vp}=Xde,Dl=ce(),Zde=ut(),Ll=Y();Dl.initSync();var Bw=Dl.get(Md.CONFIG_PARAMS.COMPONENTSROOT),gV="npm install --force --omit=dev --json",efe=`${gV} --dry-run`,tfe=Dl.get(Md.CONFIG_PARAMS.ROOTPATH),xS=ja.join(tfe,"ssh");RV.exports={installModules:ife,auditModules:ofe,installAllRootModules:rfe,uninstallRootModule:nfe,linkHarperdb:sfe,runCommand:vd};async function rfe(e=!1,t=Dl.get(Md.CONFIG_PARAMS.ROOTPATH)){await BS();let r=!1,n=process.env;Ld.pathExistsSync(xS)&&Ld.readdirSync(xS).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+ja.join(xS,"config")+" -o UserKnownHostsFile="+ja.join(xS,"known_hosts"),...process.env},r=!0)});try{let s=Dl.get(Md.CONFIG_PARAMS.ROOTPATH),i=ja.join(s,"node_modules","harperdb");Ld.lstatSync(i).isSymbolicLink()&&Ld.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Ll.error("Error removing symlink:",s)}await vd(e?"npm install --force --ignore-scripts --no-bin-links":"npm install --force --no-bin-links",t,n)}a(rfe,"installAllRootModules");async function nfe(e){await vd(`npm uninstall ${e}`,Dl.get(Md.CONFIG_PARAMS.ROOTPATH))}a(nfe,"uninstallRootModule");async function sfe(){await BS(),await vd(`npm link ${Jde}`,Dl.get(Md.CONFIG_PARAMS.ROOTPATH))}a(sfe,"linkHarperdb");async function vd(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await EV(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")&&Ll.error("Error running NPM command:",e,s),Ll.trace(n,s),n?.replace(`
30
- `,"")}a(vd,"runCommand");async function ife(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";Ll.warn(t,e);let r=AV(e);if(r)throw $p(r,r.message,Vp.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?efe:gV;await BS(),await TV(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(Bw,u),d,p=null;try{let{stdout:_,stderr:h}=await EV(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,ww.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=Je()[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 A=o.openDB(p,R);A.encoder=null,console.log("copying",p,"from",e,"to",t),await d(E,A,h,f)}if(i){let p=n.openDB(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,A=null;for(;E-- >0;)try{for(let O of p.getKeys({start:A,transaction:S}))try{A=O;let{value:v,version:F}=p.getEntry(O,{transaction:S});l=_.put(O,v,h?F:void 0),g++,S.openTimer&&(S.openTimer=0),R+=(O?.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 O=="symbol"?"symbol":O,"from",e,"to",t,v)}console.log("finish copying, copied",g,"entries",R,"bytes");return}catch{if(typeof A=="string"){if(A==="z")return console.error("Reached end of dbi",A,"for",e,"to",t);A=A.slice(0,-2)+"z"}else if(typeof A=="number")A++;else return console.error("Unknown key type",A,"for",e,"to",t)}}a(d,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{f.done(),o.close()}}var x$,bS,wl,ww,B$,H$,OS,k$,Iw,Wa,wS=be(()=>{Pe();x$=require("lmdb"),bS=require("path"),wl=require("fs-extra"),ww=M(ae()),B$=M(i_()),H$=M(s_()),OS=M(vt());H();ho();k$=M(Ao()),Iw=M(yt()),Wa=M(z());a(rde,"compactOnStart");a(U$,"getTotalDBRecordCount");a(F$,"copyDb")});var za=w((hMe,W$)=>{"use strict";var nde=require("minimist"),{isMainThread:Pw,parentPort:Hp,threadId:fMe}=require("worker_threads"),it=(H(),C(q)),Wi=z(),Dw=se(),PS=SS(),CS=or(),_Me=Tt(),V$=yt(),fi=Id(),G$=Do(),{compactOnStart:sde}=(wS(),C(NS)),ide=da(),{restartWorkers:DS,onMessageByType:ode}=et(),{handleHDBError:ade,hdb_errors:cde}=pe(),{HTTP_STATUS_CODES:lde}=cde,kp=ae(),{sendOperationToNode:q$,getThisNodeName:ude,monitorNodeCAs:dde}=(es(),C(Po)),{getHDBNodeTable:pMe}=(ul(),C(WO));kp.initSync();var Bp=`Restarting HarperDB. This may take up to ${it.RESTART_TIMEOUT_MS/1e3} seconds.`,fde="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",_de="Invalid service",Pd,Ps;W$.exports={restart:K$,restartService:Lw};Pw&&ode(it.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await Lw({service:e.workerType}):K$({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function K$(e){Ps=Object.keys(e).length===0,Pd=await fi.isServiceRegistered(it.PROCESS_DESCRIPTORS.HDB);let t=nde(process.argv);if(t.service){await Lw(t);return}if(Ps&&!Pd){console.error(fde);return}if(Ps&&console.log(Bp),Pd){fi.enterPM2Mode(),Wi.notify(Bp);let r=ide(Object.keys(it.CONFIG_PARAM_MAP),!0);return Dw.isEmptyOrZeroLength(Object.keys(r))||V$.updateConfigValue(void 0,void 0,r,!0,!0),pde(),Bp}return Pw?(Wi.notify(Bp),kp.get(it.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await sde(),process.env.HARPER_EXIT_ON_RESTART&&process.exit(0),setTimeout(()=>{DS()},50)):Hp.postMessage({type:it.ITC_EVENT_TYPES.RESTART}),Bp}a(K$,"restart");async function Lw(e){let{service:t}=e;if(it.HDB_PROCESS_SERVICES[t]===void 0)throw ade(new Error,_de,lde.BAD_REQUEST,void 0,void 0,!0);if(fi.expectedRestartOfChildren(),Pd=await fi.isServiceRegistered(it.PROCESS_DESCRIPTORS.HDB),!Pw){e.replicated&&dde(),Hp.postMessage({type:it.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===ude())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 it.HDB_PROCESS_SERVICES.clustering:if(!kp.get(it.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=$$;break}Ps&&console.log("Restarting clustering"),Wi.notify("Restarting clustering"),await Y$();break;case it.HDB_PROCESS_SERVICES.clustering_config:case it.HDB_PROCESS_SERVICES["clustering config"]:if(!kp.get(it.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=$$;break}Ps&&console.log("Restarting clustering_config"),Wi.notify("Restarting clustering_config"),await fi.reloadClustering();break;case"custom_functions":case"custom functions":case it.HDB_PROCESS_SERVICES.harperdb:case it.HDB_PROCESS_SERVICES.http_workers:case it.HDB_PROCESS_SERVICES.http:if(Ps&&!Pd){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}Ps&&console.log("Restarting http_workers"),Wi.notify("Restarting http_workers"),Ps?await fi.restart(it.PROCESS_DESCRIPTORS.HDB):await DS("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Wi.error(r),Ps&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(Lw,"restartService");async function pde(){await Y$(),await fi.restart(it.PROCESS_DESCRIPTORS.HDB),await Dw.async_set_timeout(2e3),kp.get(it.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await Cw(),Ps&&(await CS.closeConnection(),process.exit(0))}a(pde,"restartPM2Mode");async function Y$(){if(!V$.getConfigFromFile(it.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await G$.getHDBProcessInfo()).clustering.length===0)Wi.trace("Clustering not running, restart will start clustering services"),await PS.generateNatsConfig(!0),await fi.startClusteringProcesses(),await fi.startClusteringThreads(),await Cw(),Ps&&await CS.closeConnection();else{await PS.generateNatsConfig(!0),Pd?(Wi.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await fi.restart(it.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await fi.restart(it.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await G$.getHDBProcessInfo()).clustering.forEach(s=>{Wi.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await Dw.async_set_timeout(3e3),await Cw(),await CS.updateLocalStreams(),Ps&&await CS.closeConnection(),Wi.trace("Restart clustering restarting ingest and reply service threads");let t=DS(it.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=DS(it.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(Y$,"restartClustering");async function Cw(){await PS.removeNatsConfig(it.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await PS.removeNatsConfig(it.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(Cw,"removeNatsConfig")});var sV=w((gMe,nV)=>{"use strict";var EMe=require("lodash"),Cn=(H(),C(q)),{handleHDBError:z$,hdb_errors:hde}=pe(),{HDB_ERROR_MSGS:mde,HTTP_STATUS_CODES:Ede}=hde,Mw=z();nV.exports={getRolePermissions:Sde};var Il=Object.create(null),gde=a(e=>({key:e,perms:{}}),"perms_template_obj"),X$=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),Z$=a((e=!1,t=!1,r=!1,n=!1)=>({[Cn.PERMS_CRUD_ENUM.READ]:e,[Cn.PERMS_CRUD_ENUM.INSERT]:t,[Cn.PERMS_CRUD_ENUM.UPDATE]:r,[Cn.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),vw=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],[Uw]:t[Uw],[xw]:t[xw]}),"attr_perms_template"),Q$=a((e,t=!1)=>({attribute_name:e,describe:t,[Fp]:t}),"timestamp_attr_perms_template"),{READ:Fp,INSERT:Uw,UPDATE:xw}=Cn.PERMS_CRUD_ENUM,eV=Object.values(Cn.PERMS_CRUD_ENUM),tV=[Fp,Uw,xw];function Sde(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[Cn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Il[t]&&Il[t].key===n)return Il[t].perms;let s=Tde(e,r);return Il[t]?Il[t].key=n:Il[t]=gde(n),Il[t].perms=s,s}catch(r){if(!e[Cn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Cn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Cn.PERMS_UPDATE_RELEASE_TIMESTAMP){let n=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw Mw.error(n),Mw.debug(r),z$(new Error,mde.OUTDATED_PERMS_TRANSLATION_ERROR,Ede.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
28
+ ${r.stack}`;throw Mw.error(n),z$(new Error)}}}a(Sde,"getRolePermissions");function Tde(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[Cn.SYSTEM_SCHEMA_NAME]=n[Cn.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=Ade(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=Rde(c,l);r[i].describe||eV.forEach(f=>{u[f]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=vw()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=vw()})}),r}a(Tde,"translateRolePermissions");function Ade(e){let t=X$(!0);return Object.keys(e).forEach(r=>{t.tables[r]=vw(!0,!0,!0,!0,!0)}),t}a(Ade,"createStructureUserPermissions");function Rde(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,f)=>{let{attribute_name:d}=f,p=f;return Cn.TIME_STAMP_NAMES.includes(d)&&(p=Q$(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||yde(f,l)}else if(u!==o){let f;Cn.TIME_STAMP_NAMES.includes(u)?f=Q$(u):f=j$(u),s.attribute_permissions.push(f)}}),c||s.attribute_permissions.push(l),s.describe=J$(s),s}else return e.describe=J$(e),e}a(Rde,"getTableAttrPerms");function J$(e){return eV.filter(t=>e[t]).length>0}a(J$,"getSchemaTableDescribePerm");function rV(e){return tV.filter(t=>e[t]).length>0}a(rV,"getAttributeDescribePerm");function yde(e,t){tV.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(yde,"checkForHashPerms")});var Gp={};ve(Gp,{authentication:()=>dV,bypassAuth:()=>Pde,login:()=>Lde,logout:()=>Mde,start:()=>Dde});function Pde(){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?wde?Nde:[]:Ode?bde:[];if(_.includes(i)||_.includes("*")){if(e.method==="OPTIONS"){let h=is.get(B.HTTP_CORSACCESSCONTROLALLOWHEADERS)??"Accept, Content-Type, Authorization",S=new No([["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 Dd.AuthAuditLog(_,h,ua.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);g.auth_strategy=S,l&&(g.session_id=l),r.referer&&(g.referer=r.referer),r.origin&&(g.origin=r.origin),h===Ws.SUCCESS?Bw.notify(g):Bw.error(g)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&Bw.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(_,Ws.SUCCESS,"mTLS")):(0,Dd.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),A=E.indexOf(":");g=E.slice(0,A),R=E.slice(A+1),d=g||R?await Ye.getUser(g,R,e):null;break;case"Bearer":try{d=await bO(S)}catch(O){if(O.message==="invalid token")try{return await lg(S),c({status:-1})}catch{throw O}}break}}catch(E){return Cde&&(Cl.get(S)||(Cl.set(S,S),f(g,Ws.FAILURE,h))),c({status:401,body:Ra({error:E.message},e)})}Cl.set(n,d),Ide&&f(d.username,Ws.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")&&wi.loginPath?(p.status=302,p.headers.set("Location",wi.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 No);for(let d=0;d<u;){let p=o[d++];f.set(p,o[d++])}}return o=null,l}a(c,"applyResponseHeaders")}function Dde({server:e,port:t,securePort:r}){e.http(dV,t||r?{port:t,securePort:r}:{port:"all"}),oV||(oV=!0,setInterval(()=>{Cl=new Map},is.get(B.AUTHENTICATION_CACHETTL)).unref(),lV.user.addListener(()=>{Cl=new Map}))}async function Lde(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 Mde(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,is,Dd,lV,Bw,bde,Ode,Nde,wde,iV,LS,uV,Ide,Cde,Cl,oV,MS=be(()=>{aV=M(An());Vr();Su();zu();Pe();cV=require("uuid"),is=M(ae());H();Dd=M(z()),lV=M(N_());Q_();uo();Bw=(0,Dd.loggerWithTag)("auth-event");is.initSync();bde=is.get(B.HTTP_CORSACCESSLIST),Ode=is.get(B.HTTP_CORS),Nde=is.get(B.OPERATIONSAPI_NETWORK_CORSACCESSLIST),wde=is.get(B.OPERATIONSAPI_NETWORK_CORS),iV=dt({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),LS=is.get(B.AUTHENTICATION_ENABLESESSIONS)??!0,uV=process.env.AUTHENTICATION_AUTHORIZELOCAL??is.get(B.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,Ide=is.get(B.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,Cde=is.get(B.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Cl=new Map;Ye.onInvalidatedUser(()=>{Cl=new Map});a(Pde,"bypassAuth");a(dV,"authentication");a(Dde,"start");a(Lde,"login");a(Mde,"logout")});var gV=w((IMe,EV)=>{"use strict";var Ne=require("joi"),fV=require("fs-extra"),_V=require("path"),os=ft(),pV=ae(),hV=(H(),C(q)),mV=z(),{hdb_errors:vde}=pe(),{HDB_ERROR_MSGS:tn}=vde,ko=/^[a-zA-Z0-9-_]+$/,Ude=/^[a-zA-Z0-9-_]+$/;EV.exports={getDropCustomFunctionValidator:Bde,setCustomFunctionValidator:Hde,addComponentValidator:qde,dropCustomFunctionProjectValidator:$de,packageComponentValidator:Vde,deployComponentValidator:Kde,setComponentFileValidator:kde,getComponentFileValidator:Gde,dropComponentFileValidator:Fde,addSSHKeyValidator:Yde,updateSSHKeyValidator:Wde,deleteSSHKeyValidator:zde,setSSHKnownHostsValidator:jde};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 xde(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(xde,"checkFileExists");function Bde(e){let t=Ne.object({project:Ne.string().pattern(ko).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(ko).custom(xde.bind(null,e.project,e.type)).custom(qp).required().messages({"string.pattern.base":tn.BAD_FILE_NAME})});return os.validateBySchema(e,t)}a(Bde,"getDropCustomFunctionValidator");function Hde(e){let t=Ne.object({project:Ne.string().pattern(ko).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 os.validateBySchema(e,t)}a(Hde,"setCustomFunctionValidator");function kde(e){let t=Ne.object({project:Ne.string().pattern(ko).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 os.validateBySchema(e,t)}a(kde,"setComponentFileValidator");function Fde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),file:Ne.string().custom(qp).optional()});return os.validateBySchema(e,t)}a(Fde,"dropComponentFileValidator");function Gde(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 os.validateBySchema(e,t)}a(Gde,"getComponentFileValidator");function qde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(vS.bind(null,!1)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME})});return os.validateBySchema(e,t)}a(qde,"addComponentValidator");function $de(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(vS.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME})});return os.validateBySchema(e,t)}a($de,"dropCustomFunctionProjectValidator");function Vde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),skip_node_modules:Ne.boolean(),skip_symlinks:Ne.boolean()});return os.validateBySchema(e,t)}a(Vde,"packageComponentValidator");function Kde(e){let t=Ne.object({project:Ne.string().pattern(ko).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 os.validateBySchema(e,t)}a(Kde,"deployComponentValidator");function Yde(e){let t=Ne.object({name:Ne.string().pattern(Ude).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 os.validateBySchema(e,t)}a(Yde,"addSSHKeyValidator");function Wde(e){let t=Ne.object({name:Ne.string().required(),key:Ne.string().required()});return os.validateBySchema(e,t)}a(Wde,"updateSSHKeyValidator");function zde(e){let t=Ne.object({name:Ne.string().required()});return os.validateBySchema(e,t)}a(zde,"deleteSSHKeyValidator");function jde(e){let t=Ne.object({known_hosts:Ne.string().required()});return os.validateBySchema(e,t)}a(jde,"setSSHKnownHostsValidator")});var Kp=w((PMe,bV)=>{"use strict";var US=require("joi"),ja=require("path"),Ld=require("fs-extra"),{exec:Qde}=require("child_process"),Jde=require("util"),SV=Jde.promisify(Qde),Md=(H(),C(q)),{PACKAGE_ROOT:Xde}=st(),{handleHDBError:$p,hdb_errors:Zde}=pe(),{HTTP_STATUS_CODES:Vp}=Zde,Pl=ae(),efe=ft(),Dl=z();Pl.initSync();var Hw=Pl.get(Md.CONFIG_PARAMS.COMPONENTSROOT),TV="npm install --force --omit=dev --json",tfe=`${TV} --dry-run`,rfe=Pl.get(Md.CONFIG_PARAMS.ROOTPATH),xS=ja.join(rfe,"ssh");bV.exports={installModules:ofe,auditModules:afe,installAllRootModules:nfe,uninstallRootModule:sfe,linkHarperdb:ife,runCommand:vd};async function nfe(e=!1,t=Pl.get(Md.CONFIG_PARAMS.ROOTPATH)){await BS();let r=!1,n=process.env;Ld.pathExistsSync(xS)&&Ld.readdirSync(xS).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+ja.join(xS,"config")+" -o UserKnownHostsFile="+ja.join(xS,"known_hosts"),...process.env},r=!0)});try{let s=Pl.get(Md.CONFIG_PARAMS.ROOTPATH),i=ja.join(s,"node_modules","harperdb");Ld.lstatSync(i).isSymbolicLink()&&Ld.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Dl.error("Error removing symlink:",s)}await vd(e?"npm install --force --ignore-scripts --no-bin-links":"npm install --force --no-bin-links",t,n)}a(nfe,"installAllRootModules");async function sfe(e){await vd(`npm uninstall ${e}`,Pl.get(Md.CONFIG_PARAMS.ROOTPATH))}a(sfe,"uninstallRootModule");async function ife(){await BS(),await vd(`npm link ${Xde}`,Pl.get(Md.CONFIG_PARAMS.ROOTPATH))}a(ife,"linkHarperdb");async function vd(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(vd,"runCommand");async function ofe(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?tfe: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=ja.join(Hw,u),d,p=null;try{let{stdout:_,stderr:h}=await SV(i,{cwd:f});d=_?_.replace(`
31
31
  `,""):null,p=h?h.replace(`
32
- `,""):null}catch(_){_.stderr?o[u].npm_error=SV(_.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 Ll.info(`finished installModules with response ${o}`),o.warning=t,o}a(ife,"installModules");function SV(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(SV,"parseNPMStdErr");async function ofe(e){Ll.info(`starting auditModules for request: ${e}`);let t=AV(e);if(t)throw $p(t,t.message,Vp.BAD_REQUEST);let{projects:r}=e;await BS(),await TV(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=ja.join(Bw,o);n[o]={npm_output:null,npm_error:null};try{let l=await vd("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=SV(l.stderr)}}return Ll.info(`finished auditModules with response ${n}`),n}a(ofe,"auditModules");async function BS(){return await vd("npm -v"),!0}a(BS,"checkNPMInstalled");async function TV(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(Bw,i.toString());if(!await Ld.pathExists(o)){t.push(i);continue}let l=ja.join(o,"package.json");await Ld.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(TV,"checkProjectPaths");function AV(e){let t=US.object({projects:US.array().min(1).items(US.string()).required(),dry_run:US.boolean().default(!1)});return Zde.validateBySchema(e,t)}a(AV,"modulesValidator")});var kw=I((DMe,IV)=>{"use strict";var Ls=require("fs-extra"),Wp=require("path"),Yp=Y(),yV=oe(),{PACKAGE_ROOT:afe}=nt(),Hw=(B(),C(G)),wV=ce(),cfe=Rt();IV.exports=lfe;async function lfe(){let e=ufe(),t=wV.get(Hw.CONFIG_PARAMS.ROOTPATH),r=Wp.join(t,"package.json"),n={dependencies:{harperdb:"file:"+afe}},s=Wp.join(t,"node_modules");Ls.ensureDirSync(s);let i,o=!0,c=!1;try{i=Ls.readJsonSync(r)}catch(l){if(yV.isEmptyOrZeroLength(e))return;if(l.code!==Hw.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!yV.isEmptyOrZeroLength(e)){for(let{name:l,package:u}of e){let f=OV(u);n.dependencies[l]=f+u}if(!o){Yp.notify("Installing components"),await NV(r,n,null),await bV(t,e);return}for(let{name:l,package:u}of e){let f=i.dependencies[l],d=OV(u);if(f===void 0||f!==d+u){c=!0;break}if(u.startsWith("file:"))try{if(Ls.statSync(new URL(u+"/package.json")).mtimeMs>Ls.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 NV(r,n,i),await bV(t,e))}a(lfe,"installComponents");function bV(e,t){return Promise.all(t.map(({name:r})=>{let n=Wp.join(e,"node_modules",r),s=Wp.join(e,"components",r);if(Ls.existsSync(n)&&Ls.lstatSync(n).isDirectory())return Ls.move(n,s,{overwrite:!0}).then(()=>{Ls.symlink(s,n)})}))}a(bV,"moveModuleToComponents");function ufe(){let e=cfe.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(ufe,"getComponentsConfig");function OV(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Wp.extname(e)||Ls.existsSync(e)?"file:":"github:"}a(OV,"getPkgPrefix");async function NV(e,t,r){Yp.trace("npm installing components package.json",t),Ls.writeFileSync(e,JSON.stringify(t,null," "));try{await Kp().installAllRootModules(wV.get(Hw.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?Ls.writeFileSync(e,JSON.stringify(r,null," ")):Ls.unlinkSync(e),n}}a(NV,"installPackages")});var Fw={};ve(Fw,{packageDirectory:()=>dfe});function dfe(e,t={skip_node_modules:!1,skip_symlinks:!1}){return new Promise((r,n)=>{let s=[];PV.default.pack(e,{dereference:!t.skip_symlinks,ignore:t.skip_node_modules?i=>i.includes("node_modules")||i.includes((0,CV.join)("cache","webpack")):void 0}).pipe((0,DV.createGzip)()).on("data",i=>s.push(i)).on("end",()=>{r(Buffer.concat(s))}).on("error",n)})}var CV,PV,DV,Gw=be(()=>{CV=require("path"),PV=M(require("tar-fs")),DV=require("node:zlib");a(dfe,"packageDirectory")});var Vw=I(UV=>{"use strict";var Oe=require("fs-extra"),qw=require("fast-glob"),we=require("path"),ffe=require("tar-fs"),_fe=require("gunzip-maybe"),$w=require("normalize-path"),Dn=mV(),Ut=Y(),at=(B(),C(G)),zt=ce(),HS=Rt(),pfe=oe(),{PACKAGE_ROOT:hfe}=nt(),{handleHDBError:xt,hdb_errors:mfe}=pe(),{basename:Efe}=require("path"),gfe=kw(),MV=ce(),{Readable:Sfe}=require("stream"),{isMainThread:Tfe}=require("worker_threads"),{HDB_ERROR_MSGS:Ml,HTTP_STATUS_CODES:Bt}=mfe,vV=tt(),{replicateOperation:pi}=(ts(),C(Po)),{packageDirectory:Afe}=(Gw(),C(Fw)),LV=Kp(),Rfe=we.join(hfe,"application-template"),yfe=zt.get(at.CONFIG_PARAMS.ROOTPATH),Qa=we.join(yfe,"ssh"),Fo=we.join(Qa,"known_hosts");function bfe(){Ut.trace("getting custom api status");let e={};try{e={port:zt.get(at.CONFIG_PARAMS.HTTP_PORT),directory:zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw xt(new Error,Ml.FUNCTION_STATUS,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,t)}return e}a(bfe,"customFunctionsStatus");function Ofe(){Ut.trace("getting custom api endpoints");let e={},t=zt.get(at.CONFIG_PARAMS.COMPONENTSROOT);try{qw.sync($w(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:qw.sync($w(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:qw.sync($w(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw xt(new Error,Ml.GET_FUNCTIONS,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,r)}return e}a(Ofe,"getCustomFunctions");function Nfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Dn.getDropCustomFunctionValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("getting custom api endpoint file content");let r=zt.get(at.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 xt(new Error,Ml.GET_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,c)}}a(Nfe,"getCustomFunction");async function wfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Dn.setCustomFunctionValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("setting custom function file content");let r=zt.get(at.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 pi(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw xt(new Error,Ml.SET_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,c)}}a(wfe,"setCustomFunction");async function Ife(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Dn.getDropCustomFunctionValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("dropping custom function file");let r=zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{Oe.unlinkSync(we.join(r,n,s,i+".js"));let o=await pi(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw xt(new Error,Ml.DROP_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,o)}}a(Ife,"dropCustomFunction");async function Cfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Dn.addComponentValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("adding component");let r=zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=we.join(r,n);Oe.mkdirSync(s,{recursive:!0}),Oe.copySync(Rfe,s);let i=await pi(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw xt(new Error,Ml.ADD_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,s)}}a(Cfe,"addComponent");async function Pfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Dn.dropCustomFunctionProjectValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("dropping custom function project");let r=zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=zt.get(at.CONFIG_PARAMS.APPS);if(!pfe.isEmptyOrZeroLength(s)){let i=!1;for(let[o,c]of s.entries())if(c.name===n){s.splice(o,1),i=!0;break}if(i)return HS.updateConfigValue(at.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=we.join(r,n);Oe.rmSync(i,{recursive:!0});let o=await pi(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw xt(new Error,Ml.DROP_FUNCTION_PROJECT,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,i)}}a(Pfe,"dropCustomFunctionProject");async function Dfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Dn.packageComponentValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let r=zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Ut.trace("packaging component",n);let s;try{s=await Oe.realpath(we.join(r,n))}catch(o){if(o.code!==at.NODE_ERROR_CODES.ENOENT)throw o;try{s=await Oe.realpath(we.join(zt.get(at.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(c){if(c.code===at.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}let i=(await Afe(s,e)).toString("base64");return{project:n,payload:i}}a(Dfe,"packageComponent");async function Lfe(e){e.project?e.project=we.parse(e.project).name:e.package&&(e.project=Mfe(e.package));let t=Dn.deployComponentValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let r=zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i,install_command:o}=e;if(Ut.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let c;if(s){c=we.join(r,n),i="file:"+c,await Oe.emptyDir(c);let S=Sfe.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((E,R)=>{S.pipe(_fe()).pipe(ffe.extract(c,{finish:E})).on("error",R)});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 A=we.join(c,"node_modules");o?await LV.runCommand(o,c):Oe.existsSync(A)||await LV.installAllRootModules(!1,c)}else{await HS.addConfig(n,{package:i}),await gfe();let S=MV.get(at.CONFIG_PARAMS.ROOTPATH);c=we.join(S,"node_modules",n)}if(Tfe)return;let l=new Map;l.isWorker=!0;let u=(jp(),C(zp)),f;u.setErrorReporter(S=>f=S);let d=Efe(c),p=u.component_errors.get(d);try{await u.loadComponent(c,l)}finally{u.component_errors.set(d,p)}if(f)throw f;Ut.info("Installed component");let _=e.restart==="rolling";e.restart=_?!1:e.restart;let h=await pi(e);if(e.restart===!0)vV.restartWorkers("http"),h.message=`Successfully deployed: ${n}, restarting HarperDB`;else if(_){let g=await Kw().executeJob({operation:"restart_service",service:"http",replicated:!0});h.restartJobId=g.job_id,h.message=`Successfully deployed: ${n}, restarting HarperDB`}else h.message=`Successfully deployed: ${n}`;return h}a(Lfe,"deployComponent");function Mfe(e){if(e.startsWith("git+ssh://"))return we.basename(e.split("#")[0].replace(/\.git$/,""));if(e.startsWith("http://")||e.startsWith("https://"))return we.basename(new URL(e.replace(/\.git$/,"")).pathname);if(e.startsWith("file://"))try{let{name:t}=JSON.parse(Oe.readFileSync(we.join(e,"package.json"),"utf8"));return we.basename(t)}catch{}return we.basename(e)}a(Mfe,"getProjectNameFromPackage");async function vfe(){let e=a(async(s,i)=>{try{let o=await Oe.readdir(s,{withFileTypes:!0});for(let c of o){let l=c.name;if(l.startsWith(".")||l==="node_modules")continue;let u=we.join(s,l);if(c.isDirectory()||c.isSymbolicLink()){let f={name:l,entries:[]};i.entries.push(f),await e(u,f)}else{let f=await Oe.stat(u),d={name:we.basename(l),mtime:f.mtime,size:f.size};i.entries.push(d)}}return i}catch(o){return Ut.warn("Error loading package",o),{error:o.toString(),entries:[]}}},"walkDir"),t=await e(zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{name:zt.get(at.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(vfe,"getComponents");async function Ufe(e){let t=Dn.getComponentFileValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let n=HS.getConfigObj()[e.project]||e.project==="harperdb"?we.join(MV.get(at.CONFIG_PARAMS.ROOTPATH),"node_modules"):zt.get(at.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===at.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${we.join(e.project,e.file)}'`):i}}a(Ufe,"getComponentFile");async function xfe(e){let t=Dn.setComponentFileValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=we.join(zt.get(at.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 pi(e);return s.message="Successfully set component: "+e.file,s}a(xfe,"setComponentFile");async function Bfe(e){let t=Dn.dropComponentFileValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{project:r,file:n}=e,s=e.file?we.join(r,n):r,i=we.join(zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),s),o=we.join(zt.get(at.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(zt.get(at.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 pi(e);return e.restart===!0?(vV.restartWorkers("http"),l.message=`Successfully dropped: ${s}, restarting HarperDB`):l.message=`Successfully dropped: ${s}`,l}a(Bfe,"dropComponent");async function Hfe(e){let t=Dn.addSSHKeyValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;Ut.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}
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(ofe,"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 afe(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=ja.join(Hw,o);n[o]={npm_output:null,npm_error:null};try{let l=await vd("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(afe,"auditModules");async function BS(){return await vd("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=ja.join(Hw,i.toString());if(!await Ld.pathExists(o)){t.push(i);continue}let l=ja.join(o,"package.json");await Ld.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 efe.validateBySchema(e,t)}a(yV,"modulesValidator")});var Fw=w((LMe,PV)=>{"use strict";var Ds=require("fs-extra"),Wp=require("path"),Yp=z(),OV=se(),{PACKAGE_ROOT:cfe}=st(),kw=(H(),C(q)),CV=ae(),lfe=yt();PV.exports=ufe;async function ufe(){let e=dfe(),t=CV.get(kw.CONFIG_PARAMS.ROOTPATH),r=Wp.join(t,"package.json"),n={dependencies:{harperdb:"file:"+cfe}},s=Wp.join(t,"node_modules");Ds.ensureDirSync(s);let i,o=!0,c=!1;try{i=Ds.readJsonSync(r)}catch(l){if(OV.isEmptyOrZeroLength(e))return;if(l.code!==kw.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(Ds.statSync(new URL(u+"/package.json")).mtimeMs>Ds.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(ufe,"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(Ds.existsSync(n)&&Ds.lstatSync(n).isDirectory())return Ds.move(n,s,{overwrite:!0}).then(()=>{Ds.symlink(s,n)})}))}a(NV,"moveModuleToComponents");function dfe(){let e=lfe.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(dfe,"getComponentsConfig");function wV(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Wp.extname(e)||Ds.existsSync(e)?"file:":"github:"}a(wV,"getPkgPrefix");async function IV(e,t,r){Yp.trace("npm installing components package.json",t),Ds.writeFileSync(e,JSON.stringify(t,null," "));try{await Kp().installAllRootModules(CV.get(kw.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?Ds.writeFileSync(e,JSON.stringify(r,null," ")):Ds.unlinkSync(e),n}}a(IV,"installPackages")});var Gw={};ve(Gw,{packageDirectory:()=>ffe});function ffe(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,qw=be(()=>{DV=require("path"),LV=M(require("tar-fs")),MV=require("node:zlib");a(ffe,"packageDirectory")});var Kw=w(BV=>{"use strict";var Oe=require("fs-extra"),$w=require("fast-glob"),we=require("path"),_fe=require("tar-fs"),pfe=require("gunzip-maybe"),Vw=require("normalize-path"),Pn=gV(),Ut=z(),at=(H(),C(q)),jt=ae(),HS=yt(),hfe=se(),{PACKAGE_ROOT:mfe}=st(),{handleHDBError:xt,hdb_errors:Efe}=pe(),{basename:gfe}=require("path"),Sfe=Fw(),UV=ae(),{Readable:Tfe}=require("stream"),{isMainThread:Afe}=require("worker_threads"),{HDB_ERROR_MSGS:Ll,HTTP_STATUS_CODES:Bt}=Efe,xV=et(),{replicateOperation:_i}=(es(),C(Po)),{packageDirectory:Rfe}=(qw(),C(Gw)),vV=Kp(),yfe=we.join(mfe,"application-template"),bfe=jt.get(at.CONFIG_PARAMS.ROOTPATH),Qa=we.join(bfe,"ssh"),Fo=we.join(Qa,"known_hosts");function Ofe(){Ut.trace("getting custom api status");let e={};try{e={port:jt.get(at.CONFIG_PARAMS.HTTP_PORT),directory:jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw xt(new Error,Ll.FUNCTION_STATUS,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,t)}return e}a(Ofe,"customFunctionsStatus");function Nfe(){Ut.trace("getting custom api endpoints");let e={},t=jt.get(at.CONFIG_PARAMS.COMPONENTSROOT);try{$w.sync(Vw(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:$w.sync(Vw(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:$w.sync(Vw(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw xt(new Error,Ll.GET_FUNCTIONS,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,r)}return e}a(Nfe,"getCustomFunctions");function wfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Pn.getDropCustomFunctionValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("getting custom api endpoint file content");let r=jt.get(at.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 xt(new Error,Ll.GET_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,c)}}a(wfe,"getCustomFunction");async function Ife(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Pn.setCustomFunctionValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("setting custom function file content");let r=jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{Oe.outputFileSync(we.join(r,n,s,i+".js"),o);let c=await _i(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw xt(new Error,Ll.SET_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,c)}}a(Ife,"setCustomFunction");async function Cfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Pn.getDropCustomFunctionValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("dropping custom function file");let r=jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{Oe.unlinkSync(we.join(r,n,s,i+".js"));let o=await _i(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw xt(new Error,Ll.DROP_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,o)}}a(Cfe,"dropCustomFunction");async function Pfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Pn.addComponentValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("adding component");let r=jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=we.join(r,n);Oe.mkdirSync(s,{recursive:!0}),Oe.copySync(yfe,s);let i=await _i(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw xt(new Error,Ll.ADD_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,s)}}a(Pfe,"addComponent");async function Dfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Pn.dropCustomFunctionProjectValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("dropping custom function project");let r=jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=jt.get(at.CONFIG_PARAMS.APPS);if(!hfe.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(at.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=we.join(r,n);Oe.rmSync(i,{recursive:!0});let o=await _i(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw xt(new Error,Ll.DROP_FUNCTION_PROJECT,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,i)}}a(Dfe,"dropCustomFunctionProject");async function Lfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Pn.packageComponentValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let r=jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Ut.trace("packaging component",n);let s;try{s=await Oe.realpath(we.join(r,n))}catch(o){if(o.code!==at.NODE_ERROR_CODES.ENOENT)throw o;try{s=await Oe.realpath(we.join(jt.get(at.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(c){if(c.code===at.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}let i=(await Rfe(s,e)).toString("base64");return{project:n,payload:i}}a(Lfe,"packageComponent");async function Mfe(e){e.project?e.project=we.parse(e.project).name:e.package&&(e.project=vfe(e.package));let t=Pn.deployComponentValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let r=jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i,install_command:o}=e;if(Ut.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=Tfe.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((E,A)=>{S.pipe(pfe()).pipe(_fe.extract(c,{finish:E})).on("error",A)});let g=await Oe.readdir(c);g.length===1&&g[0]==="package"&&(await Oe.copy(we.join(c,"package"),c),await Oe.remove(we.join(c,"package")));let R=we.join(c,"node_modules");o?await vV.runCommand(o,c):Oe.existsSync(R)||await vV.installAllRootModules(!1,c)}else{await HS.addConfig(n,{package:i}),await Sfe();let S=UV.get(at.CONFIG_PARAMS.ROOTPATH);c=we.join(S,"node_modules",n)}if(Afe)return;let l=new Map;l.isWorker=!0;let u=(jp(),C(zp)),f;u.setErrorReporter(S=>f=S);let d=gfe(c),p=u.component_errors.get(d);try{await u.loadComponent(c,l)}finally{u.component_errors.set(d,p)}if(f)throw f;Ut.info("Installed component");let _=e.restart==="rolling";e.restart=_?!1:e.restart;let h=await _i(e);if(e.restart===!0)xV.restartWorkers("http"),h.message=`Successfully deployed: ${n}, restarting HarperDB`;else if(_){let g=await Yw().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(Mfe,"deployComponent");function vfe(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(vfe,"getProjectNameFromPackage");async function Ufe(){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 Ut.warn("Error loading package",o),{error:o.toString(),entries:[]}}},"walkDir"),t=await e(jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{name:jt.get(at.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(Ufe,"getComponents");async function xfe(e){let t=Pn.getComponentFileValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let n=HS.getConfigObj()[e.project]||e.project==="harperdb"?we.join(UV.get(at.CONFIG_PARAMS.ROOTPATH),"node_modules"):jt.get(at.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===at.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${we.join(e.project,e.file)}'`):i}}a(xfe,"getComponentFile");async function Bfe(e){let t=Pn.setComponentFileValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=we.join(jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await Oe.ensureFile(n),await Oe.outputFile(n,e.payload,r)):await Oe.ensureDir(n);let s=await _i(e);return s.message="Successfully set component: "+e.file,s}a(Bfe,"setComponentFile");async function Hfe(e){let t=Pn.dropComponentFileValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{project:r,file:n}=e,s=e.file?we.join(r,n):r,i=we.join(jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),s),o=we.join(jt.get(at.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(at.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 _i(e);return e.restart===!0?(xV.restartWorkers("http"),l.message=`Successfully dropped: ${s}, restarting HarperDB`):l.message=`Successfully dropped: ${s}`,l}a(Hfe,"dropComponent");async function kfe(e){let t=Pn.addSSHKeyValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;Ut.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
34
  Host ${s}
35
35
  HostName ${i}
36
36
  User git
37
37
  IdentityFile ${c}
38
38
  IdentitiesOnly yes`;await Oe.pathExists(l)?await Oe.appendFile(l,`
39
39
  `+u):await Oe.outputFile(l,u);let f="";if(await Oe.pathExists(Fo)||(await Oe.writeFile(Fo,""),await Oe.chmod(Fo,"0600")),i=="github.com"&&!(await Oe.readFile(Fo,"utf8")).includes("github.com"))try{let S=(await(await fetch("https://api.github.com/meta")).json()).ssh_keys;for(let g of S)Oe.appendFile(Fo,"github.com "+g+`
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(Fo,o);let d=await pi(e);return d.message=`Added ssh key: ${r}${f}`,d}a(Hfe,"addSSHKey");async function kfe(e){let t=Dn.updateSSHKeyValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{name:r,key:n}=e;Ut.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 pi(e);return i.message=`Updated ssh key: ${r}`,i}a(kfe,"updateSSHKey");async function Ffe(e){let t=Dn.deleteSSHKeyValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{name:r}=e;Ut.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 pi(e);return c.message=`Deleted ssh key: ${r}`,c}a(Ffe,"deleteSSHKey");async function Gfe(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(Gfe,"listSSHKeys");async function qfe(e){let t=Dn.setSSHKnownHostsValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{known_hosts:r}=e;await Oe.outputFile(Fo,r);let n=await pi(e);return n.message="Known hosts successfully set",n}a(qfe,"setSSHKnownHosts");async function $fe(e){return await Oe.pathExists(Fo)?{known_hosts:await Oe.readFile(Fo,"utf8")}:{known_hosts:null}}a($fe,"getSSHKnownHosts");Object.assign(UV,{customFunctionsStatus:bfe,getCustomFunctions:Ofe,getCustomFunction:Nfe,setCustomFunction:wfe,dropCustomFunction:Ife,addComponent:Cfe,dropCustomFunctionProject:Pfe,packageComponent:Dfe,deployComponent:Lfe,getComponents:vfe,getComponentFile:Ufe,setComponentFile:xfe,dropComponent:Bfe,addSSHKey:Hfe,updateSSHKey:kfe,deleteSSHKey:Ffe,listSSHKeys:Gfe,setSSHKnownHosts:qfe,getSSHKnownHosts:$fe})});var Yw=I((xMe,BV)=>{"use strict";var Ms=require("joi"),xV=ut();BV.exports={readTransactionLogValidator:Vfe,deleteTransactionLogsBeforeValidator:Kfe};function Vfe(e){let t=Ms.object({schema:Ms.string(),database:Ms.string(),table:Ms.string().required(),from:Ms.date().timestamp(),to:Ms.date().timestamp(),limit:Ms.number().min(1)});return xV.validateBySchema(e,t)}a(Vfe,"readTransactionLogValidator");function Kfe(e){let t=Ms.object({schema:Ms.string(),database:Ms.string(),table:Ms.string().required(),timestamp:Ms.date().timestamp().required()});return xV.validateBySchema(e,t)}a(Kfe,"deleteTransactionLogsBeforeValidator")});var GS=I((HMe,$V)=>{"use strict";var Ww=(B(),C(G)),Qp=ir(),HV=oe(),kV=ce(),FV=To(),GV=Y(),{handleHDBError:kS,hdb_errors:Yfe}=pe(),{HTTP_STATUS_CODES:FS}=Yfe,{readTransactionLogValidator:Wfe,deleteTransactionLogsBeforeValidator:zfe}=Yw(),qV=Wn(),jfe="Logs successfully deleted from transaction log.",Qfe="All logs successfully deleted from transaction log.";$V.exports={readTransactionLog:Jfe,deleteTransactionLogsBefore:Zfe};async function Jfe(e){let t=Wfe(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=HV.checkSchemaTableExist(e.database,e.table);if(r)throw kS(new Error,r,FS.NOT_FOUND,void 0,void 0,!0);return kV.get(Ww.CONFIG_PARAMS.CLUSTERING_ENABLED)?await Xfe(e):(GV.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)),qV.readAuditLog(e))}a(Jfe,"readTransactionLog");async function*Xfe(e){let t=FV.createNatsTableStreamName(e.database,e.table),r=await Qp.viewStreamIterator(t,parseInt(e.from),e.limit);for await(let n of r){let s=Math.floor(n?.nats_timestamp/1e6);if(e.to&&s>e.to)break;let i={operation:n?.entry?.operation,user:n?.entry?.__origin?.user,timestamp:s,records:n?.entry?.records,attributes:n?.entry?.attributes};n?.entry?.operation===Ww.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(Xfe,"readTransactionLogNats");async function Zfe(e){let t=zfe(e);if(t)throw kS(t,t.message,FS.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!kV.get(Ww.CONFIG_PARAMS.CLUSTERING_ENABLED))return GV.info("Delete transaction logs called for Plexus"),qV.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=HV.checkSchemaTableExist(r,n);if(i)throw kS(new Error,i,FS.NOT_FOUND,void 0,void 0,!0);let o=FV.createNatsTableStreamName(r,n),{jsm:c}=await Qp.getNATSReferences(),l=await Qp.getStreamInfo(o),u=new Date(l.state.first_ts).getTime();if(s<=u)return`No transactions exist before: ${s}`;let f=jfe,d,p=new Date(l.state.last_ts).getTime();return s>p?(d=l.state.last_seq+1,f=Qfe):d=(await Qp.viewStream(o,parseInt(s),1))[0].nats_sequence,await Qp.purgeTableStream(r,n,{seq:d}),f}a(Zfe,"deleteTransactionLogsBefore")});var KV=I((FMe,VV)=>{"use strict";var zw=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}};VV.exports=zw});var WV=I((qMe,YV)=>{"use strict";var jw=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};YV.exports=jw});var Jw=I((VMe,jV)=>{"use strict";var zV=KV(),e_e=WV(),{HDB_ERROR_MSGS:t_e}=Hn(),Qw=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=t_e.OP_AUTH_PERMS_ERROR,this.unauthorized_access={},this.invalid_schema_items=[]}handleUnauthorizedItem(t){return this.invalid_schema_items=[],this.unauthorized_access=[t],this}handleInvalidItem(t){return this.invalid_schema_items=[t],this.unauthorized_access=[],this}addInvalidItem(t,r,n){if(r&&n){let s=`${r}_${n}`;if(this.unauthorized_access[s])return}this.invalid_schema_items.push(t)}addUnauthorizedTable(t,r,n){let s=new zV(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new e_e(c,s[c]);i.push(l)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new zV(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=Qw});var KS=I((zMe,f1)=>{"use strict";var Xw=yn(),qS=Wr(),vs=Vg(),Zp=Ao(),Zw=Vc(),r_e=AN(),n_e=lG(),eh=Rn(),$S=q_(),Sr=Y(),s_e=NN(),i_e=Ed(),o_e=JN(),a_e=nS(),c_e=ew(),l_e=tw(),u_e=aS(),d_e=lS(),eI=uS(),Go=oe(),f_e=qq(),tI=hS(),XV=za(),nn=(B(),C(G)),ZV=rV(),__e=Do(),e1=(zu(),C(ep)),t1=(MS(),C(Gp)),r1=Rt(),cr=Vw(),p_e=require("alasql"),n1=GS(),s1=Kp(),Ud=rs(),i1=(Al(),C(Tl)),o1=Jw(),{handleHDBError:Ln,hdb_errors:a1}=pe(),{addNodeBack:YMe,removeNodeBack:WMe}=(Al(),C(Tl)),{HDB_ERROR_MSGS:xr,HTTP_STATUS_CODES:Jp}=a1,X=new Map,c1="delete",Ja="insert",qo="read",vl="update",Xp="describe",QV=Zp.describeSchema.name,JV=Zp.describeTable.name,l1={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},h_e={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},m_e="catchup",E_e="handleGetJob",g_e="handleGetJobsByStartDate",VS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},S_e=[vs.createTable.name,vs.createAttribute.name,vs.dropTable.name,vs.dropAttribute.name],u1={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},ne=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};X.set(Xw.insert.name,new ne(!1,[Ja]));X.set(Xw.update.name,new ne(!1,[vl]));X.set(Xw.upsert.name,new ne(!1,[Ja,vl]));X.set(qS.searchByConditions.name,new ne(!1,[qo]));X.set(qS.searchByHash.name,new ne(!1,[qo]));X.set(qS.searchByValue.name,new ne(!1,[qo]));X.set(qS.search.name,new ne(!1,[qo]));X.set(vs.createSchema.name,new ne(!0,[]));X.set(vs.createTable.name,new ne(!0,[]));X.set(vs.createAttribute.name,new ne(!1,[Ja]));X.set(vs.dropSchema.name,new ne(!0,[]));X.set(vs.dropTable.name,new ne(!0,[]));X.set(vs.dropAttribute.name,new ne(!0,[]));X.set(Zp.describeSchema.name,new ne(!1,[qo]));X.set(Zp.describeTable.name,new ne(!1,[qo]));X.set(Zw.deleteRecord.name,new ne(!1,[c1]));X.set(eh.addUser.name,new ne(!0,[]));X.set(eh.alterUser.name,new ne(!0,[]));X.set(eh.dropUser.name,new ne(!0,[]));X.set(eh.listUsersExternal.name,new ne(!0,[]));X.set($S.listRoles.name,new ne(!0,[]));X.set($S.addRole.name,new ne(!0,[]));X.set($S.alterRole.name,new ne(!0,[]));X.set($S.dropRole.name,new ne(!0,[]));X.set(s_e.name,new ne(!0,[]));X.set(i_e.name,new ne(!0,[]));X.set(o_e.name,new ne(!0,[]));X.set(a_e.name,new ne(!0,[]));X.set(c_e.name,new ne(!0,[]));X.set(l_e.name,new ne(!0,[]));X.set(eI.setRoutes.name,new ne(!0,[]));X.set(eI.getRoutes.name,new ne(!0,[]));X.set(eI.deleteRoutes.name,new ne(!0,[]));X.set(r1.setConfiguration.name,new ne(!0,[]));X.set(u_e.clusterStatus.name,new ne(!0,[]));X.set(d_e.name,new ne(!0,[]));X.set(tI.getFingerprint.name,new ne(!0,[]));X.set(tI.setLicense.name,new ne(!0,[]));X.set(Zw.deleteFilesBefore.name,new ne(!0,[]));X.set(Zw.deleteAuditLogsBefore.name,new ne(!0,[]));X.set(XV.restart.name,new ne(!0,[]));X.set(XV.restartService.name,new ne(!0,[]));X.set(r_e.name,new ne(!0,[]));X.set(n_e.name,new ne(!0,[qo]));X.set(__e.systemInformation.name,new ne(!0,[]));X.set(r1.getConfiguration.name,new ne(!0,[]));X.set(n1.readTransactionLog.name,new ne(!0,[]));X.set(n1.deleteTransactionLogsBefore.name,new ne(!0,[]));X.set(s1.installModules.name,new ne(!0,[]));X.set(s1.auditModules.name,new ne(!0,[]));X.set(Ud.createCsr.name,new ne(!0,[]));X.set(Ud.signCertificate.name,new ne(!0,[]));X.set(Ud.listCertificates.name,new ne(!0,[]));X.set(Ud.addCertificate.name,new ne(!0,[]));X.set(Ud.removeCertificate.name,new ne(!0,[]));X.set(Ud.getKey.name,new ne(!0,[]));X.set(i1.addNodeBack.name,new ne(!0,[]));X.set(i1.removeNodeBack.name,new ne(!0,[]));X.set(e1.createTokens.name,new ne(!1,[]));X.set(e1.refreshOperationToken.name,new ne(!1,[]));X.set(t1.login.name,new ne(!1,[]));X.set(t1.logout.name,new ne(!1,[]));X.set(cr.customFunctionsStatus.name,new ne(!0,[]));X.set(cr.getCustomFunctions.name,new ne(!0,[]));X.set(cr.getComponents.name,new ne(!0,[]));X.set(cr.getComponentFile.name,new ne(!0,[]));X.set(cr.setComponentFile.name,new ne(!0,[]));X.set(cr.dropComponent.name,new ne(!0,[]));X.set(cr.getCustomFunction.name,new ne(!0,[]));X.set(cr.setCustomFunction.name,new ne(!0,[]));X.set(cr.dropCustomFunction.name,new ne(!0,[]));X.set(cr.addComponent.name,new ne(!0,[]));X.set(cr.dropCustomFunctionProject.name,new ne(!0,[]));X.set(cr.packageComponent.name,new ne(!0,[]));X.set(cr.deployComponent.name,new ne(!0,[]));X.set(cr.addSSHKey.name,new ne(!0,[]));X.set(cr.updateSSHKey.name,new ne(!0,[]));X.set(cr.deleteSSHKey.name,new ne(!0,[]));X.set(cr.listSSHKeys.name,new ne(!0,[]));X.set(cr.setSSHKnownHosts.name,new ne(!0,[]));X.set(cr.getSSHKnownHosts.name,new ne(!0,[]));X.set(tI.getRegistrationInfo.name,new ne(!1,[]));X.set(eh.userInfo.name,new ne(!1,[]));X.set(Zp.describeAll.name,new ne(!1,[]));X.set(E_e,new ne(!1,[]));X.set(g_e,new ne(!0,[]));X.set(m_e,new ne(!0,[]));X.set(VS.CSV_DATA_LOAD,new ne(!1,[Ja,vl]));X.set(VS.CSV_URL_LOAD,new ne(!1,[Ja,vl]));X.set(VS.CSV_FILE_LOAD,new ne(!1,[Ja,vl]));X.set(VS.IMPORT_FROM_S3,new ne(!1,[Ja,vl]));X.set(u1.EXPORT_TO_S3,new ne(!0,[]));X.set(u1.EXPORT_LOCAL,new ne(!0,[]));X.set(nn.VALID_SQL_OPS_ENUM.DELETE,new ne(!1,[c1]));X.set(nn.VALID_SQL_OPS_ENUM.SELECT,new ne(!1,[qo]));X.set(nn.VALID_SQL_OPS_ENUM.INSERT,new ne(!1,[Ja]));X.set(nn.VALID_SQL_OPS_ENUM.UPDATE,new ne(!1,[vl]));f1.exports={verifyPerms:A_e,verifyPermsAst:T_e,verifyBulkLoadAttributePerms:y_e};function T_e(e,t,r){if(Go.isEmptyOrZeroLength(e))throw Sr.info("verify_perms_ast has an empty user parameter"),Ln(new Error);if(Go.isEmptyOrZeroLength(t))throw Sr.info("verify_perms_ast has an empty user parameter"),Ln(new Error);if(Go.isEmptyOrZeroLength(r))throw Sr.info("verify_perms_ast has a null operation parameter"),Ln(new Error);try{let n=new o1,s=new f_e(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw Sr.info("No schemas defined in verifyPermsAst(), will not continue."),Ln(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&l1[r])throw Ln(new Error,xr.DROP_SYSTEM,Jp.FORBIDDEN);if(c&&!l)return null;let u=ZV.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof p_e.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(u));for(let d=0;d<i.length;d++){let p=s.getTablesBySchemaName(i[d]);p&&o.set(i[d],p)}let f=d1(t,r,o,n);return f||(o.forEach((d,p)=>{for(let _=0;_<d.length;_++){let h=s.getAttributesBySchemaTableName(p,d[_]),S=nI(t.role.permission,p,d[_]);rI(h,S,r,d[_],p,n)}}),n.getPermsResponse())}catch(n){throw Ln(n)}}a(T_e,"verifyPermsAst");function A_e(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw Sr.info("null required parameter in verifyPerms"),Ln(new Error,xr.DEFAULT_INVALID_REQUEST,Jp.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 o1;if(Go.isEmptyOrZeroLength(e.hdb_user?.role)||Go.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(xr.USER_HAS_NO_PERMS(e.hdb_user?.username));let l=!!e.hdb_user?.role?.permission?.super_user,u=e.hdb_user?.role?.permission?.structure_user,f=o.has(nn.SYSTEM_SCHEMA_NAME)||s===nn.SYSTEM_SCHEMA_NAME;if(l&&f&&h_e[e.operation]&&(i===nn.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME||i===nn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||i===nn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME))return null;if(f&&l1[r])throw Ln(new Error,xr.DROP_SYSTEM,Jp.FORBIDDEN);if(l&&!f||u===!0&&(r===vs.createSchema.name||r===vs.dropSchema.name))return null;if(S_e.indexOf(r)>=0&&(u===!0||Array.isArray(u)))return u===!0||u.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let d=ZV.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=d),(r===QV||r===JV)&&!d.super_user){if(s===nn.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===JV&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][Xp]))return c.handleInvalidItem(xr.TABLE_NOT_FOUND(s,i))}let p=d1(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&&nn.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let S=[],g=d[s].tables[i];g[nn.PERMS_CRUD_ENUM.READ]&&(g.attribute_permissions.length>0?g.attribute_permissions.filter(E=>E[nn.PERMS_CRUD_ENUM.READ]).forEach(E=>{S.push(E.attribute_name)}):S=global.hdb_schema[s][i].attributes.map(A=>A.attribute),e.get_attributes=S)}let _=R_e(e),h=nI(e.hdb_user?.role?.permission,s,i);return rI(_,h,r,i,s,c,n),c.getPermsResponse()}a(A_e,"verifyPerms");function d1(e,t,r,n,s){if(Go.arrayHasEmptyValues([e,t,r]))throw Sr.info("hasPermissions has an invalid parameter"),Ln(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.`),Ln(new Error,xr.OP_NOT_FOUND(t),Jp.BAD_REQUEST);if(X.get(t)&&X.get(t).requires_su)return Sr.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;!Go.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 _=xr.UNKNOWN_OP_AUTH_ERROR(t,l,f);throw Sr.error(_),Sr.error(p),Ln(a1.CHECK_LOGS_WRAPPER(_))}}}return r.size<2?n.getPermsResponse():null}a(d1,"hasPermissions");function rI(e,t,r,n,s,i,o){if(!e||!t)throw Sr.info("no attributes specified in checkAttributePerms."),Ln(new Error);let c=X.get(r).perms;if(!c||c==="")throw Sr.info(`no permissions found for ${r} in checkAttributePerms().`),Ln(new Error);if(Go.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(xr.ATTR_NOT_FOUND(s,n,f),s,n);continue}if(c)for(let p of c){if(nn.TIME_STAMP_NAMES.includes(d.attribute_name)&&p!==qo)throw Ln(new Error,xr.SYSTEM_TIMESTAMP_PERMS_ERR,Jp.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(rI,"checkAttributePerms");function R_e(e){let t=new Set;try{if(e.action)return t;if(e.operation===nn.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS&&e.conditions.forEach(r=>{t.add(r.search_attribute)}),e&&e.search_attribute&&t.add(e.search_attribute),!e.records||e.records.length===0){if(!e.get_attributes||!e.get_attributes.length===0)return t;for(let r=0;r<e.get_attributes.length;r++)t.add(e.get_attributes[r])}else for(let r=0;r<e.records.length;r++){let n=Object.keys(e.records[r]);for(let s=0;s<n.length;s++)t.add(n[s])}}catch(r){Sr.info(r)}return t}a(R_e,"getRecordAttributes");function nI(e,t,r){let n=new Map;if(Go.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(nI,"getAttributePermissions");function y_e(e,t,r,n,s,i,o){let c=new Set(i),l=nI(e,n,s);rI(c,l,t,s,n,o,r)}a(y_e,"verifyBulkLoadAttributePerms")});var WS=I((QMe,E1)=>{"use strict";E1.exports={evaluateSQL:x_e,processAST:m1,convertSQLToAST:h1,checkASTPermissions:p1};var b_e=yn(),_1=require("util"),O_e=_1.callbackify(b_e.insert),N_e=Wr().search,w_e=ZH().update,I_e=_1.callbackify(w_e),C_e=tk().convertDelete,Xa=require("alasql"),P_e=KS(),YS=Y(),D_e=aE(),L_e=oe(),th=(B(),C(G)),{hdb_errors:M_e,handleHDBError:sI}=pe(),{HTTP_STATUS_CODES:iI}=M_e;D_e(Xa);var v_e=403,U_e="There was a problem performing this insert. Please check the logs and try again.",oI=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function x_e(e,t){let r=e.parsed_sql_object;if(!r){r=h1(e.sql);let n,s=r.ast.statements[0];if(s instanceof Xa.yy.Insert?n=s.into.databaseid:s instanceof Xa.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Xa.yy.Update||s instanceof Xa.yy.Delete?n=s.table.databaseid:YS.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Xa.yy.Select)&&L_e.isEmptyOrZeroLength(n))return t("No schema specified",null)}m1(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(x_e,"evaluateSQL");function p1(e,t){let r;try{r=P_e.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(p1,"checkASTPermissions");function h1(e){let t=new oI;if(!e)throw sI(new Error,"The 'sql' parameter is missing from the request body",iI.BAD_REQUEST);try{let r=e.trim(),n=Xa.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
41
- `);throw n[1]?sI(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,iI.BAD_REQUEST):sI(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",iI.BAD_REQUEST)}return t}a(h1,"convertSQLToAST");function m1(e,t,r){try{let n=B_e;if(!e.bypass_auth&&!t.permissions_checked){let i=p1(e,t);if(i&&i.length>0)return r(v_e,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case th.VALID_SQL_OPS_ENUM.SELECT:n=N_e,s=t.ast.statements[0];break;case th.VALID_SQL_OPS_ENUM.INSERT:n=H_e;break;case th.VALID_SQL_OPS_ENUM.UPDATE:n=I_e;break;case th.VALID_SQL_OPS_ENUM.DELETE:n=C_e;break;default:throw new Error(`unsupported SQL type ${t.variant} in SQL: ${e}`)}n(s,(i,o)=>{if(i){r(i);return}r(null,o)})}catch(n){return r(n)}}a(m1,"processAST");function B_e(e,t){YS.info(e),t("unknown sql statement")}a(B_e,"nullFunction");function H_e({statement:e,hdb_user:t},r){let n=e.into,s={schema:n.databaseid,table:n.tableid,operation:"insert",hdb_user:t},i=e.columns.map(o=>o.columnid);try{s.records=k_e(i,e.values)}catch(o){return r(o)}O_e(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){YS.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(H_e,"convertInsert");function k_e(e,t){try{return t.map(r=>{if(e.length!==r.length)throw"number of values do not match number of columns in insert";let n={};return r.forEach((s,i)=>{if(s.columnid)throw"cannot use a column in insert value";"value"in s?n[e[i]]=s.value:n[e[i]]=Xa.compile(`SELECT ${s.toString()} AS [${th.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw YS.error(r),new Error(U_e)}}a(k_e,"createDataObjects")});var fI=I((eve,A1)=>{var JS=require("clone"),XS=ut(),F_e=oe(),jS=(B(),C(G)),XMe=Y(),aI=require("fs"),lI=require("joi"),{string:QS}=lI.types(),{hdb_errors:G_e,handleHDBError:zS}=pe(),{HDB_ERROR_MSGS:ZMe,HTTP_STATUS_CODES:cI}=G_e,{common_validators:xd}=vi(),g1=" is required",q_e=["insert","update","upsert"],uI={database:{presence:!1,format:xd.schema_format,length:xd.schema_length},schema:{presence:!1,format:xd.schema_format,length:xd.schema_length},table:{presence:!0,format:xd.schema_format,length:xd.schema_length},action:{inclusion:{within:q_e,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},$_e={schema:QS.required(),table:QS.required(),action:QS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:V_e,AWS_SECRET:K_e,AWS_BUCKET:Y_e,AWS_FILE_KEY:W_e,REGION:z_e}=jS.S3_BUCKET_AUTH_KEYS,j_e={s3:{presence:!0},[`s3.${V_e}`]:{presence:!0,type:"String"},[`s3.${K_e}`]:{presence:!0,type:"String"},[`s3.${Y_e}`]:{presence:!0,type:"String"},[`s3.${W_e}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${z_e}`]:{presence:!0,type:"String"}},S1=JS(uI);S1.data.presence={message:g1};var T1=JS(uI);T1.file_path.presence={message:g1};var Q_e=Object.assign(JS(uI),j_e),dI=JS($_e);dI.csv_url=QS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();dI.passthrough_headers=lI.object();function J_e(e){let t=XS.validateObject(e,S1);return ZS(e,t)}a(J_e,"dataObject");function X_e(e){let t=XS.validateBySchema(e,lI.object(dI));return ZS(e,t)}a(X_e,"urlObject");function Z_e(e){let t=XS.validateObject(e,T1);return ZS(e,t)}a(Z_e,"fileObject");function epe(e){let t=XS.validateObject(e,Q_e);return ZS(e,t)}a(epe,"s3FileObject");function ZS(e,t){if(!t){let r=F_e.checkGlobalSchemaTable(e.schema,e.table);if(r)return zS(new Error,r,cI.BAD_REQUEST);if(e.operation===jS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{aI.accessSync(e.file_path,aI.constants.R_OK|aI.constants.F_OK)}catch(n){return n.code===jS.NODE_ERROR_CODES.ENOENT?zS(n,`No such file or directory ${n.path}`,cI.BAD_REQUEST):n.code===jS.NODE_ERROR_CODES.EACCES?zS(n,`Permission denied ${n.path}`,cI.BAD_REQUEST):zS(n)}}return t}a(ZS,"postValidateChecks");A1.exports={dataObject:J_e,urlObject:X_e,fileObject:Z_e,s3FileObject:epe}});var _I=I((rve,R1)=>{"use strict";var rh=Y(),eT=(B(),C(G));async function tpe(e,t,r,n=void 0){if(!e||typeof e!="function")throw new Error("Invalid function parameter");let s;try{return s=await e(t),r&&await r(t,s,n),t.operation===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(tpe,"callOperationFunctionAsAwait");R1.exports={callOperationFunctionAsAwait:tpe}});var pI=I((sve,b1)=>{"use strict";var{S3:rpe,GetObjectCommand:npe}=require("@aws-sdk/client-s3");b1.exports={getFileStreamFromS3:spe,getS3AuthObj:y1};async function spe(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await y1(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new npe(r))).Body}a(spe,"getFileStreamFromS3");function y1(e,t,r){return new rpe({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(y1,"getS3AuthObj")});var N1=I((ove,O1)=>{"use strict";var hI=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}},mI=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};O1.exports={BulkLoadFileObject:hI,BulkLoadDataObject:mI}});var I1=I((cve,w1)=>{"use strict";var EI=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};w1.exports=EI});var yI=I((pve,K1)=>{"use strict";var tT=yn(),nT=fI(),ipe=require("needle"),hi=(B(),C(G)),uve=St(),Bd=oe(),{handleHDBError:Ht,hdb_errors:B1}=pe(),{HTTP_STATUS_CODES:Br,HDB_ERROR_MSGS:Tr,CHECK_LOGS_WRAPPER:xl}=B1,Hd=Y(),gI=require("papaparse");Bd.promisifyPapaParse();var mi=require("fs-extra"),ope=require("path"),{chain:C1}=require("stream-chain"),P1=require("stream-json/streamers/StreamArray"),D1=require("stream-json/utils/Batch"),L1=require("stream-chain/utils/comp"),{finished:M1}=require("stream"),ape=ce(),H1=_I(),cpe=pI(),{BulkLoadFileObject:TI,BulkLoadDataObject:lpe}=N1(),AI=Jw(),{verifyBulkLoadAttributePerms:k1}=KS(),dve=I1(),fve=ir(),_ve=To(),{databases:upe}=(Pe(),C(rt)),{coerceType:dpe}=(Gf(),C(bI)),v1="No records parsed from csv file.",Ul=`${ape.get("HDB_ROOT")}/tmp`,{schema_regex:fpe}=vi(),U1=1024*1024*2,x1=5e3,_pe={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};K1.exports={csvDataLoad:ppe,csvURLLoad:hpe,csvFileLoad:mpe,importFromS3:Epe};async function ppe(e,t){let r=nT.dataObject(e);if(r)throw Ht(r,r.message,Br.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=q1(e.schema,e.table),i=gI.parse(e.data,{header:!0,skipEmptyLines:!0,transform:SI.bind(null,s),dynamicTyping:!1}),o=new AI;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&k1(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 Ht(new Error,c,Br.BAD_REQUEST,void 0,void 0,!0);let l=new lpe(e.action,e.schema,e.table,i.data);return n=await H1.callOperationFunctionAsAwait($1,l,null),n.message===v1?v1:V1(n.records,n.number_written)}catch(s){throw Bl(s)}}a(ppe,"csvDataLoad");async function hpe(e){let t=nT.urlObject(e);if(t)throw Ht(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Ul}/${r}`;try{await gpe(e,r)}catch(s){throw Hd.error(Tr.DOWNLOAD_FILE_ERR(r)+" - "+s),Ht(s,xl(Tr.DOWNLOAD_FILE_ERR(r)))}try{let s=new TI(this.job_operation_function.name,e.action,e.schema,e.table,n,hi.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await RI(s);return await rT(n),i}catch(s){throw await rT(n),Bl(s)}}a(hpe,"csvURLLoad");async function mpe(e){let t=nT.fileObject(e);if(t)throw Ht(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=new TI(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,hi.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await RI(r)}catch(n){throw Bl(n)}}a(mpe,"csvFileLoad");async function Epe(e){let t=nT.s3FileObject(e);if(t)throw Ht(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=ope.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Ul}/${s}`;let i=new TI(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await Spe(s,e);let o=await RI(i);return await rT(r),o}catch(n){throw await rT(r),Bl(n)}}a(Epe,"importFromS3");async function gpe(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await ipe("get",e.csv_url,n)}catch(n){let s=`Error downloading CSV file from ${e.csv_url}, status code: ${n.statusCode}. Check the log for more information.`;throw Ht(n,s,n.statusCode,hi.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}Ape(r,e.csv_url),await Tpe(t,r.raw)}a(gpe,"downloadCSVFile");async function Spe(e,t){try{let r=`${Ul}/${e}`;await mi.mkdirp(Ul),await mi.writeFile(`${Ul}/${e}`,"",{flag:"a+"});let n=await mi.createWriteStream(r),s=await cpe.getFileStreamFromS3(t);await new Promise((i,o)=>{s.on("error",function(c){o(c)}),s.pipe(n).on("error",function(c){o(c)}).on("close",function(){Hd.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Hd.error(Tr.S3_DOWNLOAD_ERR+" - "+r),Ht(r,xl(Tr.S3_DOWNLOAD_ERR))}}a(Spe,"downloadFileFromS3");async function Tpe(e,t){try{await mi.mkdirp(Ul),await mi.writeFile(`${Ul}/${e}`,t)}catch(r){throw Hd.error(Tr.WRITE_TEMP_FILE_ERR),Ht(r,xl(Tr.DEFAULT_BULK_LOAD_ERR))}}a(Tpe,"writeFileToTempFolder");async function rT(e){if(e)try{await mi.access(e),await mi.unlink(e)}catch{Hd.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(rT,"deleteTempFile");function Ape(e,t){if(e.statusCode!==B1.HTTP_STATUS_CODES.OK)throw Ht(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Br.BAD_REQUEST);if(!_pe[e.headers["content-type"]])throw Ht(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Br.BAD_REQUEST);if(!e.raw)throw Ht(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Br.BAD_REQUEST)}a(Ape,"validateURLResponse");async function RI(e){try{let t;switch(e.file_type){case hi.VALID_S3_FILE_TYPES.CSV:t=await Rpe(e);break;case hi.VALID_S3_FILE_TYPES.JSON:t=await ype(e);break;default:throw Ht(new Error,Tr.DEFAULT_BULK_LOAD_ERR,Br.BAD_REQUEST,hi.LOG_LEVELS.ERROR,Tr.INVALID_FILE_EXT_ERR(e))}return V1(t.records,t.number_written)}catch(t){throw Bl(t)}}a(RI,"fileLoad");async function F1(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&&k1(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=Ht(c);r(l)}}a(F1,"validateChunk");async function G1(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Bd.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Bd.isEmpty(c)&&!Bd.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 H1.callOperationFunctionAsAwait($1,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=Ht(c,xl(Tr.INSERT_CSV_ERR),Br.INTERNAL_SERVER_ERROR,hi.LOG_LEVELS.ERROR,Tr.INSERT_CSV_ERR+" - "+c);r(l)}}a(G1,"insertChunk");async function Rpe(e){let t={records:0,number_written:0},r=q1(e.schema,e.table);try{let n=new AI,s=mi.createReadStream(e.file_path,{highWaterMark:U1});s.setEncoding("utf8"),await gI.parsePromise(s,F1.bind(null,e,n),SI.bind(null,r));let i=n.getPermsResponse();if(i)throw Ht(new Error,i,Br.BAD_REQUEST);return s=mi.createReadStream(e.file_path,{highWaterMark:U1}),s.setEncoding("utf8"),await gI.parsePromise(s,G1.bind(null,e,t),SI.bind(null,r)),s.destroy(),t}catch(n){throw Ht(n,xl(Tr.PAPA_PARSE_ERR),Br.INTERNAL_SERVER_ERROR,hi.LOG_LEVELS.ERROR,Tr.PAPA_PARSE_ERR+n)}}a(Rpe,"callPapaParse");function q1(e,t){let r=upe[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>dpe(i,s));return n}a(q1,"createTransformMap");function SI(e,t,r){let n=e.get(r);return n?n(t):Bd.autoCast(t)}a(SI,"typeFunction");async function ype(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new AI,s=C1([mi.createReadStream(e.file_path,{encoding:"utf-8"}),P1.withParser(),c=>c.value,new D1({batchSize:x1}),L1(async c=>{await F1(e,n,r,c)})]);await new Promise((c,l)=>{M1(s,u=>{u?l(u):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw Ht(new Error,i,Br.BAD_REQUEST);let o=C1([mi.createReadStream(e.file_path,{encoding:"utf-8"}),P1.withParser(),c=>c.value,new D1({batchSize:x1}),L1(async c=>{await G1(e,t,r,c)})]);return await new Promise((c,l)=>{M1(o,u=>{u?l(u):c()}),o.resume()}),t}catch(n){throw Ht(n,xl(Tr.INSERT_JSON_ERR),Br.INTERNAL_SERVER_ERROR,hi.LOG_LEVELS.ERROR,Tr.INSERT_JSON_ERR+n)}}a(ype,"insertJson");async function $1(e){let t={};try{e.data&&e.data.length>0&&bpe(e.data[0])?t=await Ope(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Hd.info(t.message))}catch(r){throw Bl(r)}return t}a($1,"callBulkFileLoad");function bpe(e){let t=Object.keys(e);for(let r of t)if(!fpe.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(bpe,"validateColumnNames");async function Ope(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=tT.insert;break;case"update":i=tT.update;break;case"upsert":i=tT.upsert;break;default:throw Ht(new Error,Tr.INVALID_ACTION_PARAM_ERR(n),Br.BAD_REQUEST,hi.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=Bd.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw Bl(o)}}a(Ope,"bulkFileLoad");function V1(e,t){return`successfully loaded ${t} of ${e} records`}a(V1,"buildResponseMsg");function Bl(e){return Ht(e,xl(Tr.DEFAULT_BULK_LOAD_ERR),Br.INTERNAL_SERVER_ERROR,hi.LOG_LEVELS.ERROR,Tr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(Bl,"buildTopLevelErrMsg")});var wI=I((mve,Z1)=>{"use strict";var NI=Wr(),Npe=pI(),{AsyncParser:wpe}=require("json2csv"),sT=require("stream"),cs=oe(),OI=require("fs-extra"),Ipe=require("path"),Us=Y(),{promisify:z1}=require("util"),nh=oe(),{handleHDBError:lr,hdb_errors:Cpe}=pe(),{HDB_ERROR_MSGS:Mn,HTTP_STATUS_CODES:ur}=Cpe,{streamAsJSON:Ppe}=(yR(),C(FL)),{Upload:Dpe}=require("@aws-sdk/lib-storage"),{toCsvStream:Lpe}=(fo(),C(oM)),Y1=["search_by_value","search_by_hash","sql","search_by_conditions"],W1=["json","csv"],j1="json",Q1="csv",Mpe="Successfully exported JSON locally.",vpe="Successfully exported CSV locally.",Upe=1e3,xpe=NI.searchByHash,Bpe=NI.searchByValue,Hpe=z1(sT.finished);Z1.exports={export_to_s3:qpe,export_local:kpe};async function kpe(e){Us.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=J1(e);if(!cs.isEmpty(t))throw Us.error(t),lr(new Error,t,ur.BAD_REQUEST,void 0,void 0,!0);if(cs.isEmpty(e.path))throw Us.error(Mn.MISSING_VALUE("path")),lr(new Error,Mn.MISSING_VALUE("path"),ur.BAD_REQUEST,void 0,void 0,!0);let r=(cs.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(Ipe.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=cs.buildFolderPath(e.path,r);await Fpe(e.path);let s=await X1(e);return await Gpe(n,e.format,s)}a(kpe,"export_local");async function Fpe(e){if(Us.trace("in confirmPath"),cs.isEmptyOrZeroLength(e))throw lr(new Error,`Invalid path: ${e}`,ur.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await OI.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,Us.error(n),lr(new Error,n,ur.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 Us.error(r),lr(new Error,r,ur.BAD_REQUEST,void 0,void 0,!0)}return!0}a(Fpe,"confirmPath");async function Gpe(e,t,r){if(Us.trace("in saveToLocal"),nh.isEmptyOrZeroLength(e))throw lr(new Error,Mn.INVALID_VALUE("file_path"),ur.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmptyOrZeroLength(t))throw lr(new Error,Mn.INVALID_VALUE("Source format"),ur.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmpty(r))throw lr(new Error,Mn.NOT_FOUND("Data"),ur.BAD_REQUEST,void 0,void 0,!0);if(t===j1){let n=OI.createWriteStream(e);return Ppe(r).pipe(n),await Hpe(n),{message:Mpe,path:e}}else if(t===Q1){let n=OI.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 wpe(i,c).fromInput(s).toOutput(n).promise(!1),{message:vpe,path:e}}throw lr(new Error,Mn.INVALID_VALUE("format"),ur.BAD_REQUEST)}a(Gpe,"saveToLocal");async function qpe(e){if(!e.s3||Object.keys(e.s3).length===0)throw lr(new Error,Mn.MISSING_VALUE("S3 object"),ur.BAD_REQUEST);if(cs.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw lr(new Error,Mn.MISSING_VALUE("aws_access_key_id"),ur.BAD_REQUEST);if(cs.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw lr(new Error,Mn.MISSING_VALUE("aws_secret_access_key"),ur.BAD_REQUEST);if(cs.isEmptyOrZeroLength(e.s3.bucket))throw lr(new Error,Mn.MISSING_VALUE("bucket"),ur.BAD_REQUEST);if(cs.isEmptyOrZeroLength(e.s3.key))throw lr(new Error,Mn.MISSING_VALUE("key"),ur.BAD_REQUEST);if(cs.isEmptyOrZeroLength(e.s3.region))throw lr(new Error,Mn.MISSING_VALUE("region"),ur.BAD_REQUEST);let t=J1(e);if(!cs.isEmpty(t))throw lr(new Error,t,ur.BAD_REQUEST);Us.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await X1(e)}catch(l){throw Us.error(l),l}let n,s=await Npe.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new sT.PassThrough;if(e.format===Q1){i=e.s3.key+".csv";let l=Lpe(r,r.getColumns?.());l.on("error",u=>{throw u}),l.pipe(o)}else if(e.format===j1){i=e.s3.key+".json";let l=new 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%Upe===0&&(l.push(f),f="")}f.length!==0&&l.push(f),l.push("]"),l.push(null)}else throw lr(new Error,Mn.INVALID_VALUE("format"),ur.BAD_REQUEST);return new Dpe({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(qpe,"export_to_s3");function J1(e){if(Us.trace("in exportCoreValidation"),cs.isEmpty(e.format))return"format missing";if(W1.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${W1.join(", ")}`;let t=e.search_operation.operation;if(cs.isEmpty(t))return"search_operation.operation missing";if(Y1.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${Y1.join(", ")}`}a(J1,"exportCoreValidation");async function X1(e){Us.trace("in getRecords");let t,r;if(nh.isEmpty(e.search_operation)||nh.isEmptyOrZeroLength(e.search_operation.operation))throw lr(new Error,Mn.INVALID_VALUE("Search operation"),ur.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=Bpe;break;case"search_by_hash":t=xpe;break;case"search_by_conditions":t=NI.searchByConditions;break;case"sql":{let n=WS();t=z1(n.evaluateSQL);break}default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,Us.error(r),lr(new Error,r,ur.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(X1,"getRecords")});var tK=I((gve,eK)=>{"use strict";var II=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};eK.exports=II});var sK=I((Tve,nK)=>{"use strict";var $pe=(B(),C(G)),rK=require("moment"),Vpe=require("uuid").v4,CI=class{static{a(this,"JobObject")}constructor(){this.id=Vpe(),this.type=void 0,this.start_datetime=rK().valueOf(),this.created_datetime=rK().valueOf(),this.end_datetime=void 0,this.status=$pe.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};nK.exports=CI});var PI=I((Rve,fK)=>{"use strict";var Kpe=require("uuid").v4,lK=yn(),uK=Wr(),Ype=ii(),Wpe=Hu(),zpe=tK(),bt=(B(),C(G)),jpe=sK(),Qpe=ng(),Ei=Y(),Jpe=vf(),kd=oe(),{promisify:Xpe}=require("util"),Hl=require("moment"),Zpe=WS(),iT=fI(),iK=wy(),{deleteTransactionLogsBeforeValidator:ehe}=Yw(),{handleHDBError:oK,hdb_errors:the,ClientError:rhe}=pe(),{HTTP_STATUS_CODES:aK}=the,cK=uK.searchByValue,nhe=uK.searchByHash,she=lK.insert,ihe=Xpe(Zpe.evaluateSQL),ohe=lK.update;fK.exports={addJob:lhe,updateJob:dhe,handleGetJob:ahe,handleGetJobsByStartDate:che,getJobById:dK};async function ahe(e){if(e.id===void 0)throw new rhe("'id' is required");let t=await dK(e.id);return kd.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}a(ahe,"handleGetJob");async function che(e){try{let t=await uhe(e);if(Ei.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=Hl(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Hl(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 Ei.error(r),new Error(r)}}a(che,"handleGetJobsByStartDate");async function lhe(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||kd.isEmptyOrZeroLength(e.operation)){let f="job parameter is invalid";return Ei.info(f),t.error=f,t}if(!bt.JOB_TYPE_ENUM[e.operation])return Ei.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case bt.OPERATIONS_ENUM.CSV_FILE_LOAD:n=iT.fileObject(e);break;case bt.OPERATIONS_ENUM.CSV_URL_LOAD:n=iT.urlObject(e);break;case bt.OPERATIONS_ENUM.CSV_DATA_LOAD:n=iT.dataObject(e);break;case bt.OPERATIONS_ENUM.IMPORT_FROM_S3:n=iT.s3FileObject(e);break;case bt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case bt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=iK(e,"date");break;case bt.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=iK(e,"timestamp");break;case bt.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=ehe(e);break;case bt.OPERATIONS_ENUM.RESTART_SERVICE:if(bt.HDB_PROCESS_SERVICES[e.service]===void 0)throw oK(new Error,"Invalid service",aK.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw oK(n,n.message,aK.BAD_REQUEST,void 0,void 0,!0);let s=new jpe;s.type=e.operation===bt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?bt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user?.username;let i=new Ype(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await cK(i))}catch(f){let d=`There was an error inserting a new job: ${f}`;return Ei.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Kpe();try{o=await cK(i)}catch(f){let d=`There was an error inserting a new job: ${f}`;return Ei.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return Ei.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new Jpe(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await she(l)}catch(f){return Ei.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,Ei.trace(f)}return t}a(lhe,"addJob");async function uhe(e){let t=Hl(e.from_date,Hl.ISO_8601),r=Hl(e.to_date,Hl.ISO_8601);if(!t.isValid())throw new Error("Invalid 'from' date, must be in ISO-8601 format (YYYY-MM-DD).");if(!r.isValid())throw new Error("Invalid 'to' date, must be in ISO-8601 format (YYYY-MM-DD)");let n=`select * from system.hdb_job where start_datetime > '${t.valueOf()}' and start_datetime < '${r.valueOf()}'`,s=new zpe(n,e.hdb_user);try{return await ihe(s)}catch(i){throw Ei.error(`there was a problem searching for jobs from date ${e.from_date} to date ${e.to_date} ${i}`),new Error("there was an error searching for jobs. Please check the log for details.")}}a(uhe,"getJobsInDateRange");async function dK(e){if(kd.isEmptyOrZeroLength(e))return kd.errorizeMessage("Invalid job ID specified.");let t=new Wpe(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await nhe(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return Ei.error(n),kd.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(dK,"getJobById");async function dhe(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(kd.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===bt.JOB_STATUS_ENUM.COMPLETE||e.status===bt.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Hl().valueOf());let t=new Qpe(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await ohe(t),r}a(dhe,"updateJob")});var TK=I((bve,SK)=>{"use strict";var _K=oe(),Ar=(B(),C(G)),fhe=require("moment"),oT=yI(),sh=Y(),pK=PI(),hK=wI(),mK=Vc(),EK=tt(),_he=GS(),phe=za(),{parentPort:hhe,isMainThread:gK}=require("worker_threads"),{onMessageByType:mhe}=tt(),DI=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function Ehe(e){if(!e||Object.keys(e).length===0)throw new Error("Empty runner passed to parseMessage");if(!e.json||Object.keys(e.json).length===0)throw new Error("Empty JSON passed to parseMessage");if(!e.job||Object.keys(e.job).length===0)throw new Error("Empty job passed to parseMessage");if(_K.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(_K.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Ar.JOB_TYPE_ENUM.csv_file_load:await ji(e,oT.csvFileLoad);break;case Ar.JOB_TYPE_ENUM.csv_url_load:await ji(e,oT.csvURLLoad);break;case Ar.JOB_TYPE_ENUM.csv_data_load:await ji(e,oT.csvDataLoad);break;case Ar.JOB_TYPE_ENUM.import_from_s3:await ji(e,oT.importFromS3);break;case Ar.JOB_TYPE_ENUM.empty_trash:break;case Ar.JOB_TYPE_ENUM.export_local:await ji(e,hK.export_local);break;case Ar.JOB_TYPE_ENUM.export_to_s3:await ji(e,hK.export_to_s3);break;case Ar.JOB_TYPE_ENUM.delete_files_before:case Ar.JOB_TYPE_ENUM.delete_records_before:await ji(e,mK.deleteFilesBefore);break;case Ar.JOB_TYPE_ENUM.delete_audit_logs_before:await ji(e,mK.deleteAuditLogsBefore);break;case Ar.JOB_TYPE_ENUM.delete_transaction_logs_before:await ji(e,_he.deleteTransactionLogsBefore);break;case Ar.JOB_TYPE_ENUM.restart_service:return await ji(e,phe.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(Ehe,"parseMessage");async function ji(e,t){try{e.job.status=Ar.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=fhe().valueOf(),await pK.updateJob(e.job),await ghe(e.job.id)}catch(r){let n=r.message!==void 0?r.message:r;typeof n=="string"?(n=`There was an error running ${t.name} job with id ${e.job.id} - ${n}`,r.message=n):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 pK.updateJob(e.job)}catch(s){throw sh.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(ji,"runJob");async function ghe(e){sh.trace("launching job thread:",e),gK?EK.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Ar.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):hhe.postMessage({type:Ar.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(ghe,"launchJobThread");gK&&mhe(Ar.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{EK.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)}});SK.exports={parseMessage:Ehe,RunnerMessage:DI}});var RK=I((Nve,AK)=>{"use strict";var LI=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};AK.exports=LI});var Kw=I((Cve,HI)=>{"use strict";var dT=Wr(),UI=WS(),aT=yI(),$o=Vg(),cT=Ao(),oh=Vc(),She=AN(),ih=Rn(),lT=q_(),It=Vw(),uT=Y(),The=NN(),Ahe=Ed(),yK=JN(),Rhe=nS(),yhe=ew(),bhe=tw(),Ohe=aS(),Nhe=lS(),MI=uS(),bK=wI(),whe=KS(),xI=PI(),V=(B(),C(G)),{hdb_errors:ch,handleHDBError:ah}=pe(),{HTTP_STATUS_CODES:OK}=ch,vI=hS(),NK=za(),xK=require("util"),Gd=yn(),Ihe=bs(),Che=Do(),wK=TK(),IK=(zu(),C(ep)),CK=(MS(),C(Gp)),PK=Rt(),DK=GS(),LK=Kp(),{setServerUtilities:Phe}=(Gf(),C(bI)),{CONTEXT:Ive}=(ga(),C(mR)),{_assignPackageExport:Dhe}=yi(),{transformReq:Lhe}=oe(),{server:Mhe}=(Kr(),C(Tu)),sn=uT.loggerWithTag("operation"),Fd=rs(),MK=(Al(),C(Tl)),vhe=_I(),vK=dT.searchByHash,Uhe=dT.searchByValue,xhe=xK.promisify(dT.search),Bhe=xK.promisify(UI.evaluateSQL),Hhe={[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=RK();async function BK(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;sn.info(c)}}catch(n){sn.error(n)}let r=await vhe.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return Hhe[e.body.operation]&&Ihe.setSchemaDataToGlobal(n=>{n&&sn.error(n)}),r}a(BK,"processLocalTransaction");var UK=Fhe();HI.exports={chooseOperation:HK,getOperationFunction:kK,operation:BI,processLocalTransaction:BK,executeJob:xs};Phe(HI.exports);Mhe.operation=BI;function HK(e){let t;try{t=kK(e)}catch(s){throw sn.error(`Error when selecting operation function - ${s}`),s}let{operation_function:r,job_operation_function:n}=t;try{if(e.operation==="sql"||e.search_operation&&e.search_operation.operation==="sql"){let s=e.operation==="sql"?e.sql:e.search_operation.sql,i=UI.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=UI.checkASTPermissions(e,i);if(o)throw sn.error(`${OK.FORBIDDEN} from operation ${e.operation}`),sn.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=whe.verifyPerms(i,s);if(o)throw sn.error(`${OK.FORBIDDEN} from operation ${e.operation}`),sn.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(HK,"chooseOperation");function kK(e){if(sn.trace(`getOperationFunction with operation: ${e.operation}`),UK.has(e.operation))return UK.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(kK,"getOperationFunction");Dhe("operation",BI);function BI(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=HK(e);return BK({body:e},n)}a(BI,"operation");async function khe(e){sn.trace("In serverUtils.catchup");let t=e.transaction,r=t.channel.split(":"),n=r[0],s=r[1];for(let i of t.transactions)try{i.schema=n,i.table=s,i[V.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case V.OPERATIONS_ENUM.INSERT:o=await Gd.insert(i);break;case V.OPERATIONS_ENUM.UPDATE:o=await Gd.update(i);break;case V.OPERATIONS_ENUM.UPSERT:o=await Gd.upsert(i);break;case V.OPERATIONS_ENUM.DELETE:o=await oh.deleteRecord(i);break;default:sn.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){sn.info("Invalid operation in transaction"),sn.error(o)}}a(khe,"catchup");async function xs(e){Lhe(e);let t,r;try{r=await xI.addJob(e),t=r.createdJob,sn.info("addJob result",r);let n=new wK.RunnerMessage(t,e);return{message:await wK.parseMessage(n)??`Starting job with id ${t.id}`,job_id:t.id}}catch(n){let s=`There was an error executing job: ${n.http_resp_msg?n.http_resp_msg:n}`;throw sn.error(s),ah(n,s)}}a(xs,"executeJob");function Fhe(){let e=new Map;return e.set(V.OPERATIONS_ENUM.INSERT,new ee(Gd.insert)),e.set(V.OPERATIONS_ENUM.UPDATE,new ee(Gd.update)),e.set(V.OPERATIONS_ENUM.UPSERT,new ee(Gd.upsert)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new ee(dT.searchByConditions)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_HASH,new ee(vK)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_ID,new ee(vK)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_VALUE,new ee(Uhe)),e.set(V.OPERATIONS_ENUM.SEARCH,new ee(xhe)),e.set(V.OPERATIONS_ENUM.SQL,new ee(Bhe)),e.set(V.OPERATIONS_ENUM.CSV_DATA_LOAD,new ee(xs,aT.csvDataLoad)),e.set(V.OPERATIONS_ENUM.CSV_FILE_LOAD,new ee(xs,aT.csvFileLoad)),e.set(V.OPERATIONS_ENUM.CSV_URL_LOAD,new ee(xs,aT.csvURLLoad)),e.set(V.OPERATIONS_ENUM.IMPORT_FROM_S3,new ee(xs,aT.importFromS3)),e.set(V.OPERATIONS_ENUM.CREATE_SCHEMA,new ee($o.createSchema)),e.set(V.OPERATIONS_ENUM.CREATE_DATABASE,new ee($o.createSchema)),e.set(V.OPERATIONS_ENUM.CREATE_TABLE,new ee($o.createTable)),e.set(V.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new ee($o.createAttribute)),e.set(V.OPERATIONS_ENUM.DROP_SCHEMA,new ee($o.dropSchema)),e.set(V.OPERATIONS_ENUM.DROP_DATABASE,new ee($o.dropSchema)),e.set(V.OPERATIONS_ENUM.DROP_TABLE,new ee($o.dropTable)),e.set(V.OPERATIONS_ENUM.DROP_ATTRIBUTE,new ee($o.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(The)),e.set(V.OPERATIONS_ENUM.ADD_NODE,new ee(Ahe)),e.set(V.OPERATIONS_ENUM.UPDATE_NODE,new ee(yK)),e.set(V.OPERATIONS_ENUM.SET_NODE_REPLICATION,new ee(yK)),e.set(V.OPERATIONS_ENUM.REMOVE_NODE,new ee(Rhe)),e.set(V.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new ee(yhe)),e.set(V.OPERATIONS_ENUM.PURGE_STREAM,new ee(bhe)),e.set(V.OPERATIONS_ENUM.SET_CONFIGURATION,new ee(PK.setConfiguration)),e.set(V.OPERATIONS_ENUM.CLUSTER_STATUS,new ee(Ohe.clusterStatus)),e.set(V.OPERATIONS_ENUM.CLUSTER_NETWORK,new ee(Nhe)),e.set(V.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new ee(MI.setRoutes)),e.set(V.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new ee(MI.getRoutes)),e.set(V.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new ee(MI.deleteRoutes)),e.set(V.OPERATIONS_ENUM.EXPORT_TO_S3,new ee(xs,bK.export_to_s3)),e.set(V.OPERATIONS_ENUM.CREATE_CSR,new ee(Fd.createCsr)),e.set(V.OPERATIONS_ENUM.SIGN_CERTIFICATE,new ee(Fd.signCertificate)),e.set(V.OPERATIONS_ENUM.LIST_CERTIFICATES,new ee(Fd.listCertificates)),e.set(V.OPERATIONS_ENUM.ADD_CERTIFICATES,new ee(Fd.addCertificate)),e.set(V.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new ee(Fd.removeCertificate)),e.set(V.OPERATIONS_ENUM.GET_KEY,new ee(Fd.getKey)),e.set(V.OPERATIONS_ENUM.ADD_NODE_BACK,new ee(MK.addNodeBack)),e.set(V.OPERATIONS_ENUM.REMOVE_NODE_BACK,new ee(MK.removeNodeBack)),e.set(V.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new ee(xs,oh.deleteFilesBefore)),e.set(V.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new ee(xs,oh.deleteFilesBefore)),e.set(V.OPERATIONS_ENUM.EXPORT_LOCAL,new ee(xs,bK.export_local)),e.set(V.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new ee(xI.handleGetJobsByStartDate)),e.set(V.OPERATIONS_ENUM.GET_JOB,new ee(xI.handleGetJob)),e.set(V.OPERATIONS_ENUM.GET_FINGERPRINT,new ee(vI.getFingerprint)),e.set(V.OPERATIONS_ENUM.SET_LICENSE,new ee(vI.setLicense)),e.set(V.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new ee(vI.getRegistrationInfo)),e.set(V.OPERATIONS_ENUM.RESTART,new ee(NK.restart)),e.set(V.OPERATIONS_ENUM.RESTART_SERVICE,new ee(xs,NK.restartService)),e.set(V.OPERATIONS_ENUM.CATCHUP,new ee(khe)),e.set(V.OPERATIONS_ENUM.SYSTEM_INFORMATION,new ee(Che.systemInformation)),e.set(V.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new ee(xs,oh.deleteAuditLogsBefore)),e.set(V.OPERATIONS_ENUM.READ_AUDIT_LOG,new ee(She)),e.set(V.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new ee(IK.createTokens)),e.set(V.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new ee(IK.refreshOperationToken)),e.set(V.OPERATIONS_ENUM.LOGIN,new ee(CK.login)),e.set(V.OPERATIONS_ENUM.LOGOUT,new ee(CK.logout)),e.set(V.OPERATIONS_ENUM.GET_CONFIGURATION,new ee(PK.getConfiguration)),e.set(V.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new ee(It.customFunctionsStatus)),e.set(V.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new ee(It.getCustomFunctions)),e.set(V.OPERATIONS_ENUM.GET_COMPONENT_FILE,new ee(It.getComponentFile)),e.set(V.OPERATIONS_ENUM.GET_COMPONENTS,new ee(It.getComponents)),e.set(V.OPERATIONS_ENUM.SET_COMPONENT_FILE,new ee(It.setComponentFile)),e.set(V.OPERATIONS_ENUM.DROP_COMPONENT,new ee(It.dropComponent)),e.set(V.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new ee(It.getCustomFunction)),e.set(V.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new ee(It.setCustomFunction)),e.set(V.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new ee(It.dropCustomFunction)),e.set(V.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new ee(It.addComponent)),e.set(V.OPERATIONS_ENUM.ADD_COMPONENT,new ee(It.addComponent)),e.set(V.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new ee(It.dropCustomFunctionProject)),e.set(V.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new ee(It.packageComponent)),e.set(V.OPERATIONS_ENUM.PACKAGE_COMPONENT,new ee(It.packageComponent)),e.set(V.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new ee(It.deployComponent)),e.set(V.OPERATIONS_ENUM.DEPLOY_COMPONENT,new ee(It.deployComponent)),e.set(V.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new ee(DK.readTransactionLog)),e.set(V.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new ee(xs,DK.deleteTransactionLogsBefore)),e.set(V.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new ee(LK.installModules)),e.set(V.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new ee(LK.auditModules)),e.set(V.OPERATIONS_ENUM.GET_BACKUP,new ee($o.getBackup)),e.set(V.OPERATIONS_ENUM.ADD_SSH_KEY,new ee(It.addSSHKey)),e.set(V.OPERATIONS_ENUM.UPDATE_SSH_KEY,new ee(It.updateSSHKey)),e.set(V.OPERATIONS_ENUM.DELETE_SSH_KEY,new ee(It.deleteSSHKey)),e.set(V.OPERATIONS_ENUM.LIST_SSH_KEYS,new ee(It.listSSHKeys)),e.set(V.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new ee(It.setSSHKnownHosts)),e.set(V.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new ee(It.getSSHKnownHosts)),e}a(Fhe,"initializeOperationFunctionMap")});var pT=I((Dve,qK)=>{"use strict";var fT=(B(),C(G)),Ghe=oe(),lh=Y(),{handleHDBError:kI,hdb_errors:_T}=pe(),{isMainThread:qhe}=require("worker_threads"),{Readable:$he}=require("stream"),FK=require("os"),Vhe=require("util"),Khe=bO(),Yhe=Vhe.promisify(Khe.authorize),GK=Kw(),{createGzip:Whe,constants:zhe}=require("zlib"),jhe=[fT.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,fT.OPERATIONS_ENUM.LOGIN,fT.OPERATIONS_ENUM.LOGOUT];function Qhe(e){let t=`Found an uncaught exception with message: ${e.message}. ${FK.EOL}Stack: ${e.stack} ${FK.EOL}Terminating ${qhe?"HDB":"thread"}.`;console.error(t),lh.fatal(t),process.exit(1)}a(Qhe,"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 Xhe(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=kI(new Error,"Invalid JSON.",_T.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(Ghe.isEmpty(e.body.operation)){let n=kI(new Error,"Request body must include an 'operation' property.",_T.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Xhe,"reqBodyValidationHandler");function Zhe(e,t,r){let n;!jhe.includes(e.body.operation)||e.body.operation===fT.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&!e.body.username&&!e.body.password?Yhe(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(kI(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(Zhe,"authHandler");async function eme(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=GK.chooseOperation(e.body);let s=await GK.processLocalTransaction(e,n);if(s instanceof $he&&s.headers){for(let[i,o]of s.headers)t.header(i,o);e.headers["accept-encoding"]?.includes("gzip")&&(t.header("content-encoding","gzip"),s=s.pipe(Whe({level:zhe.Z_BEST_SPEED})))}return s}catch(s){throw lh.error(s),s}}a(eme,"handlePostRequest");qK.exports={authHandler:Zhe,handlePostRequest:eme,handleServerUncaughtException:Qhe,serverErrorHandler:Jhe,reqBodyValidationHandler:Xhe}});var YK=I((Mve,KK)=>{"use strict";var tme=require("fastify-plugin"),{handlePostRequest:$K,authHandler:rme,reqBodyValidationHandler:nme}=pT();async function sme(e){e.decorate("hdbCore",{preValidation:[nme,rme],request:a(t=>VK($K(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>VK($K(t,r,!0)),"requestWithoutAuthentication")})}a(sme,"hdbCore");async function VK(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(VK,"convertAsyncIterators");KK.exports=tme(sme)});var zK=I((xve,WK)=>{"use strict";var Uve=require("fs"),hT=ce();hT.initSync();var{CONFIG_PARAMS:FI}=(B(),C(G)),ime=1024*1024*1024;function ome(e){let t=hT.get(FI.HTTP_TIMEOUT),r=hT.get(FI.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:ime,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:hT.get(FI.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(ome,"getServerOptions");WK.exports=ome});var JK=I((Hve,QK)=>{"use strict";var GI=ce();GI.initSync();var{CONFIG_PARAMS:jK}=(B(),C(G));function ame(){let e=GI.get(jK.HTTP_CORSACCESSLIST),t=GI.get(jK.HTTP_CORS),r;return t&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},e&&e.length>0&&e[0]!==null&&e[0]!=="*"&&(r.origin=(n,s)=>s(null,e.indexOf(n)!==-1))),r}a(ame,"getCORSOptions");QK.exports=ame});var eY=I((Fve,ZK)=>{"use strict";var XK=ce();XK.initSync();var cme=(B(),C(G));function lme(){return XK.get(cme.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(lme,"getHeaderTimeoutConfig");ZK.exports=lme});var $I={};ve($I,{customFunctionsServer:()=>fme,ready:()=>pY,start:()=>dme});function dme(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){Vo||(Vo=_Y(t),We.http((await Vo).server));let o=await Vo,c=(0,qI.dirname)(s),l=(0,qI.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!tY.has(c)){tY.add(c);try{o.register(pme(c,l))}catch(u){if(u.message==="Root plugin has already booted")_t.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw u}}},ready:pY}}async function fme(){try{_t.info("In Custom Functions Fastify server"+process.cwd()),_t.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),_t.debug(`Custom Functions server process ${process.pid} starting up.`),await _me();let e=aY.get(x.HTTP_SECUREPORT)>0,t;try{t=Vo=await _Y(e)}catch(r){throw _t.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw _t.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){_t.error(`Custom Functions ${process.pid} Error: ${e}`),_t.error(e),process.exit(1)}}async function _me(){try{_t.info("Custom Functions starting configuration."),await cY.setUsersWithRolesCache(),_t.info("Custom Functions completed configuration.")}catch(e){_t.error(e)}}function pme(e,t){return async function(r){try{_t.info("Custom Functions starting buildRoutes"),_t.trace("Loading fastify routes folder "+e),(0,rY.existsSync)(e)&&r.register(oY.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:_t.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?_t.error(s.message):s&&_t.error(s),o()})}catch(n){_t.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function _Y(e){_t.info("Custom Functions starting buildServer.");let t=(0,lY.default)(e),r=(0,nY.default)(t);r.server.headersTimeout=(0,dY.default)(),r.setErrorHandler(fY.serverErrorHandler);let n=(0,uY.default)();return n&&r.register(sY.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(iY.default),await r.register(ume),await r.after(),jf(r),_t.info("Custom Functions completed buildServer."),r}function pY(){if(Vo)return Vo.then?Vo.then(e=>e.ready()):Vo.ready()}var qI,rY,nY,sY,iY,oY,aY,_t,ume,cY,lY,uY,dY,fY,Vo,tY,hY=be(()=>{qI=require("path"),rY=require("fs"),nY=M(require("fastify")),sY=M(require("@fastify/cors")),iY=M(SO()),oY=M(require("@fastify/autoload")),aY=M(ce());B();_t=M(Y()),ume=M(YK()),cY=M(Rn()),lY=M(zK()),uY=M(JK()),dY=M(eY()),fY=M(pT());fo();Kr();tY=new Set;a(dme,"start");a(fme,"customFunctionsServer");a(_me,"setUp");a(pme,"buildRouteFolder");a(_Y,"buildServer");a(pY,"ready")});var VI={};ve(VI,{start:()=>hme});function hme(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,TY.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){EY||(EY=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=mY.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,gY.default)(s,(0,SY.realpathSync)(o))}}return i(s)},{runFirst:!0})),mY.set(r,n)}}}var gY,SY,TY,mY,EY,AY=be(()=>{gY=M(require("send")),SY=require("fs"),TY=M(require("serve-static")),mY=new Map;a(hme,"start")});var KI={};ve(KI,{start:()=>mme});function mme({override:e}){return{handleFile:a((t,r,n)=>{mT.default.debug(`Loading env file: ${n}`);for(let[s,i]of Object.entries((0,RY.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 RY,mT,yY=be(()=>{RY=require("dotenv"),mT=M(Y());a(mme,"start")});var OY={};ve(OY,{Request:()=>YI,createReuseportFd:()=>ET});var bY,YI,WI,zI,ET,jI=be(()=>{bY=require("os"),YI=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 zI(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 WI(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)}},WI=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)}},zI=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,bY.platform)()!="win32"&&(ET=require("node-unix-socket").createReuseportFd)});var JI=I((jve,NY)=>{"use strict";var uh=ce();uh.initSync();var qd=require("fs-extra"),QI=require("path"),$d=(B(),C(G)),Eme=require("crypto"),gme=require("uuid").v4;NY.exports=Sme;function Sme(){if(uh.getHdbBasePath()!==void 0){let e=QI.join(uh.getHdbBasePath(),$d.LICENSE_KEY_DIR_NAME,$d.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=QI.join(uh.getHdbBasePath(),$d.LICENSE_KEY_DIR_NAME,$d.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=QI.join(uh.getHdbBasePath(),$d.LICENSE_KEY_DIR_NAME,$d.JWT_ENUM.JWT_PASSPHRASE_NAME);try{qd.accessSync(r),qd.accessSync(e),qd.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=gme(),i=Eme.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});qd.writeFileSync(r,s),qd.writeFileSync(e,i.privateKey),qd.writeFileSync(t,i.publicKey)}else throw n}}}a(Sme,"checkJWTTokenExist")});var IY=I((Jve,wY)=>{"use strict";var XI=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};wY.exports={HdbInfoInsertObject:XI}});var DY=I((Zve,PY)=>{"use strict";var CY=(B(),C(G)),ZI=class{static{a(this,"UpgradeObject")}constructor(t,r){this[CY.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[CY.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};PY.exports={UpgradeObject:ZI}});var gT=I((tUe,MY)=>{"use strict";var Bs=require("prompt"),Vd=require("chalk"),LY=Y(),gi=require("os"),eC=da(),tC=["yes","y"];async function Tme(e){let t=`${gi.EOL}`+Vd.bold.green("Your current HarperDB version requires that we complete an update process.")+`${gi.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${gi.EOL}${gi.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${gi.EOL}`;Bs.override=eC(["CONFIRM_UPGRADE"]),Bs.start(),Bs.message=t;let r={properties:{CONFIRM_UPGRADE:{description:Vd.magenta(`${gi.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 Bs.get([r])}catch(s){return LY.error("There was an error when prompting user about an upgrade."),LY.error(s),!1}return tC.includes(n.CONFIRM_UPGRADE)}a(Tme,"forceUpdatePrompt");async function Ame(e){let t=`${gi.EOL}`+Vd.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.${gi.EOL}`);Bs.override=eC(["CONFIRM_DOWNGRADE"]),Bs.start(),Bs.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:Vd.magenta(`${gi.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 Bs.get([r]);return tC.includes(n.CONFIRM_DOWNGRADE)}a(Ame,"forceDowngradePrompt");async function Rme(){let e=`${gi.EOL}`+Vd.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");Bs.override=eC(["GENERATE_CERTS"]),Bs.start(),Bs.message=e;let t={properties:{GENERATE_CERTS:{description:Vd.magenta(`${gi.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 Bs.get([t]);return tC.includes(r.GENERATE_CERTS)}a(Rme,"upgradeCertsPrompt");MY.exports={forceUpdatePrompt:Tme,forceDowngradePrompt:Ame,upgradeCertsPrompt:Rme}});var nC=I((nUe,vY)=>{"use strict";var rC=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};vY.exports=rC});var xY=I((lUe,UY)=>{"use strict";var yme=oe(),bme=Rt(),iUe=Y(),oUe=require("path"),aUe=require("fs"),cUe=(B(),C(G));UY.exports={getOldPropsValue:Ome};function Ome(e,t,r=!1){let n=t.getRaw(e);return yme.isNotEmptyAndHasValue(n)?n:r?bme.getDefaultConfig(e):""}a(Ome,"getOldPropsValue")});var FY=I((dUe,kY)=>{"use strict";var Za=require("path"),ec=require("fs-extra"),Nme=require("properties-reader"),wme=nC(),dr=Y(),{getOldPropsValue:pt}=xY(),{HDB_SETTINGS_NAMES:Ee,CONFIG_PARAMS:kl}=(B(),C(G)),Fl=Rt(),ST=ce(),BY=oe(),Qi=(B(),C(G)),sC=new wme("3.1.0"),HY=[];function Ime(){let e=Nme(ST.get(Ee.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),dr.info(t);let r=` ;Settings for the HarperDB process.
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(Fo,o);let d=await _i(e);return d.message=`Added ssh key: ${r}${f}`,d}a(kfe,"addSSHKey");async function Ffe(e){let t=Pn.updateSSHKeyValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{name:r,key:n}=e;Ut.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 _i(e);return i.message=`Updated ssh key: ${r}`,i}a(Ffe,"updateSSHKey");async function Gfe(e){let t=Pn.deleteSSHKeyValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{name:r}=e;Ut.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 _i(e);return c.message=`Deleted ssh key: ${r}`,c}a(Gfe,"deleteSSHKey");async function qfe(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(qfe,"listSSHKeys");async function $fe(e){let t=Pn.setSSHKnownHostsValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{known_hosts:r}=e;await Oe.outputFile(Fo,r);let n=await _i(e);return n.message="Known hosts successfully set",n}a($fe,"setSSHKnownHosts");async function Vfe(e){return await Oe.pathExists(Fo)?{known_hosts:await Oe.readFile(Fo,"utf8")}:{known_hosts:null}}a(Vfe,"getSSHKnownHosts");Object.assign(BV,{customFunctionsStatus:Ofe,getCustomFunctions:Nfe,getCustomFunction:wfe,setCustomFunction:Ife,dropCustomFunction:Cfe,addComponent:Pfe,dropCustomFunctionProject:Dfe,packageComponent:Lfe,deployComponent:Mfe,getComponents:Ufe,getComponentFile:xfe,setComponentFile:Bfe,dropComponent:Hfe,addSSHKey:kfe,updateSSHKey:Ffe,deleteSSHKey:Gfe,listSSHKeys:qfe,setSSHKnownHosts:$fe,getSSHKnownHosts:Vfe})});var Ww=w((BMe,kV)=>{"use strict";var Ls=require("joi"),HV=ft();kV.exports={readTransactionLogValidator:Kfe,deleteTransactionLogsBeforeValidator:Yfe};function Kfe(e){let t=Ls.object({schema:Ls.string(),database:Ls.string(),table:Ls.string().required(),from:Ls.date().timestamp(),to:Ls.date().timestamp(),limit:Ls.number().min(1)});return HV.validateBySchema(e,t)}a(Kfe,"readTransactionLogValidator");function Yfe(e){let t=Ls.object({schema:Ls.string(),database:Ls.string(),table:Ls.string().required(),timestamp:Ls.date().timestamp().required()});return HV.validateBySchema(e,t)}a(Yfe,"deleteTransactionLogsBeforeValidator")});var GS=w((kMe,KV)=>{"use strict";var zw=(H(),C(q)),Qp=or(),FV=se(),GV=ae(),qV=To(),$V=z(),{handleHDBError:kS,hdb_errors:Wfe}=pe(),{HTTP_STATUS_CODES:FS}=Wfe,{readTransactionLogValidator:zfe,deleteTransactionLogsBeforeValidator:jfe}=Ww(),VV=Yn(),Qfe="Logs successfully deleted from transaction log.",Jfe="All logs successfully deleted from transaction log.";KV.exports={readTransactionLog:Xfe,deleteTransactionLogsBefore:e_e};async function Xfe(e){let t=zfe(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(zw.CONFIG_PARAMS.CLUSTERING_ENABLED)?await Zfe(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(Xfe,"readTransactionLog");async function*Zfe(e){let t=qV.createNatsTableStreamName(e.database,e.table),r=await Qp.viewStreamIterator(t,parseInt(e.from),e.limit);for await(let n of r){let s=Math.floor(n?.nats_timestamp/1e6);if(e.to&&s>e.to)break;let i={operation:n?.entry?.operation,user:n?.entry?.__origin?.user,timestamp:s,records:n?.entry?.records,attributes:n?.entry?.attributes};n?.entry?.operation===zw.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(Zfe,"readTransactionLogNats");async function e_e(e){let t=jfe(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(zw.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 Qp.getNATSReferences(),l=await Qp.getStreamInfo(o),u=new Date(l.state.first_ts).getTime();if(s<=u)return`No transactions exist before: ${s}`;let f=Qfe,d,p=new Date(l.state.last_ts).getTime();return s>p?(d=l.state.last_seq+1,f=Jfe):d=(await Qp.viewStream(o,parseInt(s),1))[0].nats_sequence,await Qp.purgeTableStream(r,n,{seq:d}),f}a(e_e,"deleteTransactionLogsBefore")});var WV=w((GMe,YV)=>{"use strict";var jw=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=jw});var jV=w(($Me,zV)=>{"use strict";var Qw=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};zV.exports=Qw});var Xw=w((KMe,JV)=>{"use strict";var QV=WV(),t_e=jV(),{HDB_ERROR_MSGS:r_e}=Bn(),Jw=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=r_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 QV(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new t_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 QV(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=Jw});var KS=w((jMe,p1)=>{"use strict";var Zw=Rn(),qS=Yr(),Ms=Vg(),Zp=Ao(),eI=Vc(),n_e=RN(),s_e=dG(),eh=An(),$S=q_(),Sr=z(),i_e=wN(),o_e=Ed(),a_e=XN(),c_e=nS(),l_e=tw(),u_e=rw(),d_e=aS(),f_e=lS(),tI=uS(),Go=se(),__e=Vq(),rI=hS(),e1=za(),rn=(H(),C(q)),t1=sV(),p_e=Do(),r1=(zu(),C(ep)),n1=(MS(),C(Gp)),s1=yt(),ur=Kw(),h_e=require("alasql"),i1=GS(),o1=Kp(),Ud=ts(),a1=(Tl(),C(Sl)),c1=Xw(),{handleHDBError:Dn,hdb_errors:l1}=pe(),{addNodeBack:WMe,removeNodeBack:zMe}=(Tl(),C(Sl)),{HDB_ERROR_MSGS:Ur,HTTP_STATUS_CODES:Jp}=l1,J=new Map,u1="delete",Ja="insert",qo="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},m_e={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},E_e="catchup",g_e="handleGetJob",S_e="handleGetJobsByStartDate",VS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},T_e=[Ms.createTable.name,Ms.createAttribute.name,Ms.dropTable.name,Ms.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}};J.set(Zw.insert.name,new re(!1,[Ja]));J.set(Zw.update.name,new re(!1,[Ml]));J.set(Zw.upsert.name,new re(!1,[Ja,Ml]));J.set(qS.searchByConditions.name,new re(!1,[qo]));J.set(qS.searchByHash.name,new re(!1,[qo]));J.set(qS.searchByValue.name,new re(!1,[qo]));J.set(qS.search.name,new re(!1,[qo]));J.set(Ms.createSchema.name,new re(!0,[]));J.set(Ms.createTable.name,new re(!0,[]));J.set(Ms.createAttribute.name,new re(!1,[Ja]));J.set(Ms.dropSchema.name,new re(!0,[]));J.set(Ms.dropTable.name,new re(!0,[]));J.set(Ms.dropAttribute.name,new re(!0,[]));J.set(Zp.describeSchema.name,new re(!1,[qo]));J.set(Zp.describeTable.name,new re(!1,[qo]));J.set(eI.deleteRecord.name,new re(!1,[u1]));J.set(eh.addUser.name,new re(!0,[]));J.set(eh.alterUser.name,new re(!0,[]));J.set(eh.dropUser.name,new re(!0,[]));J.set(eh.listUsersExternal.name,new re(!0,[]));J.set($S.listRoles.name,new re(!0,[]));J.set($S.addRole.name,new re(!0,[]));J.set($S.alterRole.name,new re(!0,[]));J.set($S.dropRole.name,new re(!0,[]));J.set(i_e.name,new re(!0,[]));J.set(o_e.name,new re(!0,[]));J.set(a_e.name,new re(!0,[]));J.set(c_e.name,new re(!0,[]));J.set(l_e.name,new re(!0,[]));J.set(u_e.name,new re(!0,[]));J.set(tI.setRoutes.name,new re(!0,[]));J.set(tI.getRoutes.name,new re(!0,[]));J.set(tI.deleteRoutes.name,new re(!0,[]));J.set(s1.setConfiguration.name,new re(!0,[]));J.set(d_e.clusterStatus.name,new re(!0,[]));J.set(f_e.name,new re(!0,[]));J.set(rI.getFingerprint.name,new re(!0,[]));J.set(rI.setLicense.name,new re(!0,[]));J.set(eI.deleteFilesBefore.name,new re(!0,[]));J.set(eI.deleteAuditLogsBefore.name,new re(!0,[]));J.set(e1.restart.name,new re(!0,[]));J.set(e1.restartService.name,new re(!0,[]));J.set(n_e.name,new re(!0,[]));J.set(s_e.name,new re(!0,[qo]));J.set(p_e.systemInformation.name,new re(!0,[]));J.set(s1.getConfiguration.name,new re(!0,[]));J.set(i1.readTransactionLog.name,new re(!0,[]));J.set(i1.deleteTransactionLogsBefore.name,new re(!0,[]));J.set(o1.installModules.name,new re(!0,[]));J.set(o1.auditModules.name,new re(!0,[]));J.set(Ud.createCsr.name,new re(!0,[]));J.set(Ud.signCertificate.name,new re(!0,[]));J.set(Ud.listCertificates.name,new re(!0,[]));J.set(Ud.addCertificate.name,new re(!0,[]));J.set(Ud.removeCertificate.name,new re(!0,[]));J.set(Ud.getKey.name,new re(!0,[]));J.set(a1.addNodeBack.name,new re(!0,[]));J.set(a1.removeNodeBack.name,new re(!0,[]));J.set(r1.createTokens.name,new re(!1,[]));J.set(r1.refreshOperationToken.name,new re(!1,[]));J.set(n1.login.name,new re(!1,[]));J.set(n1.logout.name,new re(!1,[]));J.set(ur.customFunctionsStatus.name,new re(!0,[]));J.set(ur.getCustomFunctions.name,new re(!0,[]));J.set(ur.getComponents.name,new re(!0,[]));J.set(ur.getComponentFile.name,new re(!0,[]));J.set(ur.setComponentFile.name,new re(!0,[]));J.set(ur.dropComponent.name,new re(!0,[]));J.set(ur.getCustomFunction.name,new re(!0,[]));J.set(ur.setCustomFunction.name,new re(!0,[]));J.set(ur.dropCustomFunction.name,new re(!0,[]));J.set(ur.addComponent.name,new re(!0,[]));J.set(ur.dropCustomFunctionProject.name,new re(!0,[]));J.set(ur.packageComponent.name,new re(!0,[]));J.set(ur.deployComponent.name,new re(!0,[]));J.set(ur.addSSHKey.name,new re(!0,[]));J.set(ur.updateSSHKey.name,new re(!0,[]));J.set(ur.deleteSSHKey.name,new re(!0,[]));J.set(ur.listSSHKeys.name,new re(!0,[]));J.set(ur.setSSHKnownHosts.name,new re(!0,[]));J.set(ur.getSSHKnownHosts.name,new re(!0,[]));J.set(rI.getRegistrationInfo.name,new re(!1,[]));J.set(eh.userInfo.name,new re(!1,[]));J.set(Zp.describeAll.name,new re(!1,[]));J.set(g_e,new re(!1,[]));J.set(S_e,new re(!0,[]));J.set(E_e,new re(!0,[]));J.set(VS.CSV_DATA_LOAD,new re(!1,[Ja,Ml]));J.set(VS.CSV_URL_LOAD,new re(!1,[Ja,Ml]));J.set(VS.CSV_FILE_LOAD,new re(!1,[Ja,Ml]));J.set(VS.IMPORT_FROM_S3,new re(!1,[Ja,Ml]));J.set(f1.EXPORT_TO_S3,new re(!0,[]));J.set(f1.EXPORT_LOCAL,new re(!0,[]));J.set(rn.VALID_SQL_OPS_ENUM.DELETE,new re(!1,[u1]));J.set(rn.VALID_SQL_OPS_ENUM.SELECT,new re(!1,[qo]));J.set(rn.VALID_SQL_OPS_ENUM.INSERT,new re(!1,[Ja]));J.set(rn.VALID_SQL_OPS_ENUM.UPDATE,new re(!1,[Ml]));p1.exports={verifyPerms:R_e,verifyPermsAst:A_e,verifyBulkLoadAttributePerms:b_e};function A_e(e,t,r){if(Go.isEmptyOrZeroLength(e))throw Sr.info("verify_perms_ast has an empty user parameter"),Dn(new Error);if(Go.isEmptyOrZeroLength(t))throw Sr.info("verify_perms_ast has an empty user parameter"),Dn(new Error);if(Go.isEmptyOrZeroLength(r))throw Sr.info("verify_perms_ast has a null operation parameter"),Dn(new Error);try{let n=new c1,s=new __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."),Dn(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&d1[r])throw Dn(new Error,Ur.DROP_SYSTEM,Jp.FORBIDDEN);if(c&&!l)return null;let u=t1.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof h_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=sI(t.role.permission,p,d[_]);nI(h,S,r,d[_],p,n)}}),n.getPermsResponse())}catch(n){throw Dn(n)}}a(A_e,"verifyPermsAst");function R_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"),Dn(new Error,Ur.DEFAULT_INVALID_REQUEST,Jp.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(Go.isEmptyOrZeroLength(e.hdb_user?.role)||Go.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&&m_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 Dn(new Error,Ur.DROP_SYSTEM,Jp.FORBIDDEN);if(l&&!f||u===!0&&(r===Ms.createSchema.name||r===Ms.dropSchema.name))return null;if(T_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(J.get(r)&&J.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 _=y_e(e),h=sI(e.hdb_user?.role?.permission,s,i);return nI(_,h,r,i,s,c,n),c.getPermsResponse()}a(R_e,"verifyPerms");function _1(e,t,r,n,s){if(Go.arrayHasEmptyValues([e,t,r]))throw Sr.info("hasPermissions has an invalid parameter"),Dn(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||J.get(t).requires_su))return null;if(!J.get(t))throw Sr.info(`operation ${t} not found.`),Dn(new Error,Ur.OP_NOT_FOUND(t),Jp.BAD_REQUEST);if(J.get(t)&&J.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=[],_=J.get(t).perms;!Go.isEmpty(s)&&_.includes(s)&&(_=[s]);for(let h=0;h<_.length;h++){let S=_[h],g=d[S];(g==null||g===!1)&&(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),Dn(l1.CHECK_LOGS_WRAPPER(_))}}}return r.size<2?n.getPermsResponse():null}a(_1,"hasPermissions");function nI(e,t,r,n,s,i,o){if(!e||!t)throw Sr.info("no attributes specified in checkAttributePerms."),Dn(new Error);let c=J.get(r).perms;if(!c||c==="")throw Sr.info(`no permissions found for ${r} in checkAttributePerms().`),Dn(new Error);if(Go.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!==qo)throw Dn(new Error,Ur.SYSTEM_TIMESTAMP_PERMS_ERR,Jp.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(nI,"checkAttributePerms");function y_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(y_e,"getRecordAttributes");function sI(e,t,r){let n=new Map;if(Go.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(sI,"getAttributePermissions");function b_e(e,t,r,n,s,i,o){let c=new Set(i),l=sI(e,n,s);nI(c,l,t,s,n,o,r)}a(b_e,"verifyBulkLoadAttributePerms")});var WS=w((JMe,S1)=>{"use strict";S1.exports={evaluateSQL:B_e,processAST:g1,convertSQLToAST:E1,checkASTPermissions:m1};var O_e=Rn(),h1=require("util"),N_e=h1.callbackify(O_e.insert),w_e=Yr().search,I_e=tk().update,C_e=h1.callbackify(I_e),P_e=nk().convertDelete,Xa=require("alasql"),D_e=KS(),YS=z(),L_e=aE(),M_e=se(),th=(H(),C(q)),{hdb_errors:v_e,handleHDBError:iI}=pe(),{HTTP_STATUS_CODES:oI}=v_e;L_e(Xa);var U_e=403,x_e="There was a problem performing this insert. Please check the logs and try again.",aI=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function B_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 Xa.yy.Insert?n=s.into.databaseid:s instanceof Xa.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Xa.yy.Update||s instanceof Xa.yy.Delete?n=s.table.databaseid:YS.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Xa.yy.Select)&&M_e.isEmptyOrZeroLength(n))return t("No schema specified",null)}g1(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(B_e,"evaluateSQL");function m1(e,t){let r;try{r=D_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 aI;if(!e)throw iI(new Error,"The 'sql' parameter is missing from the request body",oI.BAD_REQUEST);try{let r=e.trim(),n=Xa.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
41
+ `);throw n[1]?iI(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,oI.BAD_REQUEST):iI(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",oI.BAD_REQUEST)}return t}a(E1,"convertSQLToAST");function g1(e,t,r){try{let n=H_e;if(!e.bypass_auth&&!t.permissions_checked){let i=m1(e,t);if(i&&i.length>0)return r(U_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=w_e,s=t.ast.statements[0];break;case th.VALID_SQL_OPS_ENUM.INSERT:n=k_e;break;case th.VALID_SQL_OPS_ENUM.UPDATE:n=C_e;break;case th.VALID_SQL_OPS_ENUM.DELETE:n=P_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 H_e(e,t){YS.info(e),t("unknown sql statement")}a(H_e,"nullFunction");function k_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=F_e(i,e.values)}catch(o){return r(o)}N_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(k_e,"convertInsert");function F_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]]=Xa.compile(`SELECT ${s.toString()} AS [${th.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw YS.error(r),new Error(x_e)}}a(F_e,"createDataObjects")});var _I=w((tve,y1)=>{var JS=require("clone"),XS=ft(),G_e=se(),jS=(H(),C(q)),ZMe=z(),cI=require("fs"),uI=require("joi"),{string:QS}=uI.types(),{hdb_errors:q_e,handleHDBError:zS}=pe(),{HDB_ERROR_MSGS:eve,HTTP_STATUS_CODES:lI}=q_e,{common_validators:xd}=Mi(),T1=" is required",$_e=["insert","update","upsert"],dI={database:{presence:!1,format:xd.schema_format,length:xd.schema_length},schema:{presence:!1,format:xd.schema_format,length:xd.schema_length},table:{presence:!0,format:xd.schema_format,length:xd.schema_length},action:{inclusion:{within:$_e,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},V_e={schema:QS.required(),table:QS.required(),action:QS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:K_e,AWS_SECRET:Y_e,AWS_BUCKET:W_e,AWS_FILE_KEY:z_e,REGION:j_e}=jS.S3_BUCKET_AUTH_KEYS,Q_e={s3:{presence:!0},[`s3.${K_e}`]:{presence:!0,type:"String"},[`s3.${Y_e}`]:{presence:!0,type:"String"},[`s3.${W_e}`]:{presence:!0,type:"String"},[`s3.${z_e}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${j_e}`]:{presence:!0,type:"String"}},A1=JS(dI);A1.data.presence={message:T1};var R1=JS(dI);R1.file_path.presence={message:T1};var J_e=Object.assign(JS(dI),Q_e),fI=JS(V_e);fI.csv_url=QS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();fI.passthrough_headers=uI.object();function X_e(e){let t=XS.validateObject(e,A1);return ZS(e,t)}a(X_e,"dataObject");function Z_e(e){let t=XS.validateBySchema(e,uI.object(fI));return ZS(e,t)}a(Z_e,"urlObject");function epe(e){let t=XS.validateObject(e,R1);return ZS(e,t)}a(epe,"fileObject");function tpe(e){let t=XS.validateObject(e,J_e);return ZS(e,t)}a(tpe,"s3FileObject");function ZS(e,t){if(!t){let r=G_e.checkGlobalSchemaTable(e.schema,e.table);if(r)return zS(new Error,r,lI.BAD_REQUEST);if(e.operation===jS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{cI.accessSync(e.file_path,cI.constants.R_OK|cI.constants.F_OK)}catch(n){return n.code===jS.NODE_ERROR_CODES.ENOENT?zS(n,`No such file or directory ${n.path}`,lI.BAD_REQUEST):n.code===jS.NODE_ERROR_CODES.EACCES?zS(n,`Permission denied ${n.path}`,lI.BAD_REQUEST):zS(n)}}return t}a(ZS,"postValidateChecks");y1.exports={dataObject:X_e,urlObject:Z_e,fileObject:epe,s3FileObject:tpe}});var pI=w((nve,b1)=>{"use strict";var rh=z(),eT=(H(),C(q));async function rpe(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(rpe,"callOperationFunctionAsAwait");b1.exports={callOperationFunctionAsAwait:rpe}});var hI=w((ive,N1)=>{"use strict";var{S3:npe,GetObjectCommand:spe}=require("@aws-sdk/client-s3");N1.exports={getFileStreamFromS3:ipe,getS3AuthObj:O1};async function ipe(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 spe(r))).Body}a(ipe,"getFileStreamFromS3");function O1(e,t,r){return new npe({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(O1,"getS3AuthObj")});var I1=w((ave,w1)=>{"use strict";var mI=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}},EI=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:mI,BulkLoadDataObject:EI}});var P1=w((lve,C1)=>{"use strict";var gI=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};C1.exports=gI});var bI=w((hve,W1)=>{"use strict";var tT=Rn(),nT=_I(),ope=require("needle"),pi=(H(),C(q)),dve=Tt(),Bd=se(),{handleHDBError:Ht,hdb_errors:k1}=pe(),{HTTP_STATUS_CODES:xr,HDB_ERROR_MSGS:Tr,CHECK_LOGS_WRAPPER:Ul}=k1,Hd=z(),SI=require("papaparse");Bd.promisifyPapaParse();var hi=require("fs-extra"),ape=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"),cpe=ae(),F1=pI(),lpe=hI(),{BulkLoadFileObject:AI,BulkLoadDataObject:upe}=I1(),RI=Xw(),{verifyBulkLoadAttributePerms:G1}=KS(),fve=P1(),_ve=or(),pve=To(),{databases:dpe}=(Pe(),C(tt)),{coerceType:fpe}=(Gf(),C(OI)),x1="No records parsed from csv file.",vl=`${cpe.get("HDB_ROOT")}/tmp`,{schema_regex:_pe}=Mi(),B1=1024*1024*2,H1=5e3,ppe={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};W1.exports={csvDataLoad:hpe,csvURLLoad:mpe,csvFileLoad:Epe,importFromS3:gpe};async function hpe(e,t){let r=nT.dataObject(e);if(r)throw Ht(r,r.message,xr.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=V1(e.schema,e.table),i=SI.parse(e.data,{header:!0,skipEmptyLines:!0,transform:TI.bind(null,s),dynamicTyping:!1}),o=new RI;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 Ht(new Error,c,xr.BAD_REQUEST,void 0,void 0,!0);let l=new upe(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(hpe,"csvDataLoad");async function mpe(e){let t=nT.urlObject(e);if(t)throw Ht(t,t.message,xr.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${vl}/${r}`;try{await Spe(e,r)}catch(s){throw Hd.error(Tr.DOWNLOAD_FILE_ERR(r)+" - "+s),Ht(s,Ul(Tr.DOWNLOAD_FILE_ERR(r)))}try{let s=new AI(this.job_operation_function.name,e.action,e.schema,e.table,n,pi.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await yI(s);return await rT(n),i}catch(s){throw await rT(n),xl(s)}}a(mpe,"csvURLLoad");async function Epe(e){let t=nT.fileObject(e);if(t)throw Ht(t,t.message,xr.BAD_REQUEST,void 0,void 0,!0);let r=new AI(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,pi.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await yI(r)}catch(n){throw xl(n)}}a(Epe,"csvFileLoad");async function gpe(e){let t=nT.s3FileObject(e);if(t)throw Ht(t,t.message,xr.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=ape.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${vl}/${s}`;let i=new AI(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await Tpe(s,e);let o=await yI(i);return await rT(r),o}catch(n){throw await rT(r),xl(n)}}a(gpe,"importFromS3");async function Spe(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await ope("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 Ht(n,s,n.statusCode,pi.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}Rpe(r,e.csv_url),await Ape(t,r.raw)}a(Spe,"downloadCSVFile");async function Tpe(e,t){try{let r=`${vl}/${e}`;await hi.mkdirp(vl),await hi.writeFile(`${vl}/${e}`,"",{flag:"a+"});let n=await hi.createWriteStream(r),s=await lpe.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(){Hd.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Hd.error(Tr.S3_DOWNLOAD_ERR+" - "+r),Ht(r,Ul(Tr.S3_DOWNLOAD_ERR))}}a(Tpe,"downloadFileFromS3");async function Ape(e,t){try{await hi.mkdirp(vl),await hi.writeFile(`${vl}/${e}`,t)}catch(r){throw Hd.error(Tr.WRITE_TEMP_FILE_ERR),Ht(r,Ul(Tr.DEFAULT_BULK_LOAD_ERR))}}a(Ape,"writeFileToTempFolder");async function rT(e){if(e)try{await hi.access(e),await hi.unlink(e)}catch{Hd.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(rT,"deleteTempFile");function Rpe(e,t){if(e.statusCode!==k1.HTTP_STATUS_CODES.OK)throw Ht(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,xr.BAD_REQUEST);if(!ppe[e.headers["content-type"]])throw Ht(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,xr.BAD_REQUEST);if(!e.raw)throw Ht(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,xr.BAD_REQUEST)}a(Rpe,"validateURLResponse");async function yI(e){try{let t;switch(e.file_type){case pi.VALID_S3_FILE_TYPES.CSV:t=await ype(e);break;case pi.VALID_S3_FILE_TYPES.JSON:t=await bpe(e);break;default:throw Ht(new Error,Tr.DEFAULT_BULK_LOAD_ERR,xr.BAD_REQUEST,pi.LOG_LEVELS.ERROR,Tr.INVALID_FILE_EXT_ERR(e))}return Y1(t.records,t.number_written)}catch(t){throw xl(t)}}a(yI,"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=Ht(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;Bd.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Bd.isEmpty(c)&&!Bd.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=Ht(c,Ul(Tr.INSERT_CSV_ERR),xr.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Tr.INSERT_CSV_ERR+" - "+c);r(l)}}a($1,"insertChunk");async function ype(e){let t={records:0,number_written:0},r=V1(e.schema,e.table);try{let n=new RI,s=hi.createReadStream(e.file_path,{highWaterMark:B1});s.setEncoding("utf8"),await SI.parsePromise(s,q1.bind(null,e,n),TI.bind(null,r));let i=n.getPermsResponse();if(i)throw Ht(new Error,i,xr.BAD_REQUEST);return s=hi.createReadStream(e.file_path,{highWaterMark:B1}),s.setEncoding("utf8"),await SI.parsePromise(s,$1.bind(null,e,t),TI.bind(null,r)),s.destroy(),t}catch(n){throw Ht(n,Ul(Tr.PAPA_PARSE_ERR),xr.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Tr.PAPA_PARSE_ERR+n)}}a(ype,"callPapaParse");function V1(e,t){let r=dpe[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>fpe(i,s));return n}a(V1,"createTransformMap");function TI(e,t,r){let n=e.get(r);return n?n(t):Bd.autoCast(t)}a(TI,"typeFunction");async function bpe(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new RI,s=D1([hi.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 Ht(new Error,i,xr.BAD_REQUEST);let o=D1([hi.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 Ht(n,Ul(Tr.INSERT_JSON_ERR),xr.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Tr.INSERT_JSON_ERR+n)}}a(bpe,"insertJson");async function K1(e){let t={};try{e.data&&e.data.length>0&&Ope(e.data[0])?t=await Npe(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Hd.info(t.message))}catch(r){throw xl(r)}return t}a(K1,"callBulkFileLoad");function Ope(e){let t=Object.keys(e);for(let r of t)if(!_pe.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(Ope,"validateColumnNames");async function Npe(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 Ht(new Error,Tr.INVALID_ACTION_PARAM_ERR(n),xr.BAD_REQUEST,pi.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=Bd.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw xl(o)}}a(Npe,"bulkFileLoad");function Y1(e,t){return`successfully loaded ${t} of ${e} records`}a(Y1,"buildResponseMsg");function xl(e){return Ht(e,Ul(Tr.DEFAULT_BULK_LOAD_ERR),xr.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Tr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(xl,"buildTopLevelErrMsg")});var II=w((Eve,tK)=>{"use strict";var wI=Yr(),wpe=hI(),{AsyncParser:Ipe}=require("json2csv"),sT=require("stream"),as=se(),NI=require("fs-extra"),Cpe=require("path"),vs=z(),{promisify:Q1}=require("util"),nh=se(),{handleHDBError:dr,hdb_errors:Ppe}=pe(),{HDB_ERROR_MSGS:Ln,HTTP_STATUS_CODES:fr}=Ppe,{streamAsJSON:Dpe}=(yR(),C(qL)),{Upload:Lpe}=require("@aws-sdk/lib-storage"),{toCsvStream:Mpe}=(uo(),C(cM)),z1=["search_by_value","search_by_hash","sql","search_by_conditions"],j1=["json","csv"],J1="json",X1="csv",vpe="Successfully exported JSON locally.",Upe="Successfully exported CSV locally.",xpe=1e3,Bpe=wI.searchByHash,Hpe=wI.searchByValue,kpe=Q1(sT.finished);tK.exports={export_to_s3:$pe,export_local:Fpe};async function Fpe(e){vs.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=Z1(e);if(!as.isEmpty(t))throw vs.error(t),dr(new Error,t,fr.BAD_REQUEST,void 0,void 0,!0);if(as.isEmpty(e.path))throw vs.error(Ln.MISSING_VALUE("path")),dr(new Error,Ln.MISSING_VALUE("path"),fr.BAD_REQUEST,void 0,void 0,!0);let r=(as.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(Cpe.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=as.buildFolderPath(e.path,r);await Gpe(e.path);let s=await eK(e);return await qpe(n,e.format,s)}a(Fpe,"export_local");async function Gpe(e){if(vs.trace("in confirmPath"),as.isEmptyOrZeroLength(e))throw dr(new Error,`Invalid path: ${e}`,fr.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await NI.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,vs.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 vs.error(r),dr(new Error,r,fr.BAD_REQUEST,void 0,void 0,!0)}return!0}a(Gpe,"confirmPath");async function qpe(e,t,r){if(vs.trace("in saveToLocal"),nh.isEmptyOrZeroLength(e))throw dr(new Error,Ln.INVALID_VALUE("file_path"),fr.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmptyOrZeroLength(t))throw dr(new Error,Ln.INVALID_VALUE("Source format"),fr.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmpty(r))throw dr(new Error,Ln.NOT_FOUND("Data"),fr.BAD_REQUEST,void 0,void 0,!0);if(t===J1){let n=NI.createWriteStream(e);return Dpe(r).pipe(n),await kpe(n),{message:vpe,path:e}}else if(t===X1){let n=NI.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 Ipe(i,c).fromInput(s).toOutput(n).promise(!1),{message:Upe,path:e}}throw dr(new Error,Ln.INVALID_VALUE("format"),fr.BAD_REQUEST)}a(qpe,"saveToLocal");async function $pe(e){if(!e.s3||Object.keys(e.s3).length===0)throw dr(new Error,Ln.MISSING_VALUE("S3 object"),fr.BAD_REQUEST);if(as.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw dr(new Error,Ln.MISSING_VALUE("aws_access_key_id"),fr.BAD_REQUEST);if(as.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw dr(new Error,Ln.MISSING_VALUE("aws_secret_access_key"),fr.BAD_REQUEST);if(as.isEmptyOrZeroLength(e.s3.bucket))throw dr(new Error,Ln.MISSING_VALUE("bucket"),fr.BAD_REQUEST);if(as.isEmptyOrZeroLength(e.s3.key))throw dr(new Error,Ln.MISSING_VALUE("key"),fr.BAD_REQUEST);if(as.isEmptyOrZeroLength(e.s3.region))throw dr(new Error,Ln.MISSING_VALUE("region"),fr.BAD_REQUEST);let t=Z1(e);if(!as.isEmpty(t))throw dr(new Error,t,fr.BAD_REQUEST);vs.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 vs.error(l),l}let n,s=await wpe.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=Mpe(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 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%xpe===0&&(l.push(f),f="")}f.length!==0&&l.push(f),l.push("]"),l.push(null)}else throw dr(new Error,Ln.INVALID_VALUE("format"),fr.BAD_REQUEST);return new Lpe({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a($pe,"export_to_s3");function Z1(e){if(vs.trace("in exportCoreValidation"),as.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(as.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){vs.trace("in getRecords");let t,r;if(nh.isEmpty(e.search_operation)||nh.isEmptyOrZeroLength(e.search_operation.operation))throw dr(new Error,Ln.INVALID_VALUE("Search operation"),fr.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=Hpe;break;case"search_by_hash":t=Bpe;break;case"search_by_conditions":t=wI.searchByConditions;break;case"sql":{let n=WS();t=Q1(n.evaluateSQL);break}default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,vs.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((Sve,rK)=>{"use strict";var CI=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};rK.exports=CI});var oK=w((Ave,iK)=>{"use strict";var Vpe=(H(),C(q)),sK=require("moment"),Kpe=require("uuid").v4,PI=class{static{a(this,"JobObject")}constructor(){this.id=Kpe(),this.type=void 0,this.start_datetime=sK().valueOf(),this.created_datetime=sK().valueOf(),this.end_datetime=void 0,this.status=Vpe.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};iK.exports=PI});var DI=w((yve,pK)=>{"use strict";var Ype=require("uuid").v4,dK=Rn(),fK=Yr(),Wpe=si(),zpe=Hu(),jpe=nK(),Ot=(H(),C(q)),Qpe=oK(),Jpe=ng(),mi=z(),Xpe=vf(),kd=se(),{promisify:Zpe}=require("util"),Bl=require("moment"),ehe=WS(),iT=_I(),aK=Iy(),{deleteTransactionLogsBeforeValidator:the}=Ww(),{handleHDBError:cK,hdb_errors:rhe,ClientError:nhe}=pe(),{HTTP_STATUS_CODES:lK}=rhe,uK=fK.searchByValue,she=fK.searchByHash,ihe=dK.insert,ohe=Zpe(ehe.evaluateSQL),ahe=dK.update;pK.exports={addJob:uhe,updateJob:fhe,handleGetJob:che,handleGetJobsByStartDate:lhe,getJobById:_K};async function che(e){if(e.id===void 0)throw new nhe("'id' is required");let t=await _K(e.id);return kd.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(che,"handleGetJob");async function lhe(e){try{let t=await dhe(e);if(mi.trace(`Searching for jobs from ${e.from_date} to ${e.to_date}`),t&&t.length>0)for(let r of t)r.start_datetime&&(r.start_datetime_converted=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 mi.error(r),new Error(r)}}a(lhe,"handleGetJobsByStartDate");async function uhe(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||kd.isEmptyOrZeroLength(e.operation)){let f="job parameter is invalid";return mi.info(f),t.error=f,t}if(!Ot.JOB_TYPE_ENUM[e.operation])return mi.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=the(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 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 Wpe(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 mi.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Ype();try{o=await uK(i)}catch(f){let d=`There was an error inserting a new job: ${f}`;return mi.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return mi.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new Xpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await ihe(l)}catch(f){return mi.error(`There was an error inserting a job for job type: ${e.operation} -- ${f}`),t.success=!1,t}if(u.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let f=`Created a job with type ${s.type} and id ${s.id}`;t.message=f,t.createdJob=s,t.success=!0,mi.trace(f)}return t}a(uhe,"addJob");async function dhe(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 jpe(n,e.hdb_user);try{return await ohe(s)}catch(i){throw mi.error(`there was a problem searching for jobs from date ${e.from_date} to date ${e.to_date} ${i}`),new Error("there was an error searching for jobs. Please check the log for details.")}}a(dhe,"getJobsInDateRange");async function _K(e){if(kd.isEmptyOrZeroLength(e))return kd.errorizeMessage("Invalid job ID specified.");let t=new zpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await she(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return mi.error(n),kd.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(_K,"getJobById");async function fhe(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(kd.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 ahe(t),r}a(fhe,"updateJob")});var RK=w((Ove,AK)=>{"use strict";var hK=se(),Ar=(H(),C(q)),_he=require("moment"),oT=bI(),sh=z(),mK=DI(),EK=II(),gK=Vc(),SK=et(),phe=GS(),hhe=za(),{parentPort:mhe,isMainThread:TK}=require("worker_threads"),{onMessageByType:Ehe}=et(),LI=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function ghe(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 zi(e,oT.csvFileLoad);break;case Ar.JOB_TYPE_ENUM.csv_url_load:await zi(e,oT.csvURLLoad);break;case Ar.JOB_TYPE_ENUM.csv_data_load:await zi(e,oT.csvDataLoad);break;case Ar.JOB_TYPE_ENUM.import_from_s3:await zi(e,oT.importFromS3);break;case Ar.JOB_TYPE_ENUM.empty_trash:break;case Ar.JOB_TYPE_ENUM.export_local:await zi(e,EK.export_local);break;case Ar.JOB_TYPE_ENUM.export_to_s3:await zi(e,EK.export_to_s3);break;case Ar.JOB_TYPE_ENUM.delete_files_before:case Ar.JOB_TYPE_ENUM.delete_records_before:await zi(e,gK.deleteFilesBefore);break;case Ar.JOB_TYPE_ENUM.delete_audit_logs_before:await zi(e,gK.deleteAuditLogsBefore);break;case Ar.JOB_TYPE_ENUM.delete_transaction_logs_before:await zi(e,phe.deleteTransactionLogsBefore);break;case Ar.JOB_TYPE_ENUM.restart_service:return await zi(e,hhe.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(ghe,"parseMessage");async function zi(e,t){try{e.job.status=Ar.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=_he().valueOf(),await mK.updateJob(e.job),await She(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(zi,"runJob");async function She(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}`}}):mhe.postMessage({type:Ar.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(She,"launchJobThread");TK&&Ehe(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:ghe,RunnerMessage:LI}});var bK=w((wve,yK)=>{"use strict";var MI=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};yK.exports=MI});var Yw=w((Pve,kI)=>{"use strict";var dT=Yr(),xI=WS(),aT=bI(),$o=Vg(),cT=Ao(),oh=Vc(),The=RN(),ih=An(),lT=q_(),Ct=Kw(),uT=z(),Ahe=wN(),Rhe=Ed(),OK=XN(),yhe=nS(),bhe=tw(),Ohe=rw(),Nhe=aS(),whe=lS(),vI=uS(),NK=II(),Ihe=KS(),BI=DI(),V=(H(),C(q)),{hdb_errors:ch,handleHDBError:ah}=pe(),{HTTP_STATUS_CODES:wK}=ch,UI=hS(),IK=za(),HK=require("util"),Gd=Rn(),Che=ys(),Phe=Do(),CK=RK(),PK=(zu(),C(ep)),DK=(MS(),C(Gp)),LK=yt(),MK=GS(),vK=Kp(),{setServerUtilities:Dhe}=(Gf(),C(OI)),{CONTEXT:Cve}=(ga(),C(mR)),{_assignPackageExport:Lhe}=Ri(),{transformReq:Mhe}=se(),{server:vhe}=(Vr(),C(Tu)),nn=uT.loggerWithTag("operation"),Fd=ts(),UK=(Tl(),C(Sl)),Uhe=pI(),xK=dT.searchByHash,xhe=dT.searchByValue,Bhe=HK.promisify(dT.search),Hhe=HK.promisify(xI.evaluateSQL),khe={[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},Z=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 Uhe.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return khe[e.body.operation]&&Che.setSchemaDataToGlobal(n=>{n&&nn.error(n)}),r}a(kK,"processLocalTransaction");var BK=Ghe();kI.exports={chooseOperation:FK,getOperationFunction:GK,operation:HI,processLocalTransaction:kK,executeJob:Us};Dhe(kI.exports);vhe.operation=HI;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=xI.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=xI.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=Ihe.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");Lhe("operation",HI);function HI(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=FK(e);return kK({body:e},n)}a(HI,"operation");async function Fhe(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 Gd.insert(i);break;case V.OPERATIONS_ENUM.UPDATE:o=await Gd.update(i);break;case V.OPERATIONS_ENUM.UPSERT:o=await Gd.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(Fhe,"catchup");async function Us(e){Mhe(e);let t,r;try{r=await BI.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(Us,"executeJob");function Ghe(){let e=new Map;return e.set(V.OPERATIONS_ENUM.INSERT,new Z(Gd.insert)),e.set(V.OPERATIONS_ENUM.UPDATE,new Z(Gd.update)),e.set(V.OPERATIONS_ENUM.UPSERT,new Z(Gd.upsert)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new Z(dT.searchByConditions)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_HASH,new Z(xK)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_ID,new Z(xK)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_VALUE,new Z(xhe)),e.set(V.OPERATIONS_ENUM.SEARCH,new Z(Bhe)),e.set(V.OPERATIONS_ENUM.SQL,new Z(Hhe)),e.set(V.OPERATIONS_ENUM.CSV_DATA_LOAD,new Z(Us,aT.csvDataLoad)),e.set(V.OPERATIONS_ENUM.CSV_FILE_LOAD,new Z(Us,aT.csvFileLoad)),e.set(V.OPERATIONS_ENUM.CSV_URL_LOAD,new Z(Us,aT.csvURLLoad)),e.set(V.OPERATIONS_ENUM.IMPORT_FROM_S3,new Z(Us,aT.importFromS3)),e.set(V.OPERATIONS_ENUM.CREATE_SCHEMA,new Z($o.createSchema)),e.set(V.OPERATIONS_ENUM.CREATE_DATABASE,new Z($o.createSchema)),e.set(V.OPERATIONS_ENUM.CREATE_TABLE,new Z($o.createTable)),e.set(V.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new Z($o.createAttribute)),e.set(V.OPERATIONS_ENUM.DROP_SCHEMA,new Z($o.dropSchema)),e.set(V.OPERATIONS_ENUM.DROP_DATABASE,new Z($o.dropSchema)),e.set(V.OPERATIONS_ENUM.DROP_TABLE,new Z($o.dropTable)),e.set(V.OPERATIONS_ENUM.DROP_ATTRIBUTE,new Z($o.dropAttribute)),e.set(V.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new Z(cT.describeSchema)),e.set(V.OPERATIONS_ENUM.DESCRIBE_DATABASE,new Z(cT.describeSchema)),e.set(V.OPERATIONS_ENUM.DESCRIBE_TABLE,new Z(cT.describeTable)),e.set(V.OPERATIONS_ENUM.DESCRIBE_ALL,new Z(cT.describeAll)),e.set(V.OPERATIONS_ENUM.DELETE,new Z(oh.deleteRecord)),e.set(V.OPERATIONS_ENUM.ADD_USER,new Z(ih.addUser)),e.set(V.OPERATIONS_ENUM.ALTER_USER,new Z(ih.alterUser)),e.set(V.OPERATIONS_ENUM.DROP_USER,new Z(ih.dropUser)),e.set(V.OPERATIONS_ENUM.LIST_USERS,new Z(ih.listUsersExternal)),e.set(V.OPERATIONS_ENUM.LIST_ROLES,new Z(lT.listRoles)),e.set(V.OPERATIONS_ENUM.ADD_ROLE,new Z(lT.addRole)),e.set(V.OPERATIONS_ENUM.ALTER_ROLE,new Z(lT.alterRole)),e.set(V.OPERATIONS_ENUM.DROP_ROLE,new Z(lT.dropRole)),e.set(V.OPERATIONS_ENUM.USER_INFO,new Z(ih.userInfo)),e.set(V.OPERATIONS_ENUM.READ_LOG,new Z(Ahe)),e.set(V.OPERATIONS_ENUM.ADD_NODE,new Z(Rhe)),e.set(V.OPERATIONS_ENUM.UPDATE_NODE,new Z(OK)),e.set(V.OPERATIONS_ENUM.SET_NODE_REPLICATION,new Z(OK)),e.set(V.OPERATIONS_ENUM.REMOVE_NODE,new Z(yhe)),e.set(V.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new Z(bhe)),e.set(V.OPERATIONS_ENUM.PURGE_STREAM,new Z(Ohe)),e.set(V.OPERATIONS_ENUM.SET_CONFIGURATION,new Z(LK.setConfiguration)),e.set(V.OPERATIONS_ENUM.CLUSTER_STATUS,new Z(Nhe.clusterStatus)),e.set(V.OPERATIONS_ENUM.CLUSTER_NETWORK,new Z(whe)),e.set(V.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new Z(vI.setRoutes)),e.set(V.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new Z(vI.getRoutes)),e.set(V.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new Z(vI.deleteRoutes)),e.set(V.OPERATIONS_ENUM.EXPORT_TO_S3,new Z(Us,NK.export_to_s3)),e.set(V.OPERATIONS_ENUM.CREATE_CSR,new Z(Fd.createCsr)),e.set(V.OPERATIONS_ENUM.SIGN_CERTIFICATE,new Z(Fd.signCertificate)),e.set(V.OPERATIONS_ENUM.LIST_CERTIFICATES,new Z(Fd.listCertificates)),e.set(V.OPERATIONS_ENUM.ADD_CERTIFICATES,new Z(Fd.addCertificate)),e.set(V.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new Z(Fd.removeCertificate)),e.set(V.OPERATIONS_ENUM.GET_KEY,new Z(Fd.getKey)),e.set(V.OPERATIONS_ENUM.ADD_NODE_BACK,new Z(UK.addNodeBack)),e.set(V.OPERATIONS_ENUM.REMOVE_NODE_BACK,new Z(UK.removeNodeBack)),e.set(V.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new Z(Us,oh.deleteFilesBefore)),e.set(V.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new Z(Us,oh.deleteFilesBefore)),e.set(V.OPERATIONS_ENUM.EXPORT_LOCAL,new Z(Us,NK.export_local)),e.set(V.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new Z(BI.handleGetJobsByStartDate)),e.set(V.OPERATIONS_ENUM.GET_JOB,new Z(BI.handleGetJob)),e.set(V.OPERATIONS_ENUM.GET_FINGERPRINT,new Z(UI.getFingerprint)),e.set(V.OPERATIONS_ENUM.SET_LICENSE,new Z(UI.setLicense)),e.set(V.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new Z(UI.getRegistrationInfo)),e.set(V.OPERATIONS_ENUM.RESTART,new Z(IK.restart)),e.set(V.OPERATIONS_ENUM.RESTART_SERVICE,new Z(Us,IK.restartService)),e.set(V.OPERATIONS_ENUM.CATCHUP,new Z(Fhe)),e.set(V.OPERATIONS_ENUM.SYSTEM_INFORMATION,new Z(Phe.systemInformation)),e.set(V.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new Z(Us,oh.deleteAuditLogsBefore)),e.set(V.OPERATIONS_ENUM.READ_AUDIT_LOG,new Z(The)),e.set(V.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new Z(PK.createTokens)),e.set(V.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new Z(PK.refreshOperationToken)),e.set(V.OPERATIONS_ENUM.LOGIN,new Z(DK.login)),e.set(V.OPERATIONS_ENUM.LOGOUT,new Z(DK.logout)),e.set(V.OPERATIONS_ENUM.GET_CONFIGURATION,new Z(LK.getConfiguration)),e.set(V.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new Z(Ct.customFunctionsStatus)),e.set(V.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new Z(Ct.getCustomFunctions)),e.set(V.OPERATIONS_ENUM.GET_COMPONENT_FILE,new Z(Ct.getComponentFile)),e.set(V.OPERATIONS_ENUM.GET_COMPONENTS,new Z(Ct.getComponents)),e.set(V.OPERATIONS_ENUM.SET_COMPONENT_FILE,new Z(Ct.setComponentFile)),e.set(V.OPERATIONS_ENUM.DROP_COMPONENT,new Z(Ct.dropComponent)),e.set(V.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new Z(Ct.getCustomFunction)),e.set(V.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new Z(Ct.setCustomFunction)),e.set(V.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new Z(Ct.dropCustomFunction)),e.set(V.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new Z(Ct.addComponent)),e.set(V.OPERATIONS_ENUM.ADD_COMPONENT,new Z(Ct.addComponent)),e.set(V.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new Z(Ct.dropCustomFunctionProject)),e.set(V.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new Z(Ct.packageComponent)),e.set(V.OPERATIONS_ENUM.PACKAGE_COMPONENT,new Z(Ct.packageComponent)),e.set(V.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new Z(Ct.deployComponent)),e.set(V.OPERATIONS_ENUM.DEPLOY_COMPONENT,new Z(Ct.deployComponent)),e.set(V.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new Z(MK.readTransactionLog)),e.set(V.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new Z(Us,MK.deleteTransactionLogsBefore)),e.set(V.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new Z(vK.installModules)),e.set(V.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new Z(vK.auditModules)),e.set(V.OPERATIONS_ENUM.GET_BACKUP,new Z($o.getBackup)),e.set(V.OPERATIONS_ENUM.ADD_SSH_KEY,new Z(Ct.addSSHKey)),e.set(V.OPERATIONS_ENUM.UPDATE_SSH_KEY,new Z(Ct.updateSSHKey)),e.set(V.OPERATIONS_ENUM.DELETE_SSH_KEY,new Z(Ct.deleteSSHKey)),e.set(V.OPERATIONS_ENUM.LIST_SSH_KEYS,new Z(Ct.listSSHKeys)),e.set(V.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new Z(Ct.setSSHKnownHosts)),e.set(V.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new Z(Ct.getSSHKnownHosts)),e}a(Ghe,"initializeOperationFunctionMap")});var pT=w((Lve,VK)=>{"use strict";var fT=(H(),C(q)),qhe=se(),lh=z(),{handleHDBError:FI,hdb_errors:_T}=pe(),{isMainThread:$he}=require("worker_threads"),{Readable:Vhe}=require("stream"),qK=require("os"),Khe=require("util"),Yhe=OO(),Whe=Khe.promisify(Yhe.authorize),$K=Yw(),{createGzip:zhe,constants:jhe}=require("zlib"),Qhe=[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 ${$he?"HDB":"thread"}.`;console.error(t),lh.fatal(t),process.exit(1)}a(Jhe,"handleServerUncaughtException");function Xhe(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(Xhe,"serverErrorHandler");function Zhe(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=FI(new Error,"Invalid JSON.",_T.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(qhe.isEmpty(e.body.operation)){let n=FI(new Error,"Request body must include an 'operation' property.",_T.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Zhe,"reqBodyValidationHandler");function eme(e,t,r){let n;!Qhe.includes(e.body.operation)||e.body.operation===fT.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&!e.body.username&&!e.body.password?Whe(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(FI(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(eme,"authHandler");async function tme(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 Vhe&&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(zhe({level:jhe.Z_BEST_SPEED})))}return s}catch(s){throw lh.error(s),s}}a(tme,"handlePostRequest");VK.exports={authHandler:eme,handlePostRequest:tme,handleServerUncaughtException:Jhe,serverErrorHandler:Xhe,reqBodyValidationHandler:Zhe}});var zK=w((vve,WK)=>{"use strict";var rme=require("fastify-plugin"),{handlePostRequest:KK,authHandler:nme,reqBodyValidationHandler:sme}=pT();async function ime(e){e.decorate("hdbCore",{preValidation:[sme,nme],request:a(t=>YK(KK(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>YK(KK(t,r,!0)),"requestWithoutAuthentication")})}a(ime,"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=rme(ime)});var QK=w((Bve,jK)=>{"use strict";var xve=require("fs"),hT=ae();hT.initSync();var{CONFIG_PARAMS:GI}=(H(),C(q)),ome=1024*1024*1024;function ame(e){let t=hT.get(GI.HTTP_TIMEOUT),r=hT.get(GI.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:ome,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:hT.get(GI.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(ame,"getServerOptions");jK.exports=ame});var ZK=w((kve,XK)=>{"use strict";var qI=ae();qI.initSync();var{CONFIG_PARAMS:JK}=(H(),C(q));function cme(){let e=qI.get(JK.HTTP_CORSACCESSLIST),t=qI.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(cme,"getCORSOptions");XK.exports=cme});var rY=w((Gve,tY)=>{"use strict";var eY=ae();eY.initSync();var lme=(H(),C(q));function ume(){return eY.get(lme.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(ume,"getHeaderTimeoutConfig");tY.exports=ume});var VI={};ve(VI,{customFunctionsServer:()=>_me,ready:()=>mY,start:()=>fme});function fme(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){Vo||(Vo=hY(t),Ye.http((await Vo).server));let o=await Vo,c=(0,$I.dirname)(s),l=(0,$I.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!nY.has(c)){nY.add(c);try{o.register(hme(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 _me(){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 pme();let e=lY.get(B.HTTP_SECUREPORT)>0,t;try{t=Vo=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 pme(){try{ht.info("Custom Functions starting configuration."),await uY.setUsersWithRolesCache(),ht.info("Custom Functions completed configuration.")}catch(e){ht.error(e)}}function hme(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(dme),await r.after(),jf(r),ht.info("Custom Functions completed buildServer."),r}function mY(){if(Vo)return Vo.then?Vo.then(e=>e.ready()):Vo.ready()}var $I,sY,iY,oY,aY,cY,lY,ht,dme,uY,dY,fY,_Y,pY,Vo,nY,EY=be(()=>{$I=require("path"),sY=require("fs"),iY=M(require("fastify")),oY=M(require("@fastify/cors")),aY=M(TO()),cY=M(require("@fastify/autoload")),lY=M(ae());H();ht=M(z()),dme=M(zK()),uY=M(An()),dY=M(QK()),fY=M(ZK()),_Y=M(rY()),pY=M(pT());uo();Vr();nY=new Set;a(fme,"start");a(_me,"customFunctionsServer");a(pme,"setUp");a(hme,"buildRouteFolder");a(hY,"buildServer");a(mY,"ready")});var KI={};ve(KI,{start:()=>mme});function mme(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(mme,"start")});var YI={};ve(YI,{start:()=>Eme});function Eme({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(Eme,"start")});var wY={};ve(wY,{Request:()=>WI,createReuseportFd:()=>ET});var NY,WI,zI,jI,ET,QI=be(()=>{NY=require("os"),WI=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 jI(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 zI(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)}},zI=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)}},jI=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 XI=w((Qve,IY)=>{"use strict";var uh=ae();uh.initSync();var qd=require("fs-extra"),JI=require("path"),$d=(H(),C(q)),gme=require("crypto"),Sme=require("uuid").v4;IY.exports=Tme;function Tme(){if(uh.getHdbBasePath()!==void 0){let e=JI.join(uh.getHdbBasePath(),$d.LICENSE_KEY_DIR_NAME,$d.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=JI.join(uh.getHdbBasePath(),$d.LICENSE_KEY_DIR_NAME,$d.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=JI.join(uh.getHdbBasePath(),$d.LICENSE_KEY_DIR_NAME,$d.JWT_ENUM.JWT_PASSPHRASE_NAME);try{qd.accessSync(r),qd.accessSync(e),qd.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=Sme(),i=gme.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});qd.writeFileSync(r,s),qd.writeFileSync(e,i.privateKey),qd.writeFileSync(t,i.publicKey)}else throw n}}}a(Tme,"checkJWTTokenExist")});var PY=w((Xve,CY)=>{"use strict";var ZI=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:ZI}});var MY=w((eUe,LY)=>{"use strict";var DY=(H(),C(q)),eC=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:eC}});var gT=w((rUe,UY)=>{"use strict";var xs=require("prompt"),Vd=require("chalk"),vY=z(),Ei=require("os"),tC=da(),rC=["yes","y"];async function Ame(e){let t=`${Ei.EOL}`+Vd.bold.green("Your current HarperDB version requires that we complete an update process.")+`${Ei.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${Ei.EOL}${Ei.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${Ei.EOL}`;xs.override=tC(["CONFIRM_UPGRADE"]),xs.start(),xs.message=t;let r={properties:{CONFIRM_UPGRADE:{description:Vd.magenta(`${Ei.EOL}[CONFIRM_UPGRADE] Do you want to upgrade your HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n;try{n=await xs.get([r])}catch(s){return vY.error("There was an error when prompting user about an upgrade."),vY.error(s),!1}return rC.includes(n.CONFIRM_UPGRADE)}a(Ame,"forceUpdatePrompt");async function Rme(e){let t=`${Ei.EOL}`+Vd.bold.green(`Your installed HarperDB version is older than the version used to create your data. Downgrading is not recommended as it is not tested and guaranteed to work. However, if you need to downgrade, and a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${Ei.EOL}`);xs.override=tC(["CONFIRM_DOWNGRADE"]),xs.start(),xs.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:Vd.magenta(`${Ei.EOL}[CONFIRM_DOWNGRADE] Do you want to proceed with using your downgraded HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n=await xs.get([r]);return rC.includes(n.CONFIRM_DOWNGRADE)}a(Rme,"forceDowngradePrompt");async function yme(){let e=`${Ei.EOL}`+Vd.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");xs.override=tC(["GENERATE_CERTS"]),xs.start(),xs.message=e;let t={properties:{GENERATE_CERTS:{description:Vd.magenta(`${Ei.EOL}[GENERATE_CERTS] Do you want HarperDB to generate all new certificates? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"yes",required:!0}}},r=await xs.get([t]);return rC.includes(r.GENERATE_CERTS)}a(yme,"upgradeCertsPrompt");UY.exports={forceUpdatePrompt:Ame,forceDowngradePrompt:Rme,upgradeCertsPrompt:yme}});var sC=w((sUe,xY)=>{"use strict";var nC=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};xY.exports=nC});var HY=w((uUe,BY)=>{"use strict";var bme=se(),Ome=yt(),oUe=z(),aUe=require("path"),cUe=require("fs"),lUe=(H(),C(q));BY.exports={getOldPropsValue:Nme};function Nme(e,t,r=!1){let n=t.getRaw(e);return bme.isNotEmptyAndHasValue(n)?n:r?Ome.getDefaultConfig(e):""}a(Nme,"getOldPropsValue")});var qY=w((fUe,GY)=>{"use strict";var Za=require("path"),ec=require("fs-extra"),wme=require("properties-reader"),Ime=sC(),_r=z(),{getOldPropsValue:mt}=HY(),{HDB_SETTINGS_NAMES:ge,CONFIG_PARAMS:Hl}=(H(),C(q)),kl=yt(),ST=ae(),kY=se(),ji=(H(),C(q)),iC=new Ime("3.1.0"),FY=[];function Cme(){let e=wme(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.
42
42
 
43
43
  ;The directory selected during install where the database files reside.
44
- ${Ee.HDB_ROOT_KEY} = ${pt(Ee.HDB_ROOT_KEY,e)}
44
+ ${ge.HDB_ROOT_KEY} = ${mt(ge.HDB_ROOT_KEY,e)}
45
45
  ;The port the HarperDB REST interface will listen on.
46
- ${Ee.SERVER_PORT_KEY} = ${pt(Ee.SERVER_PORT_KEY,e)}
46
+ ${ge.SERVER_PORT_KEY} = ${mt(ge.SERVER_PORT_KEY,e)}
47
47
  ;Set to true to enable HTTPS on the HarperDB REST endpoint. Requires a valid certificate and key.
48
- ${Ee.HTTP_SECURE_ENABLED_KEY} = ${pt(Ee.HTTP_SECURE_ENABLED_KEY,e)}
48
+ ${ge.HTTP_SECURE_ENABLED_KEY} = ${mt(ge.HTTP_SECURE_ENABLED_KEY,e)}
49
49
  ;The path to the SSL certificate used when running with HTTPS enabled.
50
- ${Ee.CERT_KEY} = ${pt(Ee.CERT_KEY,e)}
50
+ ${ge.CERT_KEY} = ${mt(ge.CERT_KEY,e)}
51
51
  ;The path to the SSL private key used when running with HTTPS enabled.
52
- ${Ee.PRIVATE_KEY_KEY} = ${pt(Ee.PRIVATE_KEY_KEY,e)}
52
+ ${ge.PRIVATE_KEY_KEY} = ${mt(ge.PRIVATE_KEY_KEY,e)}
53
53
  ;Set to true to enable Cross Origin Resource Sharing, which allows requests across a domain.
54
- ${Ee.CORS_ENABLED_KEY} = ${pt(Ee.CORS_ENABLED_KEY,e)}
54
+ ${ge.CORS_ENABLED_KEY} = ${mt(ge.CORS_ENABLED_KEY,e)}
55
55
  ;Allows for setting allowable domains with CORS. Comma separated list.
56
- ${Ee.CORS_WHITELIST_KEY} = ${pt(Ee.CORS_WHITELIST_KEY,e)}
56
+ ${ge.CORS_WHITELIST_KEY} = ${mt(ge.CORS_WHITELIST_KEY,e)}
57
57
  ;Length of time in milliseconds after which a request will timeout. Defaults to 120,000 ms (2 minutes).
58
- ${Ee.SERVER_TIMEOUT_KEY} = ${pt(Ee.SERVER_TIMEOUT_KEY,e,!0)}
58
+ ${ge.SERVER_TIMEOUT_KEY} = ${mt(ge.SERVER_TIMEOUT_KEY,e,!0)}
59
59
  ;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
- ${Ee.SERVER_KEEP_ALIVE_TIMEOUT_KEY} = ${pt(Ee.SERVER_KEEP_ALIVE_TIMEOUT_KEY,e,!0)}
60
+ ${ge.SERVER_KEEP_ALIVE_TIMEOUT_KEY} = ${mt(ge.SERVER_KEEP_ALIVE_TIMEOUT_KEY,e,!0)}
61
61
  ;Limit the amount of time the parser will wait to receive the complete HTTP headers.. Defaults to 60,000 ms (1 minute).
62
- ${Ee.SERVER_HEADERS_TIMEOUT_KEY} = ${pt(Ee.SERVER_HEADERS_TIMEOUT_KEY,e,!0)}
62
+ ${ge.SERVER_HEADERS_TIMEOUT_KEY} = ${mt(ge.SERVER_HEADERS_TIMEOUT_KEY,e,!0)}
63
63
  ;Define whether to log to file or not.
64
- ${Ee.LOG_TO_FILE} = ${Fl.getDefaultConfig(kl.LOGGING_FILE)}
64
+ ${ge.LOG_TO_FILE} = ${kl.getDefaultConfig(Hl.LOGGING_FILE)}
65
65
  ;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
- ${Ee.LOG_TO_STDSTREAMS} = ${Fl.getDefaultConfig(kl.LOGGING_STDSTREAMS)}
66
+ ${ge.LOG_TO_STDSTREAMS} = ${kl.getDefaultConfig(Hl.LOGGING_STDSTREAMS)}
67
67
  ;Set to control amount of logging generated. Accepted levels are trace, debug, warn, error, fatal.
68
- ${Ee.LOG_LEVEL_KEY} = ${pt(Ee.LOG_LEVEL_KEY,e)}
68
+ ${ge.LOG_LEVEL_KEY} = ${mt(ge.LOG_LEVEL_KEY,e)}
69
69
  ;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
- ${Ee.LOG_PATH_KEY} = ${pt(Ee.LOG_PATH_KEY,e)}
70
+ ${ge.LOG_PATH_KEY} = ${mt(ge.LOG_PATH_KEY,e)}
71
71
  ;Set to true to enable daily log file rotations - each log file name will be prepended with YYYY-MM-DD.
72
- ${Ee.LOG_DAILY_ROTATE_KEY} = ${pt(Ee.LOG_DAILY_ROTATE_KEY,e)}
72
+ ${ge.LOG_DAILY_ROTATE_KEY} = ${mt(ge.LOG_DAILY_ROTATE_KEY,e)}
73
73
  ;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
74
  ;daily log files which may consume a large amount of storage depending on your log settings.
75
- ${Ee.LOG_MAX_DAILY_FILES_KEY} = ${pt(Ee.LOG_MAX_DAILY_FILES_KEY,e)}
75
+ ${ge.LOG_MAX_DAILY_FILES_KEY} = ${mt(ge.LOG_MAX_DAILY_FILES_KEY,e)}
76
76
  ;The environment used by NodeJS. Setting to production will be the most performant, settings to development will generate more logging.
77
- ${Ee.PROPS_ENV_KEY} = ${pt(Ee.PROPS_ENV_KEY,e)}
77
+ ${ge.PROPS_ENV_KEY} = ${mt(ge.PROPS_ENV_KEY,e)}
78
78
  ;This allows self signed certificates to be used in clustering. This is a security risk
79
79
  ;as clustering will not validate the cert, so should only be used internally.
80
80
  ;The HDB install creates a self signed certificate, if you use that cert this must be set to true.
81
- ${Ee.ALLOW_SELF_SIGNED_SSL_CERTS} = ${pt(Ee.ALLOW_SELF_SIGNED_SSL_CERTS,e,!0)}
81
+ ${ge.ALLOW_SELF_SIGNED_SSL_CERTS} = ${mt(ge.ALLOW_SELF_SIGNED_SSL_CERTS,e,!0)}
82
82
  ;Set the max number of processes HarperDB will start. This can also be limited by number of cores and licenses.
83
- ${Ee.MAX_HDB_PROCESSES} = ${pt(Ee.MAX_HDB_PROCESSES,e)}
83
+ ${ge.MAX_HDB_PROCESSES} = ${mt(ge.MAX_HDB_PROCESSES,e)}
84
84
  ;Set to true to enable clustering. Requires a valid enterprise license.
85
- ${Ee.CLUSTERING_ENABLED_KEY} = ${pt(Ee.CLUSTERING_ENABLED_KEY,e,!0)}
85
+ ${ge.CLUSTERING_ENABLED_KEY} = ${mt(ge.CLUSTERING_ENABLED_KEY,e,!0)}
86
86
  ;The port that will be used for HarperDB clustering.
87
- ${Ee.CLUSTERING_PORT_KEY} = ${pt(Ee.CLUSTERING_PORT_KEY,e)}
87
+ ${ge.CLUSTERING_PORT_KEY} = ${mt(ge.CLUSTERING_PORT_KEY,e)}
88
88
  ;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
- ${Ee.CLUSTERING_NODE_NAME_KEY} = ${pt(Ee.CLUSTERING_NODE_NAME_KEY,e)}
89
+ ${ge.CLUSTERING_NODE_NAME_KEY} = ${mt(ge.CLUSTERING_NODE_NAME_KEY,e)}
90
90
  ;The user used to connect to other instances of HarperDB, this user must have a role of cluster_user.
91
- ${Ee.CLUSTERING_USER_KEY} = ${pt(Ee.CLUSTERING_USER_KEY,e)}
91
+ ${ge.CLUSTERING_USER_KEY} = ${mt(ge.CLUSTERING_USER_KEY,e)}
92
92
  ;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
- ${Ee.DISABLE_TRANSACTION_LOG_KEY} = ${pt(Ee.DISABLE_TRANSACTION_LOG_KEY,e,!0)}
93
+ ${ge.DISABLE_TRANSACTION_LOG_KEY} = ${mt(ge.DISABLE_TRANSACTION_LOG_KEY,e,!0)}
94
94
  ;Defines the length of time an operation token will be valid until it expires. Example values: https://github.com/vercel/ms
95
- ${Ee.OPERATION_TOKEN_TIMEOUT_KEY} = ${pt(Ee.OPERATION_TOKEN_TIMEOUT_KEY,e,!0)}
95
+ ${ge.OPERATION_TOKEN_TIMEOUT_KEY} = ${mt(ge.OPERATION_TOKEN_TIMEOUT_KEY,e,!0)}
96
96
  ;Defines the length of time a refresh token will be valid until it expires. Example values: https://github.com/vercel/ms
97
- ${Ee.REFRESH_TOKEN_TIMEOUT_KEY} = ${pt(Ee.REFRESH_TOKEN_TIMEOUT_KEY,e,!0)}
97
+ ${ge.REFRESH_TOKEN_TIMEOUT_KEY} = ${mt(ge.REFRESH_TOKEN_TIMEOUT_KEY,e,!0)}
98
98
  ;The port the IPC server will run on.
99
- ${Ee.IPC_SERVER_PORT} = ${Fl.getDefaultConfig(kl.IPC_NETWORK_PORT)}
99
+ ${ge.IPC_SERVER_PORT} = ${kl.getDefaultConfig(Hl.IPC_NETWORK_PORT)}
100
100
  ;Run HDB in the foreground.
101
- ${Ee.RUN_IN_FOREGROUND} = ${Fl.getDefaultConfig(kl.OPERATIONSAPI_FOREGROUND)}
101
+ ${ge.RUN_IN_FOREGROUND} = ${kl.getDefaultConfig(Hl.OPERATIONSAPI_FOREGROUND)}
102
102
  ;Set to true to enable custom API endpoints. Requires a valid enterprise license.
103
- ${Ee.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${Fl.getDefaultConfig(kl.CUSTOMFUNCTIONS_ENABLED)}
103
+ ${ge.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${kl.getDefaultConfig(Hl.CUSTOMFUNCTIONS_ENABLED)}
104
104
  ;The port used to access the custom functions server.
105
- ${Ee.CUSTOM_FUNCTIONS_PORT_KEY} = ${Fl.getDefaultConfig(kl.HTTP_PORT)}
105
+ ${ge.CUSTOM_FUNCTIONS_PORT_KEY} = ${kl.getDefaultConfig(Hl.HTTP_PORT)}
106
106
  ;The path to the folder containing HarperDB custom function files.
107
- ${Ee.CUSTOM_FUNCTIONS_DIRECTORY_KEY} = ${Za.join(pt(Ee.HDB_ROOT_KEY,e),"custom_functions")}
107
+ ${ge.CUSTOM_FUNCTIONS_DIRECTORY_KEY} = ${Za.join(mt(ge.HDB_ROOT_KEY,e),"custom_functions")}
108
108
  ;Set the max number of processes HarperDB will start for the Custom Functions server
109
- ${Ee.MAX_CUSTOM_FUNCTION_PROCESSES} = ${Fl.getDefaultConfig(kl.HTTP_THREADS)}
110
- `,n=ST.get("settings_path"),s=Za.dirname(n),i=Za.join(s,"3_1_0_upgrade_settings.bak");try{dr.info(`Backing up old settings file to: ${i}`),ec.copySync(n,i)}catch(c){throw dr.error(c),console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),c}try{dr.info("New settings file values for 3.1.0 upgrade:",r),dr.info(`Creating new/upgraded settings file at '${n}'`),ec.writeFileSync(n,r),dr.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."),dr.error("Attempting to reset the settings file to its original state. Use the '.bak' file if this fails."),dr.error(c),ec.copySync(i,n),c}ST.initSync();let o="New settings file for 3.1.0 upgrade successfully created.";return console.log(o),dr.info(o),o}a(Ime,"updateSettingsFile_3_1_0");function Cme(){let e=Za.join(BY.getHomeDir(),Qi.HDB_HOME_DIR_NAME,Qi.LICENSE_KEY_DIR_NAME,Qi.LICENSE_FILE_NAME),t=Za.join(BY.getHomeDir(),Qi.HDB_HOME_DIR_NAME,Qi.LICENSE_KEY_DIR_NAME,Qi.REG_KEY_FILE_NAME),r=Za.join(ST.getHdbBasePath(),Qi.LICENSE_KEY_DIR_NAME,Qi.LICENSE_FILE_NAME),n=Za.join(r,Qi.LICENSE_FILE_NAME),s=Za.join(r,Qi.REG_KEY_FILE_NAME),i="Move license files for version 3.1.0";console.log(i),dr.info(i);let o="Creating .license directory";console.log(o),dr.info(o),ec.mkdirpSync(r);try{ec.accessSync(e);try{let c="Moving licence file";console.log(c),dr.info(c),ec.moveSync(e,n);let l="License file successfully moved.";console.log(l),dr.info(l)}catch{let l="moving license file failed";console.error(l),dr.error(l)}}catch{let l=`license file '${e}' does not exist.`;console.warn(l),dr.warn(l)}try{ec.accessSync(t);try{let c="Moving registration file";console.log(c),dr.info(c),ec.moveSync(t,s);let l="Registration file successfully moved.";console.log(l),dr.info(l)}catch{let l="moving registration file failed";console.error(l),dr.error(l)}}catch{let l=`registration file '${t}' does not exist.`;console.warn(l),dr.warn(l)}}a(Cme,"moveLicenseFiles");sC.sync_functions.push(Ime);sC.sync_functions.push(Cme);HY.push(sC);kY.exports=HY});var KY=I((_Ue,VY)=>{"use strict";var ls=dt(),{insertRecords:Pme}=kc(),Dme=pn(),tc=vt(),Lme=oe(),Ko=Y(),Mme=oe(),Ji=require("fs-extra"),Yo=require("path"),vme=require("cli-progress"),dh=require("assert"),Ume=require("pino"),xme=ce();VY.exports=Bme;var TT,GY,AT,iC,on,fh=!1;async function Bme(e=!0){return TT=xme.getHdbBasePath(),GY=Yo.join(TT,"schema"),AT=Yo.join(TT,"4_0_0_upgrade_tmp"),iC=Yo.join(TT,"transactions"),console.info("Reindexing upgrade started for schemas"),Ko.notify("Reindexing upgrade started for schemas"),await qY(GY,!1,e),await Ji.pathExists(iC)&&(console.info(`
109
+ ${ge.MAX_CUSTOM_FUNCTION_PROCESSES} = ${kl.getDefaultConfig(Hl.HTTP_THREADS)}
110
+ `,n=ST.get("settings_path"),s=Za.dirname(n),i=Za.join(s,"3_1_0_upgrade_settings.bak");try{_r.info(`Backing up old settings file to: ${i}`),ec.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}'`),ec.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),ec.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(Cme,"updateSettingsFile_3_1_0");function Pme(){let e=Za.join(kY.getHomeDir(),ji.HDB_HOME_DIR_NAME,ji.LICENSE_KEY_DIR_NAME,ji.LICENSE_FILE_NAME),t=Za.join(kY.getHomeDir(),ji.HDB_HOME_DIR_NAME,ji.LICENSE_KEY_DIR_NAME,ji.REG_KEY_FILE_NAME),r=Za.join(ST.getHdbBasePath(),ji.LICENSE_KEY_DIR_NAME,ji.LICENSE_FILE_NAME),n=Za.join(r,ji.LICENSE_FILE_NAME),s=Za.join(r,ji.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),ec.mkdirpSync(r);try{ec.accessSync(e);try{let c="Moving licence file";console.log(c),_r.info(c),ec.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{ec.accessSync(t);try{let c="Moving registration file";console.log(c),_r.info(c),ec.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(Pme,"moveLicenseFiles");iC.sync_functions.push(Cme);iC.sync_functions.push(Pme);FY.push(iC);GY.exports=FY});var WY=w((pUe,YY)=>{"use strict";var cs=_t(),{insertRecords:Dme}=kc(),Lme=_n(),tc=vt(),Mme=se(),Ko=z(),vme=se(),Qi=require("fs-extra"),Yo=require("path"),Ume=require("cli-progress"),dh=require("assert"),xme=require("pino"),Bme=ae();YY.exports=Hme;var TT,$Y,AT,oC,sn,fh=!1;async function Hme(e=!0){return TT=Bme.getHdbBasePath(),$Y=Yo.join(TT,"schema"),AT=Yo.join(TT,"4_0_0_upgrade_tmp"),oC=Yo.join(TT,"transactions"),console.info("Reindexing upgrade started for schemas"),Ko.notify("Reindexing upgrade started for schemas"),await VY($Y,!1,e),await Qi.pathExists(oC)&&(console.info(`
111
111
 
112
- Reindexing upgrade started for transaction logs`),Ko.notify("Reindexing upgrade started for transaction logs"),await qY(iC,!0,e)),Ko.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(fh?", but errors occurred":"")}a(Bme,"reindexUpgrade");async function qY(e,t,r){let n=await Ji.readdir(e),s=n.length;for(let i=0;i<s;i++){let o=n[i],c=Yo.join(e,o.toString());if(o===".DS_Store")continue;let l=await Ji.readdir(c),u=l.length;for(let f=0;f<u;f++){let d=l[f];if(d!==".DS_Store"&&Ji.statSync(Yo.join(c,d)).isDirectory())try{await Hme(o,d,t),on.info(`Reindexing started for ${o}.${d}`),Ko.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${d}`),await Fme(o,d,c,t,r),on.info(`Reindexing completed for ${o}.${d}`),Ko.notify(`Reindexing completed for ${o}.${d}`)}catch(p){fh=!0,p.schema_path=c,p.table_name=d,Ko.error("There was an error with the reindex upgrade, check the logs in hdb/3_0_0_upgrade_tmp for more details"),Ko.error(p),on.error(p),console.error(p)}}}if(!fh)try{await Ji.rm(AT,{recursive:!0})}catch{}}a(qY,"processTables");async function Hme(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=Yo.join(AT,s);await Ji.ensureDir(AT),await Ji.writeFile(i,""),on=Ume({level:"debug",formatters:{bindings(){}}},i)}a(Hme,"initPinoLogger");var kme=20;async function Fme(e,t,r,n,s){let i;try{i=await ls.openEnvironment(r,t,n)}catch(E){if(E.message==="MDB_INVALID: File is not an LMDB file"){Ko.notify(`${e}.${t} file is not from the old environment and has been skipped`),console.info(`${e}.${t} file is not from the old environment and has been skipped`),on.error(E);return}throw E}let o=$me(i.dbis),c=ls.openDBI(i,o),l=Object.keys(i.dbis),u=ls.statDBI(i,o);on.info(`Old environment stats: ${JSON.stringify(u)}`);let f=new vme.SingleBar({format:`${e}.${t} |{bar}| {percentage}% || {value}/{total} records`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:!0,clearOnComplete:!1});f.start(u.entryCount,0,{});let d=await ls.createEnvironment(r,t,!1);ls.createDBI(d,o,!1,!0);let p=[];try{for(let E of c.getRange({start:!1}))E.value={...E.value},p.push(E),n||e==="system"&&(t==="hdb_schema"&&(E.key=E.key.toString(),E.value.name=E.value.name.toString()),t==="hdb_table"&&(E.key=E.key.toString(),E.value.schema=E.value.schema.toString(),E.value.name=E.value.name.toString()),t==="hdb_attribute"&&(E.key=E.key.toString(),E.value.schema=E.value.schema.toString(),E.value.table=E.value.table.toString(),E.value.attribute=E.value.attribute.toString())),p.length>kme&&await _();await _()}catch(E){throw fh=!0,on.error(E),E}async function _(){let E,R=p.map(({value:v})=>v);n?E=await Promise.all(R.map(v=>Gme(d,v))):E=await Pme(d,o,l.filter(v=>v!=="__blob__"),R,!1);for(let v=0,k=p.length;v<k;v++){let{key:F,value:K}=p[v];on.info(`Record hash value: ${F} hash: ${o}`);let re;n?re=E[v]:re=E.written_hashes.indexOf(F)>-1,dh(re,!0),qme(d,o,K[o],n),on.info(`Insert success, written hashes: ${E.written_hashes}`),f.increment()}p=[],f.value/f.total*100%10===0&&Ko.notify(`${e}.${t} ${f.value}/${f.total} records inserted`),on.info(`${f.value}/${f.total} records inserted`)}a(_,"finishOutstanding"),f.stop();let h=ls.statDBI(i,o),S=ls.statDBI(d,o);if(on.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${S.entryCount}`),dh.deepStrictEqual(h.entryCount,S.entryCount),await ls.closeEnvironment(i),await ls.closeEnvironment(d),delete global.lmdb_map[`${e}.${t}`],s){let E=Yo.join(r,t),R=Yo.join(E,"data.mdb"),N=Yo.join(E,"lock.mdb");await Ji.unlink(R),await Ji.unlink(N),await Ji.rmdir(E),on.info(`Deleted old environment files from schema folder: ${R}, ${N}`)}let g=await ls.openEnvironment(r,t),A=ls.statDBI(g,o);on.info(`New stats: ${JSON.stringify(S)}. New stats after move: ${JSON.stringify(A)}`),dh.deepStrictEqual(A.entryCount,S.entryCount),await ls.closeEnvironment(g),delete global.lmdb_map[`${e}.${t}`]}a(Fme,"processTable");async function Gme(e,t){ls.initializeDBIs(e,tc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,tc.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[tc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[tc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),Mme.isEmpty(t.user_name)||e.dbis[tc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[tc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a(Gme,"insertTransaction");function qme(e,t,r,n){let i=e.dbis[t].get(r);dh.deepStrictEqual(typeof i,"object");let o;if(n){let c={[tc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[tc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE]:i.hash_values};o=Object.entries(c)}else o=Object.entries(i);for(let[c,l]of o)if(c!==t&&e.dbis[c]!==void 0&&!Lme.isEmptyOrZeroLength(l))if(n&&c==="hash_value")for(let u=0,f=l.length;u<f;u++){let d=l[u];$Y(e,c,d,r)}else $Y(e,c,l,r)}a(qme,"validateIndices");function $Y(e,t,r,n){try{let s=!1,i=Dme.getIndexedValues(r);if(!i)return;for(let o of i)s=e.dbis[t].doesExist(o,n),s||on.info(`Validate indices did not find value in new DBI: ${o}. Hash: ${n}`),dh.deepStrictEqual(s,!0)}catch(s){fh=!0,on.error(s),console.error(s)}}a($Y,"validateIndex");function $me(e){let t;for(let[r,n]of Object.entries(e))if(n.__dbi_defintion__.is_hash_attribute===!0){t=r;break}return t}a($me,"getHashDBI")});var QY=I((mUe,jY)=>{"use strict";var RT=require("path"),rc=require("fs-extra"),Vme=nC(),Gl=Y(),YY=Rt(),oC=ce(),Si=(B(),C(G)),yT=oe(),Kme=require("properties-reader"),Yme=ii(),Wme=ng(),zme=Wr(),hUe=require("util"),jme=zme.searchByValue,Qme=yn(),Jme=uS(),Xme=St(),Zme=KY(),WY=rs(),eEe=gT(),hh=new Vme("4.0.0"),zY=[],_h,ph;async function tEe(){try{if(await eEe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),_h){let t=yT.changeExtension(_h,".bak");await rc.move(_h,t)}if(ph){let t=yT.changeExtension(ph,".bak");await rc.move(ph,t)}await WY.generateKeys()}else console.log("Using existing certificates."),WY.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(tEe,"generateNewKeys");async function rEe(){console.log("Updating HarperDB nodes."),Gl.info("Updating HarperDB nodes.");let e=[];try{let t=new Yme(Si.SYSTEM_SCHEMA_NAME,Si.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await jme(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!Xme.NATS_TERM_CONSTRAINTS_RX.test(c.name)){let f=`Node name '${c.name}' is invalid, must not contain ., * or >. Please change name and try again.`;throw console.error(f),f}let l={host:c.host,port:c.port};e.push(l);let u=[];for(let f=0,d=c.subscriptions.length;f<d;f++){let p=c.subscriptions[f],_=p.channel.split(":");u.push({schema:_[0],table:_[1],publish:p.publish,subscribe:p.subscribe})}n.push({name:c.name,subscriptions:u,system_info:{hdb_version:Si.PRE_4_0_0_VERSION,node_version:void 0,platform:void 0}})}if(yT.isEmptyOrZeroLength(n))return;let s=new Wme(Si.SYSTEM_SCHEMA_NAME,Si.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await Qme.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(rEe,"updateNodes");async function nEe(){let e=oC.get(Si.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(RT.join("config","settings.js"))){Gl.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),Gl.info(t);let r=RT.dirname(e),n=oC.get(Si.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),s=RT.join(n,"backup","4_0_0_upgrade_settings.bak"),i=RT.join(n,Si.HDB_CONFIG_FILE);try{Gl.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),rc.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{Gl.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),Gl.info("Updating env variables with new settings values");let d=YY.initOldConfig(e);_h=d[Si.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],ph=d[Si.CONFIG_PARAMS.TLS_PRIVATEKEY.toLowerCase()],YY.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();rc.accessSync(o,rc.constants.F_OK|rc.constants.R_OK);let l=Kme(o).get(Si.HDB_SETTINGS_NAMES.INSTALL_USER),u=`settings_path = ${i}
113
- install_user = ${l}`;try{rc.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{oC.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{rc.removeSync(r),console.log(f),Gl.info(f)}catch(d){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),d}}a(nEe,"updateSettingsFile_4_0_0");hh.async_functions.push(nEe);hh.async_functions.push(tEe);hh.async_functions.push(Zme);hh.async_functions.push(rEe);zY.push(hh);jY.exports=zY});var aC=I((gUe,eW)=>{"use strict";var ql=oe(),sEe=(B(),C(G)),JY=Y(),{DATA_VERSION:iEe,UPGRADE_VERSION:oEe}=sEe.UPGRADE_JSON_FIELD_NAMES_ENUM,XY=FY(),bT=QY(),$l=new Map;XY&&XY.forEach(e=>{$l.set(e.version,e)});bT&&bT.forEach(e=>{$l.set(e.version,e)});bT&&bT.forEach(e=>{$l.set(e.version,e)});function aEe(){return[...$l.keys()].sort(ql.compareVersions)}a(aEe,"getSortedVersions");function ZY(e){let t=e[iEe],r=e[oEe];return ql.isEmptyOrZeroLength(t)||ql.isEmptyOrZeroLength(r)?(JY.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),JY.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."),[]):[...$l.keys()].sort(ql.compareVersions).filter(function(n){return ql.compareVersions(n,t)>0&&ql.compareVersions(n,r)<=0})}a(ZY,"getVersionsForUpgrade");function cEe(e){return ZY(e).length>0}a(cEe,"hasUpgradesRequired");function lEe(e){return ql.isEmptyOrZeroLength(e)?null:$l.has(e)?$l.get(e):null}a(lEe,"getDirectiveByVersion");eW.exports={getSortedVersions:aEe,getDirectiveByVersion:lEe,getVersionsForUpgrade:ZY,hasUpgradesRequired:cEe}});var mh=I((TUe,iW)=>{"use strict";var uEe=require("util"),cC=require("chalk"),dEe=require("os"),rW=yn(),fEe=Wr(),us=(B(),C(G)),nW=IY(),uC=Ly(),{UpgradeObject:tW}=DY(),{forceDowngradePrompt:_Ee}=gT(),{packageJson:pEe}=nt(),OT=Y(),Kd=oe(),dC=bs(),hEe=(Pe(),C(rt)),mEe=aC(),EEe=uEe.promisify(dC.setSchemaDataToGlobal),gEe=fEe.searchByValue,SEe="info_id",TEe="2.9.9",AEe="3.0.0";async function REe(e){let t=new nW.HdbInfoInsertObject(1,e,e),r=new uC.InsertObject(us.OPERATIONS_ENUM.INSERT,us.SYSTEM_SCHEMA_NAME,us.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,us.INFO_TABLE_HASH_ATTRIBUTE,[t]);return dC.setSchemaDataToGlobal(),rW.insert(r)}a(REe,"insertHdbInstallInfo");async function lC(e){let t,r=await sW(),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 nW.HdbInfoInsertObject(i,e,e);let o=new uC.InsertObject(us.OPERATIONS_ENUM.INSERT,us.SYSTEM_SCHEMA_NAME,us.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,us.INFO_TABLE_HASH_ATTRIBUTE,[t]);return await EEe(),rW.insert(o)}a(lC,"insertHdbUpgradeInfo");async function sW(){let e=new uC.NoSQLSeachObject(us.SYSTEM_SCHEMA_NAME,us.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,SEe,us.INFO_TABLE_HASH_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await gEe(e))}catch(r){console.error(r)}return t}a(sW,"getAllHdbInfoRecords");async function yEe(){let e=await sW();if(e.length===0)return;let t,r=new Map;for(let s of e)r.set(s.info_id,s);let n=Math.max.apply(null,[...r.keys()]);return t=r.get(n),t}a(yEe,"getLatestHdbInfoRecord");async function bEe(){OT.info("Checking if HDB software has been updated");try{let e=pEe.version;if(!e)throw new Error("Could not find the version number in the package.json file");let t=await yEe(),r;if(Kd.isEmpty(t))r=TEe;else if(r=t.data_version_num,Kd.compareVersions(r.toString(),e.toString())>0){if(!Kd.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(cC.yellow(`This instance's data was last run on version ${r}`)),console.error(cC.red(`You have installed a version lower than the version that your data was created on or was upgraded to. This may cause issues and is currently not supported.${dEe.EOL}${us.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");Kd.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(cC.yellow(`This instance's data was last run on version ${r}`)),await _Ee(new tW(r,e))?await lC(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(dC.setSchemaDataToGlobal(),OEe(r),e.toString()===r.toString())return;let n=new tW(r,e);if(mEe.hasUpgradesRequired(n))return n;Kd.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await lC(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(bEe,"getVersionUpdateInfo");function OEe(e){let t=`You are attempting to upgrade from an old instance of HarperDB that is no longer supported. In order to upgrade to this version, you must do a fresh install. If you need support, please contact ${us.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in hEe.databases.system))throw console.log(t),new Error(t);if(!Kd.isEmpty(e)&&e<AEe)throw console.log(t),new Error(t)}a(OEe,"checkIfInstallIsSupported");iW.exports={insertHdbInstallInfo:REe,insertHdbUpgradeInfo:lC,getVersionUpdateInfo:bEe}});var lW=I((RUe,cW)=>{"use strict";var NT=require("joi"),{boolean:NEe,string:fC,number:wEe}=NT.types(),oW=require("fs-extra"),Eh=(B(),C(G)),aW=require("path"),IEe=ut();cW.exports=CEe;function CEe(e){let t=fC.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=NT.object({[Eh.INSTALL_PROMPTS.ROOTPATH]:NT.custom(PEe),[Eh.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:NT.alternatives([wEe.min(0),fC]).allow("null",null),[Eh.INSTALL_PROMPTS.TC_AGREEMENT]:fC.valid("yes","YES","Yes"),[Eh.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[Eh.INSTALL_PROMPTS.CLUSTERING_ENABLED]:NEe});return IEe.validateBySchema(e,r)}a(CEe,"installValidator");function PEe(e,t){if(oW.existsSync(aW.join(e,"system/hdb_user/data.mdb"))||oW.existsSync(aW.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(PEe,"validateRootAvailable")});var hC=I((bUe,uW)=>{"use strict";var{mkdirpSync:DEe,copySync:LEe}=require("fs-extra"),nc=require("path"),gh=(B(),C(G)),{PACKAGE_ROOT:MEe}=nt(),pC=Y(),vEe=Wn(),_C=Eo(),UEe=Et();uW.exports=xEe;async function xEe(e){pC.trace("Mounting HarperDB"),Vl(e),Vl(nc.join(e,"backup")),Vl(nc.join(e,"keys")),Vl(nc.join(e,"keys",gh.LICENSE_FILE_NAME)),Vl(nc.join(e,"log")),Vl(nc.join(e,"database")),Vl(nc.join(e,"components")),LEe(nc.resolve(MEe,"./utility/install/README.md"),nc.join(e,"README.md")),await BEe()}a(xEe,"mountHdb");async function BEe(){let e=x_(),t=Object.keys(_C);for(let r=0;r<t.length;r++){let n=t[r],s=_C[n].hash_attribute;try{UEe.initSystemSchemaPaths(gh.SYSTEM_SCHEMA_NAME,n);let i=new e(gh.SYSTEM_SCHEMA_NAME,n,s);i.attributes=_C[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,["hdb_user","hdb_role"].includes(n)&&(i.audit=!0),await vEe.createTable(n,i)}catch(i){throw pC.error(`issue creating environment for ${gh.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(BEe,"createLMDBTables");function Vl(e){DEe(e,{mode:gh.HDB_FILE_PERMISSIONS}),pC.info(`Directory ${e} created`)}a(Vl,"makeDirectory")});var CT=I((IUe,yW)=>{"use strict";var EC=require("os"),hW=require("inquirer"),ks=require("fs-extra"),HEe=require("properties-reader"),Yl=require("chalk"),Zi=require("path"),kEe=require("human-readable-ids").hri,FEe=require("ora"),GEe=require("yaml"),fr=Y(),sc=ce(),Sh=oe(),IT=da(),mW=mh(),{packageJson:EW}=nt(),_e=(B(),C(G)),{CONFIG_PARAM_MAP:NUe,CONFIG_PARAMS:Ct}=_e,qEe=lW(),$Ee=hC(),gC=Rt(),VEe=Rn(),KEe=q_(),YEe=JI(),WEe=bs(),zEe=require("util").promisify,jEe=zEe(WEe.setSchemaDataToGlobal),dW=rs(),Kl=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),kr=a(e=>Yl.magenta.bold(e),"HDB_PROMPT_MSG"),QEe="https://harperdb.io/legal/end-user-license-agreement",ic=EC.EOL,Wo="",JEe="yes",fW="Starting HarperDB install...",_W="HarperDB installation was successful.",pW="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",XEe="An out of date version of HarperDB is already installed.",mC="It appears that HarperDB is already installed. Exiting install...",ZEe="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])$/),ege=new RegExp(/^[^\s.,*>]+$/),tge=EC.homedir(),rge=Zi.join(tge,_e.HDB_ROOT_DIR_NAME),nge="HDB_ADMIN",sge="CLUSTER_USER",ige="dev",oge="localhost",wT={[Ct.HTTP_CORS]:!0,[Ct.HTTP_CORSACCESSLIST]:["*"],[Ct.HTTP_PORT]:9926,[Ct.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Ct.THREADS_COUNT]:1,[Ct.THREADS_DEBUG]:!0,[Ct.LOGGING_STDSTREAMS]:!0,[Ct.LOGGING_LEVEL]:"info",[Ct.OPERATIONSAPI_NETWORK_PORT]:9925,[Ct.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:"},oc=IT([_e.INSTALL_PROMPTS.HDB_CONFIG]),Xi,gW=!1,SC=!1,SW=!1;yW.exports={install:TW,updateConfigEnv:Ege,setIgnoreExisting:gge};TW.createSuperUser=RW;async function TW(){console.log(kr(ic+fW+ic)),fr.notify(fW);let e;oc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&(e=age());let t=lge();Object.assign(t,e),t[_e.INSTALL_PROMPTS.TC_AGREEMENT]&&t[_e.INSTALL_PROMPTS.ROOTPATH]&&t[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&t[_e.INSTALL_PROMPTS.DEFAULTS_MODE]===void 0&&(SW=!0,t[_e.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=qEe(t);if(r)throw r.message;await uge(),await dge(t);let n=await cge(t);Xi=n[_e.INSTALL_PROMPTS.ROOTPATH],oc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&Zi.dirname(oc[_e.INSTALL_PROMPTS.HDB_CONFIG])===Xi&&(gW=!0),!SC&&!oc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&await ks.pathExists(Zi.join(Xi,_e.HDB_CONFIG_FILE))&&(console.error(mC),process.exit());let s=FEe({prefixText:kr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),Sh.isEmpty(Xi))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");sc.setHdbBasePath(Xi),await $Ee(Xi),await fge(),await _ge(n),fr.initLogSettings(!0),await RW(n),await hge(n),await dW.updateConfigCert(),await dW.generateCertsKeys(),await mge(),YEe(),s.stop(),console.log(kr(ic+_W+ic)),fr.notify(_W)}a(TW,"install");function age(){let e=GEe.parseDocument(ks.readFileSync(oc[_e.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=gC.flattenConfig(e.toJSON());return t[_e.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[_e.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(age,"getConfigFromFile");async function cge(e){fr.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:Kl,when:zo(e[_e.INSTALL_PROMPTS.ROOTPATH],Hr.DESTINATION),name:_e.INSTALL_PROMPTS.ROOTPATH,prefix:Wo,default:rge,validate:a(async s=>Hs(s)?Hs(s):await ks.pathExists(Zi.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:Kl,when:zo(e[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Hr.HDB_USERNAME),name:_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Wo,default:nge,validate:a(s=>Hs(s)?Hs(s):(t=s,!0),"validate"),message:kr(Hr.HDB_USERNAME)},{type:"password",when:zo(e[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Hr.HDB_PASS),name:_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Wo,validate:a(s=>Hs(s)?Hs(s):!0,"validate"),message:kr(Hr.HDB_PASS)},{type:"input",transformer:Kl,when:zo(e[_e.INSTALL_PROMPTS.DEFAULTS_MODE],Hr.DEFAULTS_MODE),name:_e.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Wo,default:ige,validate:a(s=>Hs(s)?Hs(s):s!=="dev"&&s!=="prod"?`Invalid response '${s}', options are 'dev' or 'prod'.`:!0,"validate"),message:kr(Hr.DEFAULTS_MODE)}];if(SW||r.push({type:"input",name:_e.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:Kl,when:zo(e[_e.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Hr.REPLICATION_HOSTNAME),prefix:Wo,default:oge,message:kr(Hr.REPLICATION_HOSTNAME)}),Sh.autoCastBoolean(e[_e.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:Kl,when:zo(e[_e.INSTALL_PROMPTS.CLUSTERING_NODENAME],Hr.NODE_NAME),name:_e.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Wo,default:kEe.random(),validate:a(i=>ege.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:kr(Hr.NODE_NAME)},{type:"input",transformer:Kl,when:zo(e[_e.INSTALL_PROMPTS.CLUSTERING_USER],Hr.CLUSTER_USERNAME),name:_e.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Wo,default:sge,validate:a(i=>Hs(i)?Hs(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,"validate"),message:kr(Hr.CLUSTER_USERNAME)},{type:"password",when:zo(e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Hr.CLUSTER_PASS),name:_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Wo,validate:a(i=>Hs(i)?Hs(i):!0,"validate"),message:kr(Hr.CLUSTER_PASS)}];r.push(...s)}let n=await hW.prompt(r);if(Object.keys(n).length===0)return e;for(let s in n)e[s]===void 0&&(e[s]=n[s]);return e}a(cge,"installPrompts");function zo(e,t){return e!==void 0?(t.includes("password")?(console.log(`${kr(t)} ${Yl.gray("[hidden]")}`),fr.trace(`${kr(t)} [hidden]`)):(console.log(`${kr(t)} ${e}`),fr.trace(`${kr(t)} ${e}`)),!1):!0}a(zo,"displayCmdEnvVar");function Hs(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(Hs,"checkForEmptyValue");function lge(){let e=Object.keys(_e.INSTALL_PROMPTS),t=IT(e),r=IT(Object.keys(_e.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=_e.CONFIG_PARAM_MAP[s.toLowerCase()];t[s]?i===void 0?n[s]=t[s]:n[i.toUpperCase()]=t[s]:i!==void 0&&r[i.toLowerCase()]&&(n[s]=r[i.toLowerCase()])}return n}a(lge,"checkForPromptOverride");async function uge(){fr.trace("Checking for existing install.");let e=Sh.getPropsFilePath(),t=await ks.pathExists(e),r;if(t){fr.trace(`Install found an existing boot prop file at:${e}`);let n=HEe(e),s=gC.getConfigValue(_e.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(_e.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await ks.pathExists(s)}if(!t&&Sh.noBootFile()&&(r=!0),r&&!SC){if(fr.trace(`Install found existing HDB config at:${e}`),await mW.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${EW.version}. Exiting install...`;console.log(ic+Yl.magenta.bold(XEe)),console.log(Yl.magenta.bold(s)),fr.error(s)}else console.log(ic+Yl.magenta.bold(mC)),fr.error(mC);process.exit(0)}}a(uge,"checkForExistingInstall");async function dge(e){fr.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${QEe}${ic}and can be viewed by typing or copying and pasting the URL into your web browser.${ic}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Wo,transformer:Kl,when:zo(e[_e.INSTALL_PROMPTS.TC_AGREEMENT],t),name:_e.INSTALL_PROMPTS.TC_AGREEMENT,message:kr(t),validate:a(s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:Yl.yellow("Please enter 'yes' or 'no'"),"validate")},n=await hW.prompt([r]);n[_e.INSTALL_PROMPTS.TC_AGREEMENT]&&n[_e.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==JEe&&(console.log(Yl.yellow(pW)),fr.error(pW),process.exit(0))}a(dge,"termsAgreement");async function fge(){let e=Zi.join(Xi,_e.HDB_CONFIG_FILE),t;try{t=EC.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=Zi.join(n,_e.HDB_HOME_DIR_NAME),i=Zi.join(s,_e.LICENSE_KEY_DIR_NAME);try{ks.mkdirpSync(s,{mode:_e.HDB_FILE_PERMISSIONS}),ks.mkdirpSync(i,{mode:_e.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${_e.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=Zi.join(s,_e.BOOT_PROPS_FILE_NAME);try{await ks.writeFile(o,r)}catch(c){throw fr.error(`There was an error creating the boot file at path: ${o}`),c}sc.setProperty(_e.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),sc.setProperty(_e.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),sc.setProperty(sc.BOOT_PROPS_FILE_PATH,o)}}a(fge,"createBootPropertiesFile");async function _ge(e){fr.trace("Creating HarperDB config file");let t=IT(Object.keys(_e.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[_e.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in wT){if(r===Ct.HTTP_PORT&&t[Ct.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??wT[r],t[Ct.HTTP_SECUREPORT]=null;continue}else if(r===Ct.HTTP_PORT)continue;if(r===Ct.OPERATIONSAPI_NETWORK_PORT&&t[Ct.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??wT[r],t[Ct.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Ct.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=wT[r])}}else t[Ct.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Ct.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Ct.HTTP_PORT.toLowerCase()]&&(t[Ct.HTTP_SECUREPORT]=null);try{oc[_e.INSTALL_PROMPTS.HDB_CONFIG]||gC.createConfigFile(t),sc.initSync()}catch(r){pge(r)}}a(_ge,"createConfigFile");function pge(e){fr.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(ZEe);let t=Zi.resolve(sc.get(sc.BOOT_PROPS_FILE_PATH),"../");t&&ks.removeSync(t),Xi&&(gW?ks.readdirSync(Xi,{withFileTypes:!0}).forEach(n=>{let s=Zi.join(n.path,n.name);s!==oc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&ks.removeSync(s)}):ks.removeSync(Xi)),process.exit(1)}a(pge,"rollbackInstall");async function AW(e,t){fr.trace("Creating admin user"),await jEe();let r;try{r=await KEe.addRole(e)}catch(n){if(n.message.includes("already exists"))t=void 0;else throw n.message+="Error creating role",n}if(t)try{t.role=r.role,await VEe.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(AW,"createAdminUser");async function RW(e){fr.trace("Creating Super user.");let t={role:"super_user",permission:{super_user:!0}},r={username:e[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await AW(t,r),delete e[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(RW,"createSuperUser");async function hge(e){fr.trace("Creating Cluster user.");let t;e[_e.INSTALL_PROMPTS.CLUSTERING_USER]&&e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[_e.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await AW({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[_e.INSTALL_PROMPTS.CLUSTERING_USER],delete e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(hge,"createClusterUser");async function mge(){let e=EW.version;if(e)await mW.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(mge,"insertHdbVersionInfo");function Ege(e){oc[_e.INSTALL_PROMPTS.HDB_CONFIG]=e}a(Ege,"updateConfigEnv");function gge(e){SC=e}a(gge,"setIgnoreExisting")});var NW=I((PUe,OW)=>{"use strict";var TC=oe(),ds=Y(),bW=aC();OW.exports={processDirectives:Sge};async function Sge(e){console.log("Starting upgrade process...");let t=bW.getVersionsForUpgrade(e),r=Rge(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;ds.notify(c),console.log(c);let l=[],u=[];try{l=Tge(o.sync_functions)}catch(f){throw ds.error(`Error while running an upgrade script for ${o.version}`),f}try{u=await Age(o.async_functions)}catch(f){throw ds.error(`Error while running an upgrade script for ${o.version}`),f}n.push(...l,...u)}return n}a(Sge,"processDirectives");function Tge(e){if(TC.isEmptyOrZeroLength(e))return ds.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return ds.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(ds.info(`Running function ${r.name}`),!(r instanceof Function)){ds.info("Variable being processed is not a function");continue}let n=r();ds.info(n),t.push(n)}return t}a(Tge,"runSyncFunctions");async function Age(e){if(TC.isEmptyOrZeroLength(e))return ds.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return ds.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(ds.info(`Running function ${s.name}`),!(s instanceof Function)){ds.info("Variable being processed is not a function");continue}let i=await s();ds.info(i),t.push(i)}return t}a(Age,"runAsyncFunctions");function Rge(e){if(TC.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=bW.getDirectiveByVersion(r);n&&t.push(n)}return t}a(Rge,"getUpgradeDirectivesToInstall")});var bC=I((LUe,LW)=>{"use strict";var PT=ce();PT.initSync();var PW=require("chalk"),wW=require("fs-extra"),Qo=Y(),jo=(B(),C(G)),yge=NW(),AC=oe(),DW=mh(),bge=gT(),IW=nR(),Oge=bs(),{packageJson:CW}=nt(),Nge=require("util").promisify,wge=Nge(Oge.setSchemaDataToGlobal),RC,{UPGRADE_VERSION:yC}=jo.UPGRADE_JSON_FIELD_NAMES_ENUM;LW.exports={upgrade:Ige};async function Ige(e){await wge(),RC===void 0&&(RC=Id()),wW.existsSync(PT.get(PT.BOOT_PROPS_FILE_PATH))||(Th("The hdb_boot_properties file was not found. Please install HDB.",jo.LOG_LEVELS.ERROR),process.exit(1)),wW.existsSync(PT.get(jo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(Th("The hdb settings file was not found. Please make sure HDB is installed.",jo.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await DW.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),Th(`This version of HarperDB is ${CW.version}`,jo.LOG_LEVELS.INFO);let r=t[yC]??CW.version;r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${jo.HDB_SUPPORT_ADDRESS}`),Qo.notify("Missing new version field from upgrade info object"),process.exit(1)),await Cge();let n,s=0;try{n=await bge.forceUpdatePrompt(t)}catch(i){Qo.error("There was an error when prompting user about upgrade."),Qo.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),Qo.info(`Starting upgrade to version ${r}`),await Pge(t),Th(`HarperDB was successfully upgraded to version ${t[yC]}`,jo.LOG_LEVELS.INFO)}a(Ige,"upgrade");async function Cge(){let e=!1,t=await IW.findPs(jo.HDB_PROC_NAME);if(AC.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await IW.findPs("hdb_express");AC.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await RC.list();AC.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(PW.red(r)),Qo.error(r),process.exit(1)}}a(Cge,"checkIfRunning");async function Pge(e){try{await yge.processDirectives(e)}catch(t){throw Th("There was an error during the data upgrade. Please check the logs.",jo.LOG_LEVELS.ERROR),t}try{await DW.insertHdbUpgradeInfo(e[yC])}catch(t){Qo.error("Error updating the 'hdb_info' system table."),Qo.error(t)}}a(Pge,"runUpgrade");function Th(e,t=void 0){t||(t=Qo.info),Qo[t](e),console.log(PW.magenta(e))}a(Th,"printToLogAndConsole")});var BW={};ve(BW,{onStorageReclamation:()=>Ah,runReclamationHandlers:()=>IC,setAvailableSpaceRatioGetter:()=>Lge});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}),wC||(wC=setTimeout(IC,vW).unref()))}async function IC(){for(let[e,t]of DT)try{let r=await xW(e),n=Dge/r;for(let s of t){let{priority:i,handler:o}=s;if(s.priority=n,n>1||i>1){let c=o(n>1?n:0);c&&(NC.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){NC.default.error?.("Error running storage reclamation handlers",r)}wC=setTimeout(IC,vW).unref()}function Lge(e){xW=e??UW}var OC,LT,NC,MT,MW,DT,Dge,vW,wC,UW,xW,vT=be(()=>{OC=require("node:fs/promises"),LT=M(tt()),NC=M(Ci());B();MT=M(ce()),MW=M(oe());MT.default.initSync();DT=new Map,Dge=MT.default.get(x.STORAGE_RECLAMATION_THRESHOLD)??.4,vW=(0,MW.convertToMS)(MT.default.get(x.STORAGE_RECLAMATION_INTERVAL))||36e5;a(Ah,"onStorageReclamation");UW=a(async e=>{if(OC.statfs){let t=await(0,OC.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"),xW=UW;a(IC,"runReclamationHandlers");a(Lge,"setAvailableSpaceRatioGetter")});var qW=I((xUe,GW)=>{"use strict";var{promises:Yd,createReadStream:Mge,createWriteStream:vge}=require("fs"),{createGzip:Uge}=require("zlib"),{promisify:xge}=require("util"),{pipeline:Bge}=require("stream"),Hge=xge(Bge),PC=require("path"),cc=ce();cc.initSync();var ac=Y(),{CONFIG_PARAMS:Wd,ITC_EVENT_TYPES:kge}=(B(),C(G)),{onMessageFromWorkers:Fge}=tt(),{convertToMS:Gge}=oe(),{onStorageReclamation:qge}=(vT(),C(BW)),$ge=6e4,Vge="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",Kge="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",CC,kW;GW.exports=FW;Fge(e=>{e.type===kge.RESTART&&(cc.initSync(!0),clearInterval(kW),cc.get(Wd.LOGGING_ROTATION_ENABLED)&&FW())});async function FW(){try{let e=ac.getLogFilePath(),t=cc.get(Wd.LOGGING_ROTATION_MAXSIZE),r=cc.get(Wd.LOGGING_ROTATION_INTERVAL),n=cc.get(Wd.LOGGING_ROTATION_RETENTION),s=0;if(qge(e,l=>{s=l},!0),!t&&!r){ac.error(Vge);return}let i=cc.get(Wd.LOGGING_ROTATION_PATH);if(!i){ac.error(Kge);return}let o;if(t){let l=t.slice(-1),u=t.slice(0,-1);l==="G"?o=u*1e9:l==="M"?o=u*1e6:o=u*1e3}let c;if(r){let l=r.slice(-1),u=r.slice(0,-1);l==="D"?c=u*1440:l==="H"?c=u*60:c=u}CC=Date.now()/6e4,ac.trace("Log rotate enabled, maxSize:",t,"interval:",r),kW=setInterval(async()=>{if(o){let l;l=await Yd.stat(e),l.size>=o&&await HW(e,i)}if(c&&Date.now()/6e4-CC>=c&&(await HW(e,i),CC=Date.now()/6e4),n||s){let l=Gge(n??"1M")/(1+s);s=0;let u=await Yd.readdir(i);for(let f of u)try{let d=await Yd.stat(PC.join(i,f));Date.now()-d.mtimeMs>l&&await Yd.unlink(PC.join(i,f))}catch(d){ac.error("Error trying to remove log",f,d)}}},$ge).unref()}catch(e){ac.error(e)}}a(FW,"logRotator");async function HW(e,t){let r=cc.get(Wd.LOGGING_ROTATION_COMPRESS),n=PC.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.log`);await Yd.rename(e,n),r&&(e=n,n+=".gz",await Hge(Mge(e),Uge(),vge(n)),await Yd.unlink(e)),ac.closeLogFile(),ac.notify(`hdb.log rotated, old log moved to ${n}`)}a(HW,"moveLogFile")});var jd=I(jW=>{"use strict";var ge=ce();ge.initSync();za();var kt=(B(),C(G)),{CONFIG_PARAMS:Ie}=kt,fs=Y(),Jo=require("fs-extra"),Xo=require("path"),Yge=JI(),{install:Wge}=CT(),DC=require("chalk"),{packageJson:zge,PACKAGE_ROOT:jge}=nt(),Zo=oe(),LC=Rt(),VW=da(),$W=SS(),Qge=bC(),Jge=qW(),{compactOnStart:Xge}=(wS(),C(NS)),Zge=require("minimist"),eSe=rs(),{startHTTPThreads:tSe}=(MC(),C(QW)),rSe=mh(),{isMainThread:nSe}=require("worker_threads"),HUe=Eo(),kUe=Ao(),FUe=wb(),GUe=x_(),UT=(B(),C(G)),eo,zd,KW=!1,sSe="Upgrade complete. Starting HarperDB.",iSe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",oSe="HarperDB not found, starting install process.",aSe="There was an error during install, check install_log.log for more details. Exiting.",cSe="HarperDB successfully started.";function lSe(){if(!KW){let e=a(()=>{Jo.removeSync(Xo.join(ge.get(kt.CONFIG_PARAMS.ROOTPATH),kt.HDB_PID_FILE)),process.exit(0)},"remove_hdb_pid");process.on("exit",()=>{e()}),process.on("SIGINT",()=>{e()}),process.on("SIGQUIT",()=>{e()}),process.on("SIGTERM",()=>{e()})}}a(lSe,"addExitListeners");async function YW(e=!1,t=!1){if(console.log(DC.magenta("Starting HarperDB...")),fs.suppressLogging?.(()=>{console.log(DC.magenta(""+Jo.readFileSync(Xo.join(jge,"utility/install/ascii_logo.txt"))))}),await zW()===!1){console.log(oSe);try{await Wge()}catch(l){console.error(aSe,l),fs.error(l),process.exit(1)}}if(!e){let l=VW(Object.keys(kt.CONFIG_PARAM_MAP),!0);!Zo.isEmpty(l)&&!Zo.isEmptyOrZeroLength(Object.keys(l))&&LC.updateConfigValue(void 0,void 0,l,!0,!0)}let r,n=zd?.service==="clustering";zd?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));let s=Xo.join(ge.get(kt.CONFIG_PARAMS.ROOTPATH),kt.HDB_PID_FILE),i=pSe(s);i&&i!==1&&hSe(i)&&(n?r=!0:(console.error(`Error: HarperDB is already running (pid: ${i})`),process.exit(4))),eo===void 0&&(eo=Id()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),ge.get(kt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await $W.generateNatsConfig(),await eo.startClusteringProcesses(!0),process.exit()),lSe(),await Jo.writeFile(Xo.join(ge.get(UT.CONFIG_PARAMS.ROOTPATH),UT.HDB_PID_FILE),`${process.pid}`),fs.info("HarperDB PID",process.pid);let o;try{let l=await rSe.getVersionUpdateInfo();l!==void 0&&(o=l[kt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await Qge.upgrade(l),console.log(sSe))}catch(l){o?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${o}. Exiting HarperDB.`,l),fs.error(l)):(console.error(iSe,l),fs.error(l)),process.exit(1)}Yge(),fSe(),await eSe.reviewSelfSignedCert(),Zo.autoCastBoolean(ge.get(kt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&nSe&&await $W.generateNatsConfig(t)}a(YW,"initialize");async function uSe(e=!1){try{zd=Zge(process.argv),zd.ROOTPATH&&LC.updateConfigObject("settings_path",Xo.join(zd.ROOTPATH,kt.HDB_CONFIG_FILE)),await YW(e,!0),ge.get(kt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Xge();let t=process.env.IS_SCRIPTED_SERVICE&&!zd.service;Zo.autoCastBoolean(ge.get(kt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await eo.startClusteringProcesses(),await eo.startClusteringThreads()),await tSe(process.env.DEV_MODE?1:ge.get(UT.CONFIG_PARAMS.THREADS_COUNT)??ge.get(UT.CONFIG_PARAMS.THREADS)),ge.get(kt.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await Jge(),t||WW()}catch(t){console.error(t),fs.error(t),process.exit(1)}}a(uSe,"main");function WW(){fs.suppressLogging(()=>{console.log(DC.magenta(`HarperDB ${zge.version} successfully started`))}),fs.notify(cSe)}a(WW,"started");async function dSe(e=!0){KW=!e;try{eo===void 0&&(eo=Id()),eo.enterPM2Mode(),await YW(),Zo.autoCastBoolean(ge.get(kt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await eo.startClusteringProcesses(),await eo.startService(kt.PROCESS_DESCRIPTORS.HDB),WW(),e&&process.exit(0)}catch(t){console.error(t),fs.error(t),process.exit(1)}}a(dSe,"launch");function fSe(){let e=Xo.join(ge.get(kt.CONFIG_PARAMS.ROOTPATH),kt.LICENSE_KEY_DIR_NAME,kt.LICENSE_FILE_NAME),t=Xo.join(e,kt.LICENSE_FILE_NAME),r=Xo.join(e,kt.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=VW(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(Zo.isEmpty(n)||Zo.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),fs.error(s)}}a(fSe,"writeLicenseFromVars");Object.assign(jW,{launch:dSe,main:uSe,isHdbInstalled:zW,startupLog:_Se});async function zW(){try{await Jo.stat(Zo.getPropsFilePath()),await Jo.stat(ge.get(kt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(Zo.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw fs.error(`Error checking for HDB install - ${e}`),e}return!0}a(zW,"isHdbInstalled");function _Se(e){let r=a(_=>_.padEnd(20),"pad"),n=`
115
- `;ge.get(Ie.REPLICATION_HOSTNAME)&&(n+=`${r("Hostname:")}${ge.get(Ie.REPLICATION_HOSTNAME)}
116
- `),ge.get(Ie.REPLICATION_URL)&&(n+=`${r("Replication Url:")}${ge.get(Ie.REPLICATION_URL)}
117
- `),n+=`${r("Worker Threads:")}${ge.get(Ie.THREADS_COUNT)}
118
- `,n+=`${r("Root Path:")}${ge.get(Ie.ROOTPATH)}
119
- `,ge.get(Ie.THREADS_DEBUG)!==!1&&(n+=`${r("Debugging:")}enabled: true`,n+=ge.get(Ie.THREADS_DEBUG_PORT)?`, TCP: ${ge.get(Ie.THREADS_DEBUG_PORT)}
112
+ Reindexing upgrade started for transaction logs`),Ko.notify("Reindexing upgrade started for transaction logs"),await VY(oC,!0,e)),Ko.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(fh?", but errors occurred":"")}a(Hme,"reindexUpgrade");async function VY(e,t,r){let n=await Qi.readdir(e),s=n.length;for(let i=0;i<s;i++){let o=n[i],c=Yo.join(e,o.toString());if(o===".DS_Store")continue;let l=await Qi.readdir(c),u=l.length;for(let f=0;f<u;f++){let d=l[f];if(d!==".DS_Store"&&Qi.statSync(Yo.join(c,d)).isDirectory())try{await kme(o,d,t),sn.info(`Reindexing started for ${o}.${d}`),Ko.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${d}`),await Gme(o,d,c,t,r),sn.info(`Reindexing completed for ${o}.${d}`),Ko.notify(`Reindexing completed for ${o}.${d}`)}catch(p){fh=!0,p.schema_path=c,p.table_name=d,Ko.error("There was an error with the reindex upgrade, check the logs in hdb/3_0_0_upgrade_tmp for more details"),Ko.error(p),sn.error(p),console.error(p)}}}if(!fh)try{await Qi.rm(AT,{recursive:!0})}catch{}}a(VY,"processTables");async function kme(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=Yo.join(AT,s);await Qi.ensureDir(AT),await Qi.writeFile(i,""),sn=xme({level:"debug",formatters:{bindings(){}}},i)}a(kme,"initPinoLogger");var Fme=20;async function Gme(e,t,r,n,s){let i;try{i=await cs.openEnvironment(r,t,n)}catch(E){if(E.message==="MDB_INVALID: File is not an LMDB file"){Ko.notify(`${e}.${t} file is not from the old environment and has been skipped`),console.info(`${e}.${t} file is not from the old environment and has been skipped`),sn.error(E);return}throw E}let o=Vme(i.dbis),c=cs.openDBI(i,o),l=Object.keys(i.dbis),u=cs.statDBI(i,o);sn.info(`Old environment stats: ${JSON.stringify(u)}`);let f=new Ume.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 cs.createEnvironment(r,t,!1);cs.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>Fme&&await _();await _()}catch(E){throw fh=!0,sn.error(E),E}async function _(){let E,A=p.map(({value:v})=>v);n?E=await Promise.all(A.map(v=>qme(d,v))):E=await Dme(d,o,l.filter(v=>v!=="__blob__"),A,!1);for(let v=0,F=p.length;v<F;v++){let{key:G,value:Y}=p[v];sn.info(`Record hash value: ${G} hash: ${o}`);let te;n?te=E[v]:te=E.written_hashes.indexOf(G)>-1,dh(te,!0),$me(d,o,Y[o],n),sn.info(`Insert success, written hashes: ${E.written_hashes}`),f.increment()}p=[],f.value/f.total*100%10===0&&Ko.notify(`${e}.${t} ${f.value}/${f.total} records inserted`),sn.info(`${f.value}/${f.total} records inserted`)}a(_,"finishOutstanding"),f.stop();let h=cs.statDBI(i,o),S=cs.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 cs.closeEnvironment(i),await cs.closeEnvironment(d),delete global.lmdb_map[`${e}.${t}`],s){let E=Yo.join(r,t),A=Yo.join(E,"data.mdb"),O=Yo.join(E,"lock.mdb");await Qi.unlink(A),await Qi.unlink(O),await Qi.rmdir(E),sn.info(`Deleted old environment files from schema folder: ${A}, ${O}`)}let g=await cs.openEnvironment(r,t),R=cs.statDBI(g,o);sn.info(`New stats: ${JSON.stringify(S)}. New stats after move: ${JSON.stringify(R)}`),dh.deepStrictEqual(R.entryCount,S.entryCount),await cs.closeEnvironment(g),delete global.lmdb_map[`${e}.${t}`]}a(Gme,"processTable");async function qme(e,t){cs.initializeDBIs(e,tc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,tc.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[tc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[tc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),vme.isEmpty(t.user_name)||e.dbis[tc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[tc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a(qme,"insertTransaction");function $me(e,t,r,n){let i=e.dbis[t].get(r);dh.deepStrictEqual(typeof i,"object");let o;if(n){let c={[tc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[tc.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&&!Mme.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($me,"validateIndices");function KY(e,t,r,n){try{let s=!1,i=Lme.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 Vme(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(Vme,"getHashDBI")});var XY=w((EUe,JY)=>{"use strict";var RT=require("path"),rc=require("fs-extra"),Kme=sC(),Fl=z(),zY=yt(),aC=ae(),gi=(H(),C(q)),yT=se(),Yme=require("properties-reader"),Wme=si(),zme=ng(),jme=Yr(),mUe=require("util"),Qme=jme.searchByValue,Jme=Rn(),Xme=uS(),Zme=Tt(),eEe=WY(),jY=ts(),tEe=gT(),hh=new Kme("4.0.0"),QY=[],_h,ph;async function rEe(){try{if(await tEe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),_h){let t=yT.changeExtension(_h,".bak");await rc.move(_h,t)}if(ph){let t=yT.changeExtension(ph,".bak");await rc.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(rEe,"generateNewKeys");async function nEe(){console.log("Updating HarperDB nodes."),Fl.info("Updating HarperDB nodes.");let e=[];try{let t=new Wme(gi.SYSTEM_SCHEMA_NAME,gi.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(!Zme.NATS_TERM_CONSTRAINTS_RX.test(c.name)){let f=`Node name '${c.name}' is invalid, must not contain ., * or >. Please change name and try again.`;throw console.error(f),f}let l={host:c.host,port:c.port};e.push(l);let u=[];for(let f=0,d=c.subscriptions.length;f<d;f++){let p=c.subscriptions[f],_=p.channel.split(":");u.push({schema:_[0],table:_[1],publish:p.publish,subscribe:p.subscribe})}n.push({name:c.name,subscriptions:u,system_info:{hdb_version:gi.PRE_4_0_0_VERSION,node_version:void 0,platform:void 0}})}if(yT.isEmptyOrZeroLength(n))return;let s=new zme(gi.SYSTEM_SCHEMA_NAME,gi.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await Jme.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{Xme.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(nEe,"updateNodes");async function sEe(){let e=aC.get(gi.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=aC.get(gi.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),s=RT.join(n,"backup","4_0_0_upgrade_settings.bak"),i=RT.join(n,gi.HDB_CONFIG_FILE);try{Fl.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),rc.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[gi.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],ph=d[gi.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();rc.accessSync(o,rc.constants.F_OK|rc.constants.R_OK);let l=Yme(o).get(gi.HDB_SETTINGS_NAMES.INSTALL_USER),u=`settings_path = ${i}
113
+ install_user = ${l}`;try{rc.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{aC.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{rc.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(sEe,"updateSettingsFile_4_0_0");hh.async_functions.push(sEe);hh.async_functions.push(rEe);hh.async_functions.push(eEe);hh.async_functions.push(nEe);QY.push(hh);JY.exports=QY});var cC=w((SUe,rW)=>{"use strict";var Gl=se(),iEe=(H(),C(q)),ZY=z(),{DATA_VERSION:oEe,UPGRADE_VERSION:aEe}=iEe.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 cEe(){return[...ql.keys()].sort(Gl.compareVersions)}a(cEe,"getSortedVersions");function tW(e){let t=e[oEe],r=e[aEe];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 lEe(e){return tW(e).length>0}a(lEe,"hasUpgradesRequired");function uEe(e){return Gl.isEmptyOrZeroLength(e)?null:ql.has(e)?ql.get(e):null}a(uEe,"getDirectiveByVersion");rW.exports={getSortedVersions:cEe,getDirectiveByVersion:uEe,getVersionsForUpgrade:tW,hasUpgradesRequired:lEe}});var mh=w((AUe,aW)=>{"use strict";var dEe=require("util"),lC=require("chalk"),fEe=require("os"),sW=Rn(),_Ee=Yr(),ls=(H(),C(q)),iW=PY(),dC=My(),{UpgradeObject:nW}=MY(),{forceDowngradePrompt:pEe}=gT(),{packageJson:hEe}=st(),OT=z(),Kd=se(),fC=ys(),mEe=(Pe(),C(tt)),EEe=cC(),gEe=dEe.promisify(fC.setSchemaDataToGlobal),SEe=_Ee.searchByValue,TEe="info_id",AEe="2.9.9",REe="3.0.0";async function yEe(e){let t=new iW.HdbInfoInsertObject(1,e,e),r=new dC.InsertObject(ls.OPERATIONS_ENUM.INSERT,ls.SYSTEM_SCHEMA_NAME,ls.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,ls.INFO_TABLE_HASH_ATTRIBUTE,[t]);return fC.setSchemaDataToGlobal(),sW.insert(r)}a(yEe,"insertHdbInstallInfo");async function uC(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 dC.InsertObject(ls.OPERATIONS_ENUM.INSERT,ls.SYSTEM_SCHEMA_NAME,ls.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,ls.INFO_TABLE_HASH_ATTRIBUTE,[t]);return await gEe(),sW.insert(o)}a(uC,"insertHdbUpgradeInfo");async function oW(){let e=new dC.NoSQLSeachObject(ls.SYSTEM_SCHEMA_NAME,ls.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,TEe,ls.INFO_TABLE_HASH_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await SEe(e))}catch(r){console.error(r)}return t}a(oW,"getAllHdbInfoRecords");async function bEe(){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(bEe,"getLatestHdbInfoRecord");async function OEe(){OT.info("Checking if HDB software has been updated");try{let e=hEe.version;if(!e)throw new Error("Could not find the version number in the package.json file");let t=await bEe(),r;if(Kd.isEmpty(t))r=AEe;else if(r=t.data_version_num,Kd.compareVersions(r.toString(),e.toString())>0){if(!Kd.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(lC.yellow(`This instance's data was last run on version ${r}`)),console.error(lC.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.${fEe.EOL}${ls.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");Kd.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(lC.yellow(`This instance's data was last run on version ${r}`)),await pEe(new nW(r,e))?await uC(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(fC.setSchemaDataToGlobal(),NEe(r),e.toString()===r.toString())return;let n=new nW(r,e);if(EEe.hasUpgradesRequired(n))return n;Kd.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await uC(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(OEe,"getVersionUpdateInfo");function NEe(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 ${ls.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in mEe.databases.system))throw console.log(t),new Error(t);if(!Kd.isEmpty(e)&&e<REe)throw console.log(t),new Error(t)}a(NEe,"checkIfInstallIsSupported");aW.exports={insertHdbInstallInfo:yEe,insertHdbUpgradeInfo:uC,getVersionUpdateInfo:OEe}});var dW=w((yUe,uW)=>{"use strict";var NT=require("joi"),{boolean:wEe,string:_C,number:IEe}=NT.types(),cW=require("fs-extra"),Eh=(H(),C(q)),lW=require("path"),CEe=ft();uW.exports=PEe;function PEe(e){let t=_C.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=NT.object({[Eh.INSTALL_PROMPTS.ROOTPATH]:NT.custom(DEe),[Eh.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:NT.alternatives([IEe.min(0),_C]).allow("null",null),[Eh.INSTALL_PROMPTS.TC_AGREEMENT]:_C.valid("yes","YES","Yes"),[Eh.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[Eh.INSTALL_PROMPTS.CLUSTERING_ENABLED]:wEe});return CEe.validateBySchema(e,r)}a(PEe,"installValidator");function DEe(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(DEe,"validateRootAvailable")});var mC=w((OUe,fW)=>{"use strict";var{mkdirpSync:LEe,copySync:MEe}=require("fs-extra"),nc=require("path"),gh=(H(),C(q)),{PACKAGE_ROOT:vEe}=st(),hC=z(),UEe=Yn(),pC=Eo(),xEe=gt();fW.exports=BEe;async function BEe(e){hC.trace("Mounting HarperDB"),$l(e),$l(nc.join(e,"backup")),$l(nc.join(e,"keys")),$l(nc.join(e,"keys",gh.LICENSE_FILE_NAME)),$l(nc.join(e,"log")),$l(nc.join(e,"database")),$l(nc.join(e,"components")),MEe(nc.resolve(vEe,"./utility/install/README.md"),nc.join(e,"README.md")),await HEe()}a(BEe,"mountHdb");async function HEe(){let e=x_(),t=Object.keys(pC);for(let r=0;r<t.length;r++){let n=t[r],s=pC[n].hash_attribute;try{xEe.initSystemSchemaPaths(gh.SYSTEM_SCHEMA_NAME,n);let i=new e(gh.SYSTEM_SCHEMA_NAME,n,s);i.attributes=pC[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,["hdb_user","hdb_role"].includes(n)&&(i.audit=!0),await UEe.createTable(n,i)}catch(i){throw hC.error(`issue creating environment for ${gh.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(HEe,"createLMDBTables");function $l(e){LEe(e,{mode:gh.HDB_FILE_PERMISSIONS}),hC.info(`Directory ${e} created`)}a($l,"makeDirectory")});var CT=w((CUe,OW)=>{"use strict";var gC=require("os"),EW=require("inquirer"),Hs=require("fs-extra"),kEe=require("properties-reader"),Kl=require("chalk"),Xi=require("path"),FEe=require("human-readable-ids").hri,GEe=require("ora"),qEe=require("yaml"),pr=z(),sc=ae(),Sh=se(),IT=da(),gW=mh(),{packageJson:SW}=st(),de=(H(),C(q)),{CONFIG_PARAM_MAP:wUe,CONFIG_PARAMS:Pt}=de,$Ee=dW(),VEe=mC(),SC=yt(),KEe=An(),YEe=q_(),WEe=XI(),zEe=ys(),jEe=require("util").promisify,QEe=jEe(zEe.setSchemaDataToGlobal),_W=ts(),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",ic=gC.EOL,Wo="",XEe="yes",pW="Starting HarperDB install...",hW="HarperDB installation was successful.",mW="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",ZEe="An out of date version of HarperDB is already installed.",EC="It appears that HarperDB is already installed. Exiting install...",ege="Aborting install",IUe=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])$/),tge=new RegExp(/^[^\s.,*>]+$/),rge=gC.homedir(),nge=Xi.join(rge,de.HDB_ROOT_DIR_NAME),sge="HDB_ADMIN",ige="CLUSTER_USER",oge="dev",age="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:"},oc=IT([de.INSTALL_PROMPTS.HDB_CONFIG]),Ji,TW=!1,TC=!1,AW=!1;OW.exports={install:RW,updateConfigEnv:gge,setIgnoreExisting:Sge};RW.createSuperUser=bW;async function RW(){console.log(Hr(ic+pW+ic)),pr.notify(pW);let e;oc[de.INSTALL_PROMPTS.HDB_CONFIG]&&(e=cge());let t=uge();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=$Ee(t);if(r)throw r.message;await dge(),await fge(t);let n=await lge(t);Ji=n[de.INSTALL_PROMPTS.ROOTPATH],oc[de.INSTALL_PROMPTS.HDB_CONFIG]&&Xi.dirname(oc[de.INSTALL_PROMPTS.HDB_CONFIG])===Ji&&(TW=!0),!TC&&!oc[de.INSTALL_PROMPTS.HDB_CONFIG]&&await Hs.pathExists(Xi.join(Ji,de.HDB_CONFIG_FILE))&&(console.error(EC),process.exit());let s=GEe({prefixText:Hr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),Sh.isEmpty(Ji))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");sc.setHdbBasePath(Ji),await VEe(Ji),await _ge(),await pge(n),pr.initLogSettings(!0),await bW(n),await mge(n),await _W.updateConfigCert(),await _W.generateCertsKeys(),await Ege(),WEe(),s.stop(),console.log(Hr(ic+hW+ic)),pr.notify(hW)}a(RW,"install");function cge(){let e=qEe.parseDocument(Hs.readFileSync(oc[de.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=SC.flattenConfig(e.toJSON());return t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(cge,"getConfigFromFile");async function lge(e){pr.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:Vl,when:zo(e[de.INSTALL_PROMPTS.ROOTPATH],Br.DESTINATION),name:de.INSTALL_PROMPTS.ROOTPATH,prefix:Wo,default:nge,validate:a(async s=>Bs(s)?Bs(s):await Hs.pathExists(Xi.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:zo(e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Br.HDB_USERNAME),name:de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Wo,default:sge,validate:a(s=>Bs(s)?Bs(s):(t=s,!0),"validate"),message:Hr(Br.HDB_USERNAME)},{type:"password",when:zo(e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Br.HDB_PASS),name:de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Wo,validate:a(s=>Bs(s)?Bs(s):!0,"validate"),message:Hr(Br.HDB_PASS)},{type:"input",transformer:Vl,when:zo(e[de.INSTALL_PROMPTS.DEFAULTS_MODE],Br.DEFAULTS_MODE),name:de.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Wo,default:oge,validate:a(s=>Bs(s)?Bs(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:zo(e[de.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Br.REPLICATION_HOSTNAME),prefix:Wo,default:age,message:Hr(Br.REPLICATION_HOSTNAME)}),Sh.autoCastBoolean(e[de.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:Vl,when:zo(e[de.INSTALL_PROMPTS.CLUSTERING_NODENAME],Br.NODE_NAME),name:de.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Wo,default:FEe.random(),validate:a(i=>tge.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:Hr(Br.NODE_NAME)},{type:"input",transformer:Vl,when:zo(e[de.INSTALL_PROMPTS.CLUSTERING_USER],Br.CLUSTER_USERNAME),name:de.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Wo,default:ige,validate:a(i=>Bs(i)?Bs(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,"validate"),message:Hr(Br.CLUSTER_USERNAME)},{type:"password",when:zo(e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Br.CLUSTER_PASS),name:de.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Wo,validate:a(i=>Bs(i)?Bs(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(lge,"installPrompts");function zo(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(zo,"displayCmdEnvVar");function Bs(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(Bs,"checkForEmptyValue");function uge(){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(uge,"checkForPromptOverride");async function dge(){pr.trace("Checking for existing install.");let e=Sh.getPropsFilePath(),t=await Hs.pathExists(e),r;if(t){pr.trace(`Install found an existing boot prop file at:${e}`);let n=kEe(e),s=SC.getConfigValue(de.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(de.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await Hs.pathExists(s)}if(!t&&Sh.noBootFile()&&(r=!0),r&&!TC){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(ic+Kl.magenta.bold(ZEe)),console.log(Kl.magenta.bold(s)),pr.error(s)}else console.log(ic+Kl.magenta.bold(EC)),pr.error(EC);process.exit(0)}}a(dge,"checkForExistingInstall");async function fge(e){pr.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${JEe}${ic}and can be viewed by typing or copying and pasting the URL into your web browser.${ic}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Wo,transformer:Vl,when:zo(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()!==XEe&&(console.log(Kl.yellow(mW)),pr.error(mW),process.exit(0))}a(fge,"termsAgreement");async function _ge(){let e=Xi.join(Ji,de.HDB_CONFIG_FILE),t;try{t=gC.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=Xi.join(n,de.HDB_HOME_DIR_NAME),i=Xi.join(s,de.LICENSE_KEY_DIR_NAME);try{Hs.mkdirpSync(s,{mode:de.HDB_FILE_PERMISSIONS}),Hs.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=Xi.join(s,de.BOOT_PROPS_FILE_NAME);try{await Hs.writeFile(o,r)}catch(c){throw pr.error(`There was an error creating the boot file at path: ${o}`),c}sc.setProperty(de.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),sc.setProperty(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),sc.setProperty(sc.BOOT_PROPS_FILE_PATH,o)}}a(_ge,"createBootPropertiesFile");async function pge(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{oc[de.INSTALL_PROMPTS.HDB_CONFIG]||SC.createConfigFile(t),sc.initSync()}catch(r){hge(r)}}a(pge,"createConfigFile");function hge(e){pr.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(ege);let t=Xi.resolve(sc.get(sc.BOOT_PROPS_FILE_PATH),"../");t&&Hs.removeSync(t),Ji&&(TW?Hs.readdirSync(Ji,{withFileTypes:!0}).forEach(n=>{let s=Xi.join(n.path,n.name);s!==oc[de.INSTALL_PROMPTS.HDB_CONFIG]&&Hs.removeSync(s)}):Hs.removeSync(Ji)),process.exit(1)}a(hge,"rollbackInstall");async function yW(e,t){pr.trace("Creating admin user"),await QEe();let r;try{r=await YEe.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 KEe.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 mge(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(mge,"createClusterUser");async function Ege(){let e=SW.version;if(e)await gW.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(Ege,"insertHdbVersionInfo");function gge(e){oc[de.INSTALL_PROMPTS.HDB_CONFIG]=e}a(gge,"updateConfigEnv");function Sge(e){TC=e}a(Sge,"setIgnoreExisting")});var IW=w((DUe,wW)=>{"use strict";var AC=se(),us=z(),NW=cC();wW.exports={processDirectives:Tge};async function Tge(e){console.log("Starting upgrade process...");let t=NW.getVersionsForUpgrade(e),r=yge(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;us.notify(c),console.log(c);let l=[],u=[];try{l=Age(o.sync_functions)}catch(f){throw us.error(`Error while running an upgrade script for ${o.version}`),f}try{u=await Rge(o.async_functions)}catch(f){throw us.error(`Error while running an upgrade script for ${o.version}`),f}n.push(...l,...u)}return n}a(Tge,"processDirectives");function Age(e){if(AC.isEmptyOrZeroLength(e))return us.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return us.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(us.info(`Running function ${r.name}`),!(r instanceof Function)){us.info("Variable being processed is not a function");continue}let n=r();us.info(n),t.push(n)}return t}a(Age,"runSyncFunctions");async function Rge(e){if(AC.isEmptyOrZeroLength(e))return us.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return us.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(us.info(`Running function ${s.name}`),!(s instanceof Function)){us.info("Variable being processed is not a function");continue}let i=await s();us.info(i),t.push(i)}return t}a(Rge,"runAsyncFunctions");function yge(e){if(AC.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=NW.getDirectiveByVersion(r);n&&t.push(n)}return t}a(yge,"getUpgradeDirectivesToInstall")});var OC=w((MUe,vW)=>{"use strict";var PT=ae();PT.initSync();var LW=require("chalk"),CW=require("fs-extra"),Qo=z(),jo=(H(),C(q)),bge=IW(),RC=se(),MW=mh(),Oge=gT(),PW=nR(),Nge=ys(),{packageJson:DW}=st(),wge=require("util").promisify,Ige=wge(Nge.setSchemaDataToGlobal),yC,{UPGRADE_VERSION:bC}=jo.UPGRADE_JSON_FIELD_NAMES_ENUM;vW.exports={upgrade:Cge};async function Cge(e){await Ige(),yC===void 0&&(yC=Id()),CW.existsSync(PT.get(PT.BOOT_PROPS_FILE_PATH))||(Th("The hdb_boot_properties file was not found. Please install HDB.",jo.LOG_LEVELS.ERROR),process.exit(1)),CW.existsSync(PT.get(jo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(Th("The hdb settings file was not found. Please make sure HDB is installed.",jo.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await MW.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),Th(`This version of HarperDB is ${DW.version}`,jo.LOG_LEVELS.INFO);let r=t[bC]??DW.version;r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${jo.HDB_SUPPORT_ADDRESS}`),Qo.notify("Missing new version field from upgrade info object"),process.exit(1)),await Pge();let n,s=0;try{n=await Oge.forceUpdatePrompt(t)}catch(i){Qo.error("There was an error when prompting user about upgrade."),Qo.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),Qo.info(`Starting upgrade to version ${r}`),await Dge(t),Th(`HarperDB was successfully upgraded to version ${t[bC]}`,jo.LOG_LEVELS.INFO)}a(Cge,"upgrade");async function Pge(){let e=!1,t=await PW.findPs(jo.HDB_PROC_NAME);if(RC.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await PW.findPs("hdb_express");RC.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await yC.list();RC.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)),Qo.error(r),process.exit(1)}}a(Pge,"checkIfRunning");async function Dge(e){try{await bge.processDirectives(e)}catch(t){throw Th("There was an error during the data upgrade. Please check the logs.",jo.LOG_LEVELS.ERROR),t}try{await MW.insertHdbUpgradeInfo(e[bC])}catch(t){Qo.error("Error updating the 'hdb_info' system table."),Qo.error(t)}}a(Dge,"runUpgrade");function Th(e,t=void 0){t||(t=Qo.info),Qo[t](e),console.log(LW.magenta(e))}a(Th,"printToLogAndConsole")});var kW={};ve(kW,{onStorageReclamation:()=>Ah,runReclamationHandlers:()=>CC,setAvailableSpaceRatioGetter:()=>Mge});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}),IC||(IC=setTimeout(CC,xW).unref()))}async function CC(){for(let[e,t]of DT)try{let r=await HW(e),n=Lge/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&&(wC.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){wC.default.error?.("Error running storage reclamation handlers",r)}IC=setTimeout(CC,xW).unref()}function Mge(e){HW=e??BW}var NC,LT,wC,MT,UW,DT,Lge,xW,IC,BW,HW,vT=be(()=>{NC=require("node:fs/promises"),LT=M(et()),wC=M(Ii());H();MT=M(ae()),UW=M(se());MT.default.initSync();DT=new Map,Lge=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(NC.statfs){let t=await(0,NC.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(CC,"runReclamationHandlers");a(Mge,"setAvailableSpaceRatioGetter")});var VW=w((BUe,$W)=>{"use strict";var{promises:Yd,createReadStream:vge,createWriteStream:Uge}=require("fs"),{createGzip:xge}=require("zlib"),{promisify:Bge}=require("util"),{pipeline:Hge}=require("stream"),kge=Bge(Hge),DC=require("path"),cc=ae();cc.initSync();var ac=z(),{CONFIG_PARAMS:Wd,ITC_EVENT_TYPES:Fge}=(H(),C(q)),{onMessageFromWorkers:Gge}=et(),{convertToMS:qge}=se(),{onStorageReclamation:$ge}=(vT(),C(kW)),Vge=6e4,Kge="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",Yge="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",PC,GW;$W.exports=qW;Gge(e=>{e.type===Fge.RESTART&&(cc.initSync(!0),clearInterval(GW),cc.get(Wd.LOGGING_ROTATION_ENABLED)&&qW())});async function qW(){try{let e=ac.getLogFilePath(),t=cc.get(Wd.LOGGING_ROTATION_MAXSIZE),r=cc.get(Wd.LOGGING_ROTATION_INTERVAL),n=cc.get(Wd.LOGGING_ROTATION_RETENTION),s=0;if($ge(e,l=>{s=l},!0),!t&&!r){ac.error(Kge);return}let i=cc.get(Wd.LOGGING_ROTATION_PATH);if(!i){ac.error(Yge);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}PC=Date.now()/6e4,ac.trace("Log rotate enabled, maxSize:",t,"interval:",r),GW=setInterval(async()=>{if(o){let l;l=await Yd.stat(e),l.size>=o&&await FW(e,i)}if(c&&Date.now()/6e4-PC>=c&&(await FW(e,i),PC=Date.now()/6e4),n||s){let l=qge(n??"1M")/(1+s);s=0;let u=await Yd.readdir(i);for(let f of u)try{let d=await Yd.stat(DC.join(i,f));Date.now()-d.mtimeMs>l&&await Yd.unlink(DC.join(i,f))}catch(d){ac.error("Error trying to remove log",f,d)}}},Vge).unref()}catch(e){ac.error(e)}}a(qW,"logRotator");async function FW(e,t){let r=cc.get(Wd.LOGGING_ROTATION_COMPRESS),n=DC.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.log`);await Yd.rename(e,n),r&&(e=n,n+=".gz",await kge(vge(e),xge(),Uge(n)),await Yd.unlink(e)),ac.closeLogFile(),ac.notify(`hdb.log rotated, old log moved to ${n}`)}a(FW,"moveLogFile")});var jd=w(JW=>{"use strict";var Se=ae();Se.initSync();za();var kt=(H(),C(q)),{CONFIG_PARAMS:Ie}=kt,ds=z(),Jo=require("fs-extra"),Xo=require("path"),Wge=XI(),{install:zge}=CT(),LC=require("chalk"),{packageJson:jge,PACKAGE_ROOT:Qge}=st(),Zo=se(),MC=yt(),YW=da(),KW=SS(),Jge=OC(),Xge=VW(),{compactOnStart:Zge}=(wS(),C(NS)),eSe=require("minimist"),tSe=ts(),{startHTTPThreads:rSe}=(vC(),C(XW)),nSe=mh(),{isMainThread:sSe}=require("worker_threads"),kUe=Eo(),FUe=Ao(),GUe=Ib(),qUe=x_(),UT=(H(),C(q)),Zi,zd,WW=!1,iSe="Upgrade complete. Starting HarperDB.",oSe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",aSe="HarperDB not found, starting install process.",cSe="There was an error during install, check install_log.log for more details. Exiting.",lSe="HarperDB successfully started.";function uSe(){if(!WW){let e=a(()=>{Jo.removeSync(Xo.join(Se.get(kt.CONFIG_PARAMS.ROOTPATH),kt.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(uSe,"addExitListeners");async function zW(e=!1,t=!1){if(console.log(LC.magenta("Starting HarperDB...")),ds.suppressLogging?.(()=>{console.log(LC.magenta(""+Jo.readFileSync(Xo.join(Qge,"utility/install/ascii_logo.txt"))))}),await QW()===!1){console.log(aSe);try{await zge()}catch(l){console.error(cSe,l),ds.error(l),process.exit(1)}}if(!e){let l=YW(Object.keys(kt.CONFIG_PARAM_MAP),!0);!Zo.isEmpty(l)&&!Zo.isEmptyOrZeroLength(Object.keys(l))&&MC.updateConfigValue(void 0,void 0,l,!0,!0)}let r,n=zd?.service==="clustering";zd?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));let s=Xo.join(Se.get(kt.CONFIG_PARAMS.ROOTPATH),kt.HDB_PID_FILE),i=hSe(s);i&&i!==1&&mSe(i)&&(n?r=!0:(console.error(`Error: HarperDB is already running (pid: ${i})`),process.exit(4))),Zi===void 0&&(Zi=Id()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),Se.get(kt.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 Zi.startClusteringProcesses(!0),process.exit()),uSe(),await Jo.writeFile(Xo.join(Se.get(UT.CONFIG_PARAMS.ROOTPATH),UT.HDB_PID_FILE),`${process.pid}`),ds.info("HarperDB PID",process.pid);let o;try{let l=await nSe.getVersionUpdateInfo();l!==void 0&&(o=l[kt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await Jge.upgrade(l),console.log(iSe))}catch(l){o?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${o}. Exiting HarperDB.`,l),ds.error(l)):(console.error(oSe,l),ds.error(l)),process.exit(1)}Wge(),_Se(),await tSe.reviewSelfSignedCert(),Zo.autoCastBoolean(Se.get(kt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&sSe&&await KW.generateNatsConfig(t)}a(zW,"initialize");async function dSe(e=!1){try{zd=eSe(process.argv),zd.ROOTPATH&&MC.updateConfigObject("settings_path",Xo.join(zd.ROOTPATH,kt.HDB_CONFIG_FILE)),await zW(e,!0),Se.get(kt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Zge();let t=process.env.IS_SCRIPTED_SERVICE&&!zd.service;Zo.autoCastBoolean(Se.get(kt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await Zi.startClusteringProcesses(),await Zi.startClusteringThreads()),await rSe(process.env.DEV_MODE?1:Se.get(UT.CONFIG_PARAMS.THREADS_COUNT)??Se.get(UT.CONFIG_PARAMS.THREADS)),Se.get(kt.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await Xge(),t||jW()}catch(t){console.error(t),ds.error(t),process.exit(1)}}a(dSe,"main");function jW(){ds.suppressLogging(()=>{console.log(LC.magenta(`HarperDB ${jge.version} successfully started`))}),ds.notify(lSe)}a(jW,"started");async function fSe(e=!0){WW=!e;try{Zi===void 0&&(Zi=Id()),Zi.enterPM2Mode(),await zW(),Zo.autoCastBoolean(Se.get(kt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await Zi.startClusteringProcesses(),await Zi.startService(kt.PROCESS_DESCRIPTORS.HDB),jW(),e&&process.exit(0)}catch(t){console.error(t),ds.error(t),process.exit(1)}}a(fSe,"launch");function _Se(){let e=Xo.join(Se.get(kt.CONFIG_PARAMS.ROOTPATH),kt.LICENSE_KEY_DIR_NAME,kt.LICENSE_FILE_NAME),t=Xo.join(e,kt.LICENSE_FILE_NAME),r=Xo.join(e,kt.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=YW(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(Zo.isEmpty(n)||Zo.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),ds.error(s)}}a(_Se,"writeLicenseFromVars");Object.assign(JW,{launch:fSe,main:dSe,isHdbInstalled:QW,startupLog:pSe});async function QW(){try{await Jo.stat(Zo.getPropsFilePath()),await Jo.stat(Se.get(kt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(Zo.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw ds.error(`Error checking for HDB install - ${e}`),e}return!0}a(QW,"isHdbInstalled");function pSe(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)}
120
120
  `:`
121
- `);let s=Xo.join(ge.get(Ie.LOGGING_ROOT),"hdb.log");n+=`${r("Logging:")}level: ${ge.get(Ie.LOGGING_LEVEL)}, location: ${s+(ge.get(Ie.LOGGING_STDSTREAMS)?", stdout/err":"")}
122
- `,n+=r("Default:"),n+=ge.get(Ie.HTTP_PORT)?`HTTP (and WS): ${ge.get(Ie.HTTP_PORT)}, `:"",n+=ge.get(Ie.HTTP_SECUREPORT)?`HTTPS (and WS): ${ge.get(Ie.HTTP_SECUREPORT)}, `:"",n+=`CORS: ${ge.get(Ie.HTTP_CORS)?`enabled for ${ge.get(Ie.HTTP_CORSACCESSLIST)}`:"disabled"}
123
- `,n+=r("Operations API:"),n+=ge.get(Ie.OPERATIONSAPI_NETWORK_PORT)?`HTTP: ${ge.get(Ie.OPERATIONSAPI_NETWORK_PORT)}, `:"",n+=ge.get(Ie.OPERATIONSAPI_NETWORK_SECUREPORT)?`HTTPS: ${ge.get(Ie.OPERATIONSAPI_NETWORK_SECUREPORT)}, `:"",n+=`CORS: ${ge.get(Ie.OPERATIONSAPI_NETWORK_CORS)?`enabled for ${ge.get(Ie.OPERATIONSAPI_NETWORK_CORSACCESSLIST)}`:"disabled"}`,n+=`, unix socket: ${ge.get(Ie.OPERATIONSAPI_NETWORK_DOMAINSOCKET)}
124
- `,n+=r("MQTT:"),n+=ge.get(Ie.MQTT_NETWORK_PORT)?`TCP: ${ge.get(Ie.MQTT_NETWORK_PORT)}, `:"",n+=ge.get(Ie.MQTT_NETWORK_SECUREPORT)?`TLS: ${ge.get(Ie.MQTT_NETWORK_SECUREPORT)}`:"",n+=ge.get(Ie.MQTT_WEBSOCKET)&&ge.get(Ie.HTTP_PORT)?`, WS: ${ge.get(Ie.HTTP_PORT)}`:"",n+=ge.get(Ie.MQTT_WEBSOCKET)&&ge.get(Ie.HTTP_SECUREPORT)?`, WSS: ${ge.get(Ie.HTTP_SECUREPORT)}
121
+ `);let s=Xo.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)}
125
125
  `:`
126
- `;let i=ge.get(Ie.REPLICATION_PORT)??ge.get(Ie.OPERATIONSAPI_NETWORK_PORT),o=ge.get(Ie.REPLICATION_SECUREPORT)??ge.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=LC.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=ge.get(Ie.HTTP_PORT)?`HTTP: ${ge.get(Ie.HTTP_PORT)}, `:"";p+=ge.get(Ie.HTTP_SECUREPORT)?`HTTPS: ${ge.get(Ie.HTTP_SECUREPORT)}, `:"",p.length>21&&(p=p.slice(0,-2));for(let _ of l)f[_]?n+=`${r(_+": ")}${f[_].slice(0,-2)}
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=MC.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)}
129
129
  `:n+=`${r(_+": ")}${p}
130
- `;console.log(n),ge.get(Ie.LOGGING_STDSTREAMS)&&fs.logsAtLevel("info")&&fs.suppressLogging(()=>{console.log(`Note that log messages are being sent to the console (stdout and stderr) in addition to the log file ${s}. This can be disabled by setting logging.stdStreams to false, and the log file can be directly monitored/tailed.`)})}a(_Se,"startupLog");function pSe(e){try{return Number.parseInt(Jo.readFileSync(e,"utf8"),10)}catch{return null}}a(pSe,"readPidFile");function hSe(e){try{return process.kill(e,0),!0}catch(t){return t.code==="EPERM"}}a(hSe,"isProcessRunning")});var $C=I(ea=>{"use strict";rm();var{isMainThread:vC,parentPort:Oh,threadId:BT,workerData:mSe}=require("node:worker_threads"),{Socket:ESe,createServer:gSe}=require("node:net"),{createServer:SSe,IncomingMessage:TSe}=require("node:http"),{createServer:ASe}=require("node:https"),{createSecureServer:RSe}=require("node:http2"),{Blob:ySe}=(As(),C(Fm)),{unlinkSync:sz,existsSync:bSe}=require("fs"),vn=Y(),ht=ce(),jt=(B(),C(G)),{server:Nh}=(Kr(),C(Tu)),{WebSocketServer:OSe}=require("ws"),{createServer:NSe}=require("node:tls"),{getTicketKeys:wSe,restartNumber:ISe,getWorkerIndex:Qd}=tt(),{Headers:UC,appendHeader:CSe}=(Q_(),C(bH)),{recordAction:Rh,recordActionBinary:JW}=($i(),C(j_)),{Request:iz,createReuseportFd:bh}=(jI(),C(OY)),{checkMemoryLimit:PSe}=yd(),{createTLSSelector:oz}=rs(),{resolvePath:az}=Rt(),{startupLog:DSe}=jd(),{Readable:XW}=require("node:stream"),LSe=yi(),cz=ht.get(jt.CONFIG_PARAMS.THREADS_DEBUG);if(cz){let e;if(vC)e=ht.get(jt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){vn.info("Could not close debugger",t)}});else{let t=ht.get(jt.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&Qd()>=0&&(e=t+Qd())}if(e){let t=ht.get(jt.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=ht.get(jt.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){vn.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&vC)try{require("inspector").open(9229)}catch(e){ISe<=1&&vn.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:MSe}=jt;ht.initSync();var vSe=ht.get(MSe.HTTP_SESSIONAFFINITY),to={},xC=new Map;ea.registerServer=FC;ea.httpServer=qC;ea.deliverSocket=kC;ea.startServers=lz;ea.listenOnPorts=uz;ea.globals=LSe;ea.when_components_loaded=null;Nh.http=qC;Nh.request=xSe;Nh.socket=BSe;Nh.ws=HSe;Nh.upgrade=_z;var yh={},xT={},HT={},BC=[];function lz(){return ea.when_components_loaded=qT().loadRootComponents(!0).then(()=>{Oh?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)kC(n,r,s);else if(t.requestId)USe(t);else if(t.type===jt.ITC_EVENT_TYPES.SHUTDOWN){vn.trace("received shutdown request",BT);for(let i in to){let o=to[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?vn.info(`Closing ${_.length} idle connections`):p&&vn.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
130
+ `;console.log(n),Se.get(Ie.LOGGING_STDSTREAMS)&&ds.logsAtLevel("info")&&ds.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(pSe,"startupLog");function hSe(e){try{return Number.parseInt(Jo.readFileSync(e,"utf8"),10)}catch{return null}}a(hSe,"readPidFile");function mSe(e){try{return process.kill(e,0),!0}catch(t){return t.code==="EPERM"}}a(mSe,"isProcessRunning")});var VC=w(ea=>{"use strict";rm();var{isMainThread:UC,parentPort:Oh,threadId:BT,workerData:ESe}=require("node:worker_threads"),{Socket:gSe,createServer:SSe}=require("node:net"),{createServer:TSe,IncomingMessage:ASe}=require("node:http"),{createServer:RSe}=require("node:https"),{createSecureServer:ySe}=require("node:http2"),{Blob:bSe}=(Ts(),C(Fm)),{unlinkSync:oz,existsSync:OSe}=require("fs"),Mn=z(),Et=ae(),Qt=(H(),C(q)),{server:Nh}=(Vr(),C(Tu)),{WebSocketServer:NSe}=require("ws"),{createServer:wSe}=require("node:tls"),{getTicketKeys:ISe,restartNumber:CSe,getWorkerIndex:Qd}=et(),{Headers:xC,appendHeader:PSe}=(Q_(),C(NH)),{recordAction:Rh,recordActionBinary:ZW}=(qi(),C(j_)),{Request:az,createReuseportFd:bh}=(QI(),C(wY)),{checkMemoryLimit:DSe}=yd(),{createTLSSelector:cz}=ts(),{resolvePath:lz}=yt(),{startupLog:LSe}=jd(),{Readable:ez}=require("node:stream"),MSe=Ri(),uz=Et.get(Qt.CONFIG_PARAMS.THREADS_DEBUG);if(uz){let e;if(UC)e=Et.get(Qt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){Mn.info("Could not close debugger",t)}});else{let t=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){Mn.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&UC)try{require("inspector").open(9229)}catch(e){CSe<=1&&Mn.trace("Could not start debugging on port 9229, you may already be debugging:",e.message)}process.on("uncaughtException",e=>{e.isHandled||e.code==="ECONNRESET"||e.code==="ECONNREFUSED"||e.message!=="write EIO"&&console.error("uncaughtException",e)});var{HDB_SETTINGS_NAMES:KUe,CONFIG_PARAMS:vSe}=Qt;Et.initSync();var USe=Et.get(vSe.HTTP_SESSIONAFFINITY),eo={},BC=new Map;ea.registerServer=GC;ea.httpServer=$C;ea.deliverSocket=FC;ea.startServers=dz;ea.listenOnPorts=fz;ea.globals=MSe;ea.when_components_loaded=null;Nh.http=$C;Nh.request=BSe;Nh.socket=HSe;Nh.ws=kSe;Nh.upgrade=hz;var yh={},xT={},HT={},HC=[];function dz(){return ea.when_components_loaded=qT().loadRootComponents(!0).then(()=>{Oh?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)FC(n,r,s);else if(t.requestId)xSe(t);else if(t.type===Qt.ITC_EVENT_TYPES.SHUTDOWN){Mn.trace("received shutdown request",BT);for(let i in eo){let o=eo[i],c;if(o.closeIdleConnections){let u=Object.getOwnPropertySymbols(o).find(p=>p.description.includes("connections")),f=0,d=setInterval(()=>{f++;let p=f>=100,_=o[u][p?"all":"idle"]();if(_.length===0){p&&clearInterval(d);return}f===1?Mn.info(`Closing ${_.length} idle connections`):p&&Mn.warn(`Forcefully closing ${_.length} active connections`);for(let h=0,S=_.length;h<S;h++){let g=_[h].socket;g._httpMessage&&!g._httpMessage.finished&&!p||(p?g.destroySoon():g.end(`HTTP/1.1 408 Request Timeout\r
131
131
  Connection: close\r
132
132
  \r
133
- `))}},25).unref()}o.close?.(()=>{if(ht.get(jt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&Qd()==0)try{sz(az(ht.get(jt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,BT),o.cantCleanupProperly||vn.warn("Had to forcefully exit the thread",BT),process.exit(0)},5e3).unref()})}if(cz||process.env.DEV_MODE)try{require("inspector").close()}catch(i){vn.info("Could not close debugger",i)}}}).ref();let e;bh&&!vSe&&(e=uz()),Promise.resolve(e).then(()=>{if(Qd()===0)try{DSe(xC)}catch(t){console.error("Error displaying start-up log",t)}Oh?.postMessage({type:jt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(lz,"startServers");function uz(){let e=[];for(let t in to){let r=to[t];if(t.includes?.("/")&&Qd()==0){bSe(t)&&sz(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),vn.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=ht.get(jt.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}),vn.trace("Listening on port "+t,BT)}).on("error",c)}))}return Promise.all(e)}a(uz,"listenOnPorts");!vC&&!mSe?.noServerStart&&lz();function kC(e,t,r){let n=e?.read?e:new ESe({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=to[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=to[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(vn.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(kC,"deliverSocket");var ZW=new Map;function USe(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=ZW.get(s),r){case"connection":i=kC(void 0,t),ZW.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(USe,"proxyRequest");var{getComponentName:kT}=(jp(),C(zp));function FC(e,t,r=!0){t||(t=ht.get(jt.CONFIG_PARAMS.HTTP_PORT));let n=to[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",nz),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else to[t]=e;e.on("unhandled",nz)}a(FC,"registerServer");function GC(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=[],ht.get(jt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:ht.get(jt.CONFIG_PARAMS.HTTP_PORT),secure:ht.get(jt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),ht.get(jt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:ht.get(jt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&ht.get(jt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:az(ht.get(jt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(GC,"getPorts");function qC(e,t){let r=[];for(let{port:n,secure:s}of GC(t))r.push(dz(n,s,t?.isOperationsServer,t?.mtls)),typeof e=="function"?BC[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,FC(e,n,!1)),HT[n]=GT(BC,n);return r}a(qC,"httpServer");function FT(e,t){let r=xC.get(e)??[];xC.set(e,[...r,t])}a(FT,"setPortServerMap");function dz(e,t,r,n){if(FT(e,{protocol_name:t?"HTTPS":"HTTP",name:kT()}),!xT[e]){let s=r?"operationsApi_network":"http",i=ht.get(s+"_keepAliveTimeout"),o=ht.get(s+"_timeout"),c=ht.get(s+"_headersTimeout"),l={keepAliveTimeout:i,headersTimeout:c,requestTimeout:o,highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,maxHeaderSize:ht.get(jt.CONFIG_PARAMS.HTTP_MAXHEADERSIZE)},u=ht.get(s+"_mtls"),f=ht.get(s+"_mtls_required"),d;t&&(d=ht.get(s+"_http2")??!r,Object.assign(l,{allowHTTP1:!0,rejectUnauthorized:!!f,requestCert:!!(u||n),ticketKeys:wSe(),SNICallback:oz(r?"operations-api":"server",u)}));let p=PSe(),_=xT[e]=(t?d?RSe:ASe:SSe)(l,async(h,S)=>{try{let A=performance.now(),E=new iz(h,S);r&&(E.isOperationsServer=!0);let R=await HT[e](E);if(!R){if(E._nodeResponse.statusCode)return;R=fz(E)}if(R.headers?.set||(R.headers=new UC(R.headers)),p?R.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):R.headers?.set?.("Server","HarperDB"),R.status===-1){for(let se of R.headers||[])S.setHeader(se[0],se[1]);return h.baseRequest=E,S.baseResponse=R,xT[e].emit("unhandled",h,S)}let N=R.status||200,v=performance.now(),k=v-A,F=R.body,K,re=!1;if(!R.handlesHeaders){let se=R.headers||new UC;F?F.length>=0?(typeof F=="string"?se.set("Content-Length",Buffer.byteLength(F)):se.set("Content-Length",F.length),K=!0):F instanceof ySe&&(F.size?se.set("Content-Length",F.size):F.on&&(re=!0,F.on("size",he=>{S.headersSent||S.setHeader("Content-Length",he)})),F=F.stream()):(se.set("Content-Length","0"),K=!0);let W=`hdb;dur=${k.toFixed(2)}`;if(R.wasCacheMiss&&(W+=", miss"),CSe(se,"Server-Timing",W,!0),!S.headersSent)if(re){if(S.statusCode=N,se)if(se[Symbol.iterator])for(let[he,Te]of se)S.setHeader(he,Te);else for(let he in se)S.setHeader(he,se[he])}else S.writeHead(N,se&&(se[Symbol.iterator]?Array.from(se):se));K&&S.end(F)}let ae=E.handlerPath,Z=E.method;if(Rh(k,"duration",ae,Z,R.wasCacheMiss==null?void 0:R.wasCacheMiss?"cache-miss":"cache-hit"),JW(N<400,"success",ae,Z),JW(1,"response_"+N,ae,Z),!K)if(F instanceof ReadableStream&&(F=XW.fromWeb(F)),(F[Symbol.iterator]||F[Symbol.asyncIterator])&&(F=XW.from(F)),F?.pipe){F.pipe(S),F.destroy&&S.on("close",()=>{F.destroy()});let se=0;F.on("data",W=>{se+=W.length}),F.on("end",()=>{Rh(performance.now()-v,"transfer",ae,Z),Rh(se,"bytes-sent",ae,Z)})}else F?.then?F.then(se=>{S.end(se)},g):S.end(F)}catch(A){g(A)}function g(A){let E=A.headers;S.writeHead(A.statusCode||500,E&&(E[Symbol.iterator]?Array.from(E):E)),S.end(A.toString()),A.statusCode?A.statusCode===500?vn.warn(A):vn.info(A):vn.error(A)}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),FC(_,e)}return xT[e]}a(dz,"getHTTPServer");function GT(e,t){let r=fz;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 fz(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new UC}}a(fz,"unhandled");function xSe(e,t){qC(e,{requestOnly:!0,...t})}a(xSe,"onRequest");function BSe(e,t){let r;if(t.securePort){FT(t.securePort,{protocol_name:"TLS",name:kT()});let n=oz("server",t.mtls);r=NSe({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),to[t.securePort]=r}return t.port&&(FT(t.port,{protocol_name:"TCP",name:kT()}),r=gSe(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),to[t.port]=r),r}a(BSe,"onSocket");Object.defineProperty(TSe.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.toLowerCase().includes("upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});var ez=[],HC={};function _z(e,t){for(let{port:r}of GC(t))ez[t?.runFirst?"unshift":"push"]({listener:e,port:r}),HC[r]=GT(ez,r)}a(_z,"onUpgrade");var tz=[],rz={};function HSe(e,t){let r=[];for(let{port:n,secure:s}of GC(t)){FT(n,{protocol_name:s?"WSS":"WS",name:kT()});let i=dz(n,s,t?.isOperationsServer,t?.mtls);yh[n]||(yh[n]=new OSe({noServer:!0,maxPayload:t.maxPayload??100*1024*1024}),yh[n].on("connection",(o,c)=>{let l=new iz(c);l.isWebSocket=!0;let u=HT[n](l);rz[n](o,l,u)}),_z((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)=>{HC[n]&&HC[n](o,c,l)})),r.push(i),tz[t?.runFirst?"unshift":"push"]({listener:e,port:n}),rz[n]=GT(tz,n),HT[n]=GT(BC,n)}return r}a(HSe,"onWebSocket");function nz(e,t){t.writeHead(404),t.end(`Not found
134
- `)}a(nz,"defaultNotFound")});var QW={};ve(QW,{startHTTPThreads:()=>FSe,startSocketServer:()=>zC,updateWorkerIdleness:()=>Rz});async function FSe(e=2,t){try{if(t)YC(0,1,!0);else{let{loadRootComponents:r}=qT();if(e===0)return(0,Fs.setMainIsWorker)(!0),await $C().startServers(),Promise.resolve([]);await r()}Az();for(let r=0;r<e;r++)YC(r,e);return Promise.all(Tz)}finally{(0,Fs.threadsHaveStarted)()}}function Az(){let e=(0,Ez.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),KC=setInterval(()=>{KT.notify(e)},kSe).unref())}function YC(e,t=1,r){if(VC++,(0,Fs.startWorker)("server/threads/threadServer.js",{name:JA.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===zA.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});Tz.push(s),await s,Jd.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=Jd.indexOf(n);o>-1&&Jd.splice(o,1)}if(a(i,"removeWorker"),Xd){let o=Xd;Xd=[];for(let c of o)Sz[c.localPort](null,c)}}}),r){let n=setInterval(()=>{WC?WC=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Fs.shutdownWorkers)(),VC=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function zC(e=0,t){if(typeof e=="string")try{(0,YT.existsSync)(e)&&(0,YT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=GSe:r=qSe(t):r=jC;let n=(0,Zd.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);return n._handle&&(n._handle.onconnection=Sz[e]=function(s,i){r.readsData||(i.reading=!1,i.readStop()),WC=!0,r(i,(o,c)=>{if(!o){if(pz){let u=i._socket||new Zd.Socket({handle:i,writable:!0,readable:!0});pz.deliverSocket(u,e,c),u.resume()}else VC>0?(Xd.length===0&&setTimeout(()=>{Xd.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,Xd.push(i)):(console.log("start up a dynamic thread to handle request"),YC(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 Zd.Socket({handle:i,writable:!0,readable:!0});KSe(u,o,e)}sr(!0,"socket-routed")})},KT.info(`HarperDB ${gz.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 jC(e,t){let r,n=0;for(let s of Jd){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 GSe(e,t){let r={};e.getpeername(r);let n=r.address,s=ef.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);jC(e,o=>{ef.set(n,{worker:o,lastUsed:i}),t(o)})}function qSe(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new Zd.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=ef.get(l),f=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=f,s(u.worker);jC(n,d=>{ef.set(l,{worker:d,lastUsed:f}),s(d,o)})})}a(r,"findByHeaderAffinity")}function Rz(){$T=0;for(let e of Jd)e.expectedIdle=e.recentELU.idle+$Se,e.requests=1;Jd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function KSe(e,t,r){let n=VSe++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),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 Fs,Zd,KT,YT,mz,Ez,gz,Jd,Xd,Sz,pz,VC,Tz,KC,kSe,WC,$T,hz,ef,$Se,VT,VSe,MC=be(()=>{Fs=M(tt()),Zd=require("net");B();KT=M(Y()),YT=require("fs");$i();mz=require("worker_threads"),Ez=M(yd()),gz=M(nt()),Jd=[],Xd=[],Sz=[],VC=0,Tz=[];mz.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Fs.onMessageFromWorkers)(e=>{e.type===QA.RESTART&&KC&&(clearInterval(KC),Az())}));kSe=6e5;a(FSe,"startHTTPThreads");a(Az,"licenseWarning");a(YC,"startHTTPWorker");a(zC,"startSocketServer");$T=0;a(jC,"findMostIdleWorker");hz=36e5,ef=new Map;a(GSe,"findByRemoteAddressAffinity");a(qSe,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of ef)r.lastUsed+hz<e&&ef.delete(t)},hz).unref();$Se=1e3;a(Rz,"updateWorkerIdleness");(0,Fs.setMonitorListener)(Rz);VT=new Map,VSe=1;a(KSe,"proxySocket")});var Bz=I((XUe,xz)=>{var bz=M(require("cluster")),lc=M(ce());B();var ro=M(Y()),Oz=M(require("fastify")),Nz=M(require("@fastify/cors")),wz=M(require("@fastify/compress")),Iz=M(require("@fastify/static")),Cz=M(SO()),Pz=M(require("path")),Dz=M(nt()),Lz=M(bs()),Mz=M(oe()),vz=M(Rn()),Uz=M(yd());Kr();var uc=M(pT());fo();lc.default.initSync();var YSe=6e4,WSe=1024*1024*1024,zSe="TRUE",{CONFIG_PARAMS:wh}=G,tf;xz.exports={hdbServer:yz,start:yz};async function yz(e){try{ro.default.debug("In Fastify server"+process.cwd()),ro.default.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),ro.default.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=bz.default.isMaster,await jSe();let t=e.securePort>0;tf=QSe(t),await tf.ready(),e||(e={}),e.isOperationsServer=!0;try{We.http(tf.server,e),tf.server.closeIdleConnections||await tf.listen({port:0,host:"::"})}catch(r){throw tf.close(),ro.default.error(r),ro.default.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),ro.default.fatal(t),process.exit(1)}}a(yz,"operationsServer");async function jSe(){ro.default.trace("Configuring HarperDB process."),Lz.default.setSchemaDataToGlobal(),await vz.default.setUsersWithRolesCache(),await Uz.default.getLicense()}a(jSe,"setUp");function QSe(e){ro.default.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=JSe(e),r=(0,Oz.default)(t);r.server.headersTimeout=ZSe(),r.setErrorHandler(uc.serverErrorHandler);let n=XSe();n&&r.register(Nz.default,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(Cz.default),r.register(wz.default),r.register(Iz.default,{root:Pz.default.join(Dz.PACKAGE_ROOT,"studio/build-local")}),jf(r);let s=lc.default.get(WA.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!Mz.default.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[uc.reqBodyValidationHandler,uc.authHandler],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),(0,uc.handlePostRequest)(i,o)}),r.get("/health",()=>"HarperDB is running."),ro.default.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(QSe,"buildServer");function JSe(e){let t=lc.default.get(wh.OPERATIONSAPI_NETWORK_TIMEOUT),r=lc.default.get(wh.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:WSe,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(JSe,"getServerOptions");function XSe(){let e=lc.default.get(wh.OPERATIONSAPI_NETWORK_CORS),t=lc.default.get(wh.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===zSe)&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},t&&t.length>0&&t[0]!==null&&t[0]!=="*"&&(r.origin=(n,s)=>s(null,t.indexOf(n)!==-1))),r}a(XSe,"getCORSOpts");function ZSe(){return lc.default.get(wh.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??YSe}a(ZSe,"getHeaderTimeoutConfig")});var tP={};ve(tP,{disableNATS:()=>tTe,publishToStream:()=>jT,setNATSReplicator:()=>QC,setPublishToStream:()=>rTe,setSubscription:()=>eP,start:()=>eTe});function eTe(){Ih.default.get(x.CLUSTERING_ENABLED)&&sTe()}function tTe(e=!0){qz=e}function rTe(e,t){jT=e,eP=t}function sTe(){if(qz||process.env._DISABLE_NATS)return;let e=Je(),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];QC(s,r,i)}}ml((r,n)=>{QC(r.tableName,r.databaseName,r),n&&Vz(r)}),!Hz&&(Hz=!0)}function QC(e,t,r){if(t==="system"&&iTe.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends Vr{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this.getId(),record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this.getId()})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this.getId(),record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this.getId(),record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this.getId()})}static defineSchema(i){Vz(i)}static subscribe(){let i=new kn;return eP(t,e,i),i}static subscribeOnThisThread(i){return i<(Ih.default.get(x.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??nTe)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new 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=$z;return i}a(n,"getNATSTransaction")}function Vz(e){let t=Ih.default.get(x.CLUSTERING_NODENAME);jT(`${XC.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,ZC.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 kz,XC,ZC,Fz,Gz,Ih,zT,qz,jT,eP,nTe,$z,Hz,iTe,WT,JC,Kz=be(()=>{Pe();ga();kz=M(ir()),XC=M(St()),ZC=M(To());_u();Fz=M(MO()),Gz=M(pn()),Ih=M(ce());B();zT=M(Y());a(eTe,"start");a(tTe,"disableNATS");jT=kz.publishToStream,eP=Fz.setSubscription;a(rTe,"setPublishToStream");nTe=2;a(sTe,"assignReplicationSource");iTe=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(QC,"setNATSReplicator");a(Vz,"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(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||(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(`${XC.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,ZC.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)}},JC=class extends WT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,Gz.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};$z=new JC});async function Qz({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await rP.get(e,{returnNonexistent:!0});i=new iP(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await rP.get(e);o&&o.delete()}i=new JT(e,t)}return n&&(n.id=e,n.user={username:t?.username},Ch.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function nP(){return QT++,QT>65500&&(QT=1),QT}function sP(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=Ii.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 Ot(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var Wz,dc,zz,jz,Yz,rP,Ch,QT,JT,iP,Jz=be(()=>{Pe();Su();Wz=M(pn()),dc=M(Y());Oc();zz=M(tt()),jz=M($C());Kr();Yz=100,rP=lt({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=lt({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,zz.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 sP(r,t,r)}catch{(0,dc.warn)("Failed to publish will",t)}Ch.delete(e.id)}})();a(Qz,"getSession");QT=1;a(nP,"getNextMessageId");JT=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(A=>A.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,dc.trace)("Resuming subscription from",s,"from",o);let _=Ii.getMatch(u,"mqtt");if(!_){let A=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw A.statusCode=404,A}if(p.url=_.relativeURL,p.url.indexOf("+")>-1||p.url.indexOf("#")>-1){let A=p.url.slice(1);if(A.indexOf("#")>-1&&A.indexOf("#")!==A.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(p.isCollection=!0,A.indexOf("+")===A.length-1)p.onlyChildren=!0,p.url="/"+A.slice(0,A.length-1);else{let E=A.split("/"),R;for(let k=0;k<E.length;k++)if(E[k].indexOf("+")>-1)if(E[k]==="+")R=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&R)throw new Error("Filters can not be combined");let N=!0;E[E.length-1]==="#"&&(E.length--,N=!1),R&&(n=a(k=>{let F=k.id;if(!Array.isArray(F))if(F?.indexOf?.("/")>-1)F=F.split("/");else return!1;if(N&&F.length!==E.length)return!1;for(let K=0;K<E.length;K++)if(E[K]!=="+"&&E[K]!==F[K])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 Ot(p,async()=>{let A=this.createContext();A.topic=s,A.retainHandling=i;let E=await S.subscribe(p,A);if(!E)return;if(!E[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let R=(async()=>{for await(let N of E)try{let v;if(N.type&&N.type!=="put"&&N.type!=="delete"&&N.type!=="message"&&N.type!=="patch"||n&&!n(N))continue;r?(N.topic=s,v=this.needsAcknowledge(N)):(N.acknowledge?.(),v=nP());let k=N.id;if(Array.isArray(k)&&(k=gu(k)),k==null&&(k=""),await this.listener(h+"/"+k,N.value,v,t)===!1)break;this.awaitingAcks?.size>Yz?await new Promise(K=>setTimeout(K,this.awaitingAcks.size-Yz)):await new Promise(setImmediate)}catch(v){(0,dc.warn)(v)}})();return E});if(g)return g.topic=s,g.qos=t.qos,this.subscriptions.push(g),g}resume(){}needsAcknowledge(t){let r=nP();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 sP(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();Ot(r,async()=>{try{if(!t){let n=await Ch.get(this.sessionId);n?.doesExist()&&await sP(n,n.data,r)}}finally{await Ch.delete(this.sessionId)}}).catch(n=>{(0,dc.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(sP,"publish");iP=class extends JT{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=nP(),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,dc.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,Wz.getNextMonotonicTime)()),(0,dc.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),rP.put(this.sessionRecord)}}});var aP={};ve(aP,{bypassAuth:()=>oTe,start:()=>aTe});function oTe(){rj=!0}function aTe({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new tj.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),_r.debug?.("Received WebSocket connection for MQTT from",u._socket.remoteAddress);let{onMessage:_,onClose:h}=Zz(u,S=>{u.send(S)},f,Promise.resolve(d).then(()=>f?.user),o);u.on("message",_),u.on("close",h),u.on("error",S=>{_r.info?.("WebSocket error",S)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let f;if(o.events.emit("connection",u),_r.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,rf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ZT.notify?.({username:f?.username,status:zs.SUCCESS,type:ua.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,rf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ZT.error?.({username:_,status:zs.FAILURE,type:ua.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),h}}else _r.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(_){o.events.emit("error",_,u),_r.error?.(_)}else if(l.required)return _r.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!f&&rj&&u.remoteAddress.includes("127.0.0.1")&&(f=await(0,ej.getSuperUser)(),_r.debug?.("Auto-authorizing local connection",f?.username));let{onMessage:d,onClose:p}=Zz(u,_=>u.write(_),null,f,o);u.on("data",d),u.on("close",p),u.on("error",_=>{_r.info?.("Socket error",_)})},{port:t,securePort:s,mtls:l})),c}function Zz(e,t,r,n,s){Xz||(Xz=!0,z_(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),es(!1,"connection","mqtt","disconnect"),_r.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"){_r.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,A(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,rf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ZT.notify?.({username:n?.username,status:zs.SUCCESS,type:ua.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(ae){return(0,rf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ZT.error?.({username:d.username,status:zs.FAILURE,type:ua.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,ae),es(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),es(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let ae=e.deserialize||(e.deserialize=po(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?ae(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(ae){return _r.error?.(ae),s.events.emit("auth-failed",d,e,ae),es(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:ae.code||5,returnCode:ae.code||128})}s.events.emit("connected",o,e),es(!0,"connection","mqtt","connect"),g({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0});let R=a(async(ae,Z,se,W)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",ae);let he=ae.indexOf("/",1),Te=he>0?ae.slice(0,he):ae;g({cmd:"publish",topic:ae,payload:await E(Z),messageId:se||Math.floor(Math.random()*1e8),qos:W.qos},Te);let Ce=e._socket??e;return Ce.writableNeedDrain?new Promise(me=>Ce.once("drain",me)):!Ce.closed}catch(he){return _r.error?.(he),o?.disconnect(),s.sessions.delete(o),!1}},"listener");o.setListener(R),o.sessionWasPresent&&await o.resume();break;case"subscribe":let N=[];for(let ae of d.subscriptions){let Z;try{let se=await o.addSubscription(ae,ae.qos>=1);Z=se?se.qos||0:c.protocolVersion<5?128:143}catch(se){s.events.emit("error",se,e,ae,o),se.statusCode?se.statusCode===500?_r.warn?.(se):_r.info?.(se):_r.error?.(se),Z=c.protocolVersion<5?128:se.statusCode===403?135:se.statusCode===404?143:128}N.push(Z)}await o.committed,g({cmd:"suback",granted:N,messageId:d.messageId});break;case"unsubscribe":{let ae=[];for(let Z of d.unsubscriptions)ae.push(o.removeSubscription(Z)?0:17);g({cmd:"unsuback",granted:ae,messageId:d.messageId});break}case"pubrel":g({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let v=d.qos===2?"pubrec":"puback",k=e.deserialize||(e.deserialize=po(r?.headers.get?.("content-type"))),K=(d.payload?.length||0)>0?k(d.payload):void 0,re;try{re=await o.publish(d,K)}catch(ae){s.events.emit("error",ae,e,d,o),_r.warn?.(ae),d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:re===!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),es(!0,"connection","mqtt","disconnect"),_r.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(R){s.events.emit("error",R,e,d,o),_r.error?.(R),g({cmd:"disconnect"})}function g(R,N){let v=(0,eA.generate)(R,c);t(v),sr(v.length,"bytes-sent",N,A(R),"mqtt")}a(g,"sendPacket");function A(R){return R.qos>0?R.cmd+",qos="+R.qos:R.cmd}a(A,"packetMethodName");function E(R){return ya(R,r)}a(E,"serialize")}),l.on("error",d=>{_r.warn("MQTT parsing error, closing connection:",d.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:f}}var eA,ej,rf,oP,tj,ZT,_r,rj,Xz,XT,nj=be(()=>{eA=require("mqtt-packet");Jz();ej=M(Rn());fo();$i();Kr();rf=M(ce());B();oP=M(Ci()),tj=require("events"),ZT=(0,oP.loggerWithTag)("auth-event"),_r=(0,oP.loggerWithTag)("mqtt"),rj=(0,rf.get)(x.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(oTe,"bypassAuth");a(aTe,"start");XT=0;a(Zz,"onSocket")});var zp={};ve(zp,{component_errors:()=>sf,getComponentName:()=>fTe,loadComponent:()=>nA,loadComponentDirectories:()=>lj,setErrorReporter:()=>dTe});function lj(e,t){t&&(lP=t),e&&(fP=e);let r=[];if((0,mt.existsSync)(cP)){let s=(0,mt.readdirSync)(cP,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,gt.join)(cP,o);r.push(nA(c,lP,$A,!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(nA(n,lP,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{cj=!0})}function dTe(e){Ph=e}async function nA(e,t,r,n,s,i){let o=(0,mt.realpathSync)(e);if(tA.has(o))return tA.get(o);tA.set(o,!0),s&&(fP=s);try{let c;n&&(sf=new Map);let l=(0,gt.join)(e,"harperdb-config.yaml");(0,mt.existsSync)(l)?c=n?(0,sA.getConfigObj)():(0,uP.parseDocument)((0,mt.readFileSync)(l,"utf8")).toJSON():!n&&(0,mt.existsSync)(l=(0,gt.join)(e,"config.yaml"))?c=(0,uP.parseDocument)((0,mt.readFileSync)(l,"utf8")).toJSON():c=_P;let u=(0,gt.join)(e,"node_modules","harperdb");try{Wl.isMainThread&&(n||(0,mt.existsSync)(u)&&(0,mt.realpathSync)(dP.PACKAGE_ROOT)!==(0,mt.realpathSync)(u))&&((0,mt.rmSync)(u,{recursive:!0,force:!0}),(0,mt.existsSync)((0,gt.join)(e,"node_modules"))||(0,mt.mkdirSync)((0,gt.join)(e,"node_modules")),(0,mt.symlinkSync)(dP.PACKAGE_ROOT,u,"dir"))}catch(p){nf.default.error("Error symlinking harperdb module",p)}let f=rA,d=n;for(let p in c){rA=p;let _=c[p];if(sf.set(n?p:(0,gt.basename)(e),!1),!_)continue;let h,S=_.package;try{if(S){let N=e,v;for(;!(0,mt.existsSync)(v=(0,gt.join)(N,"node_modules",p));)if(N=(0,gt.dirname)(N),N.length<(0,aj.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=uTe[p];if(!h)continue;let g=a(N=>(N.origin=r,lt(N)),"ensureTable"),A=_.network||(_.port||_.securePort)&&_,E=A?.securePort||A?.https&&A.port,R=!A?.https&&A?.port;if(Wl.isMainThread&&(h=await h.startOnMainThread?.({server:We,ensureTable:g,port:R,securePort:E,resources:t,..._})||h,n&&A))for(let N of[R,E])try{if(+N&&!sj.includes(N)){let v=pP.get(x.HTTP_SESSIONAFFINITY);v&&nf.default.warn("Session affinity is not recommended and may cause memory leaks"),(v||!ET)&&(sj.push(N),zC(N,v))}}catch(v){console.error("Error listening on socket",N,v,p)}if(t.isWorker&&(h=await h.start?.({server:We,ensureTable:g,port:R,securePort:E,resources:t,..._})||h),fP.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&_.files!=null){if(_.files.includes(".."))throw(0,oj.handleHDBError)("Can not reference parent directories");let N=(0,gt.join)(e,_.files).replace(/\\/g,"/"),v=N.indexOf("/*");if(v>-1&&_.files!==_P[p]?.files&&!(0,mt.existsSync)(N.slice(0,v)))throw new Error(`The path '${N.slice(0,v)}' does not exist and cannot be used as the base of the resolved 'files' path value '${_.files}'`);let k=(0,gt.basename)(e),F=_.path||"/";F=F.startsWith("/")?F:F.startsWith("./")?"/"+k+F.slice(2):F==="."?"/"+k:"/"+k+"/"+F;let K,re,ae;if(_.root){let se=_.root;se.startsWith("/")&&(se=se.slice(1)),se.endsWith("/")&&(se=se.slice(0,-1)),se+="/",re=(0,gt.join)(e,se)}else(ae=N.indexOf("/*"))>-1?(re=N.slice(0,ae+1),K=(0,gt.relative)(e,re)):_.files.indexOf("/")>-1&&(re=N.slice(0,N.lastIndexOf("/")+1),K=(0,gt.relative)(e,re));let Z=!1;if(Wl.isMainThread&&h.setupDirectory&&(Z=await h.setupDirectory?.(F,re,t)),t.isWorker&&h.handleDirectory&&(Z=await h.handleDirectory?.(F,re,t)),Z){d=!0;continue}for(let se of await(0,ij.default)(N,{onlyFiles:!1,objectMode:!0})){let{path:W,dirent:he}=se;d=!0;let Te=(0,gt.relative)(e,W).replace(/\\/g,"/");if(K)if(Te.startsWith(K))Te=Te.slice(K.length+1);else throw new Error(`The root path '${_.root}' does not reference a valid part of the file path '${Te}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Ce=F+(F.endsWith("/")?"":"/")+Te;try{if(he.isFile()){let me=await lTe(W);Wl.isMainThread&&await h.setupFile?.(me,Ce,W,t),t.isWorker&&await h.handleFile?.(me,Ce,W,t)}else Wl.isMainThread&&await h.setupDirectory?.(Ce,W,t),t.isWorker&&await h.handleDirectory?.(Ce,W,t)}catch(me){me.message=`Could not load ${he.isFile()?"file":"directory"} '${W}'${_.module?" using '"+_.module+"'":""} for application '${e}' due to: ${me.message}`,Ph?.(me),((0,of.getWorkerIndex)()===0?console:nf.default).error(me),t.set(_.path||"/",new Sa(me)),sf.set(n?p:(0,gt.basename)(e),me.message)}}}}catch(g){g.message=`Could not load component '${p}' for application '${(0,gt.basename)(e)}' due to: ${g.message}`,Ph?.(g),((0,of.getWorkerIndex)()===0?console:nf.default).error(g),t.set(_.path||"/",new Sa(g),null,!0),sf.set(n?p:(0,gt.basename)(e),g.message)}}if(rA=f,Wl.isMainThread&&!cj&&i&&(0,of.watchDir)(e,async()=>lj()),c.extensionModule){let p=await jE((0,gt.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,of.getWorkerIndex)()===0?console:nf.default).error(p),sf.set((0,gt.basename)(e),p)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,Ph?.(c),t.set("",new Sa(c))}}var mt,gt,Wl,uP,pP,dP,ij,of,nf,oj,aj,cTe,sA,lTe,cP,fP,cj,lP,sf,uTe,_P,sj,tA,Ph,rA,fTe,jp=be(()=>{mt=require("fs"),gt=require("path"),Wl=require("worker_threads"),uP=require("yaml"),pP=M(ce()),dP=M(nt());B();ML();mM();WB();JB();XB();vH();hY();AY();yY();ij=M(require("fast-glob")),of=M(tt()),nf=M(Y());nO();Kr();oj=M(pe());Pe();MC();aj=M(ce()),cTe=M(Bz());MS();Kz();ts();nj();sA=M(Rt());jI();ER();({readFile:lTe}=mt.promises),cP=(0,sA.resolvePath)(pP.get(x.COMPONENTSROOT)),fP=new Map,sf=new Map;a(lj,"loadComponentDirectories");uTe={REST:tg,rest:tg,graphql:UR,graphqlSchema:TR,roles:rO,jsResource:iO,fastifyRoutes:$I,login:aO,static:VI,operationsApi:cTe,customFunctions:{},http:{},clustering:tP,replication:Po,authentication:Gp,mqtt:aP,loadEnv:KI},_P={rest:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(_P,"static",{value:{files:"web/**"}});sj=[],tA=new Map;a(dTe,"setErrorReporter");fTe=a(()=>rA,"getComponentName");a(nA,"loadComponent")});var qT=I((I0e,dj)=>{var{isMainThread:uj}=require("worker_threads"),{getTables:_Te,getDatabases:N0e,table:w0e}=(Pe(),C(rt)),{loadComponentDirectories:pTe,loadComponent:hTe}=(jp(),C(zp)),{resetResources:mTe}=(Su(),C(CL)),ETe=kw(),gTe=Rt(),{dirname:STe}=require("path"),{getConnection:TTe}=ir(),ATe=ce(),{CONFIG_PARAMS:RTe}=(B(),C(G)),{loadCertificates:yTe}=rs(),hP=new Map;async function bTe(e=!1){!uj&&ATe.get(RTe.CLUSTERING_ENABLED)&&TTe();try{uj&&await ETe()}catch(n){console.error(n)}let t=mTe();_Te(),t.isWorker=e,await yTe(),await hTe(STe(gTe.getConfigFilePath()),t,"hdb",!0,hP),await pTe(hP,t);let r=[];for(let[n]of hP)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(bTe,"loadRootComponents");dj.exports.loadRootComponents=bTe});var tt=I((P0e,Ai)=>{"use strict";rm();var{Worker:OTe,MessageChannel:NTe,parentPort:no,isMainThread:TP,threadId:wTe,workerData:so}=require("worker_threads"),{PACKAGE_ROOT:ITe}=nt(),{join:hj,isAbsolute:CTe,extname:PTe}=require("path"),{server:mj}=(Kr(),C(Tu)),{watch:DTe,readdir:LTe}=require("fs/promises"),{totalmem:fj}=require("os"),af=(B(),C(G)),Ej=ce(),Ti=Y(),{randomBytes:MTe}=require("crypto"),{_assignPackageExport:vTe}=yi(),_j=1024*1024,fc=[],Gs=[],UTe=50,AP=1e4,xTe="restart",gj="request_thread_info",Sj="resource_report",Tj="thread_info",Aj="added-port",BTe="ack",mP;vTe("threads",Gs);Ai.exports={startWorker:EP,restartWorkers:yP,shutdownWorkers:qTe,workers:fc,setMonitorListener:QTe,onMessageFromWorkers:$Te,onMessageByType:Ij,broadcast:KTe,broadcastWithAcknowledgement:WTe,setChildListenerByType:GTe,getWorkerIndex:Rj,getWorkerCount:yj,getTicketKeys:Oj,setMainIsWorker:kTe,setTerminateTimeout:HTe,restartNumber:so?.restartNumber||1};Gs.onMessageByType=Ij;Gs.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Gs.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};Ai.exports.whenThreadsStarted=new Promise(e=>{Ai.exports.threadsHaveStarted=e});var RP;function HTe(e){AP=e}a(HTe,"setTerminateTimeout");function Rj(){return so?so.workerIndex:RP?0:void 0}a(Rj,"getWorkerIndex");function yj(){return so?so.workerCount:RP?1:void 0}a(yj,"getWorkerCount");function kTe(e){RP=e,Ai.exports.threadsHaveStarted()}a(kTe,"setMainIsWorker");var bj=1,iA;function Oj(){return iA||(iA=TP?MTe(48):so.ticketKeys,iA)}a(Oj,"getTicketKeys");Object.defineProperty(mj,"workerIndex",{get(){return Rj()}});Object.defineProperty(mj,"workerCount",{get(){return yj()}});var Nj={[gj](e,t){zTe(t)},[Sj](e,t){jTe(t,e)}};function EP(e,t={}){let r=process.constrainedMemory?.()||fj();r=Math.min(r,fj(),2e4*_j);let n=Ej.get(af.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 Gs){let u=new NTe;u.existingPort=l,i.push(u),o.push(u.port2)}PTe(e)||(e+=".js");let c=new OTe(CTe(e)?e:hj(ITe,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],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:Ai.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 aA(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>EP(e,t),c.on("error",l=>{Ti.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{fc.splice(fc.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<UTe?(t.unexpectedRestarts=c.unexpectedRestarts+1,EP(e,t)):Ti.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{Nj[l.type]?.(l,c)}),fc.push(c),XTe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(EP,"startWorker");var FTe=[af.THREAD_TYPES.HTTP];async function yP(e=null,t=Math.max(bj>3,1),r=!0){if(TP){try{process.chdir(process.cwd())}catch(o){Ti.error("Unable to reestablish current working directory",o)}if(r){let{loadRootComponents:o}=qT();await o()}Ai.exports.restartNumber++,t<1&&(t=t*fc.length);let n=[],s=[];for(let o of fc.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Ti.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Ai.exports.restartNumber,type:af.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=FTe.indexOf(o.name)>-1,l=new Promise(u=>{let f=setTimeout(()=>{Ti.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},AP*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===af.ITC_EVENT_TYPES.CHILD_STARTED&&(Ti.trace("Worker has started",u.threadId),d(),s.splice(s.indexOf(f)),u.off("message",p))},"startListener");Ti.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(af.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else no.postMessage({type:xTe,workerType:e})}a(yP,"restartWorkers");function GTe(e,t){Nj[e]=t}a(GTe,"setChildListenerByType");function qTe(e){return yP(e,1/0,!1)}a(qTe,"shutdownWorkers");var wj=[];function $Te(e){wj.push(e)}a($Te,"onMessageFromWorkers");var gP=new Map;function Ij(e,t){let r=gP.get(e);r||gP.set(e,r=[]),r.push(t)}a(Ij,"onMessageByType");var VTe=10;async function KTe(e,t){let r=0;for(let n of Gs)try{n.postMessage(e),r++>VTe&&(r=0,await new Promise(setImmediate))}catch(s){Ti.error("Unable to send message to worker",s)}t&&Pj(e,null)}a(KTe,"broadcast");var oA=new Map,YTe=1;function WTe(e){return new Promise(t=>{let r=0;for(let n of Gs)try{let s=YTe++,i=a(()=>{oA.delete(s),--r===0&&t(),n!==no&&--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){Ti.error("Unable to send message to worker",s)}r===0&&t()})}a(WTe,"broadcastWithAcknowledgement");function zTe(e){e.postMessage({type:Tj,workers:Cj()})}a(zTe,"sendThreadInfo");function Cj(){let e=Date.now();return fc.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(Cj,"getChildWorkerInfo");function jTe(e,t){e.resources=t,e.resources.updated=Date.now()}a(jTe,"recordResourceReport");var SP;function QTe(e){SP=e}a(QTe,"setMonitorListener");var JTe=1e3,pj=!1;function XTe(){pj||(pj=!0,setInterval(()=>{for(let e of fc){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}SP&&SP()},JTe).unref())}a(XTe,"startMonitoring");var ZTe=1e3;if(no&&so?.addPorts){aA(no);for(let e=0,t=so.addPorts.length;e<t;e++){let r=so.addPorts[e];r.threadId=so.addThreadIds[e],aA(r)}setInterval(()=>{let e=process.memoryUsage();no.postMessage({type:Sj,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},ZTe).unref(),mP=a(()=>new Promise((e,t)=>{no.on("message",r),no.postMessage({type:gj});function r(n){n.type===Tj&&(no.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else mP=Cj;Ai.exports.getThreadInfo=mP;function aA(e,t){Gs.push(e),e.on("message",r=>{if(r.type===Aj)r.port.threadId=r.threadId,aA(r.port);else if(r.type===BTe){let n=oA.get(r.id);n&&n()}else Pj(r,e)}).on("close",()=>{Gs.splice(Gs.indexOf(e),1)}).on("exit",()=>{Gs.splice(Gs.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(aA,"addPort");function Pj(e,t){for(let n of wj)n(e,t);let r=gP.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){Ti.error(s)}}a(Pj,"notifyMessageListeners");if(TP){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await LTe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(hj(s,o.name));try{for await(let{filename:o}of DTe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await yP(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");Ai.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else no.on("message",async e=>{let{type:t}=e;t===af.ITC_EVENT_TYPES.SHUTDOWN&&(Ai.exports.restartNumber=e.restartNumber,no.unref(),setTimeout(()=>{Ti.warn("Thread did not voluntarily terminate",wTe),process.exit(0)},AP).unref())})});var fB={};ve(fB,{ACTION_32_BIT:()=>Wm,ACTION_64_BIT:()=>rAe,AUDIT_STORE_OPTIONS:()=>xp,Decoder:()=>hl,HAS_BLOBS:()=>$n,HAS_CURRENT_RESIDENCY_ID:()=>xc,HAS_EXPIRATION_EXTENDED_TYPE:()=>n_,HAS_ORIGINATING_OPERATION:()=>r_,HAS_PREVIOUS_RESIDENCY_ID:()=>Bc,REMOTE_SEQUENCE_UPDATE:()=>vg,createAuditEntry:()=>bu,getLastRemoved:()=>EN,openAuditStore:()=>uA,readAuditEntry:()=>Nt,removeAuditEntry:()=>dA,setAuditRetention:()=>tAe,transactionKeyEncoder:()=>kj});function uA(e){let t=e.auditStore=e.openDB(bP.AUDIT_STORE_NAME,{create:!1,...xp});t||(t=e.auditStore=e.openDB(bP.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=NP;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()-OP/(1+i*i)})){try{p=dA(t,h,S)}catch(g){cf.warn("Error removing audit entry",g)}if(_=h,await new Promise(setImmediate),++d>=eAe){o=10;break}}await p}finally{d===0?o=Math.min(o<<1,OP/10):(Lj(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&&!Dj)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(Dj=!0,cf.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=nAe(r),s;if(n&$n){s=Nt(r);let i=e.tableStores[s.tableId],o=i.getEntry(s.recordId);(!o||o.version!==s.version||!o.value)&&Dc(()=>Aa(s.getValue(i)),i.rootStore)}if((n&15)===wP){s=s||Nt(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){IP[0]=t,e.put(Symbol.for("last-removed"),Fj)}function EN(e){let t=e.get(Symbol.for("last-removed"));if(t)return Fj.set(t),IP[0]}function tAe(e,t=NP){OP=e,NP=t}function bu(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?_c.setFloat64(0,n):qs.set(KR),h=9),l){if(l&255)throw new Error("Illegal extended type");h+=3}A(s),A(t),g(r),_c.setFloat64(h,e),h+=8,l&xc&&A(u),l&Bc&&A(f),l&n_&&(_c.setFloat64(h,d),h+=8),l&r_&&A(qj[p]),i?g(i):qs[h++]=0,l?_c.setUint32(n?8:0,_|l|3221225472):qs[n?8:0]=_;let S=qs.subarray(0,h);if(c)return Buffer.concat([S,c]);return S;function g(E){let R=h;h+=1,h=(0,zl.writeKey)(E,qs,h);let N=h-R-1;N>127?N>16383?(cf.error("Key or username was too large for audit entry",E),h=R+1,qs[R]=0):(qs.copyWithin(R+2,R+1,h),_c.setUint16(R,N|32768),h++):qs[R]=N}function A(E){E<128?qs[h++]=E:E<16384?(_c.setUint16(h,E|32768),h+=2):E<1056964608?(_c.setUint32(h,E|3221225472),h+=4):(qs[h]=255,_c.setUint32(h+1,E),h+=5)}}function nAe(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new hl(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function Nt(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&xc&&(p=n.readInt()),i&Bc&&(_=n.readInt()),i&n_&&(h=n.readFloat64()),i&r_){let E=n.readInt();S=qj[E]}l=n.readInt();let g=n.position,A=n.position+=l;return{type:Gj[i&7],tableId:c,nodeId:o,get recordId(){return(0,zl.readKey)(e,u,f)},getBinaryRecordId(){return e.subarray(u,f)},version:d,previousLocalTime:s,get user(){return A>g?(0,zl.readKey)(e,g,A):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(E,R,N){if(i&cA||i&Dh&&!R)return Dc(()=>E.decoder.decode(e.subarray(n.position,r)),E.rootStore);if(i&Dh&&N)return Gb(E.getEntry(this.recordId),N,E)},getBinaryValue(){return i&(cA|Dh)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:p,previousResidencyId:_,expiresAt:h,originatingOperation:S}}catch(n){return cf.error("Reading audit entry error",n,e),{}}}var zl,lA,bP,Lh,Hj,cf,qs,_c,kj,xp,OP,eAe,IP,Fj,NP,Dj,cA,Dh,Mj,wP,vj,Uj,xj,Bj,Wm,rAe,vg,xc,Bc,r_,n_,$n,Gj,qj,hl,ho=be(()=>{zl=require("ordered-binary"),lA=M(ce()),bP=M(vt());B();Lh=M(tt()),Hj=M(oe());Ou();cf=M(Y());xE();As();vT();(0,lA.initSync)();qs=Buffer.alloc(2816),_c=new DataView(qs.buffer,qs.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,zl.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,zl.readKey)(e,t,r)}},xp={encoding:"binary",keyEncoder:kj},OP=(0,Hj.convertToMS)((0,lA.get)(x.LOGGING_AUDITRETENTION))||86400*3,eAe=1e3,IP=new Float64Array(1),Fj=new Uint8Array(IP.buffer),NP=1e4,Dj=!1;a(uA,"openAuditStore");a(dA,"removeAuditEntry");a(Lj,"updateLastRemoved");a(EN,"getLastRemoved");a(tAe,"setAuditRetention");cA=16,Dh=32,Mj=1,wP=2,vj=3,Uj=4,xj=5,Bj=6,Wm=14,rAe=15,vg=11,xc=512,Bc=1024,r_=2048,n_=4096,$n=8192,Gj={put:Mj|cA,[Mj]:"put",delete:wP,[wP]:"delete",message:vj|cA,[vj]:"message",invalidate:Uj|Dh,[Uj]:"invalidate",patch:xj|Dh,[xj]:"patch",relocate:Bj,[Bj]:"relocate"},qj={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(bu,"createAuditEntry");a(nAe,"readAction");a(Nt,"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 DP(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=Vj,sAe(e.primaryStore,e.auditStore)):(c=$j,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{Kj($j[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[o];u||(u=l[o]=new Map,u.envs=l,u.tableId=o,u.store=e.primaryStore),t=gu(t);let f=new PP(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=Nt(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,CP.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,CP.info)(_)}}}if(l==null)break;let d=l.lastIndexOf?.("/",l.length-2);d!==l.length-1&&u++,d>-1?l=l.slice(0,d+1):l=null}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function sAe(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let l=Vj[s];if(!l)return;let u=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{Kj(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function Yj(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function UF(e){return e.nextTransaction||(DP({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),Yj(e)),e.nextTransaction}var CP,$j,Vj,PP,gN=be(()=>{CP=M(Y());_u();Su();ho();$j=Object.create(null),Vj=Object.create(null);a(DP,"addSubscription");PP=class extends kn{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(Kj,"notifyFromTransactionData");a(sAe,"listenToCommits");a(Yj,"nextTransaction");a(UF,"whenNextTransaction")});var bI={};ve(bI,{EVICTED:()=>Ea,INVALIDATED:()=>Fn,coerceType:()=>pA,makeTable:()=>mA,setServerUtilities:()=>fAe});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:A}=e;S??=0;let{attributes:E}=e;E||(E=[]);let R=zR(i,n,l),N,v,k={},F=Promise.resolve(),K,re,ae;for(let z of E)(z.assignCreatedTime||z.name==="__createdtime__")&&(K=z),(z.assignUpdatedTime||z.name==="__updatedtime__")&&(re=z),z.expiresAt&&(ae=z),z.isPrimaryKey&&(k=z);let Z,se=[],W=[],he=1,Te=2,Ce={},me={},Xt=864e5,ct=0,yr,gs,Bn,su=!1,iu,xA=new Map,BA=new Map,Dt,mf,jh=Ql.get(x.REPLICATION_DATABASES);if(Array.isArray(jh)){for(let z of jh)if(z.name===c&&z.replicateTo>=0){mf=z.replicateTo;break}}let Qh=i.getRange({start:!1,end:!1}).constructor,Ef=10,Jh=6;g&&Tf(),Ah(i.env.path,z=>{if(v)return ca(z)});class De extends Vr{#e;#t;#n;#r;#s;#i;static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=g;static databasePath=o;static databaseName=c;static attributes=E;static replicate=_;static sealed=d;static splitSegments=p??!0;static createdTimeProperty=K;static updatedTimeProperty=re;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return h}static dbisDB=f;static schemaDefined=u;static sourcedFrom(m,T){if(T&&(this.sourceOptions=T,(T.expiration||T.eviction||T.scanInterval)&&this.setTTLExpiration(T)),T?.intermediateSource)m.intermediateSource=!0,this.sources.unshift(m);else{if(this.sources.some(b=>!b.intermediateSource)){if(this.sources.some(b=>b.name===m.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(m)}v=v||m.get&&(!m.get.reliesOnPrototype||m.prototype.get),N=N||m.load;let O=a(b=>{let U=this.sources;if(U=U.filter(L=>L.intermediateSource&&L[b]&&(!L[b].reliesOnPrototype||L.prototype[b])),U.length>0)if(U.length===1){let L=U[0];return(P,H,$)=>{if(P?.source!==L)return L[b](H,$,P)}}else return(L,P,H)=>{let $=[];for(let j of U){if(L?.source===j)break;$.push(j[b](P,H,L))}return Promise.all($)}},"getApplyToIntermediateSource"),w=this.sources[this.sources.length-1];w.intermediateSource&&(w={});let y=a(b=>{if(w[b]&&(!w[b].reliesOnPrototype||w.prototype[b]))return(U,L,P)=>{if(!U?.source)return w[b](L,P,U)}},"getApplyToCanonicalSource");Ce={put:y("put"),patch:y("patch"),delete:y("delete"),publish:y("publish")},me={put:O("put"),patch:O("patch"),delete:O("delete"),publish:O("publish"),invalidate:O("invalidate")};let D=w.shouldRevalidateEvents;return(async()=>{let b=!1,U,L=a(async(P,H)=>{let $=P.value,j=P.table?$e[c][P.table]:De;if(c===yf&&(P.table===du.ROLE_TABLE_NAME||P.table===du.USER_TABLE_NAME)&&(b=!0),P.id===void 0&&(P.id=$[j.primaryKey],P.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(P));P.source=m;let Q={residencyId:uu(P.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:P.nodeId},q=await j.getResource(P.id,H,Q);switch(P.finished&&await P.finished,P.type){case"put":return D?q._writeInvalidate(Q):q._writeUpdate($,!0,Q);case"patch":return D?q._writeInvalidate(Q):q._writeUpdate($,!1,Q);case"delete":return q._writeDelete(Q);case"publish":return q._writePublish($,Q);case"invalidate":return q._writeInvalidate(Q);case"relocate":return q._writeRelocate(Q);default:xe.default.error?.("Unknown operation",P.type,P.id)}},"writeUpdate");try{let P=m.subscribe;P&&A==null&&(A=!0);let H={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},$=m.subscribeOnThisThread?m.subscribeOnThisThread((0,jl.getWorkerIndex)(),H):(0,jl.getWorkerIndex)()===0,j=P&&$&&await m.subscribe?.(H);if(j){let Q;for await(let q of j)try{if(!(q.type==="transaction"?q.writes[0]:q)){xe.default.error?.("Bad subscription event",q);continue}if(q.source=m,q.type==="end_txn"){if(Q?.resolve(),q.localTime&&U!==q.localTime){if(q.remoteNodeIds?.length>0){let fe=[Symbol.for("seq"),q.remoteNodeIds[0]],ie=f.get(fe),J=ie?.nodes;J||(J=[]);for(let ye of q.remoteNodeIds.slice(1)){let Re=J.find(Be=>Be.id===ye);J=J.filter(Be=>Be.id!==ye||Be===Re),Re||(Re={id:ye,seqId:0},J.push(Re)),Re.seqId=Math.max(ie?.seqId??1,q.localTime),ye===Q?.nodeId&&(Re.lastTxnTime=q.timestamp)}let le=Math.max(ie?.seqId??1,q.localTime);xe.default.trace?.("Received txn",c,new Date(le),new Date(q.localTime),q.remoteNodeIds),f.put(fe,{seqId:le,nodes:J})}U=q.localTime}q.onCommit&&Q?.committed.then(q.onCommit);continue}if(Q)if(q.beginTxn)Q.resolve();else{Q.write_promises.push(L(q,Q));continue}!q.timestamp&&q.version&&(q.timestamp=q.version);let te=Ot(q,()=>{if(q.type==="transaction"){let fe=[];for(let ie of q.writes)try{fe.push(L(ie,q))}catch(J){throw J.message+=" writing "+JSON.stringify(ie)+" of event "+JSON.stringify(q),J}return Promise.all(fe)}else if(q.type==="define_schema"){let fe=this.attributes.slice(0),ie;for(let J of q.attributes)fe.find(le=>le.name===J.name)||(fe.push(J),ie=!0);ie&&(lt({table:s,database:c,attributes:fe,origin:"cluster"}),vh.signalSchemaChange(new Uh.SchemaEventMsg(process.pid,$t.CREATE_TABLE,c,s)))}else return q.beginTxn?(Q=q,Q.write_promises=[L(q,q)],new Promise(fe=>{Q.resolve=()=>fe(Promise.all(Q.write_promises))})):L(q,q)});Q&&(Q.committed=te),b&&te&&!te?.waitingForUserChange&&(te.then(()=>vh.signalUserChange(new Uh.UserEventMsg(process.pid))),te.waitingForUserChange=!0),q.onCommit&&(te?te.then(q.onCommit):q.onCommit())}catch(ue){xe.default.error?.("error in subscription handler",ue)}}}catch(P){xe.default.error?.(P)}})(),this}static get isCaching(){return v}static get shouldRevalidateEvents(){return this.prototype.get!==De.prototype.get}static getResource(m,T,O){let w=super.getResource(m,T,O);if(m!=null){Ir(m);try{if(w.getRecord?.())return w;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let y=!O?.async||i.cache?.get?.(m),D=Gr(T),b=D.getReadTxn();if(b?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return ou(m,T,{transaction:b,ensureLoaded:O?.ensureLoaded},y,U=>{if(U?De._updateResource(w,U):w.#e=null,T.onlyIfCached&&T.noCacheStore){if(!w.doesExist())throw new wr.ServerError("Entry is not cached",504)}else if(O?.ensureLoaded){let L=dn(m,U,T,w);if(L)return D?.disregardReadTxn(),w.#i=!0,MP(L,P=>(De._updateResource(w,P),w))}return w})}catch(y){throw y.message.includes("Unable to serialize object")&&(y.message+=": "+JSON.stringify(m)),y}}return w}static _updateResource(m,T){m.#r=T,m.#e=T?.value??null,m.#n=T?.version}ensureLoaded(){let m=dn(this.getId(),this.#r,this.getContext());if(m)return this.#i=!0,MP(m,T=>{this.#r=T,this.#e=T.value,this.#n=T.version})}static getNewId(){let m=k?.type;if(m==="String"||m==="ID")return super.getNewId();if(!Dt){let y=i.getEntry(Symbol.for("id_allocation")),D=y?.value,b;if(D&&D.nodeName===server.hostname&&(!pAe(i)||D.pid===process.pid)){let U=D.start,L=D.end;b=U;for(let P of i.getKeys({start:L,end:U,limit:1,reverse:!0}))b=P}else D=w(y?.version??null),b=D.start;Dt=new BigInt64Array([BigInt(b)+1n]),Dt=new BigInt64Array(i.getUserSharedBuffer("id",Dt.buffer)),Dt.maxSafeId=D.end}let T=Number(Atomics.add(Dt,0,1n)),O=m==="Int"?512:1048576;if(T+O>=Dt.maxSafeId){let y=a(D=>{Dt.maxSafeId=T+(m==="Int"?1023:4194303);let b=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,U=D?void 0:i.useReadTransaction(),L=Number(Dt[0]);for(let $ of i.getKeys({start:L+1,end:b,limit:1,transaction:U}))b=$;U?.done();let{value:P,version:H}=i.getEntry(Symbol.for("id_allocation"));if(Dt.maxSafeId<b){if(P.end>Dt.maxSafeId-100)return;xe.default.info?.("New id allocation",T,Dt.maxSafeId,H),i.put(Symbol.for("id_allocation"),{start:P.start,end:Dt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),H)}else{xe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${Dt.maxSafeId}, but id of ${b} detected`);let $=w(H);$.alreadyUpdated||Atomics.store(Dt,0,BigInt($.start+1)),Dt.maxSafeId=$.end}},"updateEnd");T+O===Dt.maxSafeId?setImmediate(y):T+100>=Dt.maxSafeId&&(xe.default.warn?.(`Synchronous id allocation required on table ${s}${m=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>y(!0)))}return T;function w(y){let D=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,b=D/4,U,L,P=!1,H,$;do{H=Math.floor(Math.random()*D),$={start:H,end:H+(m==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},U=0;for(let j of i.getKeys({start:H,limit:1,reverse:!0}))U=j;L=D;for(let j of i.getKeys({start:H+1,end:D,limit:1}))L=j;b*=.875,b<1e3&&!P&&(P=!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":""}`,H,U,L,b))}while(!(b<L-H&&(b<H-U||U===0)));return i.transactionSync(()=>{let j=i.getEntry(Symbol.for("id_allocation"));return(j?.version??null)==y?(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,Xt=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Xt=Xt||(h+S)/4,ca()}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,T,O){if(De.getResidencyById)return De.getResidencyById(m[t]);let w=mf;if(T.replicateTo!=null){if(Array.isArray(T.replicateTo))return T.replicateTo.includes(server.hostname)?T.replicateTo:[server.hostname,...T.replicateTo];T.replicateTo>=0&&(w=T.replicateTo)}if(w>=0&&server.nodes){let y=[server.hostname];if(O)y.push(...O.slice(0,w));else{let D=server.nodes.map(L=>L.name),b=Math.floor(D.length*Math.random());y.push(...D.slice(b,b+w));let U=b+w-D.length;U>0&&y.push(...D.slice(0,U))}return y}}static enableAuditing(m=!0){g=m,m&&Tf(),De.audit=m}static coerceId(m){return m===""?null:pA(m,k)}static async dropTable(){delete $e[c][s];for(let m of i.getRange({versions:!0,snapshot:!1,lazy:!0}))m.metadataFlags&$n&&m.value&&Aa(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,$t.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this.isCollection)return this.search(m);if(this.getId()===null)return m?.conditions?this.search(m):{records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:E};if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this.getContext()?.returnNonexistent)return this}allowRead(m,T){let O=Sf(m);if(O?.read){if(O.isSuperUser)return!0;let w=O.attribute_permissions,y=T?.select;if(w?.length>0||su&&y){if(T||(T={}),y){let D=w?.length>0&&LP(w,"read");T.select=y.map(b=>{let U=b.name||b;if(!D||D[U]){let L=Bn[U]?.definition?.tableClass;if(L){if(b.name||(b={name:b}),!L.prototype.allowRead.call(null,m,b))return!1;if(!b.select)return b.name}return b}}).filter(Boolean)}else T.select=w.filter(D=>D.read&&!Bn[D.attribute_name]).map(D=>D.attribute_name);return T}else return!0}}allowUpdate(m,T){let O=Sf(m);if(O?.update){let w=O.attribute_permissions;if(w?.length>0){let y=LP(w,"update");for(let D in T)if(!y[D])return!1;for(let D of w){let b=D.attribute_name;!D.update&&!(b in T)&&(T[b]=this.getProperty(b))}}return aa(this.getContext())}}allowCreate(m,T){if(this.isCollection){let O=Sf(m);if(O?.insert){let w=O.attribute_permissions;if(w?.length>0){let y=LP(w,"insert");for(let D in T)if(!y[D])return!1;return aa(this.getContext())}else return aa(this.getContext())}}else return this.allowUpdate(m,{})}allowDelete(m){return Sf(m)?.delete&&aa(this.getContext())}update(m,T){if(!Gr(this.getContext()))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let w;return typeof m=="object"&&m&&(T?(Object.isFrozen(m)&&(m={...m}),this.#e={},this.#t=m):(w=this.#t,w&&(m=Object.assign(w,m)),this.#t=m)),this._writeUpdate(this.#t,T),this}addTo(m,T){if(typeof T=="number"||typeof T=="bigint")this.#s===zj?this.set(m,(+this.getProperty(m)||0)+T):(this.#s||this.update(),this.set(m,new kE(T)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,T){if(typeof T=="number")return this.addTo(m,-T);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this.#r}getRecord(){return this.#e}getChanges(){return this.#t}_setChanges(m){this.#t=m}setRecord(m){this.#e=m}invalidate(){this._writeInvalidate()}_writeInvalidate(m){let T=this.getContext(),O=this.getId();Ir(O),Gr(this.getContext()).addWrite({key:O,store:i,invalidated:!0,entry:this.#r,before:Ce.invalidate?.bind(this,T,O),beforeIntermediate:me.invalidate?.bind(this,T,O),commit:a((y,D)=>{if(oa(y,D,m?.nodeId)<=0)return;let b=null;for(let U in r)b||(b={}),b[U]=this.getProperty(U);xe.default.trace?.(`Invalidating entry id: ${O}, timestamp: ${new Date(y).toISOString()}`),R(O,b,this.#r,y,Fn,g,{user:T?.user,residencyId:m?.residencyId,nodeId:m?.nodeId},"invalidate")},"commit")})}_writeRelocate(m){let T=this.getContext(),O=this.getId();Ir(O),Gr(this.getContext()).addWrite({key:O,store:i,invalidated:!0,entry:this.#r,before:Ce.relocate?.bind(this,T,O),beforeIntermediate:me.relocate?.bind(this,T,O),commit:a((y,D)=>{if(oa(y,D,m?.nodeId)<=0)return;let b=De.getResidencyRecord(m.residencyId),U=0,L=null,P=D?.value;if(b&&!b.includes(server.hostname)){for(let H in r)L||(L={}),L[H]=P(H);U=Fn}else L=P;xe.default.trace?.(`Relocating entry id: ${O}, timestamp: ${new Date(y).toISOString()}`),R(O,L,this.#r,y,U,g,{user:T.user,residencyId:m.residencyId,nodeId:m.nodeId,expiresAt:m.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(m,T){let O={previousResidency:this.getResidencyRecord(m.residencyId),isRelocation:!0},w=this.getResidency(T.value,O),y;if(w){if(!Array.isArray(w))throw new Error("Residency must be an array, but was: "+w);if(!w.includes(server.hostname))return;y=uu(w)}let b=R(m.key,T.value,m,m.version,0,!0,{residencyId:y,expiresAt:T.expiresAt},"relocate",!1,null)}static evict(m,T,O){let w=this.Source,y;if(!((v||g)&&(!T||(y=i.getEntry(m),!y||!T)||y.version!==O))){if(v){if(i.hasLock(m,y.version))return;let D;for(let b in r)D||(D={}),D[b]=T[b];if(D)return R(m,D,y,O,Ea,null,null,null,!0)}if(i.ifVersion(m,O,()=>{un(m,T,null)}),g)return R(m,null,y,O,Ea,null,null,null,!0);Uc(i,y??i.getEntry(m),O)}}lock(){throw new Error("Not yet implemented")}static operation(m,T){return m.table||=s,m.schema||=c,rQ.operation(m,T)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,T,O){let w=this.getContext(),y=Gr(w),D=this.getId();Ir(D);let b=this.#r;this.#s=T?zj:lAe;let U={key:D,store:i,entry:b,nodeName:w?.nodeName,validate:a(L=>{m||(m=this.#t),T||m&&BE(this.#t===m?this:m)?w?.source||(y.checkOverloaded(),this.validate(m,!T),re&&(m[re.name]=re.type==="Date"?new Date(L):re.type==="String"?new Date(L).toISOString():L),T&&(t&&m[t]!==D&&(m[t]=D),K&&(b?.value?m[K.name]=b?.value[K.name]:m[K.name]=K.type==="Date"?new Date(L):K.type==="String"?new Date(L).toISOString():L),m=el(m))):y.removeWrite(U)},"validate"),before:T?Ce.put?()=>Ce.put(w,D,m):null:Ce.patch?()=>Ce.patch(w,D,m):Ce.put?()=>Ce.put(w,D,el(this)):null,beforeIntermediate:T?me.put?()=>me.put(w,D,m):null:me.patch?()=>me.patch(w,D,m):me.put?()=>me.put(w,D,el(this)):null,commit:a((L,P,H)=>{if(H){if(w&&P?.version>(w.lastModified||0)&&(w.lastModified=P.version),this.#r=P,P?.value&&P.value.getRecord)throw new Error("Can not assign a record to a record, check for circular references");T||(this.#e=P?.value??null)}this.#t=void 0,this.#n=L;let $=P?.value,j=m;this.#s=0;let Q=!1,q=oa(L,P,O?.nodeId),ue;if(q<=0)if(g){let le=P.localTime,ye=P.version;xe.default.trace?.("Applying CRDT update to record with id: ",D,"applying later update:",ye);let Re=[];for(;le>L||ye>=L&&le>0;){let Be=l.get(le);if(!Be)break;let it=Nt(Be);if(ye=it.version,ye>=L){if(ye===L){if(q=oa(L,{version:ye,localTime:le},O?.nodeId),q===0)return;if(q>0)continue}if(it.type==="patch")Re.push(it),ue=m;else if(it.type==="put"||it.type==="delete")return}le=it.previousLocalTime}Re.sort((Be,it)=>Be.version-it.version);for(let Be of Re){let it=Be.getValue(i);if(j=UE(j,it,T),xe.default.debug?.("Rebuilding update with future patch:",j),!j)return}}else{if(T)return;j=UE(j,$,T),xe.default.debug?.("Rebuilding update without audit:",j)}let te;if(T?te=j:(this.#e=$,te=el(this,j)),this.#e=te,te&&te.getRecord)throw new Error("Can not assign a record to a record, check for circular references");let fe;if(O?.residencyId!=null)fe=O.residencyId;else{b?.residencyId&&(w.previousResidency=De.getResidencyRecord(b.residencyId));let le=De.getResidency(te,w);if(le){if(!Array.isArray(le))throw new Error("Residency must be an array, got: "+le);if(!le.includes(server.hostname))if(ue??=te,Q=!0,De.getResidencyById)te=void 0;else{te=null;for(let ye in r)te||(te={}),te[ye]=ue[ye]}}fe=uu(le)}T||(ue=m);let ie=w?.expiresAt??(h?h+Date.now():-1);xe.default.trace?.(`Saving record with id: ${D}, timestamp: ${new Date(L).toISOString()}${ie?", expires at: "+new Date(ie).toISOString():""}${P?", replaces entry from: "+new Date(P.version).toISOString():", new entry"}`,(()=>{try{return JSON.stringify(te).slice(0,100)}catch{return""}})()),un(D,$,te);let J=T?"put":"patch";R(D,te,P,L,Q?Fn:0,g,{omitLocalRecord:Q,user:w?.user,residencyId:fe,expiresAt:ie,nodeId:O?.nodeId,originatingOperation:w?.originatingOperation},J,!1,ue),w.expiresAt&&ca()},"commit")};y.addWrite(U)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this.isCollection){for await(let T of this.search(m))(await De.getResource(T[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this.#e?this._writeDelete(m):!1}_writeDelete(m){let T=Gr(this.getContext()),O=this.getId();Ir(O);let w=this.getContext();return T.addWrite({key:O,store:i,entry:this.#r,nodeName:w?.nodeName,before:Ce.delete?.bind(this,w,O),beforeIntermediate:me.delete?.bind(this,w,O),commit:a((y,D,b)=>{let U=D?.value;b&&(w&&D?.version>(w.lastModified||0)&&(w.lastModified=D.version),De._updateResource(this,D)),!(oa(y,D,m?.nodeId)<=0)&&(un(this.getId(),U),xe.default.trace?.(`Deleting record with id: ${O}, txn timestamp: ${new Date(y).toISOString()}`),g||A?(R(O,null,this.#r,y,0,g,{user:w?.user,nodeId:m?.nodeId},"delete"),g||ca()):Uc(i,D))},"commit")}),!0}search(m){let T=this.getContext(),O=Gr(T);if(!m)throw new Error("No query provided");let w=m.conditions;w?w.length===void 0&&(w=w[Symbol.iterator]?Array.from(w):[w]):w=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this.getId()&&(w=[{attribute:null,comparator:Array.isArray(this.getId())?"prefix":"starts_with",value:this.getId()}].concat(w));let y,D={};function b(J,le){let ye;switch(le){case"and":case void 0:if(J.length<1)throw new Error('An "and" operator requires at least one condition');ye=!0;break;case"or":if(J.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+le)}for(let Re of J){if(Re.conditions){Re.conditions=b(Re.conditions,Re.operator);continue}let Be=Re[0]??Re.attribute,it=Be==null?k:wi(E,Be);if(it)(it.type||fR[Re.comparator])&&(Re[1]===void 0?Re.value=L(Re.value,it):Re[1]=L(Re[1],it));else if(Be!=null)throw(0,wr.handleHDBError)(new Error,`${Be} is not a defined attribute`,404);if(Re.chainedConditions)if(Re.chainedConditions.length===1&&(!Re.operator||Re.operator=="and")){let Cr=Re.chainedConditions[0],qr,Ae;if(Cr.comparator==="gt"||Cr.comparator==="greater_than"||Cr.comparator==="ge"||Cr.comparator==="greater_than_equal"?(qr=Re,Ae=Cr):(qr=Cr,Ae=Re),qr.comparator!=="lt"&&qr.comparator!=="less_than"&&qr.comparator!=="le"&&qr.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let et=Ae.comparator==="ge"||Ae.comparator==="greater_than_equal",Lt=qr.comparator==="le"||qr.comparator==="less_than_equal";Re.comparator=(et?"ge":"gt")+(Lt?"le":"lt"),Re.value=[Ae.value,qr.value]}else throw new Error("Multiple chained conditions are not currently supported")}return J}a(b,"prepareConditions");function U(J,le){if(m.enforceExecutionOrder)return J;for(let ye of J)ye.conditions&&(ye.conditions=U(ye.conditions,ye.operator));return J.length>1&&le!=="or"?(0,eQ.sortBy)(J,ym(De)):J}a(U,"orderConditions");function L(J,le){return Array.isArray(J)?J.map(ye=>pA(ye,le)):pA(J,le)}a(L,"coerceTypedValues");let P=m.operator;(w.length>0||P)&&(w=b(w,P));let H=typeof m.sort=="object"&&m.sort,$;if(H&&P!=="or"){let J=H.attribute;if(J==null)throw new wr.ClientError("Sort requires an attribute");if(y=w.find(le=>Eu(le.attribute)===Eu(J)),!y){let le=wi(E,J);if(!le)throw(0,wr.handleHDBError)(new Error,`${Array.isArray(J)?J.join("."):J} is not a defined attribute`,404);if(le.indexed)y={attribute:J,comparator:"sort"},w.push(y);else if(w.length===0&&!m.allowFullScan)throw(0,wr.handleHDBError)(new Error,`${Array.isArray(J)?J.join("."):J} is not indexed and not combined with any other conditions`,404)}y&&(y.descending=!!H.descending)}w=U(w,P),H&&(y&&w[0]===y?H.next&&($={dbOrderedAttribute:H.attribute,attribute:H.next.attribute,descending:H.next.descending,next:H.next.next}):(y&&w.splice(w.indexOf(y),1),$=H));let j=m.select;if(w.length===0&&(w=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:w,operator:P,postOrdering:$,selectApplied:!!j};let Q=O.useReadTxn(),q=_R(w,P,De,Q,m,T,(J,le)=>cu(J,j,T,Q,le),D),ue=m.ensureLoaded!==!1;$||(q=ie(q));let te=De.transformEntryForSelect(j,T,Q,D,ue,!0),fe=De.transformToOrderedSelect(q,j,$,Q,T,te);function ie(J){return m.offset||m.limit!==void 0?J.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):J}return a(ie,"applyOffset"),$&&(fe=ie(fe)),fe.onDone=()=>{fe.onDone=null,O.doneReadTxn()},fe.selectApplied=!0,fe.getColumns=()=>{if(j){let J=[];for(let le of j)le==="*"?J.push(...E.map(ye=>ye.name)):J.push(le.name||le);return J}return E.filter(J=>!J.computed&&!J.relationship).map(J=>J.name)},fe}static transformToOrderedSelect(m,T,O,w,y,D){let b=new Qh;if(O){m=cu(m,T,w,y,null);let U;b.iterate=function(){let P,H=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),$,j=O.dbOrderedAttribute,Q,q,ue=!0;function te(ie){let J=ie.next&&te(ie.next),le=ie.descending;return(ye,Re)=>{let Be=au(ye,ie.attribute,w),it=au(Re,ie.attribute,w),Cr=le?(0,Jl.compareKeys)(it,Be):(0,Jl.compareKeys)(Be,it);return Cr===0?J?.(ye,Re)||0:Cr}}a(te,"createComparator");let fe=te(O);return{async next(){let ie;if(P)if(ie=P.next(),ie.done){if($)return b.onDone&&b.onDone(),ie}else return{value:await D.call(this,ie.value)};U=[],Q&&U.push(Q);do if(ie=await H.next(),ie.done){if($=!0,U.length)break;return b.onDone&&b.onDone(),ie}else{let J=ie.value;if(J?.then&&(J=await J),j){let le=au(J,j,w);if(ue)ue=!1,q=le;else if(le!==q){q=le,Q=J;break}}U.push(J)}while(!0);return O.isGrouped,U.sort(fe),P=U[Symbol.iterator](),ie=P.next(),ie.done?(b.onDone&&b.onDone(),ie):{value:await D.call(this,ie.value)}},return(){b.onDone&&b.onDone(),H.return()},throw(){b.onDone&&b.onDone(),H.throw()}}};let L=a(P=>{if(typeof T=="object"&&Array.isArray(P.attribute))for(let H=0;H<T.length;H++){let $=T[H],j;if($.name===P.attribute[0]){for(j=$.sort||($.sort={});j.next;)j=j.next;j.attribute=P.attribute.slice(1),j.descending=P.descending}else $===P.attribute[0]&&(T[H]=j={name:$,sort:{attribute:P.attribute.slice(1),descending:P.descending}})}P.next&&L(P.next)},"applySortingOnSelect");L(O)}else b.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),b=b.map(function(U){try{let L=D.call(this,U);return typeof L?.catch=="function"?L.catch(P=>{throw P.partialObject={[t]:U.key},P}):L}catch(L){throw L.partialObject={[t]:U.key},L}});return b}static transformEntryForSelect(m,T,O,w,y,D){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let P=a(H=>(T?.transaction?.stale&&(T.transaction.stale=!1),H?.key??H),"transform");return m===t?P:m.asArray?H=>[P(H)]:H=>({[t]:P(H)})}let b;y&&v&&!(typeof m=="string"?[m]:m)?.every(P=>{let H;return typeof P=="object"?H=P.name:H=P,r[H]||H===t})&&(b=!0);let U,L=a(function(P){let H;if(T?.transaction?.stale&&(T.transaction.stale=!1),P!=null){if(H=P.value||P.deref?.()?.value,!H&&(P.key===void 0||P.deref)||P.metadataFlags&Fn){if(P.metadataFlags&Fn&&T.replicateFrom===!1&&D&&P.residencyId)return hc.SKIP;if(P=ou(P.key??P,T,{transaction:O,lazy:m?.length<4,ensureLoaded:y},this?.isSync,$=>$),P?.then)return P.then(L.bind(this));H=P?.value}if(b&&P?.metadataFlags&(Fn|Ea)||P?.expiresAt!=null&&P?.expiresAt<Date.now()){if(T.onlyIfCached&&T.noCacheStore)return{[t]:P.key,message:"This entry has expired"};let $=dn(P.key??P,P,T);if($?.then)return $.then(L)}}if(H==null)return D?hc.SKIP:H;if(m&&!(m[0]==="*"&&m.length===1)){let $,j=a((q,ue)=>{let te;typeof q=="object"?te=q.name:te=q;let fe=Bn?.[te],ie;if(fe){let J=w?.[te];if(J)if(J.hasMappings){let ye=fe.from?H[fe.from]:Eu(P.key);ie=J.get(ye),ie||(ie=[])}else ie=J.fromRecord?.(H);else ie=fe(H,T,P);let le=a(ye=>{if(ye&&typeof ye=="object"){let Re=fe.definition?.tableClass||De;U||(U={});let Be=U[te]||(U[te]=Re.transformEntryForSelect(te===q?null:q.select||(Array.isArray(q)?q:null),T,O,J,y));if(Array.isArray(ye)){let it=[],Cr=Re.transformToOrderedSelect(ye,q.select,typeof q.sort=="object"&&q.sort,T,O,Be)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),qr=a(et=>{for(;!et.done;){if(et?.then)return et.then(qr);it.push(et.value),et=Cr.next()}ue(it,te)},"nextValue"),Ae=qr(Cr.next());Ae&&($||($=[]),$.push(Ae));return}else if(ye=Be.call(this,ye),ye?.then){$||($=[]),$.push(ye.then(it=>ue(it,te)));return}}ue(ye,te)},"handleResolvedValue");ie?.then?($||($=[]),$.push(ie.then(le))):le(ie);return}else ie=H[te],ie&&typeof ie=="object"&&te!==q&&(ie=De.transformEntryForSelect(q.select||q,T,O,null)({value:ie}));ue(ie,te)},"selectAttribute"),Q;if(typeof m=="string")j(m,q=>{Q=q});else if(Array.isArray(m))if(m.asArray)Q=[],m.forEach((q,ue)=>{q==="*"?m[ue]=H:j(q,te=>Q[ue]=te)});else{Q={};let q=m.forceNulls;for(let ue of m)if(ue==="*")for(let te in H)Q[te]=H[te];else j(ue,(te,fe)=>{te===void 0&&q&&(te=null),Q[fe]=te})}else throw new wr.ClientError("Invalid select"+m);return $?Promise.all($).then(()=>Q):Q}return H},"transform");return L}async subscribe(m){if(!l)throw new Error("Can not subscribe to a table without an audit log");g||lt({table:s,database:c,schemaDefined:u,attributes:E,audit:!0}),m||(m={});let T=!m.rawEvents,O=[],w=this,y=DP(De,this.getId()??null,function(b,U,L,P){try{let H=U.getValue?.(i,T),$=U.type;if(!H&&$==="patch"&&T){let Q=i.getEntry(b);Q?.version===U.version?H=Q.value:H=U.getValue?.(i,!0,L),$="put"}let j={id:b,localTime:L,value:H,version:U.version,type:$,beginTxn:P};O?O.push(j):this.send(j)}catch(H){xe.default.error?.(H)}},m.startTime||0,m),D=(async()=>{this.isCollection&&(y.includeDescendants=!0,m.onlyChildren&&(y.onlyChildren=!0)),m.supportsTransactions&&(y.supportsTransactions=!0);let b=this.getId(),U=m.previousCount;U>1e3&&(U=1e3);let L=m.startTime;if(this.isCollection){if(L){if(U)throw new wr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:P,value:H}of l.getRange({start:L,exclusiveStart:!0,snapshot:!1})){let $=Nt(H);if($.tableId!==n)continue;let j=$.recordId;if(b==null||Xj(b,j)){let Q=$.getValue(i,T,P);if(y.send({id:j,localTime:P,value:Q,version:$.version,type:$.type}),y.queue?.length>Qj&&await y.waitForDrain()===!1)return}y.startTime=P}}else if(U){let P=[];for(let{key:H,value:$}of l.getRange({start:"z",end:!1,reverse:!0}))try{let j=Nt($);if(j.tableId!==n)continue;let Q=j.recordId;if(b==null||Xj(b,Q)){let q=j.getValue(i,T,H);if(P.push({id:Q,localTime:H,value:q,version:j.version,type:j.type}),--U<=0)break}}catch(j){xe.default.error("Error getting history entry",H,j)}for(let H=P.length;H>0;)y.send(P[--H]);P[0]&&(y.startTime=P[0].localTime)}else if(!m.omitCurrent){for(let{key:P,value:H,version:$,localTime:j}of i.getRange({start:b??!1,end:b==null?void 0:[b,Jl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(H&&(y.send({id:P,localTime:j,value:H,version:$,type:"put"}),y.queue?.length>Qj&&await y.waitForDrain()===!1))return}}else{U&&!L&&(L=0);let P=this.#r?.localTime;if(P===WR&&(i.cache?.delete(b),this.#r=i.getEntry(b),xe.default.trace?.("re-retrieved record",P,this.#r?.localTime),P=this.#r?.localTime),xe.default.trace?.("Subscription from",L,"from",b,P),L<P){let H=[],$=P;do{let j=l.get($);if(j){m.omitCurrent=!0;let Q=Nt(j),q=Q.getValue(i,T,$);T&&(Q.type="put"),H.push({id:b,value:q,localTime:$,...Q}),$=Q.previousLocalTime}else break;U&&U--}while($>L&&U!==0);for(let j=H.length;j>0;)y.send(H[--j]);y.startTime=P}!m.omitCurrent&&this.doesExist()&&y.send({id:b,localTime:P,value:this.#e,version:this.#n,type:"put"})}for(let P of O)y.send(P);O=null})();return m.listener&&y.on("data",m.listener),y}static subscribeOnThisThread(m,T){return m===0||T?.crossThreads===!1}doesExist(){return!!(this.#e||this.#s)}publish(m,T){this._writePublish(m,T)}_writePublish(m,T){let O=Gr(this.getContext()),w=this.getId()||null;w!=null&&Ir(w);let y=this.getContext();O.addWrite({key:w,store:i,entry:this.#r,nodeName:y?.nodeName,validate:a(()=>{y?.source||(O.checkOverloaded(),this.validate(m))},"validate"),before:Ce.publish?.bind(this,y,w,m),beforeIntermediate:me.publish?.bind(this,y,w,m),commit:a((D,b,U)=>{b===void 0&&A&&!g&&ca(),xe.default.trace?.(`Publishing message to id: ${w}, timestamp: ${new Date(D).toISOString()}`),R(w,b?.value??null,b,b?.version||D,0,!0,{user:y?.user,residencyId:T?.residencyId,expiresAt:y?.expiresAt,nodeId:T?.nodeId},"message",!1,m)},"commit")})}validate(m,T){let O,w=a((y,D,b)=>{if(D.type&&y!=null)if(T&&y.__op__&&(y=y.value),D.properties){typeof y!="object"&&(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be an object${D.type?" ("+D.type+")":""}`);let U=D.properties;for(let L=0,P=U.length;L<P;L++){let H=U[L],$=w(y[H.name],H,b+"."+H.name);$&&(y[H.name]=$)}if(D.sealed&&y!=null&&typeof y=="object")for(let L in y)U.find(P=>P.name===L)||(O||(O=[])).push(`Property ${L} is not allowed within object in property ${b}`)}else switch(D.type){case"Int":(typeof y!="number"||y>>0!==y)&&(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof y!="number"||!(Math.floor(y)===y&&Math.abs(y)<=9007199254740992))&&(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof y!="number"&&(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a number`);break;case"ID":typeof y=="string"||y?.length>0&&y.every?.(U=>typeof U=="string")||(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a string, or an array of strings`);break;case"String":typeof y!="string"&&(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a string`);break;case"Boolean":typeof y!="boolean"&&(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a boolean`);break;case"Date":if(!(y instanceof Date)){if(typeof y=="string"||typeof y=="number")return new Date(y);(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a Date`)}break;case"BigInt":if(typeof y!="bigint"){if(typeof y=="string"||typeof y=="number")return BigInt(y);(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a bigint`)}break;case"Bytes":if(!(y instanceof Uint8Array)){if(typeof y=="string")return Buffer.from(y);(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(y instanceof Pi)){if(typeof y=="string"&&(y=Buffer.from(y)),y instanceof Buffer)return createBlob(y,{type:"text/plain"});(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a Blob`)}break;case"array":if(Array.isArray(y)){if(D.elements)for(let U=0,L=y.length;U<L;U++){let P=y[U],H=w(P,D.elements,b+"[*]");H&&(y[U]=H)}}else(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be an Array`);break}D.nullable===!1&&y==null&&(O||(O=[])).push(`Property ${b} is required (and not does not allow null values)`)},"validateValue");for(let y=0,D=E.length;y<D;y++){let b=E[y];if(!(b.relationship||b.computed)&&(!T||b.name in m)){let U=w(m[b.name],b,b.name);U&&(m[b.name]=U)}}if(d)for(let y in m)E.find(D=>D.name===y)||(O||(O=[])).push(`Property ${y} is not allowed`);if(O)throw new wr.ClientError(O.join(". "))}getUpdatedTime(){return this.#n}wasLoadedFromSource(){return v?!!this.#i:void 0}static async addAttributes(m){let T=E.slice(0);for(let O of m){if(!O.name)throw new wr.ClientError("Attribute name is required");if(O.name.match(/[`/]/))throw new wr.ClientError("Attribute names cannot include backticks or forward slashes");(0,tQ.validateAttribute)(O.name),T.push(O)}return lt({table:s,database:c,schemaDefined:u,attributes:T}),De.indexingOperation}static async removeAttributes(m){let T=E.filter(O=>!m.includes(O.name));return lt({table:s,database:c,schemaDefined:u,attributes:T}),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,T=_A.default.statfsSync?.(m)??{};return{available:T.bavail*T.bsize,free:T.bfree*T.bsize,size:T.blocks*T.bsize}}static async getRecordCount(m){let T=i.getStats().entryCount,O=1e3/2,w=performance.now(),y=Math.floor(T/2),D=m?.exactCount,b=0,U=0,L;for(let{value:P}of i.getRange({start:!0,lazy:!0,snapshot:!1}))if(P!=null&&b++,U++,await pc(),!D&&U<y&&performance.now()-w>O){L=U;break}if(L){let P=b;b=0;for(let{value:ie}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:L,snapshot:!1}))ie!=null&&b++,await pc();let H=L*2,$=(b+P)/H,j=Math.pow((b-P+1)/L/2,2)+$*(1-$)/H,Q=Math.max(Math.sqrt(j)*T,1),q=Math.round($*T),ue=Math.max(q-1.96*Q,b+P),te=Math.min(q+1.96*Q,T),fe=Math.pow(10,Math.round(Math.log10(Q)));return fe>q&&(fe=fe/10),b=Math.round(q/fe)*fe,{recordCount:b,estimatedRange:[Math.round(ue),Math.round(te)]}}return{recordCount:b}}static updatedAttributes(){Bn=this.propertyResolvers={$id:a((m,T,O)=>({value:O.key}),"$id"),$updatedtime:a((m,T,O)=>O.version,"$updatedtime"),$record:a((m,T,O)=>O?{value:m}:m,"$record")};for(let m of this.attributes){m.resolve=null;let T=m.relationship,O=m.computed;if(T)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),O&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),su=!0,T.to)m.elements?.definition?(Bn[m.name]=m.resolve=(w,y,D)=>{let b=w[T.from?T.from:t],U=m.elements.definition.tableClass;return D?mu({attribute:T.to,value:b},Gr(y).getReadTxn(),!1,U,!1).asArray:U.search([{attribute:T.to,value:b}],y).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,T.from&&(m.resolve.from=T.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(T.from){let w=m.definition||m.elements?.definition;w?(Bn[m.name]=m.resolve=(y,D,b)=>{let U=y[T.from];if(U!==void 0){if(m.elements){let L,P=U?.map(H=>{let $=b?w.tableClass.primaryStore.getEntry(H,{transaction:Gr(D).getReadTxn()}):w.tableClass.get(H,D);return $?.then&&(L=!0),$});return T.filterMissing?L?Promise.all(P).then(H=>H.filter(Zj)):P.filter(Zj):L?Promise.all(P):P}return b?w.tableClass.primaryStore.getEntry(U,{transaction:Gr(D).getReadTxn()}):w.tableClass.get(U,D)}},m.set=(y,D)=>{if(Array.isArray(D)){let b=D.map(U=>U.getId?.()||U[w.tableClass.primaryKey]);y[T.from]=b}else{let b=D.getId?.()||D[w.tableClass.primaryKey];y[T.from]=b}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=T.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`);else O&&(typeof O.from=="function"&&this.setComputedAttribute(m.name,O.from),Bn[m.name]=m.resolve=(w,y,D)=>{let b=typeof O.from=="string"?w[O.from]:w,U=this.userResolvers[m.name];if(U)return U(b,y,D);xe.default.warn(`Computed attribute "${m.name}" does not have a function assigned to it. Please use setComputedAttribute('${m.name}', resolver) to assign a resolver function.`),this.userResolvers[m.name]=()=>{}})}FE(this,this)}static setComputedAttribute(m,T){let O=wi(E,m);if(!O){console.error(`The attribute "${m}" does not exist in the table "${s}"`);return}if(!O.computed){console.error(`The attribute "${m}" is not defined as computed in the table "${s}"`);return}this.userResolvers[m]=T}static async deleteHistory(m=0,T=!1){let O;for(let{key:w,value:y}of l.getRange({start:0,end:m}))await pc(),Nt(y).tableId===n&&(O=dA(l,w,y));if(T)for(let w of i.getRange({start:0,versions:!0})){let{key:y,value:D,localTime:b}=w;await pc(),D===null&&b<m&&(O=Uc(i,w))}await O}static async*getHistory(m=0,T=1/0){for(let{key:O,value:w}of l.getRange({start:m||1,end:T})){await pc();let y=Nt(w);y.tableId===n&&(yield{id:y.recordId,localTime:O,version:y.version,type:y.type,value:y.getValue(i,!0,O),user:y.user,operation:y.originatingOperation})}}static async getHistoryOfRecord(m){let T=[];if(m==null)throw new Error("An id is required");let O=i.getEntry(m);if(!O)return T;let w=O.localTime;if(!w)throw new Error("The entry does not have a local audit time");let y=0;do{await pc();let D=l.get(w);if(D){let b=Nt(D);T.push({id:b.recordId,localTime:w,version:b.version,type:b.type,value:b.getValue(i,!0,w),user:b.user}),w=b.previousLocalTime}else break}while(y<1e3&&w);return T.reverse()}static cleanup(){Z?.remove()}}De.updatedAttributes();let gf=De.prototype;return h&&De.setTTLExpiration(h/1e3),ae&&lu(),De;function un(z,m,T){let O;for(let w in r){let y=r[w],D=y.isIndexing,b=Bn[w],U=T&&(b?b(T):T[w]),L=m&&(b?b(m):m[w]);if(U===L&&!D)continue;O=!0;let P=y.indexNulls,H=(0,Mh.getIndexedValues)(U,P),$=(0,Mh.getIndexedValues)(L,P);if($?.length>0){let j=new Set($);if(H=H?H.filter(Q=>{if(j.has(Q))j.delete(Q);else return!0}):[],$=Array.from(j),($.length>0||H.length>0)&&Wj){let Q=$.concat(H).map(q=>({key:q,value:z}));y.prefetch(Q,Jj)}for(let Q=0,q=$.length;Q<q;Q++)y.remove($[Q],z)}else H?.length>0&&Wj&&y.prefetch(H.map(j=>({key:j,value:z})),Jj);if(H)for(let j=0,Q=H.length;j<Q;j++)y.put(H[j],z)}return O}a(un,"updateIndices");function Ir(z){switch(typeof z){case"number":return!0;case"string":if(z.length<659)return!0;if(z.length>jj)throw new Error("Primary key size is too large: "+z.length);break;case"object":if(z===null)throw new Error("Invalid primary key of null");break;case"bigint":if(z<2n**64n&&z>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof z)}if((0,Jl.writeKey)(z,uAe,0)>jj)throw new Error("Primary key size is too large: "+z.length);return!0}a(Ir,"checkValidId");function ou(z,m,T,O,w){if(De.getResidencyById&&T.ensureLoaded&&m?.replicateFrom!==!1){let D=De.getResidencyById(z);if(D&&!D.includes(server.hostname)&&N)return N({key:z,residency:D}).then(w)}let y=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),T.transaction?.isDone)return w(null,z);let D=i.getEntry(z,T);return D?.residencyId&&D.metadataFlags&Fn&&N&&T.ensureLoaded&&m?.replicateFrom!==!1?N(D).then(b=>w(b,z),b=>(xe.default.error?.("Error loading remote record",z,D,T,b),w(null,z))):(D&&m&&(D?.version>(m.lastModified||0)&&(m.lastModified=D.version),D?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=D.localTime)),w(D,z))},"whenPrefetched");return O?y():he>0?(he--,y()):new Promise((D,b)=>{he===0?(he--,i.prefetch([z],()=>{U(),L()})):(se.push(z),W.push(L),se.length>Jh&&(he--,U()));function U(){if(se.length>0){let P=W;i.prefetch(se,()=>{he===-1?U():he++;for(let H of P)H()}),se=[],W=[],Te>2&&Te--}else he=Te,Te<Ef&&Te++}a(U,"prefetch");function L(){try{D(y())}catch(P){b(P)}}a(L,"load")})}a(ou,"loadLocalRecord");function Sf(z){if(!z?.role)return;let m=z.role.permission;if(m.super_user)return dAe;let T=m[c],O,w=T?.tables;if(w)return w[s];if(c==="data"&&(O=m[s])&&!O.tables)return O}a(Sf,"getTablePermissions");function dn(z,m,T,O){if(v){let w=!1;if(T.noCache?w=!0:(m?(!m.value||m.metadataFlags&(Fn|Ea)||m.expiresAt!=null&&m.expiresAt<Date.now())&&(w=!0):w=!0,es(!w,"cache-hit",s)),w){let y=Xh(z,m,T).then(D=>(D?.value&&D?.value.getRecord?.()&&xe.default.error?.("Can not assign a record that is already a resource"),T&&(D?.version>(T.lastModified||0)&&(T.lastModified=D.version),T.lastRefreshed=Date.now()),D));if(T?.onlyIfCached||m?.value&&O?.allowStaleWhileRevalidate?.(m,z)){if(y.catch(D=>xe.default.warn?.(D)),T?.onlyIfCached&&!O.doesExist())throw new wr.ServerError("Entry is not cached",504);return}else return y}}else if(m?.value&&m.expiresAt!=null&&m.expiresAt<Date.now())return De.evict(m.key,m.value,m.version),m.value=null,{then(w){return w(m)}}}a(dn,"ensureLoadedFromSource");function Gr(z){let m=z?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let T=m.next;if(!T)return m=m.next=new bc,m.lmdbDb=i,m;m=T}while(!0)}else return new Tm}a(Gr,"txnForContext");function au(z,m,T){if(!z)return;let O=z.value||i.getEntry(z.key)?.value;if(typeof m=="object"){let y=Bn,D=O;for(let b=0,U=m.length;b<U;b++){let L=m[b],P=y?.[L];D=P&&D?P(D,T,!0)?.value:D?.[L],y=P?.definition?.tableClass?.propertyResolvers}return D}let w=Bn[m];return w?w(O,T):O[m]}a(au,"getAttributeValue");function cu(z,m,T,O,w){let y=w?.length,D={transaction:O,lazy:y>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},b;function U(L,P){let H=L?.value;if(!H)return hc.SKIP;for(let $=0;$<y;$++)if(!b?.includes($)&&!w[$](H,L))return hc.SKIP;return P!==void 0&&(L.key=P),L}if(a(U,"processEntry"),y>0||!z.hasEntries){let L=z.map(P=>{if(b=null,typeof P=="object"&&P?.key!==void 0)return y>0?U(P):P;if(P==null)return hc.SKIP;for(let H=0;H<y;H++){let j=w[H].idFilter;if(j){if(!j(P))return hc.SKIP;b||(b=[]),b.push(H)}}return ou(P,T,D,!1,U)});return Array.isArray(z)&&(L=L.filter(P=>P!==hc.SKIP)),L.hasEntries=!0,L}return z}a(cu,"transformToEntries");function oa(z,m,T=server.replication?.getThisNodeId(l)){if(z<=m?.version){if(m?.version===z&&T!==void 0){let O=server.replication?.exportIdMapping(l),w=m.localTime,y=w&&l.get(w);if(y){let D,b,U=Nt(y);for(let L in O)O[L]===T&&(D=L),O[L]===U.nodeId&&(b=L);if(D>b)return 1;if(D===b)return 0}}return-1}return 1}a(oa,"precedesExistingVersion");async function Xh(z,m,T){let O=m?.metadataFlags,w=m?.version,y,D;if(!i.attemptLock(z,w,()=>{clearTimeout(D);let P=i.getEntry(z);!P||!P.value||P.metadataFlags&(Fn|Ea)?y(Xh(z,i.getEntry(z),T)):y(P)}))return new Promise(P=>{y=P,D=setTimeout(()=>{i.unlock(z,w)},cAe)});let b=m?.value,U={requestContext:T,replacingRecord:b,replacingEntry:m,replacingVersion:w,noCacheStore:!1,source:null,resourceCache:T?.resourceCache},L=T?.responseHeaders;return new Promise((P,H)=>{let $;MP(Ot(U,async j=>{let Q=performance.now(),q,ue,te;try{for(let le of De.sources)if(le.get&&(!le.get.reliesOnPrototype||le.prototype.get)){if(le.available?.(m)===!1)continue;if(U.source=le,q=await le.get(z,U),q)break}te=O&Fn;let ie=U.lastModified||te&&w;ue=te||ie>w||!b,ie||(ie=(0,Mh.getNextMonotonicTime)());let J=performance.now()-Q;if(sr(J,"cache-resolution",s,null,"success"),L&&ZE(L,"Server-Timing",`cache-resolve;dur=${J.toFixed(2)}`,!0),j.timestamp=ie,h&&U.expiresAt==null&&(U.expiresAt=Date.now()+h),q){if(typeof q!="object")throw new Error("Only objects can be cached and stored in tables");if(q.status>0&&q.headers)if(q.status>=300)if(q.status===304)q=b,ie=w;else throw new wr.ServerError(q.body||"Error from source",q.status);else q=q.body;typeof q.toJSON=="function"&&(q=q.toJSON()),t&&q[t]!==z&&(q[t]=z)}$=!0,P({key:z,version:ie,value:q})}catch(ie){ie.message+=` while resolving record ${z} for ${s}`,b&&((ie.code==="ECONNRESET"||ie.code==="ECONNREFUSED"||ie.code==="EAI_AGAIN")&&!T?.mustRevalidate||T?.staleIfError&&(ie.statusCode===500||ie.statusCode===502||ie.statusCode===503||ie.statusCode===504))?(P({key:z,version:w,value:b}),xe.default.trace?.(ie.message,"(returned stale record)")):H(ie);let J=performance.now()-Q;sr(J,"cache-resolution",s,null,"fail"),L&&ZE(L,"Server-Timing",`cache-resolve;dur=${J.toFixed(2)}`,!0),U.transaction.abort();return}if(T?.noCacheStore||U.noCacheStore){U.transaction.abort();return}Gr(U).addWrite({key:z,store:i,entry:m,nodeName:"source",commit:a((ie,J)=>{if(J?.version!==w)return;let le=un(z,b,q);q?(me.put?.(U,z,q),xe.default.trace?.(`Writing resolved record from source with id: ${z}, timestamp: ${new Date(ie).toISOString()}`),R(z,q,J,ie,0,g&&ue||null,{user:U?.user,expiresAt:U.expiresAt},"put",!!te)):J&&(me.delete?.(U,z),xe.default.trace?.(`Deleting resolved record from source with id: ${z}, timestamp: ${new Date(ie).toISOString()}`),g||A?R(z,null,J,ie,0,g&&ue||null,{user:U?.user},"delete",!!te):Uc(i,J,w))},"commit")})}),()=>{i.unlock(z,w)},j=>{i.unlock(z,w),$&&xe.default.error?.("Error committing cache update",j)})})}a(Xh,"getFromSource");function aa(z){if(!z||z.user?.role?.permission?.super_user)return!0;if(z.replicateTo)throw new wr.ClientError("Can not specify replication parameters without super user permissions",403);if(z.replicatedConfirmation)throw new wr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(aa,"checkContextPermissions");function ca(z){let m=!1;if(z&&(z-ct>1&&(m=!0),ct=z),!(Xt===yr&&!m)&&(yr=Xt,(0,jl.getWorkerIndex)()===(0,jl.getWorkerCount)()-1))return gs&&clearTimeout(gs),Xt?new Promise(T=>{let O=new Date;O.setMonth(0),O.setDate(1),O.setHours(0),O.setMinutes(0),O.setSeconds(0);let w=Xt/(1+ct),y=m?Date.now():Math.ceil((Date.now()-O.getTime())/w)*w+O.getTime(),D=a(b=>{xe.default.trace?.(`Scheduled next cleanup scan at ${new Date(b)}`),gs=setTimeout(()=>F=F.then(async()=>{if(D(Math.max(b+Xt,Date.now())),i.rootStore.status!=="open"){clearTimeout(gs);return}let U=50,L=new Array(U),P=0,H=Math.pow(ct,8)*(Ql.get(x.STORAGE_RECLAMATION_EVICTIONFACTOR)??1e5),$=S/Math.pow(Math.max(ct,1),4);xe.default.info?.(`Starting cleanup scan for ${s}, evict threshold ${H}, adjusted eviction ${$}ms`);function j(Q,q,ue,te){let fe=Q+$-Date.now();if(fe<0)return!0;if(ct){let ie=i.lastSize;return ue&$n&&Yf(te,J=>{J.size&&(ie+=J.size)}),xe.default.trace?.(`shouldEvict adjusted ${fe} ${ie}, ${fe*(Q-q)/ie} < ${H}`),fe*(Q-q)/ie<H}return!1}a(j,"shouldEvict");try{let Q=0;for(let q of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let{key:ue,value:te,version:fe,expiresAt:ie,metadataFlags:J}=q,le;te===null&&!g&&fe+aAe<Date.now()?le=Uc(i,q,fe):ie!=null&&j(ie,fe,J,te)&&(le=De.evict(ue,te,fe),Q++),le&&(await L[P],L[P]=le.catch(ye=>{xe.default.error?.("Cleanup error",ye)}),++P>=U&&(P=0)),await pc()}xe.default.info?.(`Finished cleanup scan for ${s}, evicted ${Q} entries`)}catch(Q){xe.default.warn?.(`Error in cleanup scan for ${s}:`,Q)}T(void 0),ct=0}),Math.min(b-Date.now(),2147483647)).unref()},"startNextTimer");D(y)}):void 0}a(ca,"scheduleCleanup");function Tf(){Z=l?.addDeleteRemovalCallback(n,i,(z,m)=>{i.remove(z,m)})}a(Tf,"addDeleteRemoval");function lu(){(0,jl.getWorkerIndex)()===0&&setInterval(async()=>{if(!iu){iu=!0;try{let z=ae.name,m=r[z];if(!m)throw new Error(`expiresAt attribute ${ae} must be indexed`);for(let T of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let O of m.getValues(T)){let w=i.getEntry(O);w?.value?w.value[z]<Date.now()&&De.evict(O,w.value,w.version):i.ifVersion(O,w?.version,()=>m.remove(T,O))}await pc()}}catch(z){xe.default.error?.("Error in evicting old records",z)}finally{iu=!1}}},oAe).unref()}a(lu,"runRecordExpirationEviction");function uu(z){if(z){let m=z.join(","),T=f.get([Symbol.for("residency_by_set"),m]);return T||(f.put([Symbol.for("residency_by_set"),m],T=Math.floor(Math.random()*2147483647)),f.put([Symbol.for("residency_by_id"),T],z),T)}}a(uu,"getResidencyId")}function LP(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 Jj(){}function fAe(e){rQ=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;_Ae.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 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 MP(e,t,r){return e?.then?e.then(t,r):t(e)}function Zj(e){return e!=null}function $s(e){try{return JSON.stringify(e)}catch{return e}}function pAe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var hc,Mh,eQ,tQ,Ql,wr,vh,Uh,xe,Jl,jl,hA,_A,iAe,rQ,oAe,aAe,Wj,cAe,zj,lAe,Fn,Ea,uAe,jj,Qj,dAe,axe,_Ae,pc,Gf=be(()=>{B();hc=require("lmdb"),Mh=M(pn()),eQ=require("lodash"),tQ=M(Uf());ga();Am();Ql=M(ce());gN();wr=M(pe()),vh=M(yo()),Uh=M(si());Pe();Ff();xe=M(Ci());Vb();Oc();Jl=require("ordered-binary"),jl=M(tt());ho();hA=M(oe());Ou();$i();xE();Q_();_A=M(require("node:fs"));As();vT();iAe=new Uint8Array(9);iAe[8]=192;oAe=6e4,aAe=864e5;Ql.initSync();Wj=Ql.get(x.STORAGE_PREFETCHWRITES),cAe=1e4,zj=1,lAe=2,Fn=1,Ea=8,uAe=Buffer.allocUnsafeSlow(8192),jj=1978,Qj=100,dAe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},axe=(0,hA.convertToMS)(Ql.get(x.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(mA,"makeTable");a(LP,"attributesAsObject");a(Jj,"noop");a(fAe,"setServerUtilities");_Ae=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(pA,"coerceType");a(fA,"rejectNaN");a(Xj,"isDescendantId");pc=a(()=>new Promise(setImmediate),"rest");a(MP,"when");a(Zj,"exists");a($s,"stringify");a(pAe,"hasOtherProcesses")});var rt={};ve(rt,{database:()=>Fu,database_envs:()=>ta,databases:()=>$e,dropDatabase:()=>jb,dropTableMeta:()=>SAe,getDatabases:()=>Je,getDefaultCompression:()=>IS,getTables:()=>hAe,onRemovedDB:()=>mp,onUpdatedTable:()=>ml,readMetaDb:()=>xh,resetDatabases:()=>Cd,table:()=>lt,tables:()=>Zn});function hAe(){return TA||Je(),Zn||{}}function Je(){if(TA)return $e;TA=!0,df=new Map;let e=(0,Qt.getHdbBasePath)()&&(0,Pt.join)((0,Qt.getHdbBasePath)(),yc),t=(0,Qt.get)(x.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Qt.get)(x.STORAGE_PATH)||e&&((0,_s.existsSync)(e)?e:(0,Pt.join)((0,Qt.getHdbBasePath)(),im)),!e)return;if((0,_s.existsSync)(e))for(let n of(0,_s.readdirSync)(e,{withFileTypes:!0})){let s=(0,Pt.basename)(n.name,".mdb");n.isFile()&&(0,Pt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&xh((0,Pt.join)(e,n.name),null,s)}if((0,_s.existsSync)((0,uf.getBaseSchemaPath)())){for(let n of(0,_s.readdirSync)((0,uf.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Pt.join)((0,uf.getBaseSchemaPath)(),n.name),i=(0,Pt.join)((0,uf.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,_s.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Pt.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Pt.join)(i,o.name);xh((0,Pt.join)(s,o.name),(0,Pt.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,_s.existsSync)(i))for(let c of(0,_s.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Pt.extname)(c.name).toLowerCase()===".mdb"&&xh((0,Pt.join)(i,c.name),(0,Pt.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],u=(0,Pt.join)(l.path,(0,Pt.basename)(c+".mdb"));(0,_s.existsSync)(u)&&xh(u,c,n,null,!0)}}for(let n in $e){let s=df.get(n);if(s){let i=$e[n];n.includes("delete")&&Ft.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(Ft.trace(`delete table class ${o}`),delete i[o])}else if(delete $e[n],n==="data"){for(let i in Zn)delete Zn[i];delete Zn[AA]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if($e.system)for(let n of r)$e.system[n]&&($e.system[n].replicate=!1);return df=null,$e}function Cd(){TA=!1;for(let[,e]of ta)e.needsDeletion=!0;Je();for(let[e,t]of ta)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),ta.delete(e),delete $e[t.databaseName],Hh.forEach(r=>r(t.databaseName)));return $e}function xh(e,t,r=xP,n,s){let i=new vP.default(e,!1);try{let o=ta.get(e);o?o.needsDeletion=!1:(o=(0,ff.open)(i),ta.set(e,o));let c=new Xl.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(EA.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,_s.existsSync)(n)&&(i.path=n,u=(0,ff.open)(i),u.isLegacy=!0):u=uA(o));let f=oQ(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 A=p.get(S);A||p.set(S,A={attributes:[]}),(g==null||h.is_hash_attribute)&&(A.primary=h),g!=null&&A.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 W of S)if(W.is_hash_attribute||W.isPrimaryKey){g=W;break}if(!g){Ft.warn(`Unable to find a primary key attribute on table ${_}, with attributes: ${JSON.stringify(S)}`);continue}}let A=f[_],E={},R=[],N,v,k=typeof g.audit=="boolean"?g.audit:(0,Qt.get)(x.LOGGING_AUDITLOG),F=g.trackDeletes,K=g.expiration,re=g.eviction,ae=g.sealed,Z=g.splitSegments,se=g.replicate;if(A)E=A.indices,R=A.attributes,A.schemaVersion++;else{N=g.tableId,N?N>=(l.get(lf)||0)&&(l.putSync(lf,N+1),Ft.info(`Updating next table id (it was out of sync) to ${N+1} for ${_}`)):(g.tableId=N=l.get(lf),N||(N=1),Ft.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(lf,N+1),l.putSync(g.key,g));let W=new Xl.default(!g.is_hash_attribute,g.is_hash_attribute);if(W.compression=g.compression,W.compression){let he=(0,Qt.get)(x.STORAGE_COMPRESSION_THRESHOLD)||iQ;W.compression.threshold=he}v=jm(o.openDB(g.key,W),o),o.databaseName=r,v.tableId=N}for(let W of S){W.attribute=W.name;try{if(!W.is_hash_attribute&&(W.indexed||W.attribute&&!W.name)){if(!E[W.name]){let Te=new Xl.default(!W.is_hash_attribute,W.is_hash_attribute);E[W.name]=o.openDB(W.key,Te),E[W.name].indexNulls=W.indexNulls}let he=R.find(Te=>Te.name===W.name);he?R.splice(R.indexOf(he),1,W):R.push(W)}}catch(he){Ft.error("Error trying to update attribute",W,R,E,he)}}if(!A){A=aQ(f,_,mA({primaryStore:v,auditStore:u,audit:k,sealed:ae,splitSegments:Z,replicate:se,expirationMS:K&&K*1e3,evictionMS:re&&re*1e3,trackDeletes:F,tableName:_,tableId:N,primaryKey:g.name,databasePath:s?r+"/"+_:r,databaseName:r,indices:E,attributes:S,schemaDefined:g.schemaDefined,dbisDB:l})),A.schemaVersion=1;for(let W of Bh)W(A)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function oQ(e){let t=$e[e];if(t||(e==="data"?t=$e[e]=Zn:e==="system"?Object.defineProperty($e,"system",{value:t=Object.create(null),configurable:!0}):t=$e[e]=Object.create(null)),df&&!df.has(e)){let r=new Set;t[AA]=r,df.set(e,r)}return t}function aQ(e,t,r){return e[t]=r,r}function Fu({database:e,table:t}){e||(e=xP),Je();let r=oQ(e),n=(0,Pt.join)((0,Qt.getHdbBasePath)(),yc),s=(0,Qt.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,Qt.get)(x.STORAGE_PATH)||((0,_s.existsSync)(n)?n:(0,Pt.join)((0,Qt.getHdbBasePath)(),im));let o=(0,Pt.join)(n,(i?t:e)+".mdb"),c=ta.get(o);if(!c||c.status==="closed"){let l=new vP.default(o,!1);c=(0,ff.open)(l),ta.set(o,c)}return c.auditStore||(c.auditStore=uA(c)),c}async function jb(e){if(!$e[e])throw new Error("Schema does not exist");let t=$e[e],r;for(let n in t)r=t[n].primaryStore.rootStore,ta.delete(r.path),r.status==="open"&&(await r.close(),await kh.remove(r.path));if(r||(r=Fu({database:e,table:null}),r.status==="open"&&(await r.close(),await kh.remove(r.path))),e==="data"){for(let n in Zn)delete Zn[n];delete Zn[AA]}delete $e[e],Hh.forEach(n=>n(e)),await NR(r)}function lt(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=xP);let h=Fu({database:r,table:t}),S=$e[r];Ft.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 A,E,R;p==null&&(p=!0);let N=new Xl.default(!1);for(let Z of o)Z.attribute&&!Z.name?(Z.name=Z.attribute,Z.indexed=!0):Z.attribute=Z.name,Z.expiresAt&&(Z.indexed=!0);let v,k;if(g){if(A=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 Z=h.auditStore;E=o.find(Te=>Te.isPrimaryKey)||{},A=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,Qt.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=[_]),Ft.trace(`${t} table loading, opening primary store`);let se=new Xl.default(!1,!0);se.compression=E.compression;let W=t+"/";if(R=h.dbisDb=h.openDB(EA.INTERNAL_DBIS_NAME,N),ae(),R.get(W))return k&&k(),Cd(),lt(e);let he=jm(h.openDB(W,se),h);h.databaseName=r,he.tableId=R.get(lf),Ft.trace(`Assigning new table id ${he.tableId} for ${t}`),he.tableId||(he.tableId=1),R.put(lf,he.tableId+1),E.tableId=he.tableId,g=aQ(S,t,mA({primaryStore:he,auditStore:Z,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:A,tableName:t,tableId:he.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:p,dbisDB:R})),g.schemaVersion=1,v=!0,R.put(W,E)}let F=g.indices;R=R||(h.dbisDb=h.openDB(EA.INTERNAL_DBIS_NAME,N)),g.dbisDB=R;let K=[];for(let{key:Z,value:se}of R.getRange({start:!0})){let[W,he]=Z.toString().split("/");if(he===""&&(he=se.name),he){if(W!==t)continue}else continue;let Te=o.find(me=>me.name===he),Ce=!Te?.indexed&&se.indexed&&!se.isPrimaryKey;if((!Te||Ce)&&(ae(),v=!0,Te||R.remove(Z),Ce)){let me=g.indices[W];me&&K.push(me)}}let re=[];try{for(let Z of o||[]){if((Z.relationship||Z.computed)&&(v=!0,Z.relationship))continue;let se=t+"/"+(Z.name||"");Object.defineProperty(Z,"key",{value:se,configurable:!0});let W=R.get(se);if(Z.isPrimaryKey){if(W=W||R.get(se=t+"/")||{},c!==void 0&&c!==g.audit||l!==void 0&&l!==g.sealed||f!==void 0&&f!==g.replicate||(+n||void 0)!==(+W.expiration||void 0)||(+s||void 0)!==(+W.eviction||void 0)){let Te={...W};typeof c=="boolean"&&(c&&g.enableAuditing(c),Te.audit=c),n&&(Te.expiration=+n),s&&(Te.eviction=+s),l!==void 0&&(Te.sealed=l),f!==void 0&&(Te.replicate=f),v=!0,ae(),R.put(se,Te)}continue}W?.attribute&&!W.name&&(W.indexed=!0);let he=!W||W.type!==Z.type||W.indexed!==Z.indexed||W.nullable!==Z.nullable||W.version!==Z.version||JSON.stringify(W.properties)!==JSON.stringify(Z.properties)||JSON.stringify(W.elements)!==JSON.stringify(Z.elements);if(Z.indexed){let Te=new Xl.default(!0,!1),Ce=h.openDB(se,Te);(he||W.indexingPID&&W.indexingPID!==process.pid||W.restartNumber<Fh.workerData?.restartNumber)&&(v=!0,ae(),W=R.get(se),(he||W.indexingPID&&W.indexingPID!==process.pid||W.restartNumber<Fh.workerData?.restartNumber)&&(v=!0,Z.indexNulls===void 0&&(Z.indexNulls=!0),g.primaryStore.getStats().entryCount>0&&(Z.lastIndexedKey=W?.lastIndexedKey??void 0,Z.indexingPID=process.pid,Ce.isIndexing=!0,Object.defineProperty(Z,"dbi",{value:Ce}),re.push(Z))),R.put(se,Z)),W?.indexNulls&&Z.indexNulls===void 0&&(Z.indexNulls=!0),Ce.indexNulls=Z.indexNulls,F[Z.name]=Ce}else he&&(v=!0,ae(),R.put(se,Z))}}finally{k&&k()}if(v&&(g.schemaVersion++,g.updatedAttributes()),Ft.trace(`${t} table loading, running index`),re.length>0||K.length>0?g.indexingOperation=gAe(g,re,K):v&&gA.signalSchemaChange(new SA.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=_,v)for(let Z of Bh)Z(g,_!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Ft.trace(`${t} table loaded`),g;function ae(){k||h.transactionSync(()=>({then(Z){k=Z}}))}a(ae,"startTxn")}async function gAe(e,t,r){try{Ft.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,ff.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 A=S.resolve,E=p&&(A?A(p):p[g]),R=(0,nQ.getIndexedValues)(E);if(R)for(let N=0,v=R.length;N<v;N++)S.dbi.put(R[N],d)}catch(A){o[g]||(o[g]=!0,Ft.error(`Error indexing attribute ${g}`,A))}}}),s.then(()=>f--,h=>{f--,Ft.error(h)}),Fh.workerData&&Fh.workerData.restartNumber!==sQ.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=d,e.dbisDB.put(h.key,h);if(i)return}f>mAe?await s:f>EAe&&await new Promise(h=>setImmediate(h))}for(let d of t)delete d.lastIndexedKey,delete d.indexingPID,d.dbi.isIndexing=!1,s=e.dbisDB.put(d.key,d)}await s,await gA.signalSchemaChange(new SA.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),Ft.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Ft.error("Error in indexing",n)}}function SAe({table:e,database:t}){let r=Fu({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 mp(e){return Hh.push(e),{remove(){let t=Hh.indexOf(e);t>-1&&Hh.splice(t,1)}}}function IS(){let e=(0,Qt.get)(x.STORAGE_COMPRESSION),t=(0,Qt.get)(x.STORAGE_COMPRESSION_DICTIONARY),r=(0,Qt.get)(x.STORAGE_COMPRESSION_THRESHOLD)||iQ,n={startingOffset:32};return t&&(n.dictionary=kh.readFileSync(t)),r&&(n.threshold=r),e&&n}var Qt,EA,ff,Pt,_s,uf,Xl,vP,kh,UP,nQ,gA,SA,Fh,Ft,sQ,xP,AA,iQ,Zn,$e,lf,Bh,Hh,TA,ta,df,mAe,EAe,Pe=be(()=>{Qt=M(ce()),EA=M(vt()),ff=require("lmdb"),Pt=require("path"),_s=require("fs"),uf=M(Et());Gf();Xl=M(s_()),vP=M(i_());B();kh=M(require("fs-extra")),UP=M(yi()),nQ=M(pn()),gA=M(yo()),SA=M(si()),Fh=require("worker_threads"),Ft=M(Y()),sQ=M(tt());ho();Ou();As();xP="data",AA=Symbol("defined-tables"),iQ=((0,Qt.get)(x.STORAGE_PAGESIZE)||4096)-60;(0,Qt.initSync)();Zn=Object.create(null),$e=Object.create(null);(0,UP._assignPackageExport)("databases",$e);(0,UP._assignPackageExport)("tables",Zn);lf=Symbol.for("next-table-id"),Bh=[],Hh=[],ta=new Map;a(hAe,"getTables");a(Je,"getDatabases");a(Cd,"resetDatabases");a(xh,"readMetaDb");a(oQ,"ensureDB");a(aQ,"setTable");a(Fu,"database");a(jb,"dropDatabase");a(lt,"table");mAe=1e3,EAe=10;a(gAe,"runIndexing");a(SAe,"dropTableMeta");a(ml,"onUpdatedTable");a(mp,"onRemovedDB");a(IS,"getDefaultCompression")});var oe=I((gxe,AQ)=>{"use strict";var mc=require("path"),fQ=require("fs-extra"),Un=Y(),cQ=require("fs-extra"),RA=require("os"),TAe=require("net"),AAe=require("recursive-iterator"),Rr=(B(),C(G)),{PACKAGE_ROOT:RAe}=nt(),yAe=nR(),lQ=require("papaparse"),yA=require("moment"),{inspect:bAe}=require("util"),uQ=require("is-number"),Exe=require("lodash"),OAe=require("minimist"),NAe=require("https"),wAe=require("http"),{hdb_errors:bA}=pe(),IAe=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,_Q=require("util").promisify(setTimeout),CAe=100,PAe=5,DAe="",LAe=4,dQ={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};AQ.exports={isEmpty:ps,isEmptyOrZeroLength:io,arrayHasEmptyValues:UAe,arrayHasEmptyOrZeroLengthValues:xAe,buildFolderPath:BAe,isBoolean:pQ,errorizeMessage:MAe,stripFileExtension:kAe,autoCast:FAe,autoCastJSON:hQ,autoCastJSONDeep:HP,removeDir:GAe,compareVersions:qAe,isCompatibleDataVersion:$Ae,escapeRawValue:VAe,unescapeValue:KAe,stringifyProps:YAe,timeoutPromise:zAe,isClusterOperation:QAe,getClusterUser:XAe,checkGlobalSchemaTable:JAe,getHomeDir:EQ,getPropsFilePath:WAe,promisifyPapaParse:ZAe,removeBOM:gQ,createEventPromise:eRe,checkProcessRunning:tRe,checkSchemaTableExist:rRe,checkSchemaExists:SQ,checkTableExists:TQ,getStartOfTomorrowInSeconds:nRe,getLimitKey:sRe,isObject:HAe,isNotEmptyAndHasValue:vAe,autoCasterIsNumberCheck:mQ,backtickASTSchemaItems:iRe,isPortTaken:jAe,createForkArgs:oRe,autoCastBoolean:aRe,async_set_timeout:_Q,getTableHashAttribute:cRe,doesSchemaExist:lRe,doesTableExist:uRe,stringifyObj:dRe,ms_to_time:fRe,changeExtension:_Re,getEnvCliRootPath:kP,noBootFile:pRe,httpRequest:hRe,transformReq:mRe,convertToMS:ERe,PACKAGE_ROOT:RAe};function MAe(e){return e instanceof Error?e:new Error(e)}a(MAe,"errorizeMessage");function ps(e){return e==null}a(ps,"isEmpty");function vAe(e){return!ps(e)&&(e||e===0||e===""||pQ(e))}a(vAe,"isNotEmptyAndHasValue");function io(e){return ps(e)||e.length===0||e.size===0}a(io,"isEmptyOrZeroLength");function UAe(e){if(ps(e))return!0;for(let t=0;t<e.length;t++)if(ps(e[t]))return!0;return!1}a(UAe,"arrayHasEmptyValues");function xAe(e){if(io(e))return!0;for(let t=0;t<e.length;t++)if(io(e[t]))return!0;return!1}a(xAe,"arrayHasEmptyOrZeroLengthValues");function BAe(...e){try{return e.join(mc.sep)}catch{console.error(e)}}a(BAe,"buildFolderPath");function pQ(e){return ps(e)?!1:e===!0||e===!1}a(pQ,"isBoolean");function HAe(e){return ps(e)?!1:typeof e=="object"}a(HAe,"isObject");function kAe(e){return io(e)?DAe:e.slice(0,-LAe)}a(kAe,"stripFileExtension");function FAe(e){return ps(e)||e===""||typeof e!="string"?e:dQ[e]!==void 0?dQ[e]:mQ(e)===!0?Number(e):IAe.test(e)?new Date(e):e}a(FAe,"autoCast");function hQ(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(hQ,"autoCastJSON");function HP(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=HP(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=HP(r);n!==r&&(e[t]=n)}return e}else return hQ(e)}a(HP,"autoCastJSONDeep");function mQ(e){if(e.startsWith("0.")&&uQ(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&uQ(e))}a(mQ,"autoCasterIsNumberCheck");async function GAe(e){if(io(e))throw new Error(`Directory path: ${e} does not exist`);try{await cQ.emptyDir(e),await cQ.remove(e)}catch(t){throw Un.error(`Error removing files in ${e} -- ${t}`),t}}a(GAe,"removeDir");function qAe(e,t){if(io(e)){Un.info("Invalid current version sent as parameter.");return}if(io(t)){Un.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(qAe,"compareVersions");function $Ae(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a($Ae,"isCompatibleDataVersion");function VAe(e){if(ps(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(VAe,"escapeRawValue");function KAe(e){if(ps(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(KAe,"unescapeValue");function YAe(e,t){if(ps(e))return Un.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}!io(n)&&n[0]===";"?r+=" "+n+s+RA.EOL:io(n)||(r+=n+"="+s+RA.EOL)}catch{Un.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(YAe,"stringifyProps");function EQ(){let e;try{e=RA.homedir()}catch{e=process.env.HOME}return e}a(EQ,"getHomeDir");function WAe(){let e=mc.join(EQ(),Rr.HDB_HOME_DIR_NAME,Rr.BOOT_PROPS_FILE_NAME);return fQ.existsSync(e)||(e=mc.join(__dirname,"../","hdb_boot_properties.file")),e}a(WAe,"getPropsFilePath");function zAe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:a(function(){clearTimeout(r)},"cancel")}}a(zAe,"timeoutPromise");async function jAe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=TAe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(jAe,"isPortTaken");function QAe(e){try{return Rr.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Un.error(`Error checking operation against cluster ops ${t}`)}return!1}a(QAe,"isClusterOperation");function JAe(e,t){let r=(Pe(),C(rt)).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 XAe(e,t){if(ps(t)){Un.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ps(e)||io(e)){Un.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){Un.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){Un.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(XAe,"getClusterUser");function ZAe(){lQ.parsePromise=function(e,t,r){return new Promise(function(n,s){lQ.parse(e,{header:!0,transformHeader:gQ,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(ZAe,"promisifyPapaParse");function gQ(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(gQ,"removeBOM");function eRe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;Un.info(`Got cluster status event response: ${bAe(s)}`);try{i.cancel()}catch{Un.error("Error trying to cancel timeout.")}n(s)})})}a(eRe,"createEventPromise");async function tRe(e){let t=!0,r=0;do await _Q(CAe*r++),(await yAe.findPs(e)).length>0&&(t=!1);while(t&&r<PAe);if(t)throw new Error(`process ${e} was not started`)}a(tRe,"checkProcessRunning");function rRe(e,t){let r=SQ(e);if(r)return r;let n=TQ(e,t);if(n)return n}a(rRe,"checkSchemaTableExist");function SQ(e){let{getDatabases:t}=(Pe(),C(rt));if(!t()[e])return bA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(SQ,"checkSchemaExists");function TQ(e,t){let{getDatabases:r}=(Pe(),C(rt));if(!r()[e][t])return bA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(TQ,"checkTableExists");function nRe(){let e=yA().utc().add(1,"d").startOf("d").unix(),t=yA().utc().unix();return e-t}a(nRe,"getStartOfTomorrowInSeconds");function sRe(){return yA().utc().format("DD-MM-YYYY")}a(sRe,"getLimitKey");function iRe(e){try{let t=new AAe(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){Un.error("Got an error back ticking items."),Un.error(t)}}a(iRe,"backtickASTSchemaItems");function oRe(e){return[e]}a(oRe,"createForkArgs");function aRe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(aRe,"autoCastBoolean");function cRe(e,t){let{getDatabases:r}=(Pe(),C(rt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(cRe,"getTableHashAttribute");function lRe(e){let{getDatabases:t}=(Pe(),C(rt));return t()[e]!==void 0}a(lRe,"doesSchemaExist");function uRe(e,t){let{getDatabases:r}=(Pe(),C(rt));return r()[e]?.[t]!==void 0}a(uRe,"doesTableExist");function dRe(e){try{return JSON.stringify(e)}catch{return e}}a(dRe,"stringifyObj");function fRe(e){let t=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(fRe,"ms_to_time");function _Re(e,t){let r=mc.basename(e,mc.extname(e));return mc.join(mc.dirname(e),r+t)}a(_Re,"changeExtension");function kP(){if(process.env[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=OAe(process.argv);if(e[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(kP,"getEnvCliRootPath");var BP;function pRe(){if(BP)return BP;let e=kP();if(kP()&&fQ.pathExistsSync(mc.join(e,Rr.HDB_CONFIG_FILE)))return BP=!0,!0}a(pRe,"noBootFile");function hRe(e,t){let r;return e.protocol==="http:"?r=wAe:r=NAe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8"),o.body="",o.on("data",c=>{o.body+=c}),o.on("end",()=>{n(o)})});i.on("error",o=>{s(o)}),i.write(t instanceof Buffer?t:JSON.stringify(t)),i.end()})}a(hRe,"httpRequest");function mRe(e){if(!e.schema&&!e.database){e.schema=Rr.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(mRe,"transformReq");function ERe(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(ERe,"convertToMS")});var ce=I((NQ,wQ)=>{"use strict";var FP=require("fs-extra"),Zl=require("path"),RQ=require("os"),gRe=require("properties-reader"),qh=Y(),Gh=oe(),Me=(B(),C(G)),OA=Rt(),SRe="Error initializing environment manager",NA="BOOT_PROPS_FILE_PATH",yQ=!1,TRe={[Me.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},ra={};Object.assign(NQ,wQ.exports={BOOT_PROPS_FILE_PATH:NA,getHdbBasePath:ARe,setHdbBasePath:RRe,get:bQ,initSync:bRe,setProperty:Ye,initTestEnvironment:NRe,setCloneVar:ORe});function ARe(){return ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(ARe,"getHdbBasePath");function RRe(e){ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(RRe,"setHdbBasePath");function bQ(e){let t=OA.getConfigValue(e);return t===void 0?ra[e]:t}a(bQ,"get");function Ye(e,t){TRe[e]&&(ra[e]=t),OA.updateConfigObject(e,t)}a(Ye,"setProperty");function yRe(){let e;try{e=Gh.getPropsFilePath(),FP.accessSync(e,FP.constants.F_OK|FP.constants.R_OK),yQ=!0;let t=gRe(e);return ra[Me.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(Me.HDB_SETTINGS_NAMES.INSTALL_USER),ra[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),ra[NA]=e,!0}catch{return qh.trace(`Environment manager found no properties file at ${e}`),!1}}a(yRe,"doesPropFileExist");function bRe(e=!1){try{((yQ||yRe()||Gh.noBootFile())&&!OQ||e)&&(OA.initConfig(e),ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=OA.getConfigValue(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){qh.error(SRe),qh.error(t),console.error(t),process.exit(1)}}a(bRe,"initSync");var OQ=!1;function ORe(e){OQ=e}a(ORe,"setCloneVar");function NRe(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=Zl.join(__dirname,"../../","unitTests");ra[NA]=Zl.join(l,"hdb_boot_properties.file"),Ye(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Zl.join(l,"settings.test")),Ye(Me.HDB_SETTINGS_NAMES.INSTALL_USER,RQ.userInfo()?RQ.userInfo().username:void 0),Ye(Me.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Ye(Me.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Zl.join(l,"envDir","log")),Ye(Me.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Ye(Me.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Ye(Me.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Ye(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Zl.join(l,"envDir")),Ye(Me.CONFIG_PARAMS.STORAGE_PATH,Zl.join(l,"envDir")),s&&(Ye(Me.CONFIG_PARAMS.HTTP_SECUREPORT,bQ(Me.CONFIG_PARAMS.HTTP_PORT)),Ye(Me.CONFIG_PARAMS.HTTP_PORT,null)),Ye(Me.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Ye(Me.CONFIG_PARAMS.HTTP_PORT,9926),Ye(Me.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Ye(Me.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Ye(Me.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Gh.isEmpty(i)?!1:i),Ye(Me.CONFIG_PARAMS.HTTP_CORS,Gh.isEmpty(i)?!1:i),Ye(Me.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Ye(Me.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Ye(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Ye(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Ye(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Zl.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Ye(Me.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Gh.isEmpty(c)?!1:c),o&&(Ye("CORS_ACCESSLIST",o),Ye(Me.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Ye(Me.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Ye(Me.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Ye(Me.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Ye(Me.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Ye(Me.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Ye(Me.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${NA}. Please check your boot props and settings files`;qh.fatal(r),qh.error(t)}}a(NRe,"initTestEnvironment")});var LQ=I((Axe,DQ)=>{"use strict";var IA=ce();IA.initSync();var wA=(B(),C(G)),{httpRequest:wRe}=oe(),PQ=require("path"),IQ=require("fs-extra"),IRe=require("yaml"),{packageDirectory:CRe}=(Gw(),C(Fw)),{encode:PRe}=require("cbor-x"),DRe=["describe_table","describe_all","describe_database","list_users","list_roles","drop_role","add_user","alter_user","drop_user","restart_service","restart","create_database","drop_database","create_table","drop_table","create_attribute","drop_attribute","search_by_id","insert","update","upsert","delete","search_by_value","csv_file_load","csv_url_load","cluster_get_routes","cluster_network","cluster_status","remove_node","add_component","deploy_component","package_component","drop_component","get_components","get_component_file","set_component_file","registration_info","get_fingerprint","set_license","get_job","search_jobs_by_start_date","read_log","read_transaction_log","read_audit_log","delete_transaction_logs_before","purge_stream","delete_records_before","install_node_modules","set_configuration","get_configuration","create_authentication_tokens","refresh_operation_token","system_information","sql","create_csr","sign_certificate","list_certificates","add_certificate","remove_certificate","add_ssh_key","update_ssh_key","delete_ssh_key","list_ssh_keys","set_ssh_known_hosts","get_ssh_known_hosts"],CQ={deploy:"deploy_component",package:"package_component"};DQ.exports={cliOperations:vRe,buildRequest:MRe};var LRe={deploy_component:a(async e=>{if(e.package)return;let t=process.cwd();e.payload=await CRe(t,{skip_node_modules:!0,...e}),e.cborEncode=!0,e.project||(e.project=PQ.basename(t))},"deploy_component")};function MRe(){let e={};for(let t of process.argv.slice(2))if(DRe.includes(t))e.operation=t;else if(CQ.hasOwnProperty(t))e.operation=CQ[t];else if(t.includes("=")){let[r,...n]=t.split("=");n=n.join("=");try{n=JSON.parse(n)}catch{}e[r]=n}return e}a(MRe,"buildRequest");async function vRe(e){e.target||(e.target=process.env.CLI_TARGET);let t;if(e.target){try{t=new URL(e.target)}catch(r){try{t=new URL(`https://${e.target}:9925`)}catch{throw r}}t={protocol:t.protocol,hostname:t.hostname,port:t.port,username:e.username||t.username||process.env.CLI_TARGET_USERNAME,password:e.password||t.password||process.env.CLI_TARGET_PASSWORD,rejectUnauthorized:e.rejectUnauthorized}}else IQ.existsSync(PQ.join(IA.get(wA.CONFIG_PARAMS.ROOTPATH),wA.HDB_PID_FILE))||(console.error("HarperDB must be running to perform this operation"),process.exit()),IQ.existsSync(IA.get(wA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))||(console.error("No domain socket found, unable to perform this operation"),process.exit());await LRe[e.operation]?.(e);try{let r=t??{protocol:"http:",socketPath: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=PRe(e));let n=await wRe(r,e),s;try{s=JSON.parse(n.body)}catch{s={status:n.statusCode+" "+(n.statusMessage||"Unknown"),body:n.body}}e.json?console.log(JSON.stringify(s,null,2)):console.log(IRe.stringify(s).trim())}catch(r){let n="Error: ";if(r?.response?.data?.error)n+=r.response.data.error;else if(r?.response?.data)n+=r?.response?.data;else return console.error(r);console.error(n)}}a(vRe,"cliOperations")});var UQ=I((yxe,vQ)=>{"use strict";var MQ=require("semver/functions/major"),{packageJson:URe}=nt(),GP=process.versions&&process.versions.node?process.versions.node:void 0;vQ.exports=xRe;function xRe(){let e=URe.engines["minimum-node"];if(GP&&MQ(GP)<MQ(e))return{error:`The minimum version of Node.js HarperDB supports is: ${e}, the currently installed Node.js version is: ${GP}. Please install a version of Node.js that is withing the defined range.`}}a(xRe,"checkNodeVersion")});var zP=I((Nxe,nJ)=>{"use strict";var xQ=require("os"),CA=require("https"),BQ=require("http"),Jt=require("fs-extra"),HQ=require("yaml"),{pipeline:kQ}=require("stream/promises"),{createWriteStream:PA,ensureDir:$h,writeFileSync:FQ}=require("fs-extra"),{join:Ri}=require("path"),VQ=require("lodash"),BRe=require("minimist"),na=require("path"),HRe=require("node:crypto"),kRe=require("properties-reader"),Ks=ce(),FRe=Do(),KP=Y(),DA=Rt(),{restart:GRe}=za(),LA=oe(),qRe=da(),$Re=bs(),{main:MA,launch:VRe}=jd(),{install:KQ,updateConfigEnv:KRe,setIgnoreExisting:vA}=CT(),YQ=hC(),cn=(B(),C(G)),{packageJson:YRe}=nt(),WRe=mh(),{sendOperationToNode:VP}=(ts(),C(Po)),{updateConfigCert:zRe}=rs(),{restartWorkers:jRe}=tt(),{databases:QRe}=(Pe(),C(rt)),{SYSTEM_TABLE_NAMES:qP,SYSTEM_SCHEMA_NAME:Oxe,CONFIG_PARAMS:Vh,OPERATIONS_ENUM:Es}=cn,JRe=1e4,XRe="clone-node-config.yaml",WQ=[qP.ROLE_TABLE_NAME,qP.USER_TABLE_NAME,qP.NODE_TABLE_NAME],ZRe={clustering_nodename:!0,clustering_leafserver_streams_path:!0,clustering_tls_certificate:!0,clustering_tls_privatekey:!0,clustering_tls_certificateauthority:!0,logging_file:!0,logging_root:!0,logging_rotation_path:!0,operationsapi_network_domainsocket:!0,operationsapi_tls_certificate:!0,operationsapi_tls_privatekey:!0,operationsapi_tls_certificateauthority:!0,rootpath:!0,storage_path:!0,storage_audit_path:!0,databases:!0,mqtt_network_mtls_certificateauthority:!0,componentsroot:!0,tls_certificate:!0,tls_privatekey:!0,tls_certificateauthority:!0,replication_hostname:!0,replication_url:!0,cloned:!0},Fr={HDB_LEADER_USERNAME:"HDB_LEADER_USERNAME",HDB_LEADER_PASSWORD:"HDB_LEADER_PASSWORD",HDB_LEADER_URL:"HDB_LEADER_URL",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",HDB_CLONE_OVERTOP:"HDB_CLONE_OVERTOP",CLONE_KEYS:"CLONE_KEYS",CLONE_USING_WS:"CLONE_USING_WS",NO_START:"NO_START"},ia=BRe(process.argv),_f=ia[Fr.HDB_LEADER_USERNAME]??process.env[Fr.HDB_LEADER_USERNAME],pf=ia[Fr.HDB_LEADER_PASSWORD]??process.env[Fr.HDB_LEADER_PASSWORD],tu=ia[Fr.HDB_LEADER_URL]??process.env[Fr.HDB_LEADER_URL],sa=ia[Fr.REPLICATION_HOSTNAME]??process.env[Fr.REPLICATION_HOSTNAME],zQ,jQ;sa&&([zQ,jQ]=sa.split(":"));var YP=(ia[Fr.HDB_CLONE_OVERTOP]??process.env[Fr.HDB_CLONE_OVERTOP])==="true",QQ=ia[Vh.CLONED.toUpperCase()]??process.env[Vh.CLONED.toUpperCase()],eye=ia[Fr.CLONE_KEYS]!=="false"&&process.env[Fr.CLONE_KEYS]!=="false",JQ=(ia[Fr.CLONE_USING_WS]??process.env[Fr.CLONE_USING_WS])==="true",XQ=(ia[Fr.NO_START]??process.env[Fr.NO_START])==="true",ms,Ec={},GQ,qQ,eu={},an,Gt,Vs,oo,ru=!1,WP=!1,hs,hf;nJ.exports=a(async function(t=!1,r=!1){if(console.info(`Starting clone node from leader node: ${tu}`),delete process.env.HDB_LEADER_URL,Gt=LA.getEnvCliRootPath(),!Gt)try{let i=Ri(xQ.homedir(),cn.HDB_HOME_DIR_NAME,cn.BOOT_PROPS_FILE_NAME);if(await Jt.pathExists(i)){let o=kRe(i);Gt=na.parse(o.get(cn.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)).dir}}catch{throw new Error("There was an error setting the clone default root path. Please set ROOTPATH using an environment or CLI variable.")}Gt?await Jt.pathExists(Gt)?console.log(`Existing HarperDB install found at ${Gt}. Clone node will only clone items that do not already exist on clone.`):(console.log(`No HarperDB install found at ${Gt} starting fresh clone`),ru=!0):(console.log("No HarperDB install found, starting fresh clone"),ru=!0),Gt||(Gt=Ri(xQ.homedir(),cn.HDB_ROOT_DIR_NAME),console.log("Using default root path",Gt));let n;try{n=Ri(Gt,XRe),ms=HQ.parseDocument(await Jt.readFile(n,"utf8"),{simpleKeys:!0}).toJSON(),console.log("Clone config file found")}catch{}let s=Ri(Gt,cn.HDB_CONFIG_FILE);if(await Jt.pathExists(s))try{GQ=HQ.parseDocument(await Jt.readFile(s,"utf8"),{simpleKeys:!0}).toJSON(),Ec=DA.flattenConfig(GQ)}catch(i){console.error("Error reading existing harperdb-config.yaml on clone",i)}if(sa){let i=new URL(tu);hf=`${i.protocol==="https:"?"wss://":"ws://"}${i.hostname}:${jQ||9933}`}if(JQ){await tye();return}if(Ec?.cloned&&QQ!=="false")return console.log("Instance marked as cloned, clone will not run"),Ks.setCloneVar(!1),Ks.initSync(),MA();an=await ZQ({operation:Es.DESCRIBE_ALL}),await tJ(),Ks.setCloneVar(!1),Ks.setHdbBasePath(Gt),Jt.ensureDir(Ks.get(cn.CONFIG_PARAMS.LOGGING_ROOT)),KP.initLogSettings(),await rye(),WP||await nye(),await oye(t,r),sa&&(await cye(),await eJ()),console.info(`
135
- Successfully cloned node: `+tu),(t||XQ)&&process.exit()},"cloneNode");async function tye(){if(Ec?.cloned&&QQ!=="false")return console.log("Instance marked as cloned, clone will not run"),Ks.setCloneVar(!1),Ks.initSync(),MA();console.log("Cloning using WebSockets");let e=gc("system"),t=Ri(e,"system.mdb"),r=Jt.existsSync(t);ru||!r||YP?(console.info("Clone node installing HarperDB"),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Gt,process.env.HDB_ADMIN_USERNAME="clone-temp-admin",process.env.HDB_ADMIN_PASSWORD=HRe.randomBytes(10).toString("base64").slice(0,10),vA(!0),await KQ()):(Ks.setCloneVar(!1),Ks.initSync()),await MA(),await tJ(!0),await zRe(),r||await QRe.system.hdb_user.delete({username:"clone-temp-admin"}),await jRe(),console.log("Adding node to the cluster");let s=await Ed()({operation:Es.ADD_NODE,url:hf});console.log("Add node response: ",s),await eJ(),console.log(`Successfully cloned node: ${tu} using WebSockets`),DA.updateConfigValue(Vh.CLONED,!0),XQ&&process.exit()}a(tye,"cloneUsingWS");async function ZQ(e){return JQ?VP({url:hf},e,{rejectUnauthorized:!1}):JSON.parse((await lye(e)).body)}a(ZQ,"leaderReq");async function eJ(){try{if(eye!==!1){console.log("Cloning JWT keys");let e=na.join(Gt,cn.LICENSE_KEY_DIR_NAME),t=await VP({url:hf},{operation:Es.GET_KEY,name:".jwtPublic"},{rejectUnauthorized:!1});FQ(na.join(e,cn.JWT_ENUM.JWT_PUBLIC_KEY_NAME),t.message);let r=await VP({url:hf},{operation:Es.GET_KEY,name:".jwtPrivate"},{rejectUnauthorized:!1});FQ(na.join(e,cn.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r.message)}}catch(e){console.error("Error cloning JWT keys",e)}}a(eJ,"cloneKeys");async function tJ(e=!1){console.info("Cloning configuration"),qQ=await ZQ({operation:Es.GET_CONFIGURATION}),eu=DA.flattenConfig(qQ);let t=ms?.componentConfig?.exclude,r={rootpath:Gt};sa&&(r.replication_hostname=zQ);for(let i in eu)if(!(eu[i]!==null&&typeof eu[i]=="object"&&!(eu[i]instanceof Array)||ZRe[i])){if(i.includes("_package")||i.includes("_port")){if(eu[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}}Ec[i]||(r[i]=eu[i])}for(let i in Ec)i!=="databases"&&typeof Ec[i]=="object"&&!(Ec[i]instanceof Array)||(r[i]=Ec[i]);let n={};if(ms?.databaseConfig?.excludeDatabases&&ms.databaseConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),ms?.clusteringConfig?.excludeDatabases&&ms.clusteringConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),Object.keys(n).length>0){r.replication_databases=[],n.system||r.replication_databases.push("system");for(let i in an)n[i]||r.replication_databases.push(i)}let s=qRe(Object.keys(cn.CONFIG_PARAM_MAP),!0);Object.assign(r,s),e||(r.cloned=!0),DA.createConfigFile(r,!0)}a(tJ,"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=Gt,!_f)throw new Error("HDB_LEADER_USERNAME is undefined.");if(process.env.HDB_ADMIN_USERNAME=_f,!pf)throw new Error("HDB_LEADER_PASSWORD is undefined.");process.env.HDB_ADMIN_PASSWORD=pf,process.env.OPERATIONSAPI_NETWORK_PORT=Ks.get(Vh.OPERATIONSAPI_NETWORK_PORT),KRe(na.join(Gt,cn.HDB_CONFIG_FILE)),vA(!0),await KQ()}a(nye,"installHDB");function gc(e){return Ks.get(cn.CONFIG_PARAMS.DATABASES)?.[e]?.path||Ks.get(Vh.STORAGE_PATH)||na.join(Gt,cn.DATABASES_DIR_NAME)}a(gc,"getDBPath");async function sye(){let e=gc("system"),t=Ri(e,"system.mdb");if(await $h(e),ru||!await Jt.exists(t)||YP){if(!sa){console.info("Cloning system database"),await $h(e);let r=PA(t,{overwrite:!0}),n={operation:Es.GET_BACKUP,database:"system",tables:WQ},s=await $Q(n,r),i=new Date(s.date);(!hs||i<hs)&&(hs=i),await Jt.utimes(t,Date.now(),i)}ru||(await YQ(Gt),await rJ(),vA(!0))}else WP=!0,console.log("Not cloning system database due to it already existing on clone");Vs=ms?.databaseConfig?.excludeDatabases,Vs=Vs?Vs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in an)await Jt.exists(na.join(gc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),Vs[r]=!0);oo=ms?.databaseConfig?.excludeTables,oo=oo?oo.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in an){if(Vs[r]){an[r]="excluded";continue}if(VQ.isEmpty(an[r]))continue;let n=[],s=!1;for(let d in an[r])oo[r+d]?(s=!0,an[r][d]="excluded"):n.push(an[r][d]);if(n.length===0)continue;if(sa){KP.debug("Setting up tables for #{db}");let d=(Pe(),C(rt)).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:Es.GET_BACKUP,database:r,tables:n}):(console.info(`Cloning database: ${r}`),i={operation:Es.GET_BACKUP,database:r});let o=gc(r);await $h(o);let c=Ri(o,r+".mdb"),l=PA(c,{overwrite:!0}),u=await $Q(i,l),f=new Date(u.date);(!hs||f<hs)&&(hs=f),await Jt.utimes(c,Date.now(),f)}}a(sye,"cloneTablesHttp");async function iye(){let e=gc("system"),t=Ri(e,"system.mdb");if(ru||!await Jt.exists(t)||YP){if(!sa){console.info("Cloning system database using fetch");let r={operation:Es.GET_BACKUP,database:"system",tables:WQ},n=await $P(r,!0),s=gc("system");await $h(s);let i=Ri(s,"system.mdb");await kQ(n.body,PA(i,{overwrite:!0}));let o=new Date(n.headers.get("date"));(!hs||o<hs)&&(hs=o),await Jt.utimes(i,Date.now(),new Date(n.headers.get("date")))}ru||(await YQ(Gt),await rJ(),vA(!0))}else WP=!0,console.log("Not cloning system database due to it already existing on clone");if(sa){KP.info("Replication hostname set, not using backup to clone databases, replication will clone");return}Vs=ms?.databaseConfig?.excludeDatabases,Vs=Vs?Vs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in an)await Jt.exists(na.join(gc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),Vs[r]=!0);oo=ms?.databaseConfig?.excludeTables,oo=oo?oo.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in an){if(Vs[r]){an[r]="excluded";continue}if(VQ.isEmpty(an[r]))continue;let n=[],s=!1;for(let f in an[r])oo[r+f]?(s=!0,an[r][f]="excluded"):n.push(f);if(n.length===0)return;let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i=await $P({operation:Es.GET_BACKUP,database:r,tables:n},!0)):(console.info(`Cloning database: ${r}`),i=await $P({operation:Es.GET_BACKUP,database:r},!0));let o=gc(r);await $h(o);let c=new Date(i.headers.get("date")),l=Ri(o,`${c.getTime()}-${r}.mdb`);await kQ(i.body,PA(l,{overwrite:!0}));let u=Ri(o,r+".mdb");await Jt.rename(l,u),(!hs||c<hs)&&(hs=c),await Jt.utimes(u,Date.now(),c)}}a(iye,"cloneTablesFetch");async function $P(e,t=!1){let r=ms?.httpsRejectUnauthorized??!1,n=new CA.Agent({rejectUnauthorized:r});r||(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0");let i={Authorization:"Basic "+Buffer.from(_f+":"+pf).toString("base64"),"Content-Type":"application/json"};t&&(i["Accept-Encoding"]="gzip");let o=await fetch(tu,{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($P,"leaderHttpReqFetch");async function oye(e,t=!1){let r=await FRe.getHDBProcessInfo();r.clustering.length===0||r.core.length===0?e?await VRe(!1):(t&&await aye(),await MA()):(console.info(await GRe({operation:Es.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 Jt.exists(e)||console.error(`The folder ${e} does not exist`),Jt.statSync(e).isDirectory()||console.error(`The path ${e} is not a folder`),e=await Jt.realpath(e),await Jt.exists(na.join(e,cn.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 $Re.setSchemaDataToGlobalAsync();let t=await Ed()({operation:Es.ADD_NODE,verify_tls:!1,url:hf,start_time:hs,authorization:{username:_f,password:pf}},!0);console.log("Add node response: ",t)}a(cye,"setupReplication");async function lye(e){let t=new CA.Agent({rejectUnauthorized:ms?.httpsRejectUnauthorized??!1}),n={Authorization:"Basic "+Buffer.from(_f+":"+pf).toString("base64"),"Content-Type":"application/json"},s=new URL(tu),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 $Q(e,t){let r=new CA.Agent({rejectUnauthorized:ms?.httpsRejectUnauthorized??!1}),s={Authorization:"Basic "+Buffer.from(_f+":"+pf).toString("base64"),"Content-Type":"application/json"},i=new URL(tu),o={protocol:i.protocol,host:i.hostname,method:"POST",headers:s};return i.protocol==="https:"&&(o.agent=r,BQ=CA),i.port&&(o.port=i.port),new Promise((c,l)=>{let u=BQ.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($Q,"leaderHttpStream");async function rJ(){let e=YRe.version;if(e)await WRe.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(rJ,"insertHdbVersionInfo")});var iJ=I((Ixe,sJ)=>{var uye=CT(),dye=Y();sJ.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 cJ=I((Pxe,aJ)=>{"use strict";var _ye=hS(),pye=Y(),oJ="Registration failed.";async function hye(){let e;try{e=await _ye.register()}catch(t){return pye.error(`Registration error ${t}`),oJ}return e||oJ}a(hye,"register");aJ.exports={register:hye}});var fJ=I((Lxe,dJ)=>{"use strict";var mye=Y(),Eye=(B(),C(G)),gye=require("util"),Sye=require("child_process"),lJ=gye.promisify(Sye.exec),Tye=Do(),Kh=Id(),uJ="Stopping HarperDB.";dJ.exports=Aye;async function Aye(){if(console.log(uJ),mye.notify(uJ),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=>{lJ(`kill ${r.pid}`)}),t.core.forEach(r=>{lJ(`kill ${r.pid}`)})}a(Aye,"stop")});var hJ=I((vxe,pJ)=>{"use strict";var QP=require("fs-extra"),JP=require("path"),jP=require("yaml"),Yh=ir(),Sc=(B(),C(G)),_J=St(),XP=Y(),Rye=Rn(),yye=lS(),bye=aS(),Oye=Do(),Wh=ce(),Nye=jd(),wye=oe();Wh.initSync();var Ys={RUNNING:"running",STOPPED:"stopped",ERRORED:"errored",NOT_INSTALLED:"not installed"},xn={LEAF:"leaf server",HUB:"hub server"},UA;pJ.exports=Iye;async function Iye(){let e={harperdb:{status:Ys.STOPPED}};if(!await Nye.isHdbInstalled()){e.harperdb.status=Ys.NOT_INSTALLED,console.log(jP.stringify(e));return}UA=Wh.get(Sc.CONFIG_PARAMS.ROOTPATH);let t;try{t=Number.parseInt(await QP.readFile(JP.join(UA,Sc.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Sc.NODE_ERROR_CODES.ENOENT){XP.info("`harperdb status` did not find a hdb.pid file"),e.harperdb.status=Ys.STOPPED,console.log(jP.stringify(e));return}throw n}let r=await Oye.getHDBProcessInfo();for(let n of r.core)if(n.pid===t){e.harperdb.status=Ys.RUNNING,e.harperdb.pid=t;break}if((Wh.get(Sc.CONFIG_PARAMS.REPLICATION_URL)||Wh.get(Sc.CONFIG_PARAMS.REPLICATION_HOSTNAME))&&(e.replication=await Pye()),e.clustering=await Cye(r),e.clustering[xn.HUB].status===Ys.RUNNING&&e.clustering[xn.LEAF].status===Ys.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(jP.stringify(e)),process.exit()}a(Iye,"status");async function Cye(e){let t={[xn.HUB]:{},[xn.LEAF]:{}};if(e.clustering.length===0)return t[xn.HUB].status=Ys.STOPPED,t[xn.LEAF].status=Ys.STOPPED,t;let{port:r}=Yh.getServerConfig(Sc.PROCESS_DESCRIPTORS.CLUSTERING_HUB),{username:n,decrypt_hash:s}=await Rye.getClusterUser();try{(await Yh.createConnection(r,n,s,!1)).close(),t[xn.HUB].status=Ys.RUNNING}catch{t[xn.HUB].status=Ys.ERRORED}let{port:i}=Yh.getServerConfig(Sc.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);try{(await Yh.createConnection(i,n,s,!1)).close(),t[xn.LEAF].status=Ys.RUNNING}catch{t[xn.LEAF].status=Ys.ERRORED}try{t[xn.HUB].pid=Number.parseInt(await QP.readFile(JP.join(UA,"clustering",_J.PID_FILES.HUB),"utf8"))}catch(o){XP.error(o),t[xn.HUB].pid=void 0}try{t[xn.LEAF].pid=Number.parseInt(await QP.readFile(JP.join(UA,"clustering",_J.PID_FILES.LEAF),"utf8"))}catch(o){XP.error(o),t[xn.LEAF].pid=void 0}return t}a(Cye,"getHubLeafStatus");async function Pye(){let e=await wye.httpRequest({method:"POST",protocol:"http:",socketPath:Wh.get(Sc.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 ZP=process.env.HDB_LEADER_URL||process.argv.includes("--HDB_LEADER_URL");ZP&&ce().setCloneVar(!0);var zh=require("node:fs"),mJ=require("node:path"),nu=Y(),EJ=LQ(),{packageJson:Dye,PACKAGE_ROOT:gJ}=nt(),Lye=UQ(),eD=(B(),C(G)),{SERVICE_ACTIONS_ENUM:ln}=eD,Mye=`
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||Mn.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){Mn.info("Could not close debugger",i)}}}).ref();let e;bh&&!USe&&(e=fz()),Promise.resolve(e).then(()=>{if(Qd()===0)try{LSe(BC)}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 eo){let r=eo[t];if(t.includes?.("/")&&Qd()==0){OSe(t)&&oz(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Mn.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=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}),Mn.trace("Listening on port "+t,BT)}).on("error",c)}))}return Promise.all(e)}a(fz,"listenOnPorts");!UC&&!ESe?.noServerStart&&dz();function FC(e,t,r){let n=e?.read?e:new gSe({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=eo[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=eo[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(Mn.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(FC,"deliverSocket");var tz=new Map;function xSe(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=tz.get(s),r){case"connection":i=FC(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(xSe,"proxyRequest");var{getComponentName:kT}=(jp(),C(zp));function GC(e,t,r=!0){t||(t=Et.get(Qt.CONFIG_PARAMS.HTTP_PORT));let n=eo[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 eo[t]=e;e.on("unhandled",iz)}a(GC,"registerServer");function qC(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(qC,"getPorts");function $C(e,t){let r=[];for(let{port:n,secure:s}of qC(t))r.push(_z(n,s,t?.isOperationsServer,t?.mtls)),typeof e=="function"?HC[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,GC(e,n,!1)),HT[n]=GT(HC,n);return r}a($C,"httpServer");function FT(e,t){let r=BC.get(e)??[];BC.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")??!r,Object.assign(l,{allowHTTP1:!0,rejectUnauthorized:!!f,requestCert:!!(u||n),ticketKeys:ISe(),SNICallback:cz(r?"operations-api":"server",u)}));let p=DSe(),_=xT[e]=(t?d?ySe:RSe:TSe)(l,async(h,S)=>{try{let R=performance.now(),E=new az(h,S);r&&(E.isOperationsServer=!0);let A=await HT[e](E);if(!A){if(E._nodeResponse.statusCode)return;A=pz(E)}if(A.headers?.set||(A.headers=new xC(A.headers)),p?A.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):A.headers?.set?.("Server","HarperDB"),A.status===-1){for(let ne of A.headers||[])S.setHeader(ne[0],ne[1]);return h.baseRequest=E,S.baseResponse=A,xT[e].emit("unhandled",h,S)}let O=A.status||200,v=performance.now(),F=v-R,G=A.body,Y,te=!1;if(!A.handlesHeaders){let ne=A.headers||new xC;G?G.length>=0?(typeof G=="string"?ne.set("Content-Length",Buffer.byteLength(G)):ne.set("Content-Length",G.length),Y=!0):G instanceof bSe&&(G.size?ne.set("Content-Length",G.size):G.on&&(te=!0,G.on("size",he=>{S.headersSent||S.setHeader("Content-Length",he)})),G=G.stream()):(ne.set("Content-Length","0"),Y=!0);let Q=`hdb;dur=${F.toFixed(2)}`;if(A.wasCacheMiss&&(Q+=", miss"),PSe(ne,"Server-Timing",Q,!0),!S.headersSent)if(te){if(S.statusCode=O,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(O,ne&&(ne[Symbol.iterator]?Array.from(ne):ne));Y&&S.end(G)}let ie=E.handlerPath,X=E.method;if(Rh(F,"duration",ie,X,A.wasCacheMiss==null?void 0:A.wasCacheMiss?"cache-miss":"cache-hit"),ZW(O<400,"success",ie,X),ZW(1,"response_"+O,ie,X),!Y)if(G instanceof ReadableStream&&(G=ez.fromWeb(G)),(G[Symbol.iterator]||G[Symbol.asyncIterator])&&(G=ez.from(G)),G?.pipe){G.pipe(S),G.destroy&&S.on("close",()=>{G.destroy()});let ne=0;G.on("data",Q=>{ne+=Q.length}),G.on("end",()=>{Rh(performance.now()-v,"transfer",ie,X),Rh(ne,"bytes-sent",ie,X)})}else G?.then?G.then(ne=>{S.end(ne)},g):S.end(G)}catch(R){g(R)}function g(R){let E=R.headers;S.writeHead(R.statusCode||500,E&&(E[Symbol.iterator]?Array.from(E):E)),S.end(R.toString()),R.statusCode?R.statusCode===500?Mn.warn(R):Mn.info(R):Mn.error(R)}a(g,"onError")});i>=0&&(_.keepAliveTimeout=i),c>=0&&(_.headersTimeout=c),t&&(_.ports||(_.ports=[]),_.ports.push(e),l.SNICallback.initialize(_),u&&(_.mtlsConfig=u),_.on("secureConnection",h=>{h._parent.startTime&&Rh(performance.now()-h._parent.startTime,"tls-handshake",e),Rh(h.isSessionReused(),"tls-reused",e)}),_.isSecure=!0),GC(_,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 xC}}a(pz,"unhandled");function BSe(e,t){$C(e,{requestOnly:!0,...t})}a(BSe,"onRequest");function HSe(e,t){let r;if(t.securePort){FT(t.securePort,{protocol_name:"TLS",name:kT()});let n=cz("server",t.mtls);r=wSe({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),eo[t.securePort]=r}return t.port&&(FT(t.port,{protocol_name:"TCP",name:kT()}),r=SSe(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),eo[t.port]=r),r}a(HSe,"onSocket");Object.defineProperty(ASe.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=[],kC={};function hz(e,t){for(let{port:r}of qC(t))rz[t?.runFirst?"unshift":"push"]({listener:e,port:r}),kC[r]=GT(rz,r)}a(hz,"onUpgrade");var nz=[],sz={};function kSe(e,t){let r=[];for(let{port:n,secure:s}of qC(t)){FT(n,{protocol_name:s?"WSS":"WS",name:kT()});let i=_z(n,s,t?.isOperationsServer,t?.mtls);yh[n]||(yh[n]=new NSe({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)=>{kC[n]&&kC[n](o,c,l)})),r.push(i),nz[t?.runFirst?"unshift":"push"]({listener:e,port:n}),sz[n]=GT(nz,n),HT[n]=GT(HC,n)}return r}a(kSe,"onWebSocket");function iz(e,t){t.writeHead(404),t.end(`Not found
134
+ `)}a(iz,"defaultNotFound")});var XW={};ve(XW,{startHTTPThreads:()=>GSe,startSocketServer:()=>jC,updateWorkerIdleness:()=>bz});async function GSe(e=2,t){try{if(t)WC(0,1,!0);else{let{loadRootComponents:r}=qT();if(e===0)return(0,ks.setMainIsWorker)(!0),await VC().startServers(),Promise.resolve([]);await r()}yz();for(let r=0;r<e;r++)WC(r,e);return Promise.all(Rz)}finally{(0,ks.threadsHaveStarted)()}}function yz(){let e=(0,Sz.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),YC=setInterval(()=>{KT.notify(e)},FSe).unref())}function WC(e,t=1,r){if(KC++,(0,ks.startWorker)("server/threads/threadServer.js",{name:JA.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===zA.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});Rz.push(s),await s,Jd.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=Jd.indexOf(n);o>-1&&Jd.splice(o,1)}if(a(i,"removeWorker"),Xd){let o=Xd;Xd=[];for(let c of o)Az[c.localPort](null,c)}}}),r){let n=setInterval(()=>{zC?zC=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,ks.shutdownWorkers)(),KC=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function jC(e=0,t){if(typeof e=="string")try{(0,YT.existsSync)(e)&&(0,YT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=qSe:r=$Se(t):r=QC;let n=(0,Zd.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()),zC=!0,r(i,(o,c)=>{if(!o){if(mz){let u=i._socket||new Zd.Socket({handle:i,writable:!0,readable:!0});mz.deliverSocket(u,e,c),u.resume()}else KC>0?(Xd.length===0&&setTimeout(()=>{Xd.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,Xd.push(i)):(console.log("start up a dynamic thread to handle request"),WC(0));ir(!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 Zd.Socket({handle:i,writable:!0,readable:!0});YSe(u,o,e)}ir(!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 QC(e,t){let r,n=0;for(let s of Jd){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 qSe(e,t){let r={};e.getpeername(r);let n=r.address,s=ef.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);QC(e,o=>{ef.set(n,{worker:o,lastUsed:i}),t(o)})}function $Se(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new Zd.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=ef.get(l),f=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=f,s(u.worker);QC(n,d=>{ef.set(l,{worker:d,lastUsed:f}),s(d,o)})})}a(r,"findByHeaderAffinity")}function bz(){$T=0;for(let e of Jd)e.expectedIdle=e.recentELU.idle+VSe,e.requests=1;Jd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function YSe(e,t,r){let n=KSe++;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 ks,Zd,KT,YT,gz,Sz,Tz,Jd,Xd,Az,mz,KC,Rz,YC,FSe,zC,$T,Ez,ef,VSe,VT,KSe,vC=be(()=>{ks=M(et()),Zd=require("net");H();KT=M(z()),YT=require("fs");qi();gz=require("worker_threads"),Sz=M(yd()),Tz=M(st()),Jd=[],Xd=[],Az=[],KC=0,Rz=[];gz.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,ks.onMessageFromWorkers)(e=>{e.type===QA.RESTART&&YC&&(clearInterval(YC),yz())}));FSe=6e5;a(GSe,"startHTTPThreads");a(yz,"licenseWarning");a(WC,"startHTTPWorker");a(jC,"startSocketServer");$T=0;a(QC,"findMostIdleWorker");Ez=36e5,ef=new Map;a(qSe,"findByRemoteAddressAffinity");a($Se,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of ef)r.lastUsed+Ez<e&&ef.delete(t)},Ez).unref();VSe=1e3;a(bz,"updateWorkerIdleness");(0,ks.setMonitorListener)(bz);VT=new Map,KSe=1;a(YSe,"proxySocket")});var kz=w((ZUe,Hz)=>{var Nz=M(require("cluster")),lc=M(ae());H();var to=M(z()),wz=M(require("fastify")),Iz=M(require("@fastify/cors")),Cz=M(require("@fastify/compress")),Pz=M(require("@fastify/static")),Dz=M(TO()),Lz=M(require("path")),Mz=M(st()),vz=M(ys()),Uz=M(se()),xz=M(An()),Bz=M(yd());Vr();var uc=M(pT());uo();lc.default.initSync();var WSe=6e4,zSe=1024*1024*1024,jSe="TRUE",{CONFIG_PARAMS:wh}=q,tf;Hz.exports={hdbServer:Oz,start:Oz};async function Oz(e){try{to.default.debug("In Fastify server"+process.cwd()),to.default.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),to.default.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=Nz.default.isMaster,await QSe();let t=e.securePort>0;tf=JSe(t),await tf.ready(),e||(e={}),e.isOperationsServer=!0;try{Ye.http(tf.server,e),tf.server.closeIdleConnections||await tf.listen({port:0,host:"::"})}catch(r){throw tf.close(),to.default.error(r),to.default.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),to.default.fatal(t),process.exit(1)}}a(Oz,"operationsServer");async function QSe(){to.default.trace("Configuring HarperDB process."),vz.default.setSchemaDataToGlobal(),await xz.default.setUsersWithRolesCache(),await Bz.default.getLicense()}a(QSe,"setUp");function JSe(e){to.default.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=XSe(e),r=(0,wz.default)(t);r.server.headersTimeout=eTe(),r.setErrorHandler(uc.serverErrorHandler);let n=ZSe();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=lc.default.get(WA.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:[uc.reqBodyValidationHandler,uc.authHandler],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),(0,uc.handlePostRequest)(i,o)}),r.get("/health",()=>"HarperDB is running."),to.default.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(JSe,"buildServer");function XSe(e){let t=lc.default.get(wh.OPERATIONSAPI_NETWORK_TIMEOUT),r=lc.default.get(wh.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:zSe,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(XSe,"getServerOptions");function ZSe(){let e=lc.default.get(wh.OPERATIONSAPI_NETWORK_CORS),t=lc.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(ZSe,"getCORSOpts");function eTe(){return lc.default.get(wh.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??WSe}a(eTe,"getHeaderTimeoutConfig")});var rP={};ve(rP,{disableNATS:()=>rTe,publishToStream:()=>jT,setNATSReplicator:()=>JC,setPublishToStream:()=>nTe,setSubscription:()=>tP,start:()=>tTe});function tTe(){Ih.default.get(B.CLUSTERING_ENABLED)&&iTe()}function rTe(e=!0){Vz=e}function nTe(e,t){jT=e,tP=t}function iTe(){if(Vz||process.env._DISABLE_NATS)return;let e=Je(),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];JC(s,r,i)}}ml((r,n)=>{JC(r.tableName,r.databaseName,r),n&&Yz(r)}),!Fz&&(Fz=!0)}function JC(e,t,r){if(t==="system"&&oTe.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 Hn;return tP(t,e,i),i}static subscribeOnThisThread(i){return i<(Ih.default.get(B.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??sTe)}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(`${ZC.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,eP.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,ZC,eP,qz,$z,Ih,zT,Vz,jT,tP,sTe,Kz,Fz,oTe,WT,XC,Wz=be(()=>{Pe();ga();Gz=M(or()),ZC=M(Tt()),eP=M(To());_u();qz=M(vO()),$z=M(_n()),Ih=M(ae());H();zT=M(z());a(tTe,"start");a(rTe,"disableNATS");jT=Gz.publishToStream,tP=qz.setSubscription;a(nTe,"setPublishToStream");sTe=2;a(iTe,"assignReplicationSource");oTe=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(JC,"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(`${ZC.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,eP.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)}},XC=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 XC});async function Xz({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await nP.get(e,{returnNonexistent:!0});i=new oP(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await nP.get(e);o&&o.delete()}i=new JT(e,t)}return n&&(n.id=e,n.user={username:t?.username},Ch.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function sP(){return QT++,QT>65500&&(QT=1),QT}function iP(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=wi.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return Nt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var jz,dc,Qz,Jz,zz,nP,Ch,QT,JT,oP,Zz=be(()=>{Pe();Su();jz=M(_n()),dc=M(z());Oc();Qz=M(et()),Jz=M(VC());Vr();zz=100,nP=dt({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),Ch=dt({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,Qz.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 Ye.getUser(r.user.username));try{await iP(r,t,r)}catch{(0,dc.warn)("Failed to publish will",t)}Ch.delete(e.id)}})();a(Xz,"getSession");QT=1;a(sP,"getNextMessageId");JT=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,dc.trace)("Resuming subscription from",s,"from",o);let _=wi.getMatch(u,"mqtt");if(!_){let R=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw R.statusCode=404,R}if(p.url=_.relativeURL,p.url.indexOf("+")>-1||p.url.indexOf("#")>-1){let R=p.url.slice(1);if(R.indexOf("#")>-1&&R.indexOf("#")!==R.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(p.isCollection=!0,R.indexOf("+")===R.length-1)p.onlyChildren=!0,p.url="/"+R.slice(0,R.length-1);else{let E=R.split("/"),A;for(let F=0;F<E.length;F++)if(E[F].indexOf("+")>-1)if(E[F]==="+")A=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&A)throw new Error("Filters can not be combined");let O=!0;E[E.length-1]==="#"&&(E.length--,O=!1),A&&(n=a(F=>{let G=F.id;if(!Array.isArray(G))if(G?.indexOf?.("/")>-1)G=G.split("/");else return!1;if(O&&G.length!==E.length)return!1;for(let Y=0;Y<E.length;Y++)if(E[Y]!=="+"&&E[Y]!==G[Y])return!1;return!0},"filter"));let v=E.indexOf("+");p.url="/"+(v>-1?E.slice(0,v):E).concat("").join("/")}}let h=_.path,S=_.Resource,g=await Nt(p,async()=>{let R=this.createContext();R.topic=s,R.retainHandling=i;let E=await S.subscribe(p,R);if(!E)return;if(!E[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let A=(async()=>{for await(let O of E)try{let v;if(O.type&&O.type!=="put"&&O.type!=="delete"&&O.type!=="message"&&O.type!=="patch"||n&&!n(O))continue;r?(O.topic=s,v=this.needsAcknowledge(O)):(O.acknowledge?.(),v=sP());let F=O.id;if(Array.isArray(F)&&(F=gu(F)),F==null&&(F=""),await this.listener(h+"/"+F,O.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,dc.warn)(v)}})();return E});if(g)return g.topic=s,g.qos=t.qos,this.subscriptions.push(g),g}resume(){}needsAcknowledge(t){let r=sP();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 iP(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 iP(n,n.data,r)}}finally{await Ch.delete(this.sessionId)}}).catch(n=>{(0,dc.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(iP,"publish");oP=class extends JT{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=sP(),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,dc.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,dc.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),nP.put(this.sessionRecord)}}});var cP={};ve(cP,{bypassAuth:()=>aTe,start:()=>cTe});function aTe(){sj=!0}function cTe({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,rf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ZT.notify?.({username:f?.username,status:Ws.SUCCESS,type:ua.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,rf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ZT.error?.({username:_,status:Ws.FAILURE,type:ua.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),h}}else hr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(_){o.events.emit("error",_,u),hr.error?.(_)}else if(l.required)return hr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!f&&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,z_(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),Zn(!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):_;ir(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,rf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ZT.notify?.({username:n?.username,status:Ws.SUCCESS,type:ua.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(ie){return(0,rf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ZT.error?.({username:d.username,status:Ws.FAILURE,type:ua.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,ie),Zn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),Zn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let ie=e.deserialize||(e.deserialize=po(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?ie(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(ie){return hr.error?.(ie),s.events.emit("auth-failed",d,e,ie),Zn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:ie.code||5,returnCode:ie.code||128})}s.events.emit("connected",o,e),Zn(!0,"connection","mqtt","connect"),g({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0});let A=a(async(ie,X,ne,Q)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",ie);let he=ie.indexOf("/",1),Re=he>0?ie.slice(0,he):ie;g({cmd:"publish",topic:ie,payload:await E(X),messageId:ne||Math.floor(Math.random()*1e8),qos:Q.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(A),o.sessionWasPresent&&await o.resume();break;case"subscribe":let O=[];for(let ie of d.subscriptions){let X;try{let ne=await o.addSubscription(ie,ie.qos>=1);X=ne?ne.qos||0:c.protocolVersion<5?128:143}catch(ne){s.events.emit("error",ne,e,ie,o),ne.statusCode?ne.statusCode===500?hr.warn?.(ne):hr.info?.(ne):hr.error?.(ne),X=c.protocolVersion<5?128:ne.statusCode===403?135:ne.statusCode===404?143:128}O.push(X)}await o.committed,g({cmd:"suback",granted:O,messageId:d.messageId});break;case"unsubscribe":{let ie=[];for(let X of d.unsubscriptions)ie.push(o.removeSubscription(X)?0:17);g({cmd:"unsuback",granted:ie,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=po(r?.headers.get?.("content-type"))),Y=(d.payload?.length||0)>0?F(d.payload):void 0,te;try{te=await o.publish(d,Y)}catch(ie){s.events.emit("error",ie,e,d,o),hr.warn?.(ie),d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:te===!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),Zn(!0,"connection","mqtt","disconnect"),hr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(A){s.events.emit("error",A,e,d,o),hr.error?.(A),g({cmd:"disconnect"})}function g(A,O){let v=(0,eA.generate)(A,c);t(v),ir(v.length,"bytes-sent",O,R(A),"mqtt")}a(g,"sendPacket");function R(A){return A.qos>0?A.cmd+",qos="+A.qos:A.cmd}a(R,"packetMethodName");function E(A){return Ra(A,r)}a(E,"serialize")}),l.on("error",d=>{hr.warn("MQTT parsing error, closing connection:",d.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:f}}var eA,rj,rf,aP,nj,ZT,hr,sj,ej,XT,ij=be(()=>{eA=require("mqtt-packet");Zz();rj=M(An());uo();qi();Vr();rf=M(ae());H();aP=M(Ii()),nj=require("events"),ZT=(0,aP.loggerWithTag)("auth-event"),hr=(0,aP.loggerWithTag)("mqtt"),sj=(0,rf.get)(B.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(aTe,"bypassAuth");a(cTe,"start");XT=0;a(tj,"onSocket")});var zp={};ve(zp,{component_errors:()=>sf,getComponentName:()=>_Te,loadComponent:()=>nA,loadComponentDirectories:()=>uj,setErrorReporter:()=>fTe});function uj(e,t){t&&(uP=t),e&&(pP=e);let r=[];if((0,ct.existsSync)(lP)){let s=(0,ct.readdirSync)(lP,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,St.join)(lP,o);r.push(nA(c,uP,$A,!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(nA(n,uP,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{lj=!0})}function fTe(e){Ph=e}async function nA(e,t,r,n,s,i){let o=(0,ct.realpathSync)(e);if(tA.has(o))return tA.get(o);tA.set(o,!0),s&&(pP=s);try{let c;n&&(sf=new Map);let l=(0,St.join)(e,"harperdb-config.yaml");(0,ct.existsSync)(l)?c=n?(0,sA.getConfigObj)():(0,dP.parseDocument)((0,ct.readFileSync)(l,"utf8")).toJSON():!n&&(0,ct.existsSync)(l=(0,St.join)(e,"config.yaml"))?c=(0,dP.parseDocument)((0,ct.readFileSync)(l,"utf8")).toJSON():c=hP;let u=(0,St.join)(e,"node_modules","harperdb");try{Yl.isMainThread&&(n||((0,ct.existsSync)(u)||!e.startsWith((0,_P.getHdbBasePath)()))&&(!(0,ct.existsSync)(u)||(0,ct.realpathSync)(fP.PACKAGE_ROOT)!==(0,ct.realpathSync)(u)))&&((0,ct.rmSync)(u,{recursive:!0,force:!0}),(0,ct.existsSync)((0,St.join)(e,"node_modules"))||(0,ct.mkdirSync)((0,St.join)(e,"node_modules")),(0,ct.symlinkSync)(fP.PACKAGE_ROOT,u,"dir"))}catch(p){nf.default.error("Error symlinking harperdb module",p)}let f=rA,d=n;for(let p in c){rA=p;let _=c[p];if(sf.set(n?p:(0,St.basename)(e),!1),!_)continue;let h,S=_.package;try{if(S){let O=e,v;for(;!(0,ct.existsSync)(v=(0,St.join)(O,"node_modules",p));)if(O=(0,St.dirname)(O),O.length<(0,_P.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=dTe[p];if(!h)continue;let g=a(O=>(O.origin=r,dt(O)),"ensureTable"),R=_.network||(_.port||_.securePort)&&_,E=R?.securePort||R?.https&&R.port,A=!R?.https&&R?.port;if(Yl.isMainThread&&(h=await h.startOnMainThread?.({server:Ye,ensureTable:g,port:A,securePort:E,resources:t,..._})||h,n&&R))for(let O of[A,E])try{if(+O&&!oj.includes(O)){let v=mP.get(B.HTTP_SESSIONAFFINITY);v&&nf.default.warn("Session affinity is not recommended and may cause memory leaks"),(v||!ET)&&(oj.push(O),jC(O,v))}}catch(v){console.error("Error listening on socket",O,v,p)}if(t.isWorker&&(h=await h.start?.({server:Ye,ensureTable:g,port:A,securePort:E,resources:t,..._})||h),pP.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 O=(0,St.join)(e,_.files).replace(/\\/g,"/"),v=O.indexOf("/*");if(v>-1&&_.files!==hP[p]?.files&&!(0,ct.existsSync)(O.slice(0,v)))throw new Error(`The path '${O.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),G=_.path||"/";G=G.startsWith("/")?G:G.startsWith("./")?"/"+F+G.slice(2):G==="."?"/"+F:"/"+F+"/"+G;let Y,te,ie;if(_.root){let ne=_.root;ne.startsWith("/")&&(ne=ne.slice(1)),ne.endsWith("/")&&(ne=ne.slice(0,-1)),ne+="/",te=(0,St.join)(e,ne)}else(ie=O.indexOf("/*"))>-1?(te=O.slice(0,ie+1),Y=(0,St.relative)(e,te)):_.files.indexOf("/")>-1&&(te=O.slice(0,O.lastIndexOf("/")+1),Y=(0,St.relative)(e,te));let X=!1;if(Yl.isMainThread&&h.setupDirectory&&(X=await h.setupDirectory?.(G,te,t)),t.isWorker&&h.handleDirectory&&(X=await h.handleDirectory?.(G,te,t)),X){d=!0;continue}for(let ne of await(0,aj.default)(O,{onlyFiles:!1,objectMode:!0})){let{path:Q,dirent:he}=ne;d=!0;let Re=(0,St.relative)(e,Q).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=G+(G.endsWith("/")?"":"/")+Re;try{if(he.isFile()){let me=await uTe(Q);Yl.isMainThread&&await h.setupFile?.(me,Ce,Q,t),t.isWorker&&await h.handleFile?.(me,Ce,Q,t)}else Yl.isMainThread&&await h.setupDirectory?.(Ce,Q,t),t.isWorker&&await h.handleDirectory?.(Ce,Q,t)}catch(me){me.message=`Could not load ${he.isFile()?"file":"directory"} '${Q}'${_.module?" using '"+_.module+"'":""} for application '${e}' due to: ${me.message}`,Ph?.(me),((0,of.getWorkerIndex)()===0?console:nf.default).error(me),t.set(_.path||"/",new Sa(me)),sf.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,of.getWorkerIndex)()===0?console:nf.default).error(g),t.set(_.path||"/",new Sa(g),null,!0),sf.set(n?p:(0,St.basename)(e),g.message)}}if(rA=f,Yl.isMainThread&&!lj&&i&&(0,of.watchDir)(e,async()=>uj()),c.extensionModule){let p=await jE((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,of.getWorkerIndex)()===0?console:nf.default).error(p),sf.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 Sa(c))}}var ct,St,Yl,dP,mP,fP,aj,of,nf,cj,_P,lTe,sA,uTe,lP,pP,lj,uP,sf,dTe,hP,oj,tA,Ph,rA,_Te,jp=be(()=>{ct=require("fs"),St=require("path"),Yl=require("worker_threads"),dP=require("yaml"),mP=M(ae()),fP=M(st());H();UL();gM();jB();ZB();eH();xH();EY();yY();OY();aj=M(require("fast-glob")),of=M(et()),nf=M(z());sO();Vr();cj=M(pe());Pe();vC();_P=M(ae()),lTe=M(kz());MS();Wz();es();ij();sA=M(yt());QI();ER();({readFile:uTe}=ct.promises),lP=(0,sA.resolvePath)(mP.get(B.COMPONENTSROOT)),pP=new Map,sf=new Map;a(uj,"loadComponentDirectories");dTe={REST:tg,rest:tg,graphql:xR,graphqlSchema:TR,roles:nO,jsResource:oO,fastifyRoutes:VI,login:cO,static:KI,operationsApi:lTe,customFunctions:{},http:{},clustering:rP,replication:Po,authentication:Gp,mqtt:cP,loadEnv:YI},hP={rest:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(hP,"static",{value:{files:"web/**"}});oj=[],tA=new Map;a(fTe,"setErrorReporter");_Te=a(()=>rA,"getComponentName");a(nA,"loadComponent")});var qT=w((C0e,fj)=>{var{isMainThread:dj}=require("worker_threads"),{getTables:pTe,getDatabases:w0e,table:I0e}=(Pe(),C(tt)),{loadComponentDirectories:hTe,loadComponent:mTe}=(jp(),C(zp)),{resetResources:ETe}=(Su(),C(DL)),gTe=Fw(),STe=yt(),{dirname:TTe}=require("path"),{getConnection:ATe}=or(),RTe=ae(),{CONFIG_PARAMS:yTe}=(H(),C(q)),{loadCertificates:bTe}=ts(),EP=new Map;async function OTe(e=!1){!dj&&RTe.get(yTe.CLUSTERING_ENABLED)&&ATe();try{dj&&await gTe()}catch(n){console.error(n)}let t=ETe();pTe(),t.isWorker=e,await bTe(),await mTe(TTe(STe.getConfigFilePath()),t,"hdb",!0,EP),await hTe(EP,t);let r=[];for(let[n]of EP)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(OTe,"loadRootComponents");fj.exports.loadRootComponents=OTe});var et=w((D0e,Ti)=>{"use strict";rm();var{Worker:NTe,MessageChannel:wTe,parentPort:ro,isMainThread:RP,threadId:ITe,workerData:no}=require("worker_threads"),{PACKAGE_ROOT:CTe}=st(),{join:mj,isAbsolute:PTe,extname:DTe}=require("path"),{server:Ej}=(Vr(),C(Tu)),{watch:LTe,readdir:MTe}=require("fs/promises"),{totalmem:_j}=require("os"),af=(H(),C(q)),gj=ae(),Si=z(),{randomBytes:vTe}=require("crypto"),{_assignPackageExport:UTe}=Ri(),pj=1024*1024,fc=[],Fs=[],xTe=50,yP=1e4,BTe="restart",Sj="request_thread_info",Tj="resource_report",Aj="thread_info",Rj="added-port",HTe="ack",gP;UTe("threads",Fs);Ti.exports={startWorker:SP,restartWorkers:OP,shutdownWorkers:$Te,workers:fc,setMonitorListener:JTe,onMessageFromWorkers:VTe,onMessageByType:Cj,broadcast:YTe,broadcastWithAcknowledgement:zTe,setChildListenerByType:qTe,getWorkerIndex:yj,getWorkerCount:bj,getTicketKeys:Nj,setMainIsWorker:FTe,setTerminateTimeout:kTe,restartNumber:no?.restartNumber||1};Fs.onMessageByType=Cj;Fs.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Fs.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};Ti.exports.whenThreadsStarted=new Promise(e=>{Ti.exports.threadsHaveStarted=e});var bP;function kTe(e){yP=e}a(kTe,"setTerminateTimeout");function yj(){return no?no.workerIndex:bP?0:void 0}a(yj,"getWorkerIndex");function bj(){return no?no.workerCount:bP?1:void 0}a(bj,"getWorkerCount");function FTe(e){bP=e,Ti.exports.threadsHaveStarted()}a(FTe,"setMainIsWorker");var Oj=1,iA;function Nj(){return iA||(iA=RP?vTe(48):no.ticketKeys,iA)}a(Nj,"getTicketKeys");Object.defineProperty(Ej,"workerIndex",{get(){return yj()}});Object.defineProperty(Ej,"workerCount",{get(){return bj()}});var wj={[Sj](e,t){jTe(t)},[Tj](e,t){QTe(t,e)}};function SP(e,t={}){let r=process.constrainedMemory?.()||_j();r=Math.min(r,_j(),2e4*pj);let n=gj.get(af.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 Fs){let u=new wTe;u.existingPort=l,i.push(u),o.push(u.port2)}DTe(e)||(e+=".js");let c=new NTe(PTe(e)?e:mj(CTe,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:Ti.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=()=>SP(e,t),c.on("error",l=>{Si.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{fc.splice(fc.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<xTe?(t.unexpectedRestarts=c.unexpectedRestarts+1,SP(e,t)):Si.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{wj[l.type]?.(l,c)}),fc.push(c),ZTe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(SP,"startWorker");var GTe=[af.THREAD_TYPES.HTTP];async function OP(e=null,t=Math.max(Oj>3,1),r=!0){if(RP){try{process.chdir(process.cwd())}catch(o){Si.error("Unable to reestablish current working directory",o)}if(r){let{loadRootComponents:o}=qT();await o()}Ti.exports.restartNumber++,t<1&&(t=t*fc.length);let n=[],s=[];for(let o of fc.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Si.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Ti.exports.restartNumber,type:af.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=GTe.indexOf(o.name)>-1,l=new Promise(u=>{let f=setTimeout(()=>{Si.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},yP*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===af.ITC_EVENT_TYPES.CHILD_STARTED&&(Si.trace("Worker has started",u.threadId),d(),s.splice(s.indexOf(f)),u.off("message",p))},"startListener");Si.trace("Waiting for worker to start",u.threadId),u.on("message",p)});s.push(f),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=za();r&&(e==="http"||!e)&&gj.get(af.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else ro.postMessage({type:BTe,workerType:e})}a(OP,"restartWorkers");function qTe(e,t){wj[e]=t}a(qTe,"setChildListenerByType");function $Te(e){return OP(e,1/0,!1)}a($Te,"shutdownWorkers");var Ij=[];function VTe(e){Ij.push(e)}a(VTe,"onMessageFromWorkers");var TP=new Map;function Cj(e,t){let r=TP.get(e);r||TP.set(e,r=[]),r.push(t)}a(Cj,"onMessageByType");var KTe=10;async function YTe(e,t){let r=0;for(let n of Fs)try{n.postMessage(e),r++>KTe&&(r=0,await new Promise(setImmediate))}catch(s){Si.error("Unable to send message to worker",s)}t&&Dj(e,null)}a(YTe,"broadcast");var oA=new Map,WTe=1;function zTe(e){return new Promise(t=>{let r=0;for(let n of Fs)try{let s=WTe++,i=a(()=>{oA.delete(s),--r===0&&t(),n!==ro&&--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){Si.error("Unable to send message to worker",s)}r===0&&t()})}a(zTe,"broadcastWithAcknowledgement");function jTe(e){e.postMessage({type:Aj,workers:Pj()})}a(jTe,"sendThreadInfo");function Pj(){let e=Date.now();return fc.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 QTe(e,t){e.resources=t,e.resources.updated=Date.now()}a(QTe,"recordResourceReport");var AP;function JTe(e){AP=e}a(JTe,"setMonitorListener");var XTe=1e3,hj=!1;function ZTe(){hj||(hj=!0,setInterval(()=>{for(let e of fc){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}AP&&AP()},XTe).unref())}a(ZTe,"startMonitoring");var eAe=1e3;if(ro&&no?.addPorts){aA(ro);for(let e=0,t=no.addPorts.length;e<t;e++){let r=no.addPorts[e];r.threadId=no.addThreadIds[e],aA(r)}setInterval(()=>{let e=process.memoryUsage();ro.postMessage({type:Tj,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},eAe).unref(),gP=a(()=>new Promise((e,t)=>{ro.on("message",r),ro.postMessage({type:Sj});function r(n){n.type===Aj&&(ro.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else gP=Pj;Ti.exports.getThreadInfo=gP;function aA(e,t){Fs.push(e),e.on("message",r=>{if(r.type===Rj)r.port.threadId=r.threadId,aA(r.port);else if(r.type===HTe){let n=oA.get(r.id);n&&n()}else Dj(r,e)}).on("close",()=>{Fs.splice(Fs.indexOf(e),1)}).on("exit",()=>{Fs.splice(Fs.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=TP.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){Si.error(s)}}a(Dj,"notifyMessageListeners");if(RP){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await MTe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(mj(s,o.name));try{for await(let{filename:o}of LTe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await OP(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");Ti.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else ro.on("message",async e=>{let{type:t}=e;t===af.ITC_EVENT_TYPES.SHUTDOWN&&(Ti.exports.restartNumber=e.restartNumber,ro.unref(),setTimeout(()=>{Si.warn("Thread did not voluntarily terminate",ITe),process.exit(0)},yP).unref())})});var pB={};ve(pB,{ACTION_32_BIT:()=>Wm,ACTION_64_BIT:()=>nAe,AUDIT_STORE_OPTIONS:()=>xp,Decoder:()=>hl,HAS_BLOBS:()=>qn,HAS_CURRENT_RESIDENCY_ID:()=>xc,HAS_EXPIRATION_EXTENDED_TYPE:()=>n_,HAS_ORIGINATING_OPERATION:()=>r_,HAS_PREVIOUS_RESIDENCY_ID:()=>Bc,REMOTE_SEQUENCE_UPDATE:()=>vg,createAuditEntry:()=>bu,getLastRemoved:()=>gN,openAuditStore:()=>uA,readAuditEntry:()=>wt,removeAuditEntry:()=>dA,setAuditRetention:()=>rAe,transactionKeyEncoder:()=>Fj});function uA(e){let t=e.auditStore=e.openDB(NP.AUDIT_STORE_NAME,{create:!1,...xp});t||(t=e.auditStore=e.openDB(NP.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=IP;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()-wP/(1+i*i)})){try{p=dA(t,h,S)}catch(g){cf.warn("Error removing audit entry",g)}if(_=h,await new Promise(setImmediate),++d>=tAe){o=10;break}}await p}finally{d===0?o=Math.min(o<<1,wP/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,cf.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=sAe(r),s;if(n&qn){s=wt(r);let i=e.tableStores[s.tableId],o=i.getEntry(s.recordId);(!o||o.version!==s.version||!o.value)&&Dc(()=>Aa(s.getValue(i)),i.rootStore)}if((n&15)===CP){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){PP[0]=t,e.put(Symbol.for("last-removed"),Gj)}function gN(e){let t=e.get(Symbol.for("last-removed"));if(t)return Gj.set(t),PP[0]}function rAe(e,t=IP){wP=e,IP=t}function bu(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?_c.setFloat64(0,n):Gs.set(YR),h=9),l){if(l&255)throw new Error("Illegal extended type");h+=3}R(s),R(t),g(r),_c.setFloat64(h,e),h+=8,l&xc&&R(u),l&Bc&&R(f),l&n_&&(_c.setFloat64(h,d),h+=8),l&r_&&R($j[p]),i?g(i):Gs[h++]=0,l?_c.setUint32(n?8:0,_|l|3221225472):Gs[n?8:0]=_;let S=Gs.subarray(0,h);if(c)return Buffer.concat([S,c]);return S;function g(E){let A=h;h+=1,h=(0,Wl.writeKey)(E,Gs,h);let O=h-A-1;O>127?O>16383?(cf.error("Key or username was too large for audit entry",E),h=A+1,Gs[A]=0):(Gs.copyWithin(A+2,A+1,h),_c.setUint16(A,O|32768),h++):Gs[A]=O}function R(E){E<128?Gs[h++]=E:E<16384?(_c.setUint16(h,E|32768),h+=2):E<1056964608?(_c.setUint32(h,E|3221225472),h+=4):(Gs[h]=255,_c.setUint32(h+1,E),h+=5)}}function sAe(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&xc&&(p=n.readInt()),i&Bc&&(_=n.readInt()),i&n_&&(h=n.readFloat64()),i&r_){let A=n.readInt();S=$j[A]}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(A,O,v){if(i&cA||i&Dh&&!O)return E||(E=Dc(()=>A.decoder.decode(e.subarray(n.position,r)),A.rootStore)),E;if(i&Dh&&v)return qb(A.getEntry(this.recordId),v,A)},getBinaryValue(){return i&(cA|Dh)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:p,previousResidencyId:_,expiresAt:h,originatingOperation:S}}catch(n){return cf.error("Reading audit entry error",n,e),{}}}var Wl,lA,NP,Lh,kj,cf,Gs,_c,Fj,xp,wP,tAe,PP,Gj,IP,Lj,cA,Dh,vj,CP,Uj,xj,Bj,Hj,Wm,nAe,vg,xc,Bc,r_,n_,qn,qj,$j,hl,ho=be(()=>{Wl=require("ordered-binary"),lA=M(ae()),NP=M(vt());H();Lh=M(et()),kj=M(se());Ou();cf=M(z());xE();Ts();vT();(0,lA.initSync)();Gs=Buffer.alloc(2816),_c=new DataView(Gs.buffer,Gs.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},wP=(0,kj.convertToMS)((0,lA.get)(B.LOGGING_AUDITRETENTION))||86400*3,tAe=1e3,PP=new Float64Array(1),Gj=new Uint8Array(PP.buffer),IP=1e4,Lj=!1;a(uA,"openAuditStore");a(dA,"removeAuditEntry");a(Mj,"updateLastRemoved");a(gN,"getLastRemoved");a(rAe,"setAuditRetention");cA=16,Dh=32,vj=1,CP=2,Uj=3,xj=4,Bj=5,Hj=6,Wm=14,nAe=15,vg=11,xc=512,Bc=1024,r_=2048,n_=4096,qn=8192,qj={put:vj|cA,[vj]:"put",delete:CP,[CP]:"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(bu,"createAuditEntry");a(sAe,"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 MP(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=Kj,iAe(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 LP(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,DP.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,DP.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 iAe(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||(MP({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),Wj(e)),e.nextTransaction}var DP,Vj,Kj,LP,SN=be(()=>{DP=M(z());_u();Su();ho();Vj=Object.create(null),Kj=Object.create(null);a(MP,"addSubscription");LP=class extends Hn{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(Yj,"notifyFromTransactionData");a(iAe,"listenToCommits");a(Wj,"nextTransaction");a(BF,"whenNextTransaction")});var OI={};ve(OI,{EVICTED:()=>Ea,INVALIDATED:()=>kn,coerceType:()=>pA,makeTable:()=>mA,setServerUtilities:()=>_Ae});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 A=jR(i,n,l),O,v,F={},G=Promise.resolve(),Y,te,ie;for(let K of E)(K.assignCreatedTime||K.name==="__createdtime__")&&(Y=K),(K.assignUpdatedTime||K.name==="__updatedtime__")&&(te=K),K.expiresAt&&(ie=K),K.isPrimaryKey&&(F=K);let X,ne=[],Q=[],he=1,Re=2,Ce={},me={},Zt=864e5,lt=0,yr,Es,xn,nu=!1,su,xA=new Map,BA=new Map,Lt,mf,jh=jl.get(B.REPLICATION_DATABASES);if(Array.isArray(jh)){for(let K of jh)if(K.name===c&&K.replicateTo>=0){mf=K.replicateTo;break}}let Qh=i.getRange({start:!1,end:!1}).constructor,Ef=10,Jh=6;g&&Tf(),Ah(i.env.path,K=>{if(v)return ca(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=te;static propertyResolvers;static userResolvers={};static sources=[];static getResidencyById;static get expirationMS(){return h}static dbisDB=f;static schemaDefined=u;static sourcedFrom(m,T){if(T&&(this.sourceOptions=T,(T.expiration||T.eviction||T.scanInterval)&&this.setTTLExpiration(T)),T?.intermediateSource)m.intermediateSource=!0,this.sources.unshift(m);else{if(this.sources.some(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),O=O||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 b=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:b("put"),patch:b("patch"),delete:b("delete"),publish:b("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===yf&&(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]],ee=f.get(fe),W=ee?.nodes;W||(W=[]);for(let Ae of U.remoteNodeIds.slice(1)){let ye=W.find(ut=>ut.id===Ae);W=W.filter(ut=>ut.id!==Ae||ut===ye),ye||(ye={id:Ae,seqId:0},W.push(ye)),ye.seqId=Math.max(ee?.seqId??1,U.localTime),Ae===oe?.nodeId&&(ye.lastTxnTime=U.timestamp)}let _e=Math.max(ee?.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 ee of U.writes)try{fe.push(k(ee,U))}catch(W){throw W.message+=" writing "+JSON.stringify(ee)+" of event "+JSON.stringify(U),W}return Promise.all(fe)}else if(U.type==="define_schema"){let fe=this.attributes.slice(0),ee;for(let W of U.attributes)fe.find(_e=>_e.name===W.name)||(fe.push(W),ee=!0);ee&&(dt({table:s,database:c,attributes:fe,origin:"cluster"}),vh.signalSchemaChange(new Uh.SchemaEventMsg(process.pid,Vt.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,T,I){let y=super.getResource(m,T,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 b=!I?.async||i.cache?.get?.(m),P=Fr(T),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,T,{transaction:N,ensureLoaded:I?.ensureLoaded},b,L=>{if(L?De._updateResource(y,L):y.#e=null,T.onlyIfCached&&T.noCacheStore){if(!y.doesExist())throw new wr.ServerError("Entry is not cached",504)}else if(I?.ensureLoaded){let k=un(m,L,T,y);if(k)return P?.disregardReadTxn(),y.#i=!0,UP(k,D=>(De._updateResource(y,D),y))}return y})}catch(b){throw b.message.includes("Unable to serialize object")&&(b.message+=": "+JSON.stringify(m)),b}}return y}static _updateResource(m,T){m.#r=T,m.#e=T?.value??null,m.#n=T?.version}ensureLoaded(){let m=un(this.getId(),this.#r,this.getContext());if(m)return this.#i=!0,UP(m,T=>{this.#r=T,this.#e=T.value,this.#n=T.version})}static getNewId(){let m=F?.type;if(m==="String"||m==="ID")return super.getNewId();if(!Lt){let b=i.getEntry(Symbol.for("id_allocation")),P=b?.value,N;if(P&&P.nodeName===server.hostname&&(!hAe(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(b?.version??null),N=P.start;Lt=new BigInt64Array([BigInt(N)+1n]),Lt=new BigInt64Array(i.getUserSharedBuffer("id",Lt.buffer)),Lt.maxSafeId=P.end}let T=Number(Atomics.add(Lt,0,1n)),I=m==="Int"?512:1048576;if(T+I>=Lt.maxSafeId){let b=a(P=>{Lt.maxSafeId=T+(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(Lt[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(Lt.maxSafeId<N){if(D.end>Lt.maxSafeId-100)return;xe.default.info?.("New id allocation",T,Lt.maxSafeId,x),i.put(Symbol.for("id_allocation"),{start:D.start,end:Lt.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 ${Lt.maxSafeId}, but id of ${N} detected`);let $=y(x);$.alreadyUpdated||Atomics.store(Lt,0,BigInt($.start+1)),Lt.maxSafeId=$.end}},"updateEnd");T+I===Lt.maxSafeId?setImmediate(b):T+100>=Lt.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(()=>b(!0)))}return T;function y(b){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)==b?(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,ca()}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,T){if(De.getResidencyById)return De.getResidencyById(m[t]);let I=mf;if(T.replicateTo!=null){if(Array.isArray(T.replicateTo))return T.replicateTo.includes(server.hostname)?T.replicateTo:[server.hostname,...T.replicateTo];T.replicateTo>=0&&(I=T.replicateTo)}if(I>=0&&server.nodes){let y=[server.hostname];if(T.previousResidency)y.push(...T.previousResidency.slice(0,I));else{let b=server.nodes.map(L=>L.name),P=Math.floor(b.length*Math.random());y.push(...b.slice(P,P+I));let N=P+I-b.length;N>0&&y.push(...b.slice(0,N))}return y}}static enableAuditing(m=!0){g=m,m&&Tf(),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&qn&&m.value&&Aa(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,Vt.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this.isCollection)return this.search(m);if(this.getId()===null)return m?.conditions?this.search(m):{records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:E};if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this.getContext()?.returnNonexistent)return this}allowRead(m,T){let I=Sf(m);if(I?.read){if(I.isSuperUser)return!0;let y=I.attribute_permissions,b=T?.select;if(y?.length>0||nu&&b){if(T||(T={}),b){let P=y?.length>0&&vP(y,"read");T.select=b.map(N=>{let L=N.name||N;if(!P||P[L]){let k=xn[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 T.select=y.filter(P=>P.read&&!xn[P.attribute_name]).map(P=>P.attribute_name);return T}else return!0}}allowUpdate(m,T){let I=Sf(m);if(I?.update){let y=I.attribute_permissions;if(y?.length>0){let b=vP(y,"update");for(let P in T)if(!b[P])return!1;for(let P of y){let N=P.attribute_name;!P.update&&!(N in T)&&(T[N]=this.getProperty(N))}}return aa(this.getContext())}}allowCreate(m,T){if(this.isCollection){let I=Sf(m);if(I?.insert){let y=I.attribute_permissions;if(y?.length>0){let b=vP(y,"insert");for(let P in T)if(!b[P])return!1;return aa(this.getContext())}else return aa(this.getContext())}}else return this.allowUpdate(m,{})}allowDelete(m){return Sf(m)?.delete&&aa(this.getContext())}update(m,T){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&&(T?(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,T),this}addTo(m,T){if(typeof T=="number"||typeof T=="bigint")this.#s===jj?this.set(m,(+this.getProperty(m)||0)+T):(this.#s||this.update(),this.set(m,new kE(T)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,T){if(typeof T=="number")return this.addTo(m,-T);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this.#r}getRecord(){return this.#e}getChanges(){return this.#t}_setChanges(m){this.#t=m}setRecord(m){this.#e=m}invalidate(){this._writeInvalidate()}_writeInvalidate(m,T){let 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(!(oa(P,N,T?.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()}`),A(y,m,this.#r,P,kn,g,{user:I?.user,residencyId:T?.residencyId,nodeId:T?.nodeId},"invalidate")}},"commit")})}_writeRelocate(m){let T=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,T,I),beforeIntermediate:me.relocate?.bind(this,T,I),commit:a((b,P)=>{if(oa(b,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=kn}else k=D;xe.default.trace?.(`Relocating entry id: ${I}, timestamp: ${new Date(b).toISOString()}`),A(I,k,this.#r,b,L,g,{user:T.user,residencyId:m.residencyId,nodeId:m.nodeId,expiresAt:m.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(m,T){let I={previousResidency:this.getResidencyRecord(m.residencyId),isRelocation:!0},y=lu(this.getResidency(T.value,I)),b;if(y){if(!y.includes(server.hostname))return;b=uu(y)}let N=A(m.key,T.value,m,m.version,0,!0,{residencyId:b,expiresAt:T.expiresAt},"relocate",!1,null)}static evict(m,T,I){let y=this.Source,b;if(!((v||g)&&(!T||(b=i.getEntry(m),!b||!T)||b.version!==I))){if(v){if(i.hasLock(m,b.version))return;let P;for(let N in r)P||(P={}),P[N]=T[N];if(P)return A(m,P,b,I,Ea,null,null,null,!0)}if(i.ifVersion(m,I,()=>{ln(m,T,null)}),g)return A(m,null,b,I,Ea,null,null,null,!0);Uc(i,b??i.getEntry(m),I)}}lock(){throw new Error("Not yet implemented")}static operation(m,T){return m.table||=s,m.schema||=c,nQ.operation(m,T)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,T,I){let y=this.getContext(),b=Fr(y),P=this.getId();Ir(P);let N=this.#r;this.#s=T?jj:uAe;let L={key:P,store:i,entry:N,nodeName:y?.nodeName,validate:a(k=>{m||(m=this.#t),T||m&&BE(this.#t===m?this:m)?y?.source||(b.checkOverloaded(),this.validate(m,!T),te&&(m[te.name]=te.type==="Date"?new Date(k):te.type==="String"?new Date(k).toISOString():k),T&&(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))):b.removeWrite(L)},"validate"),before:T?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:T?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");T||(this.#e=D?.value??null)}this.#t=void 0,this.#n=k;let $=D?.value,j=m;this.#s=0;let oe=!1,U=oa(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 ut=l.get(_e);if(!ut)break;let rt=wt(ut);if(Ae=rt.version,Ae>=k){if(Ae===k){if(U=oa(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((ut,rt)=>ut.version-rt.version);for(let ut of ye){let rt=ut.getValue(i);if(j=UE(j,rt,T),xe.default.debug?.("Rebuilding update with future patch:",j),!j)return}}else{if(T)return;j=UE(j,$,T),xe.default.debug?.("Rebuilding update without audit:",j)}let ce;if(T?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)}T||(ue=m);let ee=y?.expiresAt??(h?h+Date.now():-1);xe.default.trace?.(`Saving record with id: ${P}, timestamp: ${new Date(k).toISOString()}${ee?", expires at: "+new Date(ee).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=T?"put":"patch";A(P,ce,D,k,oe?kn:0,g,{omitLocalRecord:oe,user:y?.user,residencyId:fe,expiresAt:ee,nodeId:I?.nodeId,originatingOperation:y?.originatingOperation},W,!1,ue),y.expiresAt&&ca()},"commit")};b.addWrite(L)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this.isCollection){for await(let T of this.search(m))(await De.getResource(T[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this.#e?this._writeDelete(m):!1}_writeDelete(m){let T=Fr(this.getContext()),I=this.getId();Ir(I);let y=this.getContext();return T.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((b,P,N)=>{let L=P?.value;N&&(y&&P?.version>(y.lastModified||0)&&(y.lastModified=P.version),De._updateResource(this,P)),!(oa(b,P,m?.nodeId)<=0)&&(ln(this.getId(),L),xe.default.trace?.(`Deleting record with id: ${I}, txn timestamp: ${new Date(b).toISOString()}`),g||R?(A(I,null,this.#r,b,0,g,{user:y?.user,nodeId:m?.nodeId},"delete"),g||ca()):Uc(i,P))},"commit")}),!0}search(m){let T=this.getContext(),I=Fr(T);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 b,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 ut=ye[0]??ye.attribute,rt=ut==null?F:Ni(E,ut);if(rt)(rt.type||fR[ye.comparator])&&(ye[1]===void 0?ye.value=k(ye.value,rt):ye[1]=k(ye[1],rt));else if(ut!=null)throw(0,wr.handleHDBError)(new Error,`${ut} 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,Qe;if(Gr.comparator==="gt"||Gr.comparator==="greater_than"||Gr.comparator==="ge"||Gr.comparator==="greater_than_equal"?(Ee=ye,Qe=Gr):(Ee=Gr,Qe=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=Qe.comparator==="ge"||Qe.comparator==="greater_than_equal",qt=Ee.comparator==="le"||Ee.comparator==="less_than_equal";ye.comparator=(nt?"ge":"gt")+(qt?"le":"lt"),ye.value=[Qe.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,tQ.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(b=y.find(_e=>Eu(_e.attribute)===Eu(W)),!b){let _e=Ni(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)b={attribute:W,comparator:"sort"},y.push(b);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)}b&&(b.descending=!!x.descending)}y=L(y,D),x&&(b&&y[0]===b?x.next&&($={dbOrderedAttribute:x.attribute,attribute:x.next.attribute,descending:x.next.descending,next:x.next.next}):(b&&y.splice(y.indexOf(b),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=_R(y,D,De,oe,m,T,(W,_e)=>au(W,j,T,oe,_e),P),ue=m.ensureLoaded!==!1;$||(U=ee(U));let ce=De.transformEntryForSelect(j,T,oe,P,ue,!0),fe=De.transformToOrderedSelect(U,j,$,oe,T,ce);function ee(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(ee,"applyOffset"),$&&(fe=ee(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,T,I,y,b,P){let N=new Qh;if(I){m=au(m,T,y,b,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(ee){let W=ee.next&&ce(ee.next),_e=ee.descending;return(Ae,ye)=>{let ut=ou(Ae,ee.attribute,y),rt=ou(ye,ee.attribute,y),Gr=_e?(0,Ql.compareKeys)(rt,ut):(0,Ql.compareKeys)(ut,rt);return Gr===0?W?.(Ae,ye)||0:Gr}}a(ce,"createComparator");let fe=ce(I);return{async next(){let ee;if(D)if(ee=D.next(),ee.done){if($)return N.onDone&&N.onDone(),ee}else return{value:await P.call(this,ee.value)};L=[],oe&&L.push(oe);do if(ee=await x.next(),ee.done){if($=!0,L.length)break;return N.onDone&&N.onDone(),ee}else{let W=ee.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](),ee=D.next(),ee.done?(N.onDone&&N.onDone(),ee):{value:await P.call(this,ee.value)}},return(){N.onDone&&N.onDone(),x.return()},throw(){N.onDone&&N.onDone(),x.throw()}}};let k=a(D=>{if(typeof T=="object"&&Array.isArray(D.attribute))for(let x=0;x<T.length;x++){let $=T[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]&&(T[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,T,I,y,b,P){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let D=a(x=>(T?.transaction?.stale&&(T.transaction.stale=!1),x?.key??x),"transform");return m===t?D:m.asArray?x=>[D(x)]:x=>({[t]:D(x)})}let N;b&&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(T?.transaction?.stale&&(T.transaction.stale=!1),D!=null){if(x=D.value||D.deref?.()?.value,!x&&(D.key===void 0||D.deref)||D.metadataFlags&kn){if(D.metadataFlags&kn&&T.replicateFrom===!1&&P&&D.residencyId)return hc.SKIP;if(D=iu(D.key??D,T,{transaction:I,lazy:m?.length<4,ensureLoaded:b},this?.isSync,$=>$),D?.then)return D.then(k.bind(this));x=D?.value}if(N&&D?.metadataFlags&(kn|Ea)||D?.expiresAt!=null&&D?.expiresAt<Date.now()){if(T.onlyIfCached&&T.noCacheStore)return{[t]:D.key,message:"This entry has expired"};let $=un(D.key??D,D,T);if($?.then)return $.then(k)}}if(x==null)return P?hc.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=xn?.[ce],ee;if(fe){let W=y?.[ce];if(W)if(W.hasMappings){let Ae=fe.from?x[fe.from]:Eu(D.key);ee=W.get(Ae),ee||(ee=[])}else ee=W.fromRecord?.(x);else ee=fe(x,T,D);let _e=a(Ae=>{if(Ae&&typeof Ae=="object"){let ye=fe.definition?.tableClass||De;L||(L={});let ut=L[ce]||(L[ce]=ye.transformEntryForSelect(ce===U?null:U.select||(Array.isArray(U)?U:null),T,I,W,b));if(Array.isArray(Ae)){let rt=[],Gr=ye.transformToOrderedSelect(Ae,U.select,typeof U.sort=="object"&&U.sort,T,I,ut)[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"),Qe=Ee(Gr.next());Qe&&($||($=[]),$.push(Qe));return}else if(Ae=ut.call(this,Ae),Ae?.then){$||($=[]),$.push(Ae.then(rt=>ue(rt,ce)));return}}ue(Ae,ce)},"handleResolvedValue");ee?.then?($||($=[]),$.push(ee.then(_e))):_e(ee);return}else ee=x[ce],ee&&typeof ee=="object"&&ce!==U&&(ee=De.transformEntryForSelect(U.select||U,T,I,null)({value:ee}));ue(ee,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||dt({table:s,database:c,schemaDefined:u,attributes:E,audit:!0}),m||(m={});let T=!m.rawEvents,I=[],y=this,b=MP(De,this.getId()??null,function(N,L,k,D){try{let x=L.getValue?.(i,T),$=L.type;if(!x&&$==="patch"&&T){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&&(b.includeDescendants=!0,m.onlyChildren&&(b.onlyChildren=!0)),m.supportsTransactions&&(b.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,T,D);if(b.send({id:j,localTime:D,value:oe,version:$.version,type:$.type}),b.queue?.length>Jj&&await b.waitForDrain()===!1)return}b.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,T,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;)b.send(D[--x]);D[0]&&(b.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,Ql.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(x&&(b.send({id:D,localTime:j,value:x,version:$,type:"put"}),b.queue?.length>Jj&&await b.waitForDrain()===!1))return}}else{L&&!k&&(k=0);let D=this.#r?.localTime;if(D===zR&&(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,T,$);T&&(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;)b.send(x[--j]);b.startTime=D}!m.omitCurrent&&this.doesExist()&&b.send({id:N,localTime:D,value:this.#e,version:this.#n,type:"put"})}for(let D of I)b.send(D);I=null})();return m.listener&&b.on("data",m.listener),b}static subscribeOnThisThread(m,T){return m===0||T?.crossThreads===!1}doesExist(){return!!(this.#e||this.#s)}publish(m,T){this._writePublish(m,T)}_writePublish(m,T){let I=Fr(this.getContext()),y=this.getId()||null;y!=null&&Ir(y);let b=this.getContext();I.addWrite({key:y,store:i,entry:this.#r,nodeName:b?.nodeName,validate:a(()=>{b?.source||(I.checkOverloaded(),this.validate(m))},"validate"),before:Ce.publish?.bind(this,b,y,m),beforeIntermediate:me.publish?.bind(this,b,y,m),commit:a((P,N,L)=>{N===void 0&&R&&!g&&ca(),xe.default.trace?.(`Publishing message to id: ${y}, timestamp: ${new Date(P).toISOString()}`),A(y,N?.value??null,N,N?.version||P,0,!0,{user:b?.user,residencyId:T?.residencyId,expiresAt:b?.expiresAt,nodeId:T?.nodeId},"message",!1,m)},"commit")})}validate(m,T){let I,y=a((b,P,N)=>{if(P.type&&b!=null)if(T&&b.__op__&&(b=b.value),P.properties){typeof b!="object"&&(I||(I=[])).push(`Value ${qs(b)} 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(b[x.name],x,N+"."+x.name);$&&(b[x.name]=$)}if(P.sealed&&b!=null&&typeof b=="object")for(let k in b)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 b!="number"||b>>0!==b)&&(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof b!="number"||!(Math.floor(b)===b&&Math.abs(b)<=9007199254740992))&&(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof b!="number"&&(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a number`);break;case"ID":typeof b=="string"||b?.length>0&&b.every?.(L=>typeof L=="string")||(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a string, or an array of strings`);break;case"String":typeof b!="string"&&(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a string`);break;case"Boolean":typeof b!="boolean"&&(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a boolean`);break;case"Date":if(!(b instanceof Date)){if(typeof b=="string"||typeof b=="number")return new Date(b);(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a Date`)}break;case"BigInt":if(typeof b!="bigint"){if(typeof b=="string"||typeof b=="number")return BigInt(b);(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a bigint`)}break;case"Bytes":if(!(b instanceof Uint8Array)){if(typeof b=="string")return Buffer.from(b);(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(b instanceof Ci)){if(typeof b=="string"&&(b=Buffer.from(b)),b instanceof Buffer)return createBlob(b,{type:"text/plain"});(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a Blob`)}break;case"array":if(Array.isArray(b)){if(P.elements)for(let L=0,k=b.length;L<k;L++){let D=b[L],x=y(D,P.elements,N+"[*]");x&&(b[L]=x)}}else(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be an Array`);break}P.nullable===!1&&b==null&&(I||(I=[])).push(`Property ${N} is required (and not does not allow null values)`)},"validateValue");for(let b=0,P=E.length;b<P;b++){let N=E[b];if(!(N.relationship||N.computed)&&(!T||N.name in m)){let L=y(m[N.name],N,N.name);L&&(m[N.name]=L)}}if(d)for(let b in m)E.find(P=>P.name===b)||(I||(I=[])).push(`Property ${b} 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 T=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,rQ.validateAttribute)(I.name),T.push(I)}return dt({table:s,database:c,schemaDefined:u,attributes:T}),De.indexingOperation}static async removeAttributes(m){let T=E.filter(I=>!m.includes(I.name));return dt({table:s,database:c,schemaDefined:u,attributes:T}),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,T=_A.default.statfsSync?.(m)??{};return{available:T.bavail*T.bsize,free:T.bfree*T.bsize,size:T.blocks*T.bsize}}static async getRecordCount(m){let T=i.getStats().entryCount,I=1e3/2,y=performance.now(),b=Math.floor(T/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 pc(),!P&&L<b&&performance.now()-y>I){k=L;break}if(k){let D=N;N=0;for(let{value:ee}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:k,snapshot:!1}))ee!=null&&N++,await pc();let x=k*2,$=(N+D)/x,j=Math.pow((N-D+1)/k/2,2)+$*(1-$)/x,oe=Math.max(Math.sqrt(j)*T,1),U=Math.round($*T),ue=Math.max(U-1.96*oe,N+D),ce=Math.min(U+1.96*oe,T),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(){xn=this.propertyResolvers={$id:a((m,T,I)=>({value:I.key}),"$id"),$updatedtime:a((m,T,I)=>I.version,"$updatedtime"),$record:a((m,T,I)=>I?{value:m}:m,"$record")};for(let m of this.attributes){m.resolve=null;let T=m.relationship,I=m.computed;if(T)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),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,T.to)m.elements?.definition?(xn[m.name]=m.resolve=(y,b,P)=>{let N=y[T.from?T.from:t],L=m.elements.definition.tableClass;return P?mu({attribute:T.to,value:N},Fr(b).getReadTxn(),!1,L,!1).asArray:L.search([{attribute:T.to,value:N}],b).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,T.from&&(m.resolve.from=T.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(T.from){let y=m.definition||m.elements?.definition;y?(xn[m.name]=m.resolve=(b,P,N)=>{let L=b[T.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 T.filterMissing?k?Promise.all(D).then(x=>x.filter(eQ)):D.filter(eQ):k?Promise.all(D):D}return N?y.tableClass.primaryStore.getEntry(L,{transaction:Fr(P).getReadTxn()}):y.tableClass.get(L,P)}},m.set=(b,P)=>{if(Array.isArray(P)){let N=P.map(L=>L.getId?.()||L[y.tableClass.primaryKey]);b[T.from]=N}else{let N=P.getId?.()||P[y.tableClass.primaryKey];b[T.from]=N}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=T.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`);else I&&(typeof I.from=="function"&&this.setComputedAttribute(m.name,I.from),xn[m.name]=m.resolve=(y,b,P)=>{let N=typeof I.from=="string"?y[I.from]:y,L=this.userResolvers[m.name];if(L)return L(N,b,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]=()=>{}})}FE(this,this)}static setComputedAttribute(m,T){let I=Ni(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]=T}static async deleteHistory(m=0,T=!1){let I;for(let{key:y,value:b}of l.getRange({start:0,end:m}))await pc(),wt(b).tableId===n&&(I=dA(l,y,b));if(T)for(let y of i.getRange({start:0,versions:!0})){let{key:b,value:P,localTime:N}=y;await pc(),P===null&&N<m&&(I=Uc(i,y))}await I}static async*getHistory(m=0,T=1/0){for(let{key:I,value:y}of l.getRange({start:m||1,end:T})){await pc();let b=wt(y);b.tableId===n&&(yield{id:b.recordId,localTime:I,version:b.version,type:b.type,value:b.getValue(i,!0,I),user:b.user,operation:b.originatingOperation})}}static async getHistoryOfRecord(m){let T=[];if(m==null)throw new Error("An id is required");let I=i.getEntry(m);if(!I)return T;let y=I.localTime;if(!y)throw new Error("The entry does not have a local audit time");let b=0;do{await pc();let P=l.get(y);if(P){let N=wt(P);T.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(b<1e3&&y);return T.reverse()}static cleanup(){X?.remove()}}De.updatedAttributes();let gf=De.prototype;return h&&De.setTTLExpiration(h/1e3),ie&&cu(),De;function ln(K,m,T){let I;for(let y in r){let b=r[y],P=b.isIndexing,N=xn[y],L=T&&(N?N(T):T[y]),k=m&&(N?N(m):m[y]);if(L===k&&!P)continue;I=!0;let D=b.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}));b.prefetch(oe,Xj)}for(let oe=0,U=$.length;oe<U;oe++)b.remove($[oe],K)}else x?.length>0&&zj&&b.prefetch(x.map(j=>({key:j,value:K})),Xj);if(x)for(let j=0,oe=x.length;j<oe;j++)b.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>Qj)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,Ql.writeKey)(K,dAe,0)>Qj)throw new Error("Primary key size is too large: "+K.length);return!0}a(Ir,"checkValidId");function iu(K,m,T,I,y){if(De.getResidencyById&&T.ensureLoaded&&m?.replicateFrom!==!1){let P=lu(De.getResidencyById(K));if(P&&!P.includes(server.hostname)&&O)return O({key:K,residency:P}).then(y)}let b=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),T.transaction?.isDone)return y(null,K);let P=i.getEntry(K,T);return P?.residencyId&&P.metadataFlags&kn&&O&&T.ensureLoaded&&m?.replicateFrom!==!1?O(P).then(N=>y(N,K),N=>(xe.default.error?.("Error loading remote record",K,P,T,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?b():he>0?(he--,b()):new Promise((P,N)=>{he===0?(he--,i.prefetch([K],()=>{L(),k()})):(ne.push(K),Q.push(k),ne.length>Jh&&(he--,L()));function L(){if(ne.length>0){let D=Q;i.prefetch(ne,()=>{he===-1?L():he++;for(let x of D)x()}),ne=[],Q=[],Re>2&&Re--}else he=Re,Re<Ef&&Re++}a(L,"prefetch");function k(){try{P(b())}catch(D){N(D)}}a(k,"load")})}a(iu,"loadLocalRecord");function Sf(K){if(!K?.role)return;let m=K.role.permission;if(m.super_user)return fAe;let T=m[c],I,y=T?.tables;if(y)return y[s];if(c==="data"&&(I=m[s])&&!I.tables)return I}a(Sf,"getTablePermissions");function un(K,m,T,I){if(v){let y=!1;if(T.noCache?y=!0:(m?(!m.value||m.metadataFlags&(kn|Ea)||m.expiresAt!=null&&m.expiresAt<Date.now())&&(y=!0):y=!0,Zn(!y,"cache-hit",s)),y){let b=Xh(K,m,T).then(P=>(P?.value&&P?.value.getRecord?.()&&xe.default.error?.("Can not assign a record that is already a resource"),T&&(P?.version>(T.lastModified||0)&&(T.lastModified=P.version),T.lastRefreshed=Date.now()),P));if(T?.onlyIfCached||m?.value&&I?.allowStaleWhileRevalidate?.(m,K)){if(b.catch(P=>xe.default.warn?.(P)),T?.onlyIfCached&&!I.doesExist())throw new wr.ServerError("Entry is not cached",504);return}else return b}}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 T=m.next;if(!T)return m=m.next=new bc,m.lmdbDb=i,m;m=T}while(!0)}else return new Tm}a(Fr,"txnForContext");function ou(K,m,T){if(!K)return;let I=K.value||i.getEntry(K.key)?.value;if(typeof m=="object"){let b=xn,P=I;for(let N=0,L=m.length;N<L;N++){let k=m[N],D=b?.[k];P=D&&P?D(P,T,!0)?.value:P?.[k],b=D?.definition?.tableClass?.propertyResolvers}return P}let y=xn[m];return y?y(I,T):I[m]}a(ou,"getAttributeValue");function au(K,m,T,I,y){let b=y?.length,P={transaction:I,lazy:b>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},N;function L(k,D){let x=k?.value;if(!x)return hc.SKIP;for(let $=0;$<b;$++)if(!N?.includes($)&&!y[$](x,k))return hc.SKIP;return D!==void 0&&(k.key=D),k}if(a(L,"processEntry"),b>0||!K.hasEntries){let k=K.map(D=>{if(N=null,typeof D=="object"&&D?.key!==void 0)return b>0?L(D):D;if(D==null)return hc.SKIP;for(let x=0;x<b;x++){let j=y[x].idFilter;if(j){if(!j(D))return hc.SKIP;N||(N=[]),N.push(x)}}return iu(D,T,P,!1,L)});return Array.isArray(K)&&(k=k.filter(D=>D!==hc.SKIP)),k.hasEntries=!0,k}return K}a(au,"transformToEntries");function oa(K,m,T=server.replication?.getThisNodeId(l)){if(K<=m?.version){if(m?.version===K&&T!==void 0){let I=server.replication?.exportIdMapping(l),y=m.localTime,b=y&&l.get(y);if(b){let P,N,L=wt(b);for(let k in I)I[k]===T&&(P=k),I[k]===L.nodeId&&(N=k);if(P>N)return 1;if(P===N)return 0}}return-1}return 1}a(oa,"precedesExistingVersion");async function Xh(K,m,T){let I=m?.metadataFlags,y=m?.version,b,P;if(!i.attemptLock(K,y,()=>{clearTimeout(P);let D=i.getEntry(K);!D||!D.value||D.metadataFlags&(kn|Ea)?b(Xh(K,i.getEntry(K),T)):b(D)}))return new Promise(D=>{b=D,P=setTimeout(()=>{i.unlock(K,y)},lAe)});let N=m?.value,L={requestContext:T,replacingRecord:N,replacingEntry:m,replacingVersion:y,noCacheStore:!1,source:null,resourceCache:T?.resourceCache},k=T?.responseHeaders;return new Promise((D,x)=>{let $;UP(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&kn;let ee=L.lastModified||ce&&y;ue=ce||ee>y||!N,ee||(ee=(0,Mh.getNextMonotonicTime)());let W=performance.now()-oe;if(ir(W,"cache-resolution",s,null,"success"),k&&ZE(k,"Server-Timing",`cache-resolve;dur=${W.toFixed(2)}`,!0),j.timestamp=ee,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,ee=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:ee,value:U})}catch(ee){ee.message+=` while resolving record ${K} for ${s}`,N&&((ee.code==="ECONNRESET"||ee.code==="ECONNREFUSED"||ee.code==="EAI_AGAIN")&&!T?.mustRevalidate||T?.staleIfError&&(ee.statusCode===500||ee.statusCode===502||ee.statusCode===503||ee.statusCode===504))?(D({key:K,version:y,value:N}),xe.default.trace?.(ee.message,"(returned stale record)")):x(ee);let W=performance.now()-oe;ir(W,"cache-resolution",s,null,"fail"),k&&ZE(k,"Server-Timing",`cache-resolve;dur=${W.toFixed(2)}`,!0),L.transaction.abort();return}if(T?.noCacheStore||L.noCacheStore){L.transaction.abort();return}Fr(L).addWrite({key:K,store:i,entry:m,nodeName:"source",commit:a((ee,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(ee).toISOString()}`),A(K,U,W,ee,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(ee).toISOString()}`),g||R?A(K,null,W,ee,0,g&&ue||null,{user:L?.user},"delete",!!ce):Uc(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 aa(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(aa,"checkContextPermissions");function ca(K){let m=!1;if(K&&(K-lt>1&&(m=!0),lt=K),!(Zt===yr&&!m)&&(yr=Zt,(0,zl.getWorkerIndex)()===(0,zl.getWorkerCount)()-1))return Es&&clearTimeout(Es),Zt?new Promise(T=>{let I=new Date;I.setMonth(0),I.setDate(1),I.setHours(0),I.setMinutes(0),I.setSeconds(0);let y=Zt/(1+lt),b=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)}`),Es=setTimeout(()=>G=G.then(async()=>{if(P(Math.max(N+Zt,Date.now())),i.rootStore.status!=="open"){clearTimeout(Es);return}let L=50,k=new Array(L),D=0,x=Math.pow(lt,8)*(jl.get(B.STORAGE_RECLAMATION_EVICTIONFACTOR)??1e5),$=S/Math.pow(Math.max(lt,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(lt){let ee=i.lastSize;return ue&qn&&Yf(ce,W=>{W.size&&(ee+=W.size)}),xe.default.trace?.(`shouldEvict adjusted ${fe} ${ee}, ${fe*(oe-U)/ee} < ${x}`),fe*(oe-U)/ee<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:ee,metadataFlags:W}=U,_e;ce===null&&!g&&fe+cAe<Date.now()?_e=Uc(i,U,fe):ee!=null&&j(ee,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 pc()}xe.default.info?.(`Finished cleanup scan for ${s}, evicted ${oe} entries`)}catch(oe){xe.default.warn?.(`Error in cleanup scan for ${s}:`,oe)}T(void 0),lt=0}),Math.min(N-Date.now(),2147483647)).unref()},"startNextTimer");P(b)}):void 0}a(ca,"scheduleCleanup");function Tf(){X=l?.addDeleteRemovalCallback(n,i,(K,m)=>{i.remove(K,m)})}a(Tf,"addDeleteRemoval");function cu(){(0,zl.getWorkerIndex)()===0&&setInterval(async()=>{if(!su){su=!0;try{let K=ie.name,m=r[K];if(!m)throw new Error(`expiresAt attribute ${ie} must be indexed`);for(let T of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let I of m.getValues(T)){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(T,I))}await pc()}}catch(K){xe.default.error?.("Error in evicting old records",K)}finally{su=!1}}},aAe).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(T=>T.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(","),T=f.get([Symbol.for("residency_by_set"),m]);return T||(f.put([Symbol.for("residency_by_set"),m],T=Math.floor(Math.random()*2147418112)+65535),f.put([Symbol.for("residency_by_id"),T],K),T)}}a(uu,"getResidencyId")}function vP(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 _Ae(e){nQ=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;pAe.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 UP(e,t,r){return e?.then?e.then(t,r):t(e)}function eQ(e){return e!=null}function qs(e){try{return JSON.stringify(e)}catch{return e}}function hAe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var hc,Mh,tQ,rQ,jl,wr,vh,Uh,xe,Ql,zl,hA,_A,oAe,nQ,aAe,cAe,zj,lAe,jj,uAe,kn,Ea,dAe,Qj,Jj,fAe,cxe,pAe,pc,Gf=be(()=>{H();hc=require("lmdb"),Mh=M(_n()),tQ=require("lodash"),rQ=M(Uf());ga();Am();jl=M(ae());SN();wr=M(pe()),vh=M(yo()),Uh=M(ni());Pe();Ff();xe=M(Ii());Kb();Oc();Ql=require("ordered-binary"),zl=M(et());ho();hA=M(se());Ou();qi();xE();Q_();_A=M(require("node:fs"));Ts();vT();oAe=new Uint8Array(9);oAe[8]=192;aAe=6e4,cAe=864e5;jl.initSync();zj=jl.get(B.STORAGE_PREFETCHWRITES),lAe=1e4,jj=1,uAe=2,kn=1,Ea=8,dAe=Buffer.allocUnsafeSlow(8192),Qj=1978,Jj=100,fAe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},cxe=(0,hA.convertToMS)(jl.get(B.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(mA,"makeTable");a(vP,"attributesAsObject");a(Xj,"noop");a(_Ae,"setServerUtilities");pAe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(pA,"coerceType");a(fA,"rejectNaN");a(Zj,"isDescendantId");pc=a(()=>new Promise(setImmediate),"rest");a(UP,"when");a(eQ,"exists");a(qs,"stringify");a(hAe,"hasOtherProcesses")});var tt={};ve(tt,{database:()=>Fu,database_envs:()=>ta,databases:()=>qe,dropDatabase:()=>Qb,dropTableMeta:()=>TAe,getDatabases:()=>Je,getDefaultCompression:()=>IS,getTables:()=>mAe,onRemovedDB:()=>mp,onUpdatedTable:()=>ml,readMetaDb:()=>xh,resetDatabases:()=>Cd,table:()=>dt,tables:()=>Xn});function mAe(){return TA||Je(),Xn||{}}function Je(){if(TA)return qe;TA=!0,df=new Map;let e=(0,Jt.getHdbBasePath)()&&(0,Dt.join)((0,Jt.getHdbBasePath)(),yc),t=(0,Jt.get)(B.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Jt.get)(B.STORAGE_PATH)||e&&((0,fs.existsSync)(e)?e:(0,Dt.join)((0,Jt.getHdbBasePath)(),im)),!e)return;if((0,fs.existsSync)(e))for(let n of(0,fs.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,fs.existsSync)((0,uf.getBaseSchemaPath)())){for(let n of(0,fs.readdirSync)((0,uf.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Dt.join)((0,uf.getBaseSchemaPath)(),n.name),i=(0,Dt.join)((0,uf.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,fs.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,fs.existsSync)(i))for(let c of(0,fs.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,fs.existsSync)(u)&&xh(u,c,n,null,!0)}}for(let n in qe){let s=df.get(n);if(s){let i=qe[n];n.includes("delete")&&Ft.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(Ft.trace(`delete table class ${o}`),delete i[o])}else if(delete qe[n],n==="data"){for(let i in Xn)delete Xn[i];delete Xn[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 df=null,qe}function Cd(){TA=!1;for(let[,e]of ta)e.needsDeletion=!0;Je();for(let[e,t]of ta)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),ta.delete(e),delete qe[t.databaseName],Hh.forEach(r=>r(t.databaseName)));return qe}function xh(e,t,r=HP,n,s){let i=new xP.default(e,!1);try{let o=ta.get(e);o?o.needsDeletion=!1:(o=(0,ff.open)(i),ta.set(e,o));let c=new Jl.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(EA.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,fs.existsSync)(n)&&(i.path=n,u=(0,ff.open)(i),u.isLegacy=!0):u=uA(o));let f=aQ(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 Q of S)if(Q.is_hash_attribute||Q.isPrimaryKey){g=Q;break}if(!g){Ft.warn(`Unable to find a primary key attribute on table ${_}, with attributes: ${JSON.stringify(S)}`);continue}}let R=f[_],E={},A=[],O,v,F=typeof g.audit=="boolean"?g.audit:(0,Jt.get)(B.LOGGING_AUDITLOG),G=g.trackDeletes,Y=g.expiration,te=g.eviction,ie=g.sealed,X=g.splitSegments,ne=g.replicate;if(R)E=R.indices,A=R.attributes,R.schemaVersion++;else{O=g.tableId,O?O>=(l.get(lf)||0)&&(l.putSync(lf,O+1),Ft.info(`Updating next table id (it was out of sync) to ${O+1} for ${_}`)):(g.tableId=O=l.get(lf),O||(O=1),Ft.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(lf,O+1),l.putSync(g.key,g));let Q=new Jl.default(!g.is_hash_attribute,g.is_hash_attribute);if(Q.compression=g.compression,Q.compression){let he=(0,Jt.get)(B.STORAGE_COMPRESSION_THRESHOLD)||oQ;Q.compression.threshold=he}v=jm(o.openDB(g.key,Q),o),o.databaseName=r,v.tableId=O}for(let Q of S){Q.attribute=Q.name;try{if(!Q.is_hash_attribute&&(Q.indexed||Q.attribute&&!Q.name)){if(!E[Q.name]){let Re=new Jl.default(!Q.is_hash_attribute,Q.is_hash_attribute);E[Q.name]=o.openDB(Q.key,Re),E[Q.name].indexNulls=Q.indexNulls}let he=A.find(Re=>Re.name===Q.name);he?A.splice(A.indexOf(he),1,Q):A.push(Q)}}catch(he){Ft.error("Error trying to update attribute",Q,A,E,he)}}if(!R){R=cQ(f,_,mA({primaryStore:v,auditStore:u,audit:F,sealed:ie,splitSegments:X,replicate:ne,expirationMS:Y&&Y*1e3,evictionMS:te&&te*1e3,trackDeletes:G,tableName:_,tableId:O,primaryKey:g.name,databasePath:s?r+"/"+_:r,databaseName:r,indices:E,attributes:S,schemaDefined:g.schemaDefined,dbisDB:l})),R.schemaVersion=1;for(let Q of Bh)Q(R)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function aQ(e){let t=qe[e];if(t||(e==="data"?t=qe[e]=Xn:e==="system"?Object.defineProperty(qe,"system",{value:t=Object.create(null),configurable:!0}):t=qe[e]=Object.create(null)),df&&!df.has(e)){let r=new Set;t[AA]=r,df.set(e,r)}return t}function cQ(e,t,r){return e[t]=r,r}function Fu({database:e,table:t}){e||(e=HP),Je();let r=aQ(e),n=(0,Dt.join)((0,Jt.getHdbBasePath)(),yc),s=(0,Jt.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,Jt.get)(B.STORAGE_PATH)||((0,fs.existsSync)(n)?n:(0,Dt.join)((0,Jt.getHdbBasePath)(),im));let o=(0,Dt.join)(n,(i?t:e)+".mdb"),c=ta.get(o);if(!c||c.status==="closed"){let l=new xP.default(o,!1);c=(0,ff.open)(l),ta.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,ta.delete(r.path),r.status==="open"&&(await r.close(),await kh.remove(r.path));if(r||(r=Fu({database:e,table:null}),r.status==="open"&&(await r.close(),await kh.remove(r.path))),e==="data"){for(let n in Xn)delete Xn[n];delete Xn[AA]}delete qe[e],Hh.forEach(n=>n(e)),await NR(r)}function dt(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,schemaDefined:p,origin:_}=e;r||(r=HP);let h=Fu({database:r,table:t}),S=qe[r];Ft.trace(`Defining ${t} in ${r}`);let g=S?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let R,E,A;p==null&&(p=!0);let O=new Jl.default(!1);for(let X of o)X.attribute&&!X.name?(X.name=X.attribute,X.indexed=!0):X.attribute=X.name,X.expiresAt&&(X.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 X=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,Jt.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=[_]),Ft.trace(`${t} table loading, opening primary store`);let ne=new Jl.default(!1,!0);ne.compression=E.compression;let Q=t+"/";if(A=h.dbisDb=h.openDB(EA.INTERNAL_DBIS_NAME,O),ie(),A.get(Q))return F&&F(),Cd(),dt(e);let he=jm(h.openDB(Q,ne),h);h.databaseName=r,he.tableId=A.get(lf),Ft.trace(`Assigning new table id ${he.tableId} for ${t}`),he.tableId||(he.tableId=1),A.put(lf,he.tableId+1),E.tableId=he.tableId,g=cQ(S,t,mA({primaryStore:he,auditStore:X,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:A})),g.schemaVersion=1,v=!0,A.put(Q,E)}let G=g.indices;A=A||(h.dbisDb=h.openDB(EA.INTERNAL_DBIS_NAME,O)),g.dbisDB=A;let Y=[];for(let{key:X,value:ne}of A.getRange({start:!0})){let[Q,he]=X.toString().split("/");if(he===""&&(he=ne.name),he){if(Q!==t)continue}else continue;let Re=o.find(me=>me.name===he),Ce=!Re?.indexed&&ne.indexed&&!ne.isPrimaryKey;if((!Re||Ce)&&(ie(),v=!0,Re||A.remove(X),Ce)){let me=g.indices[Q];me&&Y.push(me)}}let te=[];try{for(let X of o||[]){if((X.relationship||X.computed)&&(v=!0,X.relationship))continue;let ne=t+"/"+(X.name||"");Object.defineProperty(X,"key",{value:ne,configurable:!0});let Q=A.get(ne);if(X.isPrimaryKey){if(Q=Q||A.get(ne=t+"/")||{},c!==void 0&&c!==g.audit||l!==void 0&&l!==g.sealed||f!==void 0&&f!==g.replicate||(+n||void 0)!==(+Q.expiration||void 0)||(+s||void 0)!==(+Q.eviction||void 0)){let Re={...Q};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,ie(),A.put(ne,Re)}continue}Q?.attribute&&!Q.name&&(Q.indexed=!0);let he=!Q||Q.type!==X.type||Q.indexed!==X.indexed||Q.nullable!==X.nullable||Q.version!==X.version||JSON.stringify(Q.properties)!==JSON.stringify(X.properties)||JSON.stringify(Q.elements)!==JSON.stringify(X.elements);if(X.indexed){let Re=new Jl.default(!0,!1),Ce=h.openDB(ne,Re);(he||Q.indexingPID&&Q.indexingPID!==process.pid||Q.restartNumber<Fh.workerData?.restartNumber)&&(v=!0,ie(),Q=A.get(ne),(he||Q.indexingPID&&Q.indexingPID!==process.pid||Q.restartNumber<Fh.workerData?.restartNumber)&&(v=!0,X.indexNulls===void 0&&(X.indexNulls=!0),g.primaryStore.getStats().entryCount>0&&(X.lastIndexedKey=Q?.lastIndexedKey??void 0,X.indexingPID=process.pid,Ce.isIndexing=!0,Object.defineProperty(X,"dbi",{value:Ce}),te.push(X))),A.put(ne,X)),Q?.indexNulls&&X.indexNulls===void 0&&(X.indexNulls=!0),Ce.indexNulls=X.indexNulls,G[X.name]=Ce}else he&&(v=!0,ie(),A.put(ne,X))}}finally{F&&F()}if(v&&(g.schemaVersion++,g.updatedAttributes()),Ft.trace(`${t} table loading, running index`),te.length>0||Y.length>0?g.indexingOperation=SAe(g,te,Y):v&&gA.signalSchemaChange(new SA.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=_,v)for(let X of Bh)X(g,_!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Ft.trace(`${t} table loaded`),g;function ie(){F||h.transactionSync(()=>({then(X){F=X}}))}a(ie,"startTxn")}async function SAe(e,t,r){try{Ft.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,ff.compareKeys)(d.lastIndexedKey,u)<0&&(u=d.lastIndexedKey),d.lastIndexedKey==null&&d.dbi.clearAsync();let f=0;for(let{key:d,value:p,version:_}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(p){if(f++,s=e.primaryStore.ifVersion(d,_,()=>{for(let h=0;h<l;h++){let S=t[h],g=S.name;try{let R=S.resolve,E=p&&(R?R(p):p[g]),A=(0,sQ.getIndexedValues)(E);if(A)for(let O=0,v=A.length;O<v;O++)S.dbi.put(A[O],d)}catch(R){o[g]||(o[g]=!0,Ft.error(`Error indexing attribute ${g}`,R))}}}),s.then(()=>f--,h=>{f--,Ft.error(h)}),Fh.workerData&&Fh.workerData.restartNumber!==iQ.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>EAe?await s:f>gAe&&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)),Ft.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Ft.error("Error in indexing",n)}}function TAe({table:e,database:t}){let r=Fu({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 mp(e){return Hh.push(e),{remove(){let t=Hh.indexOf(e);t>-1&&Hh.splice(t,1)}}}function IS(){let e=(0,Jt.get)(B.STORAGE_COMPRESSION),t=(0,Jt.get)(B.STORAGE_COMPRESSION_DICTIONARY),r=(0,Jt.get)(B.STORAGE_COMPRESSION_THRESHOLD)||oQ,n={startingOffset:32};return t&&(n.dictionary=kh.readFileSync(t)),r&&(n.threshold=r),e&&n}var Jt,EA,ff,Dt,fs,uf,Jl,xP,kh,BP,sQ,gA,SA,Fh,Ft,iQ,HP,AA,oQ,Xn,qe,lf,Bh,Hh,TA,ta,df,EAe,gAe,Pe=be(()=>{Jt=M(ae()),EA=M(vt()),ff=require("lmdb"),Dt=require("path"),fs=require("fs"),uf=M(gt());Gf();Jl=M(s_()),xP=M(i_());H();kh=M(require("fs-extra")),BP=M(Ri()),sQ=M(_n()),gA=M(yo()),SA=M(ni()),Fh=require("worker_threads"),Ft=M(z()),iQ=M(et());ho();Ou();Ts();HP="data",AA=Symbol("defined-tables"),oQ=((0,Jt.get)(B.STORAGE_PAGESIZE)||4096)-60;(0,Jt.initSync)();Xn=Object.create(null),qe=Object.create(null);(0,BP._assignPackageExport)("databases",qe);(0,BP._assignPackageExport)("tables",Xn);lf=Symbol.for("next-table-id"),Bh=[],Hh=[],ta=new Map;a(mAe,"getTables");a(Je,"getDatabases");a(Cd,"resetDatabases");a(xh,"readMetaDb");a(aQ,"ensureDB");a(cQ,"setTable");a(Fu,"database");a(Qb,"dropDatabase");a(dt,"table");EAe=1e3,gAe=10;a(SAe,"runIndexing");a(TAe,"dropTableMeta");a(ml,"onUpdatedTable");a(mp,"onRemovedDB");a(IS,"getDefaultCompression")});var se=w((Sxe,RQ)=>{"use strict";var mc=require("path"),_Q=require("fs-extra"),vn=z(),lQ=require("fs-extra"),RA=require("os"),AAe=require("net"),RAe=require("recursive-iterator"),Rr=(H(),C(q)),{PACKAGE_ROOT:yAe}=st(),bAe=nR(),uQ=require("papaparse"),yA=require("moment"),{inspect:OAe}=require("util"),dQ=require("is-number"),gxe=require("lodash"),NAe=require("minimist"),wAe=require("https"),IAe=require("http"),{hdb_errors:bA}=pe(),CAe=/^((\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)))$/,pQ=require("util").promisify(setTimeout),PAe=100,DAe=5,LAe="",MAe=4,fQ={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};RQ.exports={isEmpty:_s,isEmptyOrZeroLength:so,arrayHasEmptyValues:xAe,arrayHasEmptyOrZeroLengthValues:BAe,buildFolderPath:HAe,isBoolean:hQ,errorizeMessage:vAe,stripFileExtension:FAe,autoCast:GAe,autoCastJSON:mQ,autoCastJSONDeep:FP,removeDir:qAe,compareVersions:$Ae,isCompatibleDataVersion:VAe,escapeRawValue:KAe,unescapeValue:YAe,stringifyProps:WAe,timeoutPromise:jAe,isClusterOperation:JAe,getClusterUser:ZAe,checkGlobalSchemaTable:XAe,getHomeDir:gQ,getPropsFilePath:zAe,promisifyPapaParse:eRe,removeBOM:SQ,createEventPromise:tRe,checkProcessRunning:rRe,checkSchemaTableExist:nRe,checkSchemaExists:TQ,checkTableExists:AQ,getStartOfTomorrowInSeconds:sRe,getLimitKey:iRe,isObject:kAe,isNotEmptyAndHasValue:UAe,autoCasterIsNumberCheck:EQ,backtickASTSchemaItems:oRe,isPortTaken:QAe,createForkArgs:aRe,autoCastBoolean:cRe,async_set_timeout:pQ,getTableHashAttribute:lRe,doesSchemaExist:uRe,doesTableExist:dRe,stringifyObj:fRe,ms_to_time:_Re,changeExtension:pRe,getEnvCliRootPath:GP,noBootFile:hRe,httpRequest:mRe,transformReq:ERe,convertToMS:gRe,PACKAGE_ROOT:yAe};function vAe(e){return e instanceof Error?e:new Error(e)}a(vAe,"errorizeMessage");function _s(e){return e==null}a(_s,"isEmpty");function UAe(e){return!_s(e)&&(e||e===0||e===""||hQ(e))}a(UAe,"isNotEmptyAndHasValue");function so(e){return _s(e)||e.length===0||e.size===0}a(so,"isEmptyOrZeroLength");function xAe(e){if(_s(e))return!0;for(let t=0;t<e.length;t++)if(_s(e[t]))return!0;return!1}a(xAe,"arrayHasEmptyValues");function BAe(e){if(so(e))return!0;for(let t=0;t<e.length;t++)if(so(e[t]))return!0;return!1}a(BAe,"arrayHasEmptyOrZeroLengthValues");function HAe(...e){try{return e.join(mc.sep)}catch{console.error(e)}}a(HAe,"buildFolderPath");function hQ(e){return _s(e)?!1:e===!0||e===!1}a(hQ,"isBoolean");function kAe(e){return _s(e)?!1:typeof e=="object"}a(kAe,"isObject");function FAe(e){return so(e)?LAe:e.slice(0,-MAe)}a(FAe,"stripFileExtension");function GAe(e){return _s(e)||e===""||typeof e!="string"?e:fQ[e]!==void 0?fQ[e]:EQ(e)===!0?Number(e):CAe.test(e)?new Date(e):e}a(GAe,"autoCast");function mQ(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(mQ,"autoCastJSON");function FP(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=FP(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=FP(r);n!==r&&(e[t]=n)}return e}else return mQ(e)}a(FP,"autoCastJSONDeep");function EQ(e){if(e.startsWith("0.")&&dQ(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&dQ(e))}a(EQ,"autoCasterIsNumberCheck");async function qAe(e){if(so(e))throw new Error(`Directory path: ${e} does not exist`);try{await lQ.emptyDir(e),await lQ.remove(e)}catch(t){throw vn.error(`Error removing files in ${e} -- ${t}`),t}}a(qAe,"removeDir");function $Ae(e,t){if(so(e)){vn.info("Invalid current version sent as parameter.");return}if(so(t)){vn.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a($Ae,"compareVersions");function VAe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(VAe,"isCompatibleDataVersion");function KAe(e){if(_s(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(KAe,"escapeRawValue");function YAe(e){if(_s(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(YAe,"unescapeValue");function WAe(e,t){if(_s(e))return vn.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+RA.EOL}!so(n)&&n[0]===";"?r+=" "+n+s+RA.EOL:so(n)||(r+=n+"="+s+RA.EOL)}catch{vn.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(WAe,"stringifyProps");function gQ(){let e;try{e=RA.homedir()}catch{e=process.env.HOME}return e}a(gQ,"getHomeDir");function zAe(){let e=mc.join(gQ(),Rr.HDB_HOME_DIR_NAME,Rr.BOOT_PROPS_FILE_NAME);return _Q.existsSync(e)||(e=mc.join(__dirname,"../","hdb_boot_properties.file")),e}a(zAe,"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=AAe.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 JAe(e){try{return Rr.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){vn.error(`Error checking operation against cluster ops ${t}`)}return!1}a(JAe,"isClusterOperation");function XAe(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(XAe,"checkGlobalSchemaTable");function ZAe(e,t){if(_s(t)){vn.warn("No CLUSTERING_USER defined, clustering disabled");return}if(_s(e)||so(e)){vn.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){vn.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){vn.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(ZAe,"getClusterUser");function eRe(){uQ.parsePromise=function(e,t,r){return new Promise(function(n,s){uQ.parse(e,{header:!0,transformHeader:SQ,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(eRe,"promisifyPapaParse");function SQ(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(SQ,"removeBOM");function tRe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;vn.info(`Got cluster status event response: ${OAe(s)}`);try{i.cancel()}catch{vn.error("Error trying to cancel timeout.")}n(s)})})}a(tRe,"createEventPromise");async function rRe(e){let t=!0,r=0;do await pQ(PAe*r++),(await bAe.findPs(e)).length>0&&(t=!1);while(t&&r<DAe);if(t)throw new Error(`process ${e} was not started`)}a(rRe,"checkProcessRunning");function nRe(e,t){let r=TQ(e);if(r)return r;let n=AQ(e,t);if(n)return n}a(nRe,"checkSchemaTableExist");function TQ(e){let{getDatabases:t}=(Pe(),C(tt));if(!t()[e])return bA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(TQ,"checkSchemaExists");function AQ(e,t){let{getDatabases:r}=(Pe(),C(tt));if(!r()[e][t])return bA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(AQ,"checkTableExists");function sRe(){let e=yA().utc().add(1,"d").startOf("d").unix(),t=yA().utc().unix();return e-t}a(sRe,"getStartOfTomorrowInSeconds");function iRe(){return yA().utc().format("DD-MM-YYYY")}a(iRe,"getLimitKey");function oRe(e){try{let t=new RAe(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){vn.error("Got an error back ticking items."),vn.error(t)}}a(oRe,"backtickASTSchemaItems");function aRe(e){return[e]}a(aRe,"createForkArgs");function cRe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(cRe,"autoCastBoolean");function lRe(e,t){let{getDatabases:r}=(Pe(),C(tt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(lRe,"getTableHashAttribute");function uRe(e){let{getDatabases:t}=(Pe(),C(tt));return t()[e]!==void 0}a(uRe,"doesSchemaExist");function dRe(e,t){let{getDatabases:r}=(Pe(),C(tt));return r()[e]?.[t]!==void 0}a(dRe,"doesTableExist");function fRe(e){try{return JSON.stringify(e)}catch{return e}}a(fRe,"stringifyObj");function _Re(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(_Re,"ms_to_time");function pRe(e,t){let r=mc.basename(e,mc.extname(e));return mc.join(mc.dirname(e),r+t)}a(pRe,"changeExtension");function GP(){if(process.env[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=NAe(process.argv);if(e[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(GP,"getEnvCliRootPath");var kP;function hRe(){if(kP)return kP;let e=GP();if(GP()&&_Q.pathExistsSync(mc.join(e,Rr.HDB_CONFIG_FILE)))return kP=!0,!0}a(hRe,"noBootFile");function mRe(e,t){let r;return e.protocol==="http:"?r=IAe:r=wAe,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(mRe,"httpRequest");function ERe(e){if(!e.schema&&!e.database){e.schema=Rr.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(ERe,"transformReq");function gRe(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(gRe,"convertToMS")});var ae=w((wQ,IQ)=>{"use strict";var qP=require("fs-extra"),Xl=require("path"),yQ=require("os"),SRe=require("properties-reader"),qh=z(),Gh=se(),Me=(H(),C(q)),OA=yt(),TRe="Error initializing environment manager",NA="BOOT_PROPS_FILE_PATH",bQ=!1,ARe={[Me.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},ra={};Object.assign(wQ,IQ.exports={BOOT_PROPS_FILE_PATH:NA,getHdbBasePath:RRe,setHdbBasePath:yRe,get:OQ,initSync:ORe,setProperty:Ke,initTestEnvironment:wRe,setCloneVar:NRe});function RRe(){return ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(RRe,"getHdbBasePath");function yRe(e){ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(yRe,"setHdbBasePath");function OQ(e){let t=OA.getConfigValue(e);return t===void 0?ra[e]:t}a(OQ,"get");function Ke(e,t){ARe[e]&&(ra[e]=t),OA.updateConfigObject(e,t)}a(Ke,"setProperty");function bRe(){let e;try{e=Gh.getPropsFilePath(),qP.accessSync(e,qP.constants.F_OK|qP.constants.R_OK),bQ=!0;let t=SRe(e);return ra[Me.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(Me.HDB_SETTINGS_NAMES.INSTALL_USER),ra[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),ra[NA]=e,!0}catch{return qh.trace(`Environment manager found no properties file at ${e}`),!1}}a(bRe,"doesPropFileExist");function ORe(e=!1){try{((bQ||bRe()||Gh.noBootFile())&&!NQ||e)&&(OA.initConfig(e),ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=OA.getConfigValue(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){qh.error(TRe),qh.error(t),console.error(t),process.exit(1)}}a(ORe,"initSync");var NQ=!1;function NRe(e){NQ=e}a(NRe,"setCloneVar");function wRe(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");ra[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,yQ.userInfo()?yQ.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,OQ(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(wRe,"initTestEnvironment")});var MQ=w((Rxe,LQ)=>{"use strict";var IA=ae();IA.initSync();var wA=(H(),C(q)),{httpRequest:IRe}=se(),DQ=require("path"),CQ=require("fs-extra"),CRe=require("yaml"),{packageDirectory:PRe}=(qw(),C(Gw)),{encode:DRe}=require("cbor-x"),LRe=["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"],PQ={deploy:"deploy_component",package:"package_component"};LQ.exports={cliOperations:URe,buildRequest:vRe};var MRe={deploy_component:a(async e=>{if(e.package)return;let t=process.cwd();e.payload=await PRe(t,{skip_node_modules:!0,...e}),e.cborEncode=!0,e.project||(e.project=DQ.basename(t))},"deploy_component")};function vRe(){let e={};for(let t of process.argv.slice(2))if(LRe.includes(t))e.operation=t;else if(PQ.hasOwnProperty(t))e.operation=PQ[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(vRe,"buildRequest");async function URe(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 CQ.existsSync(DQ.join(IA.get(wA.CONFIG_PARAMS.ROOTPATH),wA.HDB_PID_FILE))||(console.error("HarperDB must be running to perform this operation"),process.exit()),CQ.existsSync(IA.get(wA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))||(console.error("No domain socket found, unable to perform this operation"),process.exit());await MRe[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=DRe(e));let n=await IRe(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(CRe.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(URe,"cliOperations")});var xQ=w((bxe,UQ)=>{"use strict";var vQ=require("semver/functions/major"),{packageJson:xRe}=st(),$P=process.versions&&process.versions.node?process.versions.node:void 0;UQ.exports=BRe;function BRe(){let e=xRe.engines["minimum-node"];if($P&&vQ($P)<vQ(e))return{error:`The minimum version of Node.js HarperDB supports is: ${e}, the currently installed Node.js version is: ${$P}. Please install a version of Node.js that is withing the defined range.`}}a(BRe,"checkNodeVersion")});var QP=w((wxe,sJ)=>{"use strict";var BQ=require("os"),CA=require("https"),HQ=require("http"),Xt=require("fs-extra"),kQ=require("yaml"),{pipeline:FQ}=require("stream/promises"),{createWriteStream:PA,ensureDir:$h,writeFileSync:GQ}=require("fs-extra"),{join:Ai}=require("path"),KQ=require("lodash"),HRe=require("minimist"),na=require("path"),kRe=require("node:crypto"),FRe=require("properties-reader"),Vs=ae(),GRe=Do(),WP=z(),DA=yt(),{restart:qRe}=za(),LA=se(),$Re=da(),VRe=ys(),{main:MA,launch:KRe}=jd(),{install:YQ,updateConfigEnv:YRe,setIgnoreExisting:vA}=CT(),WQ=mC(),an=(H(),C(q)),{packageJson:WRe}=st(),zRe=mh(),{sendOperationToNode:YP}=(es(),C(Po)),{updateConfigCert:jRe}=ts(),{restartWorkers:QRe}=et(),{databases:JRe}=(Pe(),C(tt)),{SYSTEM_TABLE_NAMES:VP,SYSTEM_SCHEMA_NAME:Nxe,CONFIG_PARAMS:Vh,OPERATIONS_ENUM:ms}=an,XRe=1e4,ZRe="clone-node-config.yaml",zQ=[VP.ROLE_TABLE_NAME,VP.USER_TABLE_NAME,VP.NODE_TABLE_NAME],eye={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"},ia=HRe(process.argv),_f=ia[kr.HDB_LEADER_USERNAME]??process.env[kr.HDB_LEADER_USERNAME],pf=ia[kr.HDB_LEADER_PASSWORD]??process.env[kr.HDB_LEADER_PASSWORD],eu=ia[kr.HDB_LEADER_URL]??process.env[kr.HDB_LEADER_URL],sa=ia[kr.REPLICATION_HOSTNAME]??process.env[kr.REPLICATION_HOSTNAME],jQ,QQ;sa&&([jQ,QQ]=sa.split(":"));var zP=(ia[kr.HDB_CLONE_OVERTOP]??process.env[kr.HDB_CLONE_OVERTOP])==="true",JQ=ia[Vh.CLONED.toUpperCase()]??process.env[Vh.CLONED.toUpperCase()],tye=ia[kr.CLONE_KEYS]!=="false"&&process.env[kr.CLONE_KEYS]!=="false",XQ=(ia[kr.CLONE_USING_WS]??process.env[kr.CLONE_USING_WS])==="true",ZQ=(ia[kr.NO_START]??process.env[kr.NO_START])==="true",hs,Ec={},qQ,$Q,Zl={},on,Gt,$s,io,tu=!1,jP=!1,ps,hf;sJ.exports=a(async function(t=!1,r=!1){if(console.info(`Starting clone node from leader node: ${eu}`),delete process.env.HDB_LEADER_URL,Gt=LA.getEnvCliRootPath(),!Gt)try{let i=Ai(BQ.homedir(),an.HDB_HOME_DIR_NAME,an.BOOT_PROPS_FILE_NAME);if(await Xt.pathExists(i)){let o=FRe(i);Gt=na.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.")}Gt?await Xt.pathExists(Gt)?console.log(`Existing HarperDB install found at ${Gt}. Clone node will only clone items that do not already exist on clone.`):(console.log(`No HarperDB install found at ${Gt} starting fresh clone`),tu=!0):(console.log("No HarperDB install found, starting fresh clone"),tu=!0),Gt||(Gt=Ai(BQ.homedir(),an.HDB_ROOT_DIR_NAME),console.log("Using default root path",Gt));let n;try{n=Ai(Gt,ZRe),hs=kQ.parseDocument(await Xt.readFile(n,"utf8"),{simpleKeys:!0}).toJSON(),console.log("Clone config file found")}catch{}let s=Ai(Gt,an.HDB_CONFIG_FILE);if(await Xt.pathExists(s))try{qQ=kQ.parseDocument(await Xt.readFile(s,"utf8"),{simpleKeys:!0}).toJSON(),Ec=DA.flattenConfig(qQ)}catch(i){console.error("Error reading existing harperdb-config.yaml on clone",i)}if(sa){let i=new URL(eu);hf=`${i.protocol==="https:"?"wss://":"ws://"}${i.hostname}:${QQ||9933}`}if(XQ){await rye();return}if(Ec?.cloned&&JQ!=="false")return console.log("Instance marked as cloned, clone will not run"),Vs.setCloneVar(!1),Vs.initSync(),MA();on=await eJ({operation:ms.DESCRIBE_ALL}),await rJ(),Vs.setCloneVar(!1),Vs.setHdbBasePath(Gt),Xt.ensureDir(Vs.get(an.CONFIG_PARAMS.LOGGING_ROOT)),WP.initLogSettings(),await nye(),jP||await sye(),await aye(t,r),sa&&(await lye(),await tJ()),console.info(`
135
+ Successfully cloned node: `+eu),(t||ZQ)&&process.exit()},"cloneNode");async function rye(){if(Ec?.cloned&&JQ!=="false")return console.log("Instance marked as cloned, clone will not run"),Vs.setCloneVar(!1),Vs.initSync(),MA();console.log("Cloning using WebSockets");let e=gc("system"),t=Ai(e,"system.mdb"),r=Xt.existsSync(t);tu||!r||zP?(console.info("Clone node installing HarperDB"),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Gt,process.env.HDB_ADMIN_USERNAME="clone-temp-admin",process.env.HDB_ADMIN_PASSWORD=kRe.randomBytes(10).toString("base64").slice(0,10),vA(!0),await YQ()):(Vs.setCloneVar(!1),Vs.initSync()),await MA(),await rJ(!0),await jRe(),r||await JRe.system.hdb_user.delete({username:"clone-temp-admin"}),await QRe(),console.log("Adding node to the cluster");let s=await Ed()({operation:ms.ADD_NODE,url:hf});console.log("Add node response: ",s),await tJ(),console.log(`Successfully cloned node: ${eu} using WebSockets`),DA.updateConfigValue(Vh.CLONED,!0),ZQ&&process.exit()}a(rye,"cloneUsingWS");async function eJ(e){return XQ?YP({url:hf},e,{rejectUnauthorized:!1}):JSON.parse((await uye(e)).body)}a(eJ,"leaderReq");async function tJ(){try{if(tye!==!1){console.log("Cloning JWT keys");let e=na.join(Gt,an.LICENSE_KEY_DIR_NAME),t=await YP({url:hf},{operation:ms.GET_KEY,name:".jwtPublic"},{rejectUnauthorized:!1});GQ(na.join(e,an.JWT_ENUM.JWT_PUBLIC_KEY_NAME),t.message);let r=await YP({url:hf},{operation:ms.GET_KEY,name:".jwtPrivate"},{rejectUnauthorized:!1});GQ(na.join(e,an.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r.message)}}catch(e){console.error("Error cloning JWT keys",e)}}a(tJ,"cloneKeys");async function rJ(e=!1){console.info("Cloning configuration"),$Q=await eJ({operation:ms.GET_CONFIGURATION}),Zl=DA.flattenConfig($Q);let t=hs?.componentConfig?.exclude,r={rootpath:Gt};sa&&(r.replication_hostname=jQ);for(let i in Zl)if(!(Zl[i]!==null&&typeof Zl[i]=="object"&&!(Zl[i]instanceof Array)||eye[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}}Ec[i]||(r[i]=Zl[i])}for(let i in Ec)i!=="databases"&&typeof Ec[i]=="object"&&!(Ec[i]instanceof Array)||(r[i]=Ec[i]);let n={};if(hs?.databaseConfig?.excludeDatabases&&hs.databaseConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),hs?.clusteringConfig?.excludeDatabases&&hs.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=$Re(Object.keys(an.CONFIG_PARAM_MAP),!0);Object.assign(r,s),e||(r.cloned=!0),DA.createConfigFile(r,!0)}a(rJ,"cloneConfig");async function nye(){process.env.HDB_FETCH==="true"?(await oye(),process.env.NODE_TLS_REJECT_UNAUTHORIZED&&delete process.env.NODE_TLS_REJECT_UNAUTHORIZED):await iye()}a(nye,"cloneDatabases");async function sye(){if(console.info("Clone node installing HarperDB."),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Gt,!_f)throw new Error("HDB_LEADER_USERNAME is undefined.");if(process.env.HDB_ADMIN_USERNAME=_f,!pf)throw new Error("HDB_LEADER_PASSWORD is undefined.");process.env.HDB_ADMIN_PASSWORD=pf,process.env.OPERATIONSAPI_NETWORK_PORT=Vs.get(Vh.OPERATIONSAPI_NETWORK_PORT),YRe(na.join(Gt,an.HDB_CONFIG_FILE)),vA(!0),await YQ()}a(sye,"installHDB");function gc(e){return Vs.get(an.CONFIG_PARAMS.DATABASES)?.[e]?.path||Vs.get(Vh.STORAGE_PATH)||na.join(Gt,an.DATABASES_DIR_NAME)}a(gc,"getDBPath");async function iye(){let e=gc("system"),t=Ai(e,"system.mdb");if(await $h(e),tu||!await Xt.exists(t)||zP){if(!sa){console.info("Cloning system database"),await $h(e);let r=PA(t,{overwrite:!0}),n={operation:ms.GET_BACKUP,database:"system",tables:zQ},s=await VQ(n,r),i=new Date(s.date);(!ps||i<ps)&&(ps=i),await Xt.utimes(t,Date.now(),i)}tu||(await WQ(Gt),await nJ(),vA(!0))}else jP=!0,console.log("Not cloning system database due to it already existing on clone");$s=hs?.databaseConfig?.excludeDatabases,$s=$s?$s.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in on)await Xt.exists(na.join(gc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),$s[r]=!0);io=hs?.databaseConfig?.excludeTables,io=io?io.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in on){if($s[r]){on[r]="excluded";continue}if(KQ.isEmpty(on[r]))continue;let n=[],s=!1;for(let d in on[r])io[r+d]?(s=!0,on[r][d]="excluded"):n.push(on[r][d]);if(n.length===0)continue;if(sa){WP.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:ms.GET_BACKUP,database:r,tables:n}):(console.info(`Cloning database: ${r}`),i={operation:ms.GET_BACKUP,database:r});let o=gc(r);await $h(o);let c=Ai(o,r+".mdb"),l=PA(c,{overwrite:!0}),u=await VQ(i,l),f=new Date(u.date);(!ps||f<ps)&&(ps=f),await Xt.utimes(c,Date.now(),f)}}a(iye,"cloneTablesHttp");async function oye(){let e=gc("system"),t=Ai(e,"system.mdb");if(tu||!await Xt.exists(t)||zP){if(!sa){console.info("Cloning system database using fetch");let r={operation:ms.GET_BACKUP,database:"system",tables:zQ},n=await KP(r,!0),s=gc("system");await $h(s);let i=Ai(s,"system.mdb");await FQ(n.body,PA(i,{overwrite:!0}));let o=new Date(n.headers.get("date"));(!ps||o<ps)&&(ps=o),await Xt.utimes(i,Date.now(),new Date(n.headers.get("date")))}tu||(await WQ(Gt),await nJ(),vA(!0))}else jP=!0,console.log("Not cloning system database due to it already existing on clone");if(sa){WP.info("Replication hostname set, not using backup to clone databases, replication will clone");return}$s=hs?.databaseConfig?.excludeDatabases,$s=$s?$s.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in on)await Xt.exists(na.join(gc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),$s[r]=!0);io=hs?.databaseConfig?.excludeTables,io=io?io.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in on){if($s[r]){on[r]="excluded";continue}if(KQ.isEmpty(on[r]))continue;let n=[],s=!1;for(let f in on[r])io[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 KP({operation:ms.GET_BACKUP,database:r,tables:n},!0)):(console.info(`Cloning database: ${r}`),i=await KP({operation:ms.GET_BACKUP,database:r},!0));let o=gc(r);await $h(o);let c=new Date(i.headers.get("date")),l=Ai(o,`${c.getTime()}-${r}.mdb`);await FQ(i.body,PA(l,{overwrite:!0}));let u=Ai(o,r+".mdb");await Xt.rename(l,u),(!ps||c<ps)&&(ps=c),await Xt.utimes(u,Date.now(),c)}}a(oye,"cloneTablesFetch");async function KP(e,t=!1){let r=hs?.httpsRejectUnauthorized??!1,n=new CA.Agent({rejectUnauthorized:r});r||(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0");let i={Authorization:"Basic "+Buffer.from(_f+":"+pf).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(KP,"leaderHttpReqFetch");async function aye(e,t=!1){let r=await GRe.getHDBProcessInfo();r.clustering.length===0||r.core.length===0?e?await KRe(!1):(t&&await cye(),await MA()):(console.info(await qRe({operation:ms.RESTART})),await LA.async_set_timeout(XRe)),e&&await LA.async_set_timeout(2e3)}a(aye,"startHDB");async function cye(){let e=process.argv[3];e&&e[0]!=="-"&&(await Xt.exists(e)||console.error(`The folder ${e} does not exist`),Xt.statSync(e).isDirectory()||console.error(`The path ${e} is not a folder`),e=await Xt.realpath(e),await Xt.exists(na.join(e,an.HDB_CONFIG_FILE))?process.env.ROOTPATH=e:process.env.RUN_HDB_APP=e)}a(cye,"setAppPath");async function lye(){console.info("Setting up replication"),await VRe.setSchemaDataToGlobalAsync();let t=await Ed()({operation:ms.ADD_NODE,verify_tls:!1,url:hf,start_time:ps,authorization:{username:_f,password:pf}},!0);console.log("Add node response: ",t)}a(lye,"setupReplication");async function uye(e){let t=new CA.Agent({rejectUnauthorized:hs?.httpsRejectUnauthorized??!1}),n={Authorization:"Basic "+Buffer.from(_f+":"+pf).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(uye,"leaderHttpReq");async function VQ(e,t){let r=new CA.Agent({rejectUnauthorized:hs?.httpsRejectUnauthorized??!1}),s={Authorization:"Basic "+Buffer.from(_f+":"+pf).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,HQ=CA),i.port&&(o.port=i.port),new Promise((c,l)=>{let u=HQ.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(VQ,"leaderHttpStream");async function nJ(){let e=WRe.version;if(e)await zRe.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(nJ,"insertHdbVersionInfo")});var oJ=w((Cxe,iJ)=>{var dye=CT(),fye=z();iJ.exports=_ye;async function _ye(){try{await dye.install()}catch(e){console.error("There was an error during the install."),console.error(e),fye.error(e),process.exit(1)}}a(_ye,"install")});var lJ=w((Dxe,cJ)=>{"use strict";var pye=hS(),hye=z(),aJ="Registration failed.";async function mye(){let e;try{e=await pye.register()}catch(t){return hye.error(`Registration error ${t}`),aJ}return e||aJ}a(mye,"register");cJ.exports={register:mye}});var _J=w((Mxe,fJ)=>{"use strict";var Eye=z(),gye=(H(),C(q)),Sye=require("util"),Tye=require("child_process"),uJ=Sye.promisify(Tye.exec),Aye=Do(),Kh=Id(),dJ="Stopping HarperDB.";fJ.exports=Rye;async function Rye(){if(console.log(dJ),Eye.notify(dJ),await Kh.isServiceRegistered(gye.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 Aye.getHDBProcessInfo();t.clustering.forEach(r=>{uJ(`kill ${r.pid}`)}),t.core.forEach(r=>{uJ(`kill ${r.pid}`)})}a(Rye,"stop")});var mJ=w((Uxe,hJ)=>{"use strict";var XP=require("fs-extra"),ZP=require("path"),JP=require("yaml"),Yh=or(),Sc=(H(),C(q)),pJ=Tt(),eD=z(),yye=An(),bye=lS(),Oye=aS(),Nye=Do(),Wh=ae(),wye=jd(),Iye=se();Wh.initSync();var Ks={RUNNING:"running",STOPPED:"stopped",ERRORED:"errored",NOT_INSTALLED:"not installed"},Un={LEAF:"leaf server",HUB:"hub server"},UA;hJ.exports=Cye;async function Cye(){let e={harperdb:{status:Ks.STOPPED}};if(!await wye.isHdbInstalled()){e.harperdb.status=Ks.NOT_INSTALLED,console.log(JP.stringify(e));return}UA=Wh.get(Sc.CONFIG_PARAMS.ROOTPATH);let t;try{t=Number.parseInt(await XP.readFile(ZP.join(UA,Sc.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Sc.NODE_ERROR_CODES.ENOENT){eD.info("`harperdb status` did not find a hdb.pid file"),e.harperdb.status=Ks.STOPPED,console.log(JP.stringify(e));return}throw n}let r=await Nye.getHDBProcessInfo();for(let n of r.core)if(n.pid===t){e.harperdb.status=Ks.RUNNING,e.harperdb.pid=t;break}if((Wh.get(Sc.CONFIG_PARAMS.REPLICATION_URL)||Wh.get(Sc.CONFIG_PARAMS.REPLICATION_HOSTNAME))&&(e.replication=await Dye()),e.clustering=await Pye(r),e.clustering[Un.HUB].status===Ks.RUNNING&&e.clustering[Un.LEAF].status===Ks.RUNNING){let n=[],s=await bye({});for(let o of s.nodes){let c={};for(let l in o)c[l.replace("_"," ")]=o[l];n.push(c)}e.clustering.network=n;let i=await Oye.clusterStatus();e.clustering.replication={"node name":i.node_name,"is enabled":i.is_enabled,connections:[]};for(let o of i.connections){let c={};c["node name"]=o?.node_name,c.status=o?.status,c.ports={clustering:o?.ports?.clustering,"operations api":o?.ports?.operations_api},c["latency ms"]=o?.latency_ms,c.uptime=o?.uptime,c.subscriptions=o?.subscriptions,c["system info"]={"hdb version":o?.system_info?.hdb_version,"node version":o?.system_info?.node_version,platform:o?.system_info?.platform},e.clustering.replication.connections.push(c)}await Yh.closeConnection()}console.log(JP.stringify(e)),process.exit()}a(Cye,"status");async function Pye(e){let t={[Un.HUB]:{},[Un.LEAF]:{}};if(e.clustering.length===0)return t[Un.HUB].status=Ks.STOPPED,t[Un.LEAF].status=Ks.STOPPED,t;let{port:r}=Yh.getServerConfig(Sc.PROCESS_DESCRIPTORS.CLUSTERING_HUB),{username:n,decrypt_hash:s}=await yye.getClusterUser();try{(await Yh.createConnection(r,n,s,!1)).close(),t[Un.HUB].status=Ks.RUNNING}catch{t[Un.HUB].status=Ks.ERRORED}let{port:i}=Yh.getServerConfig(Sc.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);try{(await Yh.createConnection(i,n,s,!1)).close(),t[Un.LEAF].status=Ks.RUNNING}catch{t[Un.LEAF].status=Ks.ERRORED}try{t[Un.HUB].pid=Number.parseInt(await XP.readFile(ZP.join(UA,"clustering",pJ.PID_FILES.HUB),"utf8"))}catch(o){eD.error(o),t[Un.HUB].pid=void 0}try{t[Un.LEAF].pid=Number.parseInt(await XP.readFile(ZP.join(UA,"clustering",pJ.PID_FILES.LEAF),"utf8"))}catch(o){eD.error(o),t[Un.LEAF].pid=void 0}return t}a(Pye,"getHubLeafStatus");async function Dye(){let e=await Iye.httpRequest({method:"POST",protocol:"http:",socketPath:Wh.get(Sc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),headers:{"Content-Type":"application/json"}},{operation:"cluster_status"});e=JSON.parse(e.body);let t={"node name":e.node_name,"is enabled":e.is_enabled,connections:[]};for(let r of e.connections)t.connections.push({"node name":r.name,url:r.url,subscriptions:r.subscriptions,replicates:r.replicates,"database sockets":r.database_sockets.map(n=>({database:n.database,connected:n.connected,latency:n.latency,"catching up from":n.catching_up_from,"thread id":n.thread_id,nodes:n.nodes}))});return t}a(Dye,"getReplicationStatus")});rm();var tD=process.env.HDB_LEADER_URL||process.argv.includes("--HDB_LEADER_URL");tD&&ae().setCloneVar(!0);var zh=require("node:fs"),EJ=require("node:path"),ru=z(),gJ=MQ(),{packageJson:Lye,PACKAGE_ROOT:SJ}=st(),Mye=xQ(),rD=(H(),C(q)),{SERVICE_ACTIONS_ENUM:cn}=rD,vye=`
136
136
  Usage: harperdb [command]
137
137
 
138
138
  With no command, harperdb will simply run HarperDB (in the foreground)
@@ -154,4 +154,4 @@ stop - Stop the harperdb background process
154
154
  help - Display this output
155
155
  upgrade - Upgrade harperdb
156
156
  version - Print the version
157
- `;async function vye(){let e=Lye();if(e)if(e.error){console.error(e.error),nu.error(e.error);return}else e.warn&&(console.warn(e.warn),nu.warn(e.warn));let t;zh.existsSync(mJ.join(gJ,"bin"))||(nu.error(`Missing \`bin\` directory at ${gJ}`),process.exit(0)),process.argv&&process.argv[2]&&!process.argv[2].startsWith("-")&&(t=process.argv[2].toLowerCase());let r=EJ.buildRequest();switch(r.operation&&(t=ln.OPERATION),t){case ln.OPERATION:return nu.trace("calling cli operations with:",r),EJ.cliOperations(r);case ln.START:return ZP?zP()(!0):jd().launch();case ln.INSTALL:return iJ()();case ln.REGISTER:return cJ().register();case ln.STOP:return fJ()().then(()=>{process.exit(0)});case ln.RESTART:return za().restart({});case ln.VERSION:return Dye.version;case ln.UPGRADE:return nu.setLogLevel(eD.LOG_LEVELS.INFO),bC().upgrade(null).then(()=>"Your instance of HarperDB is up to date!");case ln.STATUS:return hJ()();case ln.RENEWCERTS:return rs().renewSelfSigned().then(()=>"Successfully renewed self-signed certificates");case ln.COPYDB:{let n=process.argv[3],s=process.argv[4];return(wS(),C(NS)).copyDb(n,s)}case ln.DEV:process.env.DEV_MODE=!0;case ln.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(mJ.join(n,eD.HDB_CONFIG_FILE))?process.env.ROOTPATH=n:process.env.RUN_HDB_APP=n}}case void 0:return ZP?zP()():jd().main();default:console.warn(`The "${t}" command is not understood.`);case ln.HELP:return Mye}}a(vye,"harperdb");vye().then(e=>{e&&(console.log(e),nu.notify(e))}).catch(e=>{e&&(console.error(e),nu.error(e)),process.exit(1)});
157
+ `;async function Uye(){let e=Mye();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(EJ.join(SJ,"bin"))||(ru.error(`Missing \`bin\` directory at ${SJ}`),process.exit(0)),process.argv&&process.argv[2]&&!process.argv[2].startsWith("-")&&(t=process.argv[2].toLowerCase());let r=gJ.buildRequest();switch(r.operation&&(t=cn.OPERATION),t){case cn.OPERATION:return ru.trace("calling cli operations with:",r),gJ.cliOperations(r);case cn.START:return tD?QP()(!0):jd().launch();case cn.INSTALL:return oJ()();case cn.REGISTER:return lJ().register();case cn.STOP:return _J()().then(()=>{process.exit(0)});case cn.RESTART:return za().restart({});case cn.VERSION:return Lye.version;case cn.UPGRADE:return ru.setLogLevel(rD.LOG_LEVELS.INFO),OC().upgrade(null).then(()=>"Your instance of HarperDB is up to date!");case cn.STATUS:return mJ()();case cn.RENEWCERTS:return ts().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(EJ.join(n,rD.HDB_CONFIG_FILE))?process.env.ROOTPATH=n:process.env.RUN_HDB_APP=n}}case void 0:return tD?QP()():jd().main();default:console.warn(`The "${t}" command is not understood.`);case cn.HELP:return vye}}a(Uye,"harperdb");Uye().then(e=>{e&&(console.log(e),ru.notify(e))}).catch(e=>{e&&(console.error(e),ru.error(e)),process.exit(1)});