harperdb 4.3.0-beta.7 → 4.3.0-beta.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/bin/harperdb.js +55 -55
- package/bin/lite.js +19 -19
- package/config/yaml/defaultConfig.yaml +2 -0
- package/dependencies/linux-x64/nats-server +0 -0
- package/launchServiceScripts/launchInstallNATSServer.js +3 -3
- package/launchServiceScripts/launchNatsIngestService.js +19 -19
- package/launchServiceScripts/launchNatsReplyService.js +19 -19
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +18 -18
- package/npm-shrinkwrap.json +144 -150
- package/package.json +5 -5
- package/resources/DatabaseTransaction.d.ts +1 -0
- package/resources/databases.d.ts +3 -1
- package/server/jobs/jobProcess.js +18 -18
- package/server/threads/threadServer.js +18 -18
- package/studio/build-local/asset-manifest.json +2 -2
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/static/js/{main.e02ed83a.js → main.dbbf05d9.js} +2 -2
- package/utility/scripts/restartHdb.js +18 -18
- /package/studio/build-local/static/js/{main.e02ed83a.js.LICENSE.txt → main.dbbf05d9.js.LICENSE.txt} +0 -0
|
@@ -1,30 +1,30 @@
|
|
|
1
|
-
"use strict";var tF=Object.create;var Za=Object.defineProperty;var rF=Object.getOwnPropertyDescriptor;var nF=Object.getOwnPropertyNames;var sF=Object.getPrototypeOf,iF=Object.prototype.hasOwnProperty;var a=(e,t)=>Za(e,"name",{value:t,configurable:!0});var ge=(e,t)=>()=>(e&&(t=e(e=0)),t);var T=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),Ye=(e,t)=>{for(var r in t)Za(e,r,{get:t[r],enumerable:!0})},yA=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of nF(t))!iF.call(e,s)&&s!==r&&Za(e,s,{get:()=>t[s],enumerable:!(n=rF(t,s))||n.enumerable});return e};var x=(e,t,r)=>(r=e!=null?tF(sF(e)):{},yA(t||!e||!e.__esModule?Za(r,"default",{value:e,enumerable:!0}):r,e)),ne=e=>yA(Za({},"__esModule",{value:!0}),e);var CA=T((Hie,IA)=>{var oF=require("fast-glob"),{statSync:XE,existsSync:jE,readFileSync:aF,writeFileSync:cF}=require("fs"),{spawnSync:uF,spawn:lF,execFileSync:Bie}=require("child_process"),{isMainThread:_F}=require("worker_threads"),{join:Ks,relative:wA}=require("path"),{PACKAGE_ROOT:Tn}=P(),{tmpdir:dF,platform:fF}=require("os");require("source-map-support").install();var EF=["resources","server","dataLayer","components"],ec="ts-build",ZE,hF=__filename.endsWith("tsBuild.js");if(hF){if(_F){let r;try{XE(Ks(Tn,ec)),r=!0}catch{}if(r)for(let n of oF.sync(EF.map(s=>s+"/**/*.ts"),{cwd:Tn})){let s=0,i=0;try{s=XE(Ks(Tn,n)).mtimeMs-5e3,i=XE(Ks(Tn,ec,n.replace(/.ts$/,".js"))).mtimeMs}catch{}if(s>i){console.warn(`TypeScript ${n} is not compiled`+(i?` (TS source file was modified at ${new Date(s)} and compiled file at ${new Date(i)})`:"")+", consider enabling auto-compilation of TypeScript in your IDE), compiling now."),ZE=!0;break}}else console.log("TypeScript modules are not compiled, compiling now"),ZE=!0;if(ZE){let n=Ks(Tn,"node_modules/.bin/tsc");fF()==="win32"&&(n+=".cmd");let s=uF(n,{cwd:Tn});if(s.stdout.length&&console.log(s.stdout.toString()),s.stderr.length&&console.log(s.stderr.toString()),r){let i=Ks(dF(),"harperdb-tsc.pid"),o;if(jE(i))try{process.kill(+aF(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=lF(n,["--watch"],{cwd:Tn,detached:!0,stdio:"ignore"});cF(i,c.pid.toString()),c.unref()}}}}let e=IA.constructor,t=e._findPath;e._findPath=function(r,n,s){if(r.startsWith(".")&&!s&&n.length===1&&n[0].startsWith(Tn)&&!n[0].includes("node_modules")){let i=wA(Tn,n[0]),o;i.startsWith(ec)?o=Ks(Tn,wA(ec,i)):o=Ks(Tn,ec,i);let c=Ks(o,r),u=c+".js";if(jE(u))return u;if(c.includes(".")&&jE(c))return c}return t(r,n,s)}}});var P=T((Gie,VA)=>{"use strict";var Xr=require("path"),mF=require("fs"),{relative:xie,join:Fie}=Xr,{existsSync:pF}=mF;function SF(){let e=__dirname;for(;!pF(Xr.join(e,"package.json"));){let t=Xr.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(SF,"getHDBPackageRoot");var Ws=SF(),DA="js",Ml=DA,TF="harperdb-config.yaml",gF="defaultConfig.yaml",RF="hdb",LA=`harperdb.${Ml}`,UA=`customFunctionsServer.${Ml}`,AF=`restartHdb.${Ml}`,th="HarperDB",Ul="Custom Functions",Pl="Clustering Hub",vl="Clustering Leaf",OF="Clustering Ingest Service",bF="Clustering Reply Service",NF="foreground.pid",yF="hdb.pid",wF="data",IF={HDB:th,CLUSTERING_HUB:Pl,CLUSTERING_LEAF:vl,CLUSTERING_INGEST_SERVICE:OF,CLUSTERING_REPLY_SERVICE:bF,CUSTOM_FUNCTIONS:Ul,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"},CF={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},DF={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},LF={harperdb:th,"clustering hub":Pl,"clustering leaf":vl,"custom functions":Ul,custom_functions:Ul,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers"},UF={CLUSTERING_HUB_PROC_DESCRIPTOR:Pl,CLUSTERING_LEAF_PROC_DESCRIPTOR:vl},eh={HDB:Xr.join(Ws,"server/harperdb"),CUSTOM_FUNCTIONS:Xr.join(Ws,"server/customFunctions"),CLUSTERING_HUB:Xr.join(Ws,"server/nats"),CLUSTERING_LEAF:Xr.join(Ws,"server/nats")},MF={HDB:Xr.join(eh.HDB,LA),CUSTOM_FUNCTIONS:Xr.join(eh.CUSTOM_FUNCTIONS,UA)},PF={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:Xr.join(Ws,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:Xr.join(Ws,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:Xr.join(Ws,"launchServiceScripts/launchUpdateNodes4-0-0.js")},vF={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},MA="support@harperdb.io",BF="customer-success@harperdb.io",PA=1,HF=4141,vA="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",xF="https://www.harperdb.io/product",FF=`For support, please submit a request at ${vA} or contact ${MA}`,BA=`For license support, please contact ${BF}`,GF="None of the specified records were found.",qF="hash attribute not found",kF=`Your current license only supports ${PA} role. ${BA}`,VF="Your current license only supports 3 connections to a node.",$F="127.0.0.1",YF=1,KF=/^\.$/,WF=/^\.\.$/,QF="U+002E",zF=/\//g,JF="U+002F",XF=/U\+002F/g,jF=/^U\+002E$/,ZF=/^U\+002EU\+002E$/,eG="d",tG=999999,rG="*",nG="--max-old-space-size=",sG="system",iG="__hdb_hash",oG=".harperdb",aG=".hdb",cG="keys",uG="hdb_boot_properties.file",lG=".updateConfig.json",_G="SIGTSTP",dG=24,fG=6e4,EG=448,hG="blob",mG="trash",pG="database",SG="schema",TG="transactions",gG=".count",RG="id",AG="PROCESS_NAME",HA={SETTINGS_PATH_KEY:"settings_path"},xA=require("lodash"),OG={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",OPERATIONSAPI_NETWORK_PORT:"OPERATIONSAPI_NETWORK_PORT",CLUSTERING_NODENAME:"CLUSTERING_NODENAME",CLUSTERING_ENABLED:"CLUSTERING_ENABLED",HDB_CONFIG:"HDB_CONFIG",OPERATIONSAPI_NETWORK_SECUREPORT:"OPERATIONSAPI_NETWORK_SECUREPORT",CLUSTERING_PORT:"CLUSTERING_PORT",HDB_ROOT:"HDB_ROOT",SERVER_PORT:"SERVER_PORT",NODE_NAME:"NODE_NAME",CLUSTERING:"CLUSTERING"},bG={HDB_PATH_KEY:"HDB_INTERNAL_PATH",HDB_AUTH_HEADER:"hdb_auth_header",HDB_USER_DATA_KEY:"hdb_user",CHUNK_SIZE:1e3,MAX_CHARACTER_SIZE:250},NG={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},yG={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"},wG={JOB_TABLE_HASH_ATTRIBUTE:"id",NODE_TABLE_HASH_ATTRIBUTE:"name",ATTRIBUTE_TABLE_HASH_ATTRIBUTE:"id",LICENSE_TABLE_HASH_ATTRIBUTE:"license_key",ROLE_TABLE_HASH_ATTRIBUTE:"id",SCHEMA_TABLE_HASH_ATTRIBUTE:"name",TABLE_TABLE_HASH_ATTRIBUTE:"id",USER_TABLE_HASH_ATTRIBUTE:"username",INFO_TABLE_ATTRIBUTE:"info_id"},br="hdb_internal:",IG={CREATE_SCHEMA:br+"create_schema",CREATE_TABLE:br+"create_table",CREATE_ATTRIBUTE:br+"create_attribute",ADD_USER:br+"add_user",ALTER_USER:br+"alter_user",DROP_USER:br+"drop_user",HDB_NODES:br+"hdb_nodes",HDB_USERS:br+"hdb_users",HDB_WORKERS:br+"hdb_workers",CATCHUP:br+"catchup",SCHEMA_CATCHUP:br+"schema_catchup",WORKER_ROOM:br+"cluster_workers"},CG={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"},DG="060493.ks",LG=".license",UG={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},j={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"},MG={CSV:".csv",JSON:".json"},PG={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},vG={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},tc={};tc[j.INSERT]=j.INSERT;tc[j.UPDATE]=j.UPDATE;tc[j.UPSERT]=j.UPSERT;tc[j.DELETE]=j.DELETE;var He=Object.create(null);He[j.DESCRIBE_ALL]=j.DESCRIBE_ALL;He[j.DESCRIBE_TABLE]=j.DESCRIBE_TABLE;He[j.DESCRIBE_SCHEMA]=j.DESCRIBE_SCHEMA;He[j.READ_LOG]=j.READ_LOG;He[j.ADD_NODE]=j.ADD_NODE;He[j.LIST_USERS]=j.LIST_USERS;He[j.LIST_ROLES]=j.LIST_ROLES;He[j.USER_INFO]=j.USER_INFO;He[j.SQL]=j.SQL;He[j.GET_JOB]=j.GET_JOB;He[j.SEARCH_JOBS_BY_START_DATE]=j.SEARCH_JOBS_BY_START_DATE;He[j.DELETE_FILES_BEFORE]=j.DELETE_FILES_BEFORE;He[j.EXPORT_LOCAL]=j.EXPORT_LOCAL;He[j.EXPORT_TO_S3]=j.EXPORT_TO_S3;He[j.CLUSTER_STATUS]=j.CLUSTER_STATUS;He[j.REMOVE_NODE]=j.REMOVE_NODE;He[j.RESTART]=j.RESTART;He[j.CUSTOM_FUNCTIONS_STATUS]=j.CUSTOM_FUNCTIONS_STATUS;He[j.GET_CUSTOM_FUNCTIONS]=j.GET_CUSTOM_FUNCTIONS;He[j.GET_CUSTOM_FUNCTION]=j.GET_CUSTOM_FUNCTION;He[j.SET_CUSTOM_FUNCTION]=j.SET_CUSTOM_FUNCTION;He[j.DROP_CUSTOM_FUNCTION]=j.DROP_CUSTOM_FUNCTION;He[j.ADD_CUSTOM_FUNCTION_PROJECT]=j.ADD_CUSTOM_FUNCTION_PROJECT;He[j.DROP_CUSTOM_FUNCTION_PROJECT]=j.DROP_CUSTOM_FUNCTION_PROJECT;He[j.PACKAGE_CUSTOM_FUNCTION_PROJECT]=j.PACKAGE_CUSTOM_FUNCTION_PROJECT;He[j.DEPLOY_CUSTOM_FUNCTION_PROJECT]=j.DEPLOY_CUSTOM_FUNCTION_PROJECT;var BG={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"},HG={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},FA={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"},xG=xA.invert(FA),FG={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"},I={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_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",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",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_PATH:"storage_path",STORAGE_AUDIT_PATH:"storage_audit_path",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"},GA={settings_path:HA.SETTINGS_PATH_KEY,hdb_root_key:I.ROOTPATH,hdb_root:I.ROOTPATH,rootpath:I.ROOTPATH,server_port_key:I.OPERATIONSAPI_NETWORK_PORT,server_port:I.OPERATIONSAPI_NETWORK_PORT,cert_key:I.TLS_CERTIFICATE,certificate:I.TLS_CERTIFICATE,private_key_key:I.TLS_PRIVATEKEY,private_key:I.TLS_PRIVATEKEY,http_secure_enabled_key:I.OPERATIONSAPI_NETWORK_HTTPS,https_on:I.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:I.OPERATIONSAPI_NETWORK_CORS,cors_on:I.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:I.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:I.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:I.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:I.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:I.LOGGING_LEVEL,log_level:I.LOGGING_LEVEL,log_path_key:I.LOGGING_ROOT,log_path:I.LOGGING_ROOT,clustering_node_name_key:I.CLUSTERING_NODENAME,node_name:I.CLUSTERING_NODENAME,clustering_enabled_key:I.CLUSTERING_ENABLED,clustering:I.CLUSTERING_ENABLED,max_http_threads:I.THREADS_COUNT,max_hdb_processes:I.THREADS_COUNT,server_timeout_key:I.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:I.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:I.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:I.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:I.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:I.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:I.LOGGING_AUDITLOG,disable_transaction_log:I.LOGGING_AUDITLOG,operation_token_timeout_key:I.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:I.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:I.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:I.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:I.HTTP_PORT,custom_functions_port:I.HTTP_PORT,custom_functions_directory_key:I.COMPONENTSROOT,custom_functions_directory:I.COMPONENTSROOT,max_custom_function_processes:I.THREADS_COUNT,log_to_file:I.LOGGING_FILE,log_to_stdstreams:I.LOGGING_STDSTREAMS,local_studio_on:I.LOCALSTUDIO_ENABLED,clustering_port:I.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:I.CLUSTERING_USER,clustering_enabled:I.CLUSTERING_ENABLED,clustering_hubserver_cluster_name:I.CLUSTERING_HUBSERVER_CLUSTER_NAME,clustering_hubserver_cluster_network_port:I.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_hubserver_cluster_network_routes:I.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,clustering_hubserver_leafnodes_network_port:I.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT,clustering_hubserver_network_port:I.CLUSTERING_HUBSERVER_NETWORK_PORT,clustering_leafserver_network_port:I.CLUSTERING_LEAFSERVER_NETWORK_PORT,clustering_leafserver_network_routes:I.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,clustering_leafserver_streams_maxage:I.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE,clustering_leafserver_streams_maxbytes:I.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES,clustering_leafserver_streams_maxmsgs:I.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS,clustering_leafserver_streams_path:I.CLUSTERING_LEAFSERVER_STREAMS_PATH,clustering_nodename:I.CLUSTERING_NODENAME,clustering_tls_certificate:I.CLUSTERING_TLS_CERTIFICATE,clustering_tls_privatekey:I.CLUSTERING_TLS_PRIVATEKEY,clustering_tls_certificateauthority:I.CLUSTERING_TLS_CERT_AUTH,clustering_tls_insecure:I.CLUSTERING_TLS_INSECURE,clustering_tls_verify:I.CLUSTERING_TLS_VERIFY,clustering_loglevel:I.CLUSTERING_LOGLEVEL,clustering_republishmessages:I.CLUSTERING_REPUBLISHMESSAGES,clustering_databaselevel:I.CLUSTERING_DATABASELEVEL,customfunctions_network_port:I.HTTP_PORT,customfunctions_tls_certificate:I.TLS_CERTIFICATE,customfunctions_network_cors:I.HTTP_CORS,customfunctions_network_corsaccesslist:I.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:I.HTTP_HEADERSTIMEOUT,customfunctions_network_https:I.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:I.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:I.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:I.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:I.HTTP_TIMEOUT,http_threads:I.THREADS_COUNT,threads:I.THREADS_COUNT,threads_count:I.THREADS_COUNT,threads_debug:I.THREADS_DEBUG,threads_debug_startingport:I.THREADS_DEBUG_STARTINGPORT,threads_debug_port:I.THREADS_DEBUG_PORT,threads_debug_host:I.THREADS_DEBUG_HOST,threads_debug_waitfordebugger:I.THREADS_DEBUG_WAITFORDEBUGGER,threads_maxheapmemory:I.THREADS_MAXHEAPMEMORY,http_session_affinity:I.HTTP_SESSIONAFFINITY,http_compressionthreshold:I.HTTP_COMPRESSIONTHRESHOLD,http_cors:I.HTTP_CORS,http_corsaccesslist:I.HTTP_CORSACCESSLIST,http_headerstimeout:I.HTTP_HEADERSTIMEOUT,http_keepalivetimeout:I.HTTP_KEEPALIVETIMEOUT,http_timeout:I.HTTP_TIMEOUT,http_port:I.HTTP_PORT,http_secureport:I.HTTP_SECUREPORT,http_mtls:I.HTTP_MTLS,http_mtls_user:I.HTTP_MTLS_USER,http_mtls_required:I.HTTP_MTLS_REQUIRED,customfunctions_processes:I.THREADS_COUNT,customfunctions_root:I.COMPONENTSROOT,localstudio_enabled:I.LOCALSTUDIO_ENABLED,logging_file:I.LOGGING_FILE,logging_level:I.LOGGING_LEVEL,logging_root:I.LOGGING_ROOT,logging_rotation_enabled:I.LOGGING_ROTATION_ENABLED,logging_rotation_compress:I.LOGGING_ROTATION_COMPRESS,logging_rotation_interval:I.LOGGING_ROTATION_INTERVAL,logging_rotation_maxsize:I.LOGGING_ROTATION_MAXSIZE,logging_rotation_path:I.LOGGING_ROTATION_PATH,logging_stdstreams:I.LOGGING_STDSTREAMS,logging_auditlog:I.LOGGING_AUDITLOG,logging_auditretention:I.LOGGING_AUDITRETENTION,logging_auditauthevents_logfailed:I.LOGGING_AUDITAUTHEVENTS_LOGFAILED,logging_auditauthevents_logsuccessful:I.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL,operationsapi_authentication_operationtokentimeout:I.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operationsapi_authentication_refreshtokentimeout:I.AUTHENTICATION_REFRESHTOKENTIMEOUT,operationsapi_network_cors:I.OPERATIONSAPI_NETWORK_CORS,operationsapi_network_corsaccesslist:I.OPERATIONSAPI_NETWORK_CORSACCESSLIST,operationsapi_network_headerstimeout:I.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,operationsapi_network_https:I.OPERATIONSAPI_NETWORK_HTTPS,operationsapi_network_keepalivetimeout:I.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,operationsapi_network_port:I.OPERATIONSAPI_NETWORK_PORT,operationsapi_network_domainsocket:I.OPERATIONSAPI_NETWORK_DOMAINSOCKET,operationsapi_network_secureport:I.OPERATIONSAPI_NETWORK_SECUREPORT,operationsapi_tls_certificate:I.OPERATIONSAPI_TLS_CERTIFICATE,operationsapi_tls_privatekey:I.OPERATIONSAPI_TLS_PRIVATEKEY,operationsapi_tls_certificateauthority:I.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY,operationsapi_network_timeout:I.OPERATIONSAPI_NETWORK_TIMEOUT,operationsapi_root:I.ROOTPATH,databases:I.DATABASES,storage_path:I.STORAGE_PATH,ignorescripts:I.IGNORE_SCRIPTS,mqtt_network_port:I.MQTT_NETWORK_PORT,mqtt_websocket:I.MQTT_WEBSOCKET,mqtt_network_secureport:I.MQTT_NETWORK_SECUREPORT,mqtt_network_mtls:I.MQTT_NETWORK_MTLS,mqtt_network_mtls_certificateAuthority:I.MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY,mqtt_network_mtls_user:I.MQTT_NETWORK_MTLS_USER,mqtt_network_mtls_required:I.MQTT_NETWORK_MTLS_REQUIRED,mqtt_requireauthentication:I.MQTT_REQUIREAUTHENTICATION,analytics_aggregatePeriod:I.ANALYTICS_AGGREGATEPERIOD,authentication_authorizelocal:I.AUTHENTICATION_AUTHORIZELOCAL,authentication_cachettl:I.AUTHENTICATION_CACHETTL,authentication_enablesessions:I.AUTHENTICATION_ENABLESESSIONS,authentication_operationtokentimeout:I.AUTHENTICATION_OPERATIONTOKENTIMEOUT,authentication_refreshtokentimeout:I.AUTHENTICATION_REFRESHTOKENTIMEOUT,componentsroot:I.COMPONENTSROOT,tls_certificate:I.TLS_CERTIFICATE,tls_privatekey:I.TLS_PRIVATEKEY,tls_certificateauthority:I.TLS_CERTIFICATEAUTHORITY,tls_ciphers:I.TLS_CIPHERS};for(let e in I){let t=I[e];GA[t.toLowerCase()]=t}var GG={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},qG={csv_file_load:"csv_file_load",csv_data_load:j.CSV_DATA_LOAD,csv_url_load:j.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"},kG={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"},VG={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},$G={VERSION_DEFAULT:"2.2.0"},YG={DEVELOPMENT:8192,DEFAULT:512},KG={IDENTIFY:"identify",AUTHENTICATE:"authenticate",AUTHENTICATE_OK:"authenticated",AUTHENTICATE_FAIL:"authenticate_fail",CONNECTION:"connection",CONNECT:"connect",CATCHUP_REQUEST:"catchup_request",CATCHUP_RESPONSE:"catchup",CONFIRM_MSG:"confirm_msg",ERROR:"error",DISCONNECT:"disconnect",SCHEMA_UPDATE_REQ:"schema_update_request",SCHEMA_UPDATE_RES:"schema_update_response",RECONNECT_ATTEMPT:"reconnect_attempt",CONNECT_ERROR:"connect_error",MESSAGE:"msg",VERSION_MISMATCH:"version_mismatch",DIRECTION_CHANGE:"direction_change"},WG={1e3:"SUCCESSFUL_SHUTDOWN",1001:"CLOSE_GOING_AWAY",1002:"CLOSE_PROTOCOL_ERROR",1003:"CLOSE_UNSUPPORTED",1005:"CLOSE_NO_STATUS",1006:"CLOSE_ABNORMAL",1007:"UNSUPPORTED_PAYLOAD",1008:"POLICY_VIOLATION",1009:"CLOSE_TOO_LARGE",1010:"MANDATORY_EXTENSION",1011:"SERVER_ERROR",1012:"SERVICE_RESTART",1013:"SERVER_BUSY",1014:"BAD_GATEWAY",1015:"HANDSHAKE_FAIL",4141:"LICENSE_LIMIT_REACHED"},QG={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST"},qA={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},zG=Symbol("metadata"),JG="__clustering__",XG=Object.values(qA),jG=15984864e5,kA={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},ZG=xA.invert(kA),eq={GET_CLUSTER_STATUS:"GET_CLUSTER_STATUS",CLUSTER_STATUS_RESPONSE:"CLUSTER_STATUS_RESPONSE",ERROR_RESPONSE:"ERROR",ADD_USER:"ADD_USER",ALTER_USER:"ALTER_USER",DROP_USER:"DROP_USER",HDB_OPERATION:"HDB_OPERATION",ADD_NODE:"ADD_NODE",UPDATE_NODE:"UPDATE_NODE",REMOVE_NODE:"REMOVE_NODE",HDB_USERS_MSG:"HDB_USERS_MSG",HDB_WORKERS:"HDB_WORKERS",HDB_TRANSACTION:"HDB_TRANSACTION"},tq=111,rq=`\r
|
|
2
|
-
`,
|
|
3
|
-
`}a(hs,"createLogRecord");function oc(e){ds&&
|
|
4
|
-
`).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:vq.basename(n.comm),cmd:n.args,ppid:Number.parseInt(n.ppid,10),uid:Number.parseInt(n.uid,10),cpu:Number.parseFloat(n["%cpu"]),memory:Number.parseFloat(n["%mem"])}))}a(Fq,"findPs")});var dt=T((Qie,oO)=>{"use strict";var Gq="__dbis__",qq="__txns__",kq="__environment_name__",Vq="__dbi_defintion__",$q={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"},Yq=["__createdtime__","__updatedtime__"],Kq="\uFFFF",iO={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},Wq=Object.values(iO);oO.exports={AUDIT_STORE_NAME:qq,INTERNAL_DBIS_NAME:Gq,DBI_DEFINITION_NAME:Vq,SEARCH_TYPES:$q,TIMESTAMP_NAMES:Yq,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:kq,TRANSACTIONS_DBI_NAMES_ENUM:iO,TRANSACTIONS_DBIS:Wq,OVERFLOW_MARKER:Kq}});var Nr=T((zie,hO)=>{"use strict";var aO=P(),cO=dt(),uO={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},lO=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),_O={500:lO("There was an error processing your request."),400:"Invalid request"},Qq=_O[uO.INTERNAL_SERVER_ERROR],zq={OP_NOT_SUPPORTED_FOR_FS:e=>`${e} is not available for this instance because it uses the File System data store.`,MISSING_VALUE:e=>`${e} is missing.`,INVALID_VALUE:e=>`${e} is invalid.`,NOT_FOUND:e=>`${e} not found.`},Jq={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},Xq={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:e=>`There was an error downloading '${e}'.`,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:e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,INVALID_FILE_EXT_ERR:e=>`Error selecting correct parser - valid file type not found in json - ${e}`,MAX_FILE_SIZE_ERR:(e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:e=>`There was an error downloading '${e}' from AWS.`,WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},jq={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 ${cO.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${cO.INTERNAL_DBIS_NAME}`,START_VALUE_REQUIRED:"start_value is required",END_VALUE_REQUIRED:"end_value is required",CANNOT_COMPARE_STRING_TO_NUMERIC_KEYS:"cannot compare a string to numeric keys",END_VALUE_MUST_BE_GREATER_THAN_START_VALUE:"end_value must be greater than or equal to start_value",UNKNOWN_SEARCH_TYPE:"unknown search type",CANNOT_DROP_TABLE_HASH_ATTRIBUTE:"cannot drop a table's hash attribute"},Zq={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${aO.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes.`,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 ${aO.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},dO={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"},ek={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:e=>`Operation '${e}' is restricted to 'super_user' roles`,OP_NOT_FOUND:e=>`Operation '${e}' 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:(e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,USER_HAS_NO_PERMS:e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},tk={ATTR_PERM_MISSING:(e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:(e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a 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:e=>`Invalid attribute '${e}' in 'attribute_permissions'`,INVALID_PERM_KEY:e=>`Invalid table permission key value '${e}'`,INVALID_ATTR_PERM_KEY:e=>`Invalid attribute permission key value '${e}'`,INVALID_ROLE_JSON_KEYS:e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,MISMATCHED_TABLE_ATTR_PERMS:e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,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:e=>`A role with name '${e}' already exists`,ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:e=>`Your role does not have permission to view database metadata for '${e}'`,SCHEMA_TABLE_PERM_ERROR:(e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:e=>`Value for '${e}' permission must be a boolean`,STRUCTURE_USER_ROLE_TYPE_ERROR:e=>`Value for '${e}' permission must be a boolean or Array`,SU_CU_ROLE_NO_PERMS_ALLOWED:e=>`Roles with '${e}' set to true cannot have other permissions set.`,SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:e=>`Missing table ${e.toUpperCase()} permission`,TABLE_PERM_NOT_BOOLEAN:e=>`Table ${e.toUpperCase()} permission must be a boolean`},rk={ATTR_NOT_FOUND:(e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,ATTR_EXISTS_ERR:(e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:e=>`Invalid table ${JSON.stringify(e)}`,SCHEMA_NOT_FOUND:e=>`database '${e}' does not exist`,SCHEMA_EXISTS_ERR:e=>`database '${e}' already exists`,TABLE_EXISTS_ERR:(e,t)=>`Table '${t}' already exists in '${e}'`,SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:(e,t)=>`Table '${e}.${t}' does not exist`,TABLE_REQUIRED_ERR:"table is required"},nk={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},sk={ALTER_USER_DUP_ROLES:e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,ALTER_USER_ROLE_NOT_FOUND:e=>`Update failed. Requested '${e}' role not found.`,DUP_ROLES_FOUND:e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,ROLE_NAME_NOT_FOUND:e=>`${e} role not found`,USER_ALREADY_EXISTS:e=>`User ${e} already exists`,USER_NOT_EXIST:e=>`User ${e} does not exist`},fO={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`},EO={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:e=>`ITC server received invalid event type: ${e}`},ik={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."},ok={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},ak={...dO,...Xq,...zq,...ek,...tk,...rk,...nk,...sk,...Zq,...fO,...EO,...ik,...ok,...Jq};hO.exports={CHECK_LOGS_WRAPPER:lO,HDB_ERROR_MSGS:ak,DEFAULT_ERROR_MSGS:_O,DEFAULT_ERROR_RESP:Qq,HTTP_STATUS_CODES:uO,LMDB_ERRORS_ENUM:jq,AUTHENTICATION_ERROR_MSGS:dO,VALIDATION_ERROR_MSGS:fO,ITC_ERRORS:EO}});var re=T((Xie,SO)=>{"use strict";var Ho=Nr(),ck=Q(),uk=P(),Gl=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,mO),this.statusCode=n||Ho.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(Ho.DEFAULT_ERROR_MSGS[n]?Ho.DEFAULT_ERROR_MSGS[n]:Ho.DEFAULT_ERROR_MSGS[Ho.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&&ck[s](i)}},lh=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}},_h=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function mO(e,t,r,n=uk.LOG_LEVELS.ERROR,s=null,i=!1){if(pO(e))return e;let o=new Gl(e,t,r,n,s);return i&&delete o.stack,o}a(mO,"handleHDBError");function pO(e){return e.__proto__.constructor.name===Gl.name}a(pO,"isHDBError");SO.exports={isHDBError:pO,handleHDBError:mO,ClientError:lh,ServerError:_h,hdb_errors:Ho}});var ze=T((Zie,NO)=>{"use strict";var _c=P(),lk=J(),tr=te(),dc=require("path"),_k=require("minimist"),TO=require("fs-extra"),gO=require("lodash");tr.initSync();var{CONFIG_PARAMS:Qs,DATABASES_PARAM_CONFIG:ac,SYSTEM_SCHEMA_NAME:ql}=_c,cc,uc,lc;function RO(){if(cc!==void 0)return cc;if(tr.getHdbBasePath()!==void 0)return cc=tr.get(Qs.STORAGE_PATH)||dc.join(tr.getHdbBasePath(),_c.DATABASES_DIR_NAME),cc}a(RO,"getBaseSchemaPath");function AO(){if(uc!==void 0)return uc;if(tr.getHdbBasePath()!==void 0)return uc=bO(ql),uc}a(AO,"getSystemSchemaPath");function OO(){if(lc!==void 0)return lc;if(tr.getHdbBasePath()!==void 0)return lc=tr.get(_c.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||dc.join(tr.getHdbBasePath(),_c.TRANSACTIONS_DIR_NAME),lc}a(OO,"getTransactionAuditStoreBasePath");function dk(e,t){let r=tr.get(Qs.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||dc.join(OO(),e.toString())}a(dk,"getTransactionAuditStorePath");function bO(e,t){e=e.toString(),t=t&&t.toString();let r=tr.get(_c.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||dc.join(RO(),e)}a(bO,"getSchemaPath");function fk(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,_k(process.argv));let n=r[Qs.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!lk.isObject(n))throw o;i=n}for(let o of i){let c=o[ql];if(!c)continue;let u=tr.get(Qs.DATABASES);u=u??{};let _=c?.tables?.[t]?.[ac.PATH];if(_)return gO.set(u,[ql,ac.TABLES,t,ac.PATH],_),tr.setProperty(Qs.DATABASES,u),_;let l=c?.[ac.PATH];if(l)return gO.set(u,[ql,ac.PATH],l),tr.setProperty(Qs.DATABASES,u),l}}let s=r[Qs.STORAGE_PATH.toUpperCase()];if(s){if(!TO.pathExistsSync(s))throw new Error(s+" does not exist");let i=dc.join(s,e);return TO.mkdirsSync(i),tr.setProperty(Qs.STORAGE_PATH,s),i}return AO()}a(fk,"initSystemSchemaPaths");function Ek(){cc=void 0,uc=void 0,lc=void 0}a(Ek,"resetPaths");NO.exports={getBaseSchemaPath:RO,getSystemSchemaPath:AO,getTransactionAuditStorePath:dk,getTransactionAuditStoreBasePath:OO,getSchemaPath:bO,initSystemSchemaPaths:fk,resetPaths:Ek}});var yr=T((noe,DO)=>{"use strict";var hk=Nr().LMDB_ERRORS_ENUM,toe=require("lmdb"),mk=dt(),roe=require("buffer").Buffer,{OVERFLOW_MARKER:yO,MAX_SEARCH_KEY_LENGTH:kl}=mk,wO=["number","string","symbol","boolean","bigint"];function pk(e){if(e=e?.primaryStore||e,!e)throw new Error(hk.ENV_REQUIRED)}a(pk,"validateEnv");function Sk(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(Sk,"stringifyData");function Tk(e){return e instanceof Date?e.valueOf():e}a(Tk,"convertKeyValueToWrite");function gk(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(wO.includes(typeof e))return e.length>kl?[e.slice(0,kl)+yO]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(wO.includes(typeof i))i.length>kl?r.push(i.slice(0,kl)+yO):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(gk,"getIndexedValues");var Vl=0,IO=0;function CO(){IO=Date.now()-performance.now()}a(CO,"adjustStartTime");CO();var Rk=6e4;setInterval(CO,Rk).unref();function Ak(){let e=performance.now()+IO;return e>Vl?(Vl=e,e):(Vl+=488e-6,Vl)}a(Ak,"getNextMonotonicTime");DO.exports={validateEnv:pk,stringifyData:Sk,convertKeyValueToWrite:Tk,getNextMonotonicTime:Ak,getIndexedValues:gk}});var LO,gn,dh,fc=ge(()=>{LO=require("events"),gn=class extends LO.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;[Symbol.asyncIterator](){let t=new dh;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(){return this.queue?.shift()}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)}},dh=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});var Di={};Ye(Di,{server:()=>Ze});var UO,Ze,rr=ge(()=>{UO=require("../../index"),Ze={};(0,UO._assignPackageExport)("server",Ze)});var hh={};Ye(hh,{loadGQLSchema:()=>Nk,start:()=>Eh,startOnMainThread:()=>bk});function Eh({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:u,NamedTypeNode:_,StringValueNode:l}=await import("graphql"),d=o(new c(r.toString(),s)),f=new Map,E=[],h;for(let p of d.definitions)switch(p.kind){case u.OBJECT_TYPE_DEFINITION:let H=function(M){if(M.kind==="NonNullType"){let K=H(M.type);return K.nullable=!1,K}if(M.kind==="ListType")return{type:"array",elements:H(M.type)};let Y={type:M.name?.value};return Object.defineProperty(Y,"location",{value:M.loc.startToken}),Y};a(H,"getProperty");let R=p.name.value,A=[],g={table:null,database:null,properties:A};f.set(R,g);for(let M of p.directives){if(M.name.value==="table"){for(let U of M.arguments)g[U.name.value]=U.value.value;g.schema&&(g.database=g.schema),g.table||(g.table=R),g.audit&&(g.audit=g.audit!=="false"),g.attributes=g.properties,E.push(g)}if(M.name.value==="sealed"&&(g.sealed=!0),M.name.value==="export"){g.export=!0;for(let U of M.arguments)U.name.value==="name"&&(g.export={name:U.value.value})}}let v=!1;for(let M of p.fields){let U=H(M.type);U.name=M.name.value,A.push(U);for(let Y of M.directives)if(Y.name.value==="primaryKey")v?console.warn("Can not define two attributes as a primary key"):(U.isPrimaryKey=!0,v=!0);else if(Y.name.value==="indexed")U.indexed=!0;else if(Y.name.value==="relationship"){let K={};for(let V of Y.arguments)K[V.name.value]=V.value.value;U.relationship=K}else if(Y.name.value==="createdTime")U.assignCreatedTime=!0;else if(Y.name.value==="updatedTime")U.assignUpdatedTime=!0;else if(Y.name.value==="expiresAt")U.expiresAt=!0;else if(Y.name.value==="allow"){let K=U.authorizedRoles=[];for(let V of Y.arguments)V.name.value==="role"&&K.push(V.value.value)}}g.type=R,R==="Query"&&(h=g)}function S(p){let R=f.get(p.type);R?(Object.defineProperty(p,"properties",{value:R.properties}),Object.defineProperty(p,"definition",{value:R})):p.type==="array"?S(p.elements):Ok.includes(p.type)||(0,MO.getWorkerIndex)()===0&&console.error(`The type ${p.type} is unknown at line ${p.location.line}, column ${p.location.column}, in ${s}`)}a(S,"connectPropertyType");for(let p of f.values())for(let R of p.properties)S(R);for(let p of E)p.tableClass=e(p),p.export&&(p.export.name===""?i.set((0,fh.dirname)(n),p.tableClass):i.set((0,fh.dirname)(n)+"/"+(p.export.name||p.type),p.tableClass))}}var fh,MO,Ok,bk,Nk,PO=ge(()=>{fh=require("path");Re();MO=x(et()),Ok=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];a(Eh,"start");bk=Eh,Nk=Eh({ensureTable:ct}).handleFile});async function $l(e){return yk?(Ec||(Ec=wk(Ck)),(await(await Ec).import(e)).namespace):import(e)}async function wk(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),Ec=new Compartment({console,Math,Date,fetch:Ik,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,BO.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:xt,tables:wr,databases:tt})}};let n=await(0,vO.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),Ec}function Ik(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 Ck(){return{Resource:xt,tables:wr}}var vO,BO,yk,Ec,mh=ge(()=>{Rn();Re();vO=require("fs/promises"),BO=require("path"),yk=!1;a($l,"secureImport");a(wk,"getCompartment");a(Ik,"secureOnlyFetch");a(Ck,"getGlobalVars")});var Sh={};Ye(Sh,{handleFile:()=>Dk});async function Dk(e,t,r,n){let s=new Map,i=(0,HO.pathToFileURL)(r).toString(),o=await $l(i);u(o.default)&&n.set((0,ph.dirname)(t),o.default),c(o,(0,ph.dirname)(t));function c(_,l){for(let d in _){let f=_[d];u(f)?n.set(l+"/"+d,f):typeof f=="object"&&c(f,l+"/"+d)}}a(c,"recurseForResources");function u(_){return typeof _=="function"&&(_.get||_.put||_.post||_.delete)}return a(u,"isResource"),s}var HO,ph,xO=ge(()=>{HO=require("url");mh();ph=require("path");a(Dk,"handleFile")});var gh={};Ye(gh,{start:()=>Lk});function Lk({resources:e}){e.set("login",Th),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var Th,FO=ge(()=>{Rn();a(Lk,"start");Th=class extends xt{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 KO={};Ye(KO,{parse:()=>Ah,streamAsJSON:()=>hc,stringify:()=>Li});function hc(e){return new Rh({value:e})}function GO(e){return console.error(e),JSON.stringify(e.toString())}function qO(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Li(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===$O)return YO(e);if(t.resolution)return t.resolution.then(()=>Li(e));throw t}}function YO(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+=YO(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Li(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Ah(e){return Pk.test(e)?Uk.parse(e):JSON.parse(e)}var kO,VO,Uk,Mk,$O,Rh,Pk,Oh=ge(()=>{kO=require("stream"),VO=x(require("json-bigint-fixes")),Uk=(0,VO.default)({useNativeBigInt:!0}),Mk=1e4,$O={};BigInt.prototype.toJSON=function(){throw $O};a(hc,"streamAsJSON");Rh=class extends kO.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(;;)if(o=i.next(),o.then&&(yield o.then(c=>(o=c,""))),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),GO)}catch(s){yield GO(s)}else yield Li(t)}else yield Li(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);qO(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>Mk?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 qO(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(GO,"handleError");a(qO,"when");a(Li,"stringify");a(YO,"jsStringify");Pk=/-?\d{16,}/;a(Ah,"parse")});var ib=T((Toe,sb)=>{"use strict";var bh=require("recursive-iterator"),vk=require("alasql"),Nh=require("clone"),WO=J(),{handleHDBError:QO,hdb_errors:Bk}=re(),{HDB_ERROR_MSGS:zO,HTTP_STATUS_CODES:JO}=Bk,{getDatabases:Hk}=(Re(),ne(Ge)),xk=["DISTINCT_ARRAY"],XO=Symbol("validateTables"),yh=Symbol("validateTable"),Soe=Symbol("getAllColumns"),jO=Symbol("validateAllColumns"),Yl=Symbol("findColumn"),ZO=Symbol("validateOrderBy"),mc=Symbol("validateSegment"),wh=Symbol("validateColumn"),eb=Symbol("setColumnsForTable"),tb=Symbol("checkColumnsForAsterisk"),rb=Symbol("validateGroupBy"),nb=Symbol("hasColumns"),Ih=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[XO](),this[tb](),this[jO]()}[XO](){if(this[nb]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[yh](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[yh](t.table)})}}[nb](){let t=!1,r=new bh(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[yh](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=Hk();if(!r[t.databaseid])throw QO(new Error,zO.SCHEMA_NOT_FOUND(t.databaseid),JO.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw QO(new Error,zO.TABLE_NOT_FOUND(t.databaseid,t.tableid),JO.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Nh(s);i.table=Nh(t),this.attributes.push(i)})}[Yl](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)}[tb](){let t=new bh(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[eb](r.tableid)}[eb](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new vk.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[jO](){this[mc](this.statement.columns,!1),this[mc](this.statement.joins,!1),this[mc](this.statement.where,!1),this[rb](this.statement.group,!1),this[mc](this.statement.order,!0)}[mc](t,r){if(!t)return;let n=new bh(t),s=[];for(let{node:i,path:o}of n)!WO.isEmpty(i)&&!WO.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[ZO](i):s.push(this[wh](i)));return s}[rb](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&xk.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Nh(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Yl](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[Yl](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`}[ZO](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[wh](t)}[wh](t){let r=this[Yl](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]}};sb.exports=Ih});var ab=T((Roe,ob)=>{"use strict";var Ch=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")}};ob.exports=Ch});var ub=T((Ooe,cb)=>{"use strict";var Dh=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};cb.exports=Dh});var fb={};Ye(fb,{HAS_EXPIRATION:()=>xh,LAST_TIMESTAMP_PLACEHOLDER:()=>Tc,LOCAL_TIMESTAMP:()=>Fk,METADATA:()=>pc,NO_TIMESTAMP:()=>Uh,PENDING_LOCAL_TIME:()=>Fh,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>Hh,RecordEncoder:()=>vh,TIMESTAMP_ASSIGN_LAST:()=>qk,TIMESTAMP_ASSIGN_NEW:()=>_b,TIMESTAMP_ASSIGN_PREVIOUS:()=>db,TIMESTAMP_PLACEHOLDER:()=>Kl,TIMESTAMP_RECORD_PREVIOUS:()=>Mh,fromResource:()=>Jl,getUpdateRecord:()=>Gh,handleLocalTimeForGets:()=>Xl});function Vk(){return Sc[0]=Sc[0]^64,Gk.getFloat64(0)}function Jl(e){Bh=!0;try{return e()}finally{Bh=!1}}function Xl(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),u=c?.value,_=u?.[pc];return _>=0&&(c.metadataFlags=_,c.localTime=u.localTime,c.value=u.value,u.expiresAt>0&&(c.expiresAt=u.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[pc]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let u=c.value,_=u[pc];return _>=0&&(c.metadataFlags=_,c.localTime=u.localTime,c.value=u.value,u.expiresAt>0&&(c.expiresAt=u.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){if(this.timerTracked||(this.timerTracked=!0,Ui.push(new WeakRef(this))),!Bh)try{throw new Error("Read transaction used outside of resource")}catch(u){this.readStack=u.stack}o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let u=0;u<Ui.length;u++){let _=Ui[u].deref();(!_||_.isDone||_.isCommitted)&&Ui.splice(u--,1)}},i.prototype.done.isTracked=!0}return e}function Gh(e,t,r){return function(n,s,i,o,c=-1,u,_,l,d="put",f,E){if(f||u==null?xo=i?.localTime?Mh|db:Uh:xo=u?i?.localTime?Mh|16384:_b|16384:Uh,l>0&&(c|=xh),Ql=c,Ph=l,i?.version===o&&u===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:xo>0},S;try{f&&(h.ifVersion=S=i?.version??null);let p=e.put(n,s,h);if(u){let R=_?.user?.username;if(E&&(Wl=e.encoder.encode(E)),f&&i?.localTime){let A=i?.localTime,g=r.get(A);if(g){let v=Lt(g).previousLocalTime;return r.put(A,zl(o,t,n,v,R,d,Wl),{ifVersion:S}),p}}r.put(Tc,zl(o,t,n,i?.localTime?1:0,R,d,Wl),{append:d!=="invalidate",instructedWrite:!0,ifVersion:S})}return p}catch(p){throw p.message+=" id: "+n+" options: "+h,p}}}var lb,Lh,Kl,Tc,Hh,Fk,pc,Sc,Gk,Uh,_b,qk,db,Mh,xh,Fh,kk,Wl,xo,Ql,Ph,vh,yoe,Bh,Ui,Fo=ge(()=>{lb=require("msgpackr");Mi();Lh=x(Q()),Kl=new Uint8Array([1,1,1,1,4,64,0,0]),Tc=new Uint8Array([1,1,1,1,1,0,0,0]),Hh=new Uint8Array([1,1,1,1,3,64,0,0]),Fk=Symbol("local-timestamp"),pc=Symbol("metadata"),Sc=new Uint8Array(8),Gk=new DataView(Sc.buffer,0,8),Uh=0,_b=0,qk=1,db=3,Mh=4,xh=16,Fh=1,xo=0,Ql=-1,Ph=0,vh=class extends lb.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(n,s){if(xo||Ql>=0){let i=0,o=xo;o&&(i+=8,xo=0);let c=Ql,u=Ph;c>=0&&(i+=2,Ql=-1,u&&(i+=8,Ph=0));let _=kk=r.call(this,n,s|2048|i);Wl=_.subarray((_.start||0)+i,_.end);let l=_.start||0;return o&&(Kl[4]=o,Kl[5]=o>>8,_.set(Kl,l),l+=8),c>=0&&(_[l++]=c,_[l++]=0,u&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(l,u)),_}else return r.call(this,n,s)}}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,u;if(i===2){if(t.copy)t.copy(Sc,0,c),c+=8;else for(let d=0;d<8;d++)Sc[d]=t[c++];u=Vk(),i=t[c]}let _;i<32&&(o=i,c+=2,o&xh&&(_=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8));let l=super.decode(t.subarray(c,s),s-c);return{localTime:u,value:l,[pc]:o,expiresAt:_}}return super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(Vk,"getTimestamp");yoe=Map.prototype.get;a(Jl,"fromResource");a(Xl,"handleLocalTimeForGets");Ui=[];setInterval(()=>{for(let e=0;e<Ui.length;e++){let t=Ui[e].deref();!t||t.isDone||t.isCommitted?Ui.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Lh.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Lh.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(Gh,"getUpdateRecord")});var jl=T((Ioe,Eb)=>{"use strict";var kh=te(),Vh=P(),{RecordEncoder:$k}=(Fo(),ne(fb));kh.initSync();var Yk=kh.get(Vh.CONFIG_PARAMS.STORAGE_COMPRESSION),Kk=kh.get(Vh.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Wk=Vh.UPDATES_PROPERTY,qh=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.compression=Yk&&r&&{startingOffset:32},this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=Kk&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:$k},this.alwaysLazyProperty=n=>n===Wk)}};Eb.exports=qh});var e_=T((Doe,mb)=>{"use strict";var Go=te(),gc=P();Go.initSync();var Qk=Go.get(gc.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Go.get(gc.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Go.get(gc.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",hb=Go.get(gc.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC),zk=Go.get(gc.CONFIG_PARAMS.STORAGE_NOREADAHEAD),Zl=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=1e3,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.noSync=Qk,this.noFSAccess=!0,hb!==void 0&&(this.overlappingSync=hb),this.noReadAhead=zk}};mb.exports=Zl;Zl.MAX_DBS=1e4});var Ke=T((Uoe,yb)=>{"use strict";var Yh=require("lmdb"),An=require("fs-extra"),Ir=require("path"),t_=yr(),Tb=Q(),nr=Nr().LMDB_ERRORS_ENUM,r_=ub(),Kh=jl(),gb=e_(),zs=dt(),pb=P(),{table:Jk,resetDatabases:Xk}=(Re(),ne(Ge)),Sb=te(),On=zs.INTERNAL_DBIS_NAME,Rb=zs.DBI_DEFINITION_NAME,jk="data.mdb",Zk="lock.mdb",Rc=".mdb",eV="-lock",$h=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=jr(t,r),this.key_type=this.dbi[zs.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[zs.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new Yh.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function n_(e,t){if(e===void 0)throw new Error(nr.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(nr.ENV_NAME_REQUIRED)}a(n_,"pathEnvNameValidation");async function Wh(e,t,r=!0){try{await An.access(e)}catch(n){throw n.code==="ENOENT"?new Error(nr.INVALID_BASE_PATH):n}try{let n=Ir.join(e,t+Rc);return await An.access(n,An.constants.R_OK|An.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await An.access(Ir.join(e,t,jk),An.constants.R_OK|An.constants.F_OK),Ir.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(nr.INVALID_ENVIRONMENT)}else throw new Error(nr.INVALID_ENVIRONMENT);throw n}}a(Wh,"validateEnvironmentPath");function s_(e,t){if(t_.validateEnv(e),t===void 0)throw new Error(nr.DBI_NAME_REQUIRED)}a(s_,"validateEnvDBIName");async function tV(e,t,r=!1,n=!1){n_(e,t);let s=Ir.basename(e);t=t.toString();let i=Sb.get(pb.CONFIG_PARAMS.DATABASES);i||Sb.setProperty(pb.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await Wh(e,t,n),Ab(e,t,r)}catch(o){if(o.message===nr.INVALID_ENVIRONMENT){let c=Ir.join(e,t);await An.mkdirp(n?c:e);let u=new gb(n?c:c+Rc,!1),_=Yh.open(u);_.dbis=Object.create(null);let l=new Kh(!1);_.openDB(On,l),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=Qh(e,t,r);return _[zs.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=_,_}throw o}}a(tV,"createEnvironment");async function rV(e,t,r,n=!0){n_(e,t),t=t.toString();let s=Ir.join(e,t);return Jk({table:t,database:Ir.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(rV,"copyEnvironment");async function Ab(e,t,r=!1){n_(e,t),t=t.toString();let n=Qh(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 Wh(e,t),i=Ir.join(e,t+Rc),o=s!=i,c=new gb(s,o),u=Yh.open(c);u.dbis=Object.create(null);let _=bb(u);for(let l=0;l<_.length;l++)jr(u,_[l]);return u[zs.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=u,u}a(Ab,"openEnvironment");async function nV(e,t,r=!1){n_(e,t),t=t.toString();let n=Ir.join(e,t+Rc),s=await Wh(e,t);if(global.lmdb_map!==void 0){let i=Qh(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await Ob(o),delete global.lmdb_map[i]}}await An.remove(s),await An.remove(s===n?s+eV:Ir.join(Ir.dirname(s),Zk))}a(nV,"deleteEnvironment");async function Ob(e){t_.validateEnv(e);let t=e[zs.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(Ob,"closeEnvironment");function Qh(e,t,r=!1){let s=`${Ir.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(Qh,"getCachedEnvironmentName");function sV(e){t_.validateEnv(e);let t=Object.create(null),r=jr(e,On);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==On)try{t[n]=Object.assign(new r_,s)}catch{Tb.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(sV,"listDBIDefinitions");function bb(e){t_.validateEnv(e);let t=[],r=jr(e,On);for(let{key:n}of r.getRange({start:!1}))n!==On&&t.push(n);return t}a(bb,"listDBIs");function iV(e,t){let n=jr(e,On).getEntry(t),s=new r_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{Tb.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(iV,"getDBIDefinition");function Nb(e,t,r,n=!r){if(s_(e,t),t=t.toString(),t===On)throw new Error(nr.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return jr(e,t)}catch(s){if(s.message===nr.DBI_DOES_NOT_EXIST){let i=new Kh(r,n===!0),o=e.openDB(t,i),c=new r_(r===!0,n);return o[Rb]=c,jr(e,On).putSync(t,c),e.dbis[t]=o,o}throw s}}a(Nb,"createDBI");function jr(e,t){if(s_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==On?r=iV(e,t):r=new r_,r===void 0)throw new Error(nr.DBI_DOES_NOT_EXIST);let n;try{let s=new Kh(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(nr.DBI_DOES_NOT_EXIST):s}return n[Rb]=r,e.dbis[t]=n,n}a(jr,"openDBI");function oV(e,t){s_(e,t),t=t.toString();let r=jr(e,t),n=r.getStats();return r[zs.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(oV,"statDBI");async function aV(e,t){try{let r=Ir.join(e,t+Rc);return(await An.stat(r)).size}catch{throw new Error(nr.INVALID_ENVIRONMENT)}}a(aV,"environmentDataSize");function cV(e,t){if(s_(e,t),t=t.toString(),t===On)throw new Error(nr.CANNOT_DROP_INTERNAL_DBIS_NAME);jr(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],jr(e,On).removeSync(t)}a(cV,"dropDBI");function uV(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{jr(e,i)}catch(o){if(o.message===nr.DBI_DOES_NOT_EXIST)Nb(e,i,i!==t,i===t),n=!0;else throw o}}n&&Xk()}a(uV,"initializeDBIs");yb.exports={openDBI:jr,openEnvironment:Ab,createEnvironment:tV,listDBIs:bb,listDBIDefinitions:sV,createDBI:Nb,dropDBI:cV,statDBI:oV,deleteEnvironment:nV,initializeDBIs:uV,TransactionCursor:$h,environmentDataSize:aV,copyEnvironment:rV,closeEnvironment:Ob}});var Ib=T((Poe,wb)=>{"use strict";var zh=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};wb.exports=zh});var Db=T((Boe,Cb)=>{"use strict";var Jh=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}};Cb.exports=Jh});var Ub=T((xoe,Lb)=>{"use strict";var Xh=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};Lb.exports=Xh});var qo=T((Voe,vb)=>{"use strict";var lV=Ke(),_V=Ib(),dV=Db(),fV=Ub(),Vn=yr(),Ac=Nr().LMDB_ERRORS_ENUM,EV=dt(),ms=P(),hV=J(),mV=require("uuid"),Goe=require("lmdb"),{handleHDBError:pV,hdb_errors:SV}=re(),{OVERFLOW_MARKER:qoe,MAX_SEARCH_KEY_LENGTH:koe}=EV,Mb=te();Mb.initSync();var i_=Mb.get(ms.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),jh=ms.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Pi=ms.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function TV(e,t,r,n,s=Vn.getNextMonotonicTime()){rm(e,t,r,n),Zh(e,t,r);let i=new _V,o=[],c=[];for(let u=0;u<n.length;u++){let _=n[u];Pb(_,!0,s);let l=gV(e,t,r,_),d=_[t];o.push(l),c.push(d)}return em(o,c,n,i,s)}a(TV,"insertRecords");function gV(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 l=c([[{}]]);Array.isArray(l)&&(c=l[0][ms.FUNC_VAL],n[o]=c)}let u=Vn.getIndexedValues(c),_=e.dbis[o];if(u){i_&&_.prefetch(u.map(l=>({key:l,value:s})),o_);for(let l=0,d=u.length;l<d;l++)_.put(u[l],s)}}i_&&e.dbis[t].prefetch([s],o_),e.dbis[t].put(s,n,n[Pi])})}a(gV,"insertRecord");function RV(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(RV,"removeSkippedRecords");function Pb(e,t,r){let n=r>0;(n||!Number.isInteger(e[Pi]))&&(e[Pi]=r||(r=Vn.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[jh]))&&(e[jh]=r||Vn.getNextMonotonicTime()):delete e[jh]}a(Pb,"setTimestamps");function Zh(e,t,r){r.indexOf(ms.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(ms.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(ms.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(ms.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),lV.initializeDBIs(e,t,r)}a(Zh,"initializeTransaction");async function AV(e,t,r,n,s=Vn.getNextMonotonicTime()){rm(e,t,r,n),Zh(e,t,r);let i=new dV,o=[],c=[],u=[];for(let _=0;_<n.length;_++){let l=n[_],d=l[t],f;try{f=tm(e,t,l,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(_);continue}c.push(f),u.push(d)}return em(c,u,n,i,s,o)}a(AV,"updateRecords");async function OV(e,t,r,n,s=Vn.getNextMonotonicTime()){try{rm(e,t,r,n)}catch(u){throw pV(u,u.message,SV.HTTP_STATUS_CODES.BAD_REQUEST)}Zh(e,t,r);let i=new fV,o=[],c=[];for(let u=0;u<n.length;u++){let _=n[u],l;hV.isEmpty(_[t])?(l=mV.v4(),_[t]=l):l=_[t];let d=tm(e,t,_,l,i,!1,s);o.push(d),c.push(l)}return em(o,c,n,i,s)}a(OV,"upsertRecords");async function em(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,u=o.length;c<u;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||Vn.getNextMonotonicTime(),RV(r,i),n}a(em,"finalizeWrite");function tm(e,t,r,n,s,i=!1,o){let c=e.dbis[t],u=c.getEntry(n),_=u?.value,l=_;if(!_){if(i)return!1;_={}}if(Pb(r,!l,o),Number.isInteger(r[Pi])&&_[Pi]>r[Pi])return!1;l&&s.original_records.push(_);let d,f=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let S=r[h],p=e.dbis[h];if(p===void 0)continue;let R=_[h];if(typeof S=="function"){let g=S([[_]]);Array.isArray(g)&&(S=g[0][ms.FUNC_VAL],r[h]=S)}if(S===R)continue;let A=Vn.getIndexedValues(R);if(A){i_&&p.prefetch(A.map(g=>({key:g,value:n})),o_);for(let g=0,v=A.length;g<v;g++)p.remove(A[g],n)}if(A=Vn.getIndexedValues(S),A){i_&&p.prefetch(A.map(g=>({key:g,value:n})),o_);for(let g=0,v=A.length;g<v;g++)p.put(A[g],n)}}let E=Object.assign({},_,r);c.put(n,E,E[Pi])},"do_put");return u?d=c.ifVersion(n,u.version,f):d=c.ifNoExists(n,f),d.then(E=>E?!0:tm(e,t,r,n,s,i,o))}a(tm,"updateUpsertRecord");function bV(e,t,r){if(Vn.validateEnv(e),t===void 0)throw new Error(Ac.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Ac.WRITE_ATTRIBUTES_REQUIRED):new Error(Ac.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(bV,"validateBasic");function rm(e,t,r,n){if(bV(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Ac.RECORDS_REQUIRED):new Error(Ac.RECORDS_MUST_BE_ARRAY)}a(rm,"validateWrite");function o_(){}a(o_,"noop");vb.exports={insertRecords:TV,updateRecords:AV,upsertRecords:OV}});var vi=T((Yoe,NV)=>{NV.exports={hdb_table:{hash_attribute:"id",name:"hdb_table",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"name"},{attribute:"hash_attribute"},{attribute:"schema"},{attribute:"residence"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_attribute:{hash_attribute:"id",name:"hdb_attribute",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"schema"},{attribute:"table"},{attribute:"attribute"},{attribute:"schema_table"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_schema:{hash_attribute:"name",name:"hdb_schema",schema:"system",residence:["*"],attributes:[{attribute:"name"},{attribute:"createddate"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metric"}]},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 Yn=T((Koe,xb)=>{"use strict";var Hb=J(),Bb=P(),ko=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,$n=require("joi"),Js={schema_format:{pattern:ko,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},yV=$n.alternatives($n.string().min(1).max(Js.schema_length.maximum).pattern(ko).messages({"string.pattern.base":"{:#label} "+Js.schema_format.message}),$n.number(),$n.array()).required(),wV=$n.alternatives($n.string().min(1).max(Js.schema_length.maximum).pattern(ko).messages({"string.pattern.base":"{:#label} "+Js.schema_format.message}),$n.number()),IV=$n.alternatives($n.string().min(1).max(Js.schema_length.maximum).pattern(ko).messages({"string.pattern.base":"{:#label} "+Js.schema_format.message}),$n.number()).required();function CV(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Js.schema_length.maximum?`'${e}' maximum of 250 characters`:ko.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(CV,"checkValidTable");function DV(e,t){return Hb.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(DV,"validateSchemaExists");function LV(e,t){let r=t.state.ancestors[0].schema;return Hb.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(LV,"validateTableExists");function UV(e,t){return e.toLowerCase()===Bb.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${Bb.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(UV,"validateSchemaName");xb.exports={common_validators:Js,schema_regex:ko,hdb_schema_table:yV,validateSchemaExists:DV,validateTableExists:LV,validateSchemaName:UV,checkValidTable:CV,hdb_database:wV,hdb_table:IV}});var rt=T((Qoe,Fb)=>{"use strict";var sr=require("validate.js");sr.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||sr.validators.type.checks[t](e)?null:` must be a '${t}' value`};sr.validators.type.checks={Object:function(e){return sr.isObject(e)&&!sr.isArray(e)},Array:sr.isArray,Integer:sr.isInteger,Number:sr.isNumber,String:sr.isString,Date:sr.isDate,Boolean:function(e){return typeof e=="boolean"}};sr.validators.hasValidFileExt=function(e,t){return sr.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};Fb.exports={validateObject:MV,validateObjectAsync:PV,validateBySchema:vV};function MV(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=sr(e,t,{format:"flat"});return r?new Error(r):null}a(MV,"validateObject");async function PV(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await sr.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(PV,"validateObjectAsync");function vV(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(vV,"validateBySchema")});var a_=T((Joe,Gb)=>{var{common_validators:Kn}=Yn(),bc=rt(),Oc="is required",ft={database:{presence:!1,format:Kn.schema_format,length:Kn.schema_length},schema:{presence:!1,format:Kn.schema_format,length:Kn.schema_length},table:{presence:!0,format:Kn.schema_format,length:Kn.schema_length},attribute:{presence:!0,format:Kn.schema_format,length:Kn.schema_length},hash_attribute:{presence:!0,format:Kn.schema_format,length:Kn.schema_length}};function Nc(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(Nc,"makeAttributesStrings");function BV(e){return e=Nc(e),ft.table.presence=!1,ft.attribute.presence=!1,ft.hash_attribute.presence=!1,bc.validateObject(e,ft)}a(BV,"schema_object");function HV(e){return e=Nc(e),ft.table.presence={message:Oc},ft.attribute.presence=!1,ft.hash_attribute.presence=!1,bc.validateObject(e,ft)}a(HV,"table_object");function xV(e){return e=Nc(e),ft.table.presence={message:Oc},ft.attribute.presence=!1,bc.validateObject(e,ft)}a(xV,"create_table_object");function FV(e){return e=Nc(e),ft.table.presence={message:Oc},ft.attribute.presence={message:Oc},ft.hash_attribute.presence=!1,bc.validateObject(e,ft)}a(FV,"attribute_object");function GV(e){return e=Nc(e),ft.table.presence={message:Oc},ft.attribute.presence=!1,ft.hash_attribute.presence=!1,bc.validateObject(e,ft)}a(GV,"describe_table");function qV(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(qV,"validateTableResidence");Gb.exports={schema_object:BV,create_table_object:xV,table_object:HV,attribute_object:FV,describe_table:GV,validateTableResidence:qV}});var kb=T((joe,qb)=>{"use strict";var kV=require("uuid"),nm=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||kV.v4(),this.schema_table=`${this.schema}.${this.table}`}};qb.exports=nm});var c_=T((eae,Vb)=>{"use strict";var VV=kb(),sm=class extends VV{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}};Vb.exports=sm});var Yb=T((rae,$b)=>{"use strict";$b.exports=YV;var $V="inserted";function YV(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===$V?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(YV,"returnObject")});var u_=T((sae,Jb)=>{"use strict";var KV=P(),im=Ke(),WV=qo(),{getSystemSchemaPath:QV,getSchemaPath:zV}=ze(),JV=vi(),XV=a_(),jV=c_(),ZV=Yb(),{handleHDBError:Kb,hdb_errors:Qb}=re(),Wb=J(),{HTTP_STATUS_CODES:e$}=Qb,om=JV.hdb_attribute,zb=[];for(let e=0;e<om.attributes.length;e++)zb.push(om.attributes[e].attribute);var t$="inserted";Jb.exports=r$;async function r$(e){let t=XV.attribute_object(e);if(t)throw Kb(new Error,t.message,Qb.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&Wb.checkGlobalSchemaTable(e.schema,e.table);if(r)throw Kb(new Error,r,e$.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=Wb.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 jV(e.schema,e.table,e.attribute,e.id);try{let i=await im.openEnvironment(zV(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}`);im.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await im.openEnvironment(QV(),KV.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:u}=await WV.insertRecords(o,om.hash_attribute,zb,[s]);return ZV(t$,c,{records:[s]},u)}catch(i){throw i}}a(r$,"lmdbCreateAttribute")});var cm=T((oae,jb)=>{var{hdb_table:n$,hdb_database:Xb}=Yn(),s$=rt(),am=require("joi"),i$={undefined:"undefined",null:"null"},o$=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||i$[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"),a$=am.object({database:Xb,schema:Xb,table:n$,records:am.array().items(am.object().custom(o$)).required()});jb.exports=function(e){return s$.validateBySchema(e,a$)}});var yc=T((uae,eN)=>{"use strict";var ps=J(),Zb=Q(),cae=cm(),{getDatabases:c$}=(Re(),ne(Ge)),{ClientError:Bi}=re();eN.exports=u$;function u$(e){if(ps.isEmpty(e))throw new Bi("invalid update parameters defined.");if(ps.isEmptyOrZeroLength(e.schema))throw new Bi("invalid schema specified.");if(ps.isEmptyOrZeroLength(e.table))throw new Bi("invalid table specified.");if(!Array.isArray(e.records))throw new Bi("records must be an array");let t=c$()[e.schema]?.[e.table];if(ps.isEmpty(t))throw new Bi(`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&&ps.isEmptyOrZeroLength(o[r]))throw Zb.error("a valid hash attribute must be provided with update record:",o),new Bi("a valid hash attribute must be provided with update record, check log for more info");if(!ps.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw Zb.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Bi(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!ps.isEmpty(o[r])&&o[r]!==""&&n.has(ps.autoCast(o[r]))&&(o.skip=!0),n.add(ps.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(u$,"insertUpdateValidate")});var wc=T((_ae,tN)=>{"use strict";var l$=P().OPERATIONS_ENUM,um=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=l$.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};tN.exports=um});var Lc=T((Eae,rN)=>{"use strict";var fae=wc(),l_=P(),_m=J(),lm=Q(),_$=require("uuid"),{handleHDBError:Ic,hdb_errors:d$}=re(),{HDB_ERROR_MSGS:Cc,HTTP_STATUS_CODES:Dc}=d$;rN.exports=f$;function f$(e,t,r){for(let s=0;s<t.length;s++)E$(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];h$(i,r,e.operation)}}a(f$,"processRows");function E$(e){if(Buffer.byteLength(String(e))>l_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Ic(new Error,Cc.ATTR_NAME_LENGTH_ERR(e),Dc.BAD_REQUEST,void 0,void 0,!0);if(_m.isEmptyOrZeroLength(e)||_m.isEmpty(e.trim()))throw Ic(new Error,Cc.ATTR_NAME_NULLISH_ERR,Dc.BAD_REQUEST,void 0,void 0,!0)}a(E$,"validateAttribute");function h$(e,t,r){if(!e.hasOwnProperty(t)||_m.isEmptyOrZeroLength(e[t])){if(r===l_.OPERATIONS_ENUM.INSERT||r===l_.OPERATIONS_ENUM.UPSERT){e[t]=_$.v4();return}throw lm.error("Update transaction aborted due to record with no hash value:",e),Ic(new Error,Cc.RECORD_MISSING_HASH_ERR,Dc.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>l_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw lm.error(e),Ic(new Error,Cc.HASH_VAL_LENGTH_ERR,Dc.BAD_REQUEST,void 0,void 0,!0);if(isNaN(e[t])&&e[t].includes("/"))throw lm.error(e),Ic(new Error,Cc.INVALID_FORWARD_SLASH_IN_HASH_ERR,Dc.BAD_REQUEST,void 0,void 0,!0)}a(h$,"validateHash")});var sN=T((mae,nN)=>{"use strict";var dm=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};nN.exports=dm});var aN=T((Sae,oN)=>{"use strict";var fm=Ke(),m$=Q(),iN=Nr().LMDB_ERRORS_ENUM;oN.exports=p$;async function p$(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 fm.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==iN.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await fm.closeEnvironment(global.lmdb_map[n]),await fm.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==iN.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){m$.error(t)}}a(p$,"cleanLMDBMap")});var Ss=T((gae,_N)=>{"use strict";var Uc=require("crypto"),S$=te(),{CONFIG_PARAMS:T$}=P(),uN="aes-256-cbc",g$=32,R$=16,Em=64,lN=32,A$=Em+lN,cN=new Map;_N.exports={encrypt:O$,decrypt:b$,createNatsTableStreamName:N$};function O$(e){let t=Uc.randomBytes(g$),r=Uc.randomBytes(R$),n=Uc.createCipheriv(uN,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(O$,"encrypt");function b$(e){let t=e.substr(0,Em),r=e.substr(Em,lN),n=e.substr(A$,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=Uc.createDecipheriv(uN,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(b$,"decrypt");function N$(e,t){let r=S$.get(T$.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=cN.get(r);return n||(n=Uc.createHash("md5").update(r).digest("hex"),cN.set(r,n)),n}a(N$,"createNatsTableStreamName")});var Hi=T((Oae,fN)=>{"use strict";var Aae=Zr(),__=Q(),dN=a_(),y$=Ss(),d_=J(),{handleHDBError:f_,hdb_errors:w$}=re(),{HDB_ERROR_MSGS:E_,HTTP_STATUS_CODES:hm}=w$,I$=te();I$.initSync();var{getDatabases:mm}=(Re(),ne(Ge));fN.exports={describeAll:C$,describeTable:h_,describeSchema:D$};async function C$(e){try{let t=d_.isEmptyOrZeroLength(e),r,n;t||(r=e.hdb_user.role.permission,n=r.super_user||r.cluster_user);let s=mm(),i={},o={},c=[],u=e?.exact_count;for(let l in s){i[l]=!0,!t&&!n&&(o[l]=e.hdb_user.role.permission[l].describe);let d=s[l];for(let f in d)try{let E;if(t||n)E=await h_({schema:l,table:f,exact_count:u});else if(r&&r[l].describe&&r[l].tables[f].describe){let h=r[l].tables[f].attribute_permissions;E=await h_({schema:l,table:f,exact_count:u},h)}E&&c.push(E)}catch(E){__.error(E)}}let _={};for(let l in c)t||n?(_[c[l].schema]==null&&(_[c[l].schema]={}),_[c[l].schema][c[l].name]=c[l],i[c[l].schema]&&delete i[c[l].schema]):o[c[l].schema]&&(_[c[l].schema]==null&&(_[c[l].schema]={}),_[c[l].schema][c[l].name]=c[l],i[c[l].schema]&&delete i[c[l].schema]);for(let l in i)t||n?_[l]={}:o[l]&&(_[l]={});return _}catch(t){return __.error("Got an error in describeAll"),__.error(t),f_(new Error,E_.DESCRIBE_ALL_ERR)}}a(C$,"describeAll");async function h_(e,t){d_.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=dN.describe_table(e);if(i)throw i;let c=mm()[r];if(!c)throw f_(new Error,E_.SCHEMA_NOT_FOUND(e.schema),hm.NOT_FOUND);let u=c[n];if(!u)throw f_(new Error,E_.TABLE_NOT_FOUND(e.schema,e.table),hm.NOT_FOUND);function _(f){l.push(Object.assign({},{attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(E=>({type:E.type,name:E.name})):void 0}))}a(_,"pushAtt");let l=[];if(s){let f={};s.forEach(E=>{E.describe&&(f[E.attribute_name]=!0)}),u.attributes.forEach(E=>{f[E.name]&&_(E)})}else u.attributes?.forEach(f=>_(f));let d={schema:r,name:u.tableName,hash_attribute:u.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:u.audit,schema_defined:u.schemaDefined,attributes:l};d.clustering_stream_name=y$.createNatsTableStreamName(d.schema,d.name);try{let f=u.getRecordCount({exactCount:e.exact_count==="true"});d.record_count=f.recordCount,d.estimated_record_range=f.estimatedRange;let E=u.auditStore;if(E)for(let h of E.getKeys({reverse:!0,limit:1}))d.last_updated_record=h[0];if(!d.last_updated_record&&u.indices.__updatedtime__)for(let h of u.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))d.last_updated_record=h}catch(f){__.warn(`unable to stat table dbi due to ${f}`)}return d}a(h_,"descTable");async function D$(e){d_.transformReq(e);let t=dN.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=mm()[n];if(!i)throw f_(new Error,E_.SCHEMA_NOT_FOUND(e.schema),hm.NOT_FOUND);let o={};for(let c in i){let u;if(r&&r.tables[c]&&(u=r.tables[c]),d_.isEmpty(u)||u.describe){let _=await h_({schema:e.schema,table:c,exact_count:e.exact_count},u?u.attribute_permissions:null);_&&(o[_.name]=_)}}return o}a(D$,"describeSchema")});var Xs=T((wae,SN)=>{var L$=vi(),{callbackify:hN,promisify:U$}=require("util"),{getDatabases:mN}=(Re(),ne(Ge));SN.exports={setSchemaDataToGlobal:EN,getTableSchema:M$,getSystemSchema:P$,setSchemaDataToGlobalAsync:U$(EN)};var pN=Hi(),Nae=hN(pN.describeAll),yae=hN(pN.describeTable);function EN(e){global.hdb_schema=mN(),e&&e()}a(EN,"setSchemaDataToGlobal");function M$(e,t,r){let n=mN()[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(M$,"getTableSchema");function P$(){return L$}a(P$,"getSystemSchema")});var en=T((Cae,AN)=>{"use strict";var p_=cm(),Ft=J(),v$=require("util"),S_=bn(),B$=Xs(),TN=Q(),{handleHDBError:xi,hdb_errors:H$}=re(),{HTTP_STATUS_CODES:Fi}=H$,x$=v$.promisify(B$.getTableSchema),F$="updated",gN="inserted",RN="upserted";AN.exports={insert:q$,update:k$,upsert:V$,validation:G$,flush:$$};async function G$(e){if(Ft.isEmpty(e))throw new Error("invalid update parameters defined.");if(Ft.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Ft.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await x$(e.schema,e.table),r=p_(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&&Ft.isEmptyOrZeroLength(c[n]))throw TN.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(!Ft.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw TN.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Ft.isEmpty(c[n])&&c[n]!==""&&s.has(Ft.autoCast(c[n]))&&(c.skip=!0),s.add(Ft.autoCast(c[n]));for(let u in c)i[u]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(G$,"validation");async function q$(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=p_(e);if(t)throw xi(new Error,t.message,Fi.BAD_REQUEST);Ft.transformReq(e);let r=Ft.checkSchemaTableExist(e.schema,e.table);if(r)throw xi(new Error,r,Fi.BAD_REQUEST);let n=await S_.createRecords(e);return m_(gN,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(q$,"insertData");async function k$(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=p_(e);if(t)throw xi(new Error,t.message,Fi.BAD_REQUEST);Ft.transformReq(e);let r=Ft.checkSchemaTableExist(e.schema,e.table);if(r)throw xi(new Error,r,Fi.BAD_REQUEST);let n=await S_.updateRecords(e);return Ft.isEmpty(n.existing_rows)?m_(F$,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):m_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(k$,"updateData");async function V$(e){if(e.operation!=="upsert")throw xi(new Error,"invalid operation, must be upsert",Fi.INTERNAL_SERVER_ERROR);let t=p_(e);if(t)throw xi(new Error,t.message,Fi.BAD_REQUEST);Ft.transformReq(e);let r=Ft.checkSchemaTableExist(e.schema,e.table);if(r)throw xi(new Error,r,Fi.BAD_REQUEST);let n=await S_.upsertRecords(e);return m_(RN,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(V$,"upsertData");function m_(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===gN?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===RN?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(m_,"returnObject");function $$(e){return Ft.transformReq(e),S_.flush(e.schema,e.table)}a($$,"flush")});var Sm=T((Lae,NN)=>{var Y$=rt(),pm=require("joi"),{hdb_table:K$,hdb_database:ON}=Yn(),bN={schema:ON,database:ON,table:K$},W$={date:pm.date().iso().required()},Q$={timestamp:pm.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};NN.exports=function(e,t){let r=t==="timestamp"?{...bN,...Q$}:{...bN,...W$},n=pm.object(r);return Y$.validateBySchema(e,n)}});var IN=T((Uae,wN)=>{var z$=rt(),Tm=require("joi"),{hdb_table:J$,hdb_database:yN}=Yn(),X$=Tm.object({schema:yN,database:yN,table:J$,hash_values:Tm.array().required(),ids:Tm.array()});wN.exports=function(e){return z$.validateBySchema(e,X$)}});var DN=T((Mae,CN)=>{"use strict";var gm=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}},Rm=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}},Am=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};CN.exports={InsertObject:gm,NoSQLSeachObject:Rm,DeleteResponseObject:Am}});var ki=T((vae,vN)=>{"use strict";var UN=Sm(),j$=IN(),Gi=J(),LN=require("moment"),MN=Q(),{promisify:Z$,callbackify:e1}=require("util"),qi=P(),t1=Xs(),Om=Z$(t1.getTableSchema),bm=bn(),{DeleteResponseObject:r1}=DN(),{handleHDBError:js,hdb_errors:n1}=re(),{HDB_ERROR_MSGS:T_,HTTP_STATUS_CODES:Zs}=n1,s1="records successfully deleted",i1=e1(PN);vN.exports={delete:i1,deleteRecord:PN,deleteFilesBefore:o1,deleteAuditLogsBefore:a1};async function o1(e){let t=UN(e,"date");if(t)throw js(t,t.message,Zs.BAD_REQUEST,void 0,void 0,!0);if(Gi.transformReq(e),!LN(e.date,LN.ISO_8601).isValid())throw js(new Error,T_.INVALID_DATE,Zs.BAD_REQUEST,qi.LOG_LEVELS.ERROR,T_.INVALID_DATE,!0);let n=Gi.checkSchemaTableExist(e.schema,e.table);if(n)throw js(new Error,n,Zs.NOT_FOUND,qi.LOG_LEVELS.ERROR,n,!0);let s=await bm.deleteRecordsBefore(e);if(await Om(e.schema,e.table),MN.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(o1,"deleteFilesBefore");async function a1(e){let t=UN(e,"timestamp");if(t)throw js(t,t.message,Zs.BAD_REQUEST,void 0,void 0,!0);if(Gi.transformReq(e),isNaN(e.timestamp))throw js(new Error,T_.INVALID_VALUE("Timestamp"),Zs.BAD_REQUEST,qi.LOG_LEVELS.ERROR,T_.INVALID_VALUE("Timestamp"),!0);let r=Gi.checkSchemaTableExist(e.schema,e.table);if(r)throw js(new Error,r,Zs.NOT_FOUND,qi.LOG_LEVELS.ERROR,r,!0);let n=await bm.deleteAuditLogsBefore(e);return await Om(e.schema,e.table),MN.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(a1,"deleteAuditLogsBefore");async function PN(e){e.ids&&(e.hash_values=e.ids);let t=j$(e);if(t)throw js(t,t.message,Zs.BAD_REQUEST,void 0,void 0,!0);Gi.transformReq(e);let r=Gi.checkSchemaTableExist(e.schema,e.table);if(r)throw js(new Error,r,Zs.NOT_FOUND,qi.LOG_LEVELS.ERROR,r,!0);try{await Om(e.schema,e.table);let n=await bm.deleteRecords(e);return Gi.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${s1}`),n}catch(n){if(n.message===qi.SEARCH_NOT_FOUND_MESSAGE){let s=new r1;return s.message=qi.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(PN,"deleteRecord")});var g_=T((Hae,xN)=>{var c1=require("crypto"),BN=9;function u1(e){let t=_1(BN),r=HN(e+t);return t+r}a(u1,"createHash");function l1(e,t){let r=e?.substr(0,BN),n=r+HN(t+r);return e===n}a(l1,"validateHash");function _1(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,n="";for(let s=0;s<e;s++){let i=Math.floor(Math.random()*r);n+=t[i]}return n}a(_1,"generateSalt");function HN(e){return c1.createHash("md5").update(e).digest("hex")}a(HN,"md5");xN.exports={hash:u1,validate:l1}});var GN=T((Fae,FN)=>{var Nm=rt(),Kt={username:{presence:!0,format:"[\\w\\-\\_]+",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 d1(e){return Kt.password.presence=!0,Kt.username.presence=!0,Kt.role.presence=!0,Kt.active.presence=!0,Nm.validateObject(e,Kt)}a(d1,"addUserValidation");function f1(e){return Kt.password.presence=!1,Kt.username.presence=!0,Kt.role.presence=!1,Kt.active.presence=!1,Nm.validateObject(e,Kt)}a(f1,"alterUserValidation");function E1(e){return Kt.password.presence=!1,Kt.username.presence=!0,Kt.role.presence=!1,Kt.active.presence=!1,Nm.validateObject(e,Kt)}a(E1,"dropUserValidation");FN.exports={addUserValidation:d1,alterUserValidation:f1,dropUserValidation:E1}});var nt=T((kae,kN)=>{"use strict";var{platform:qae}=require("os"),h1="nats-server.zip",ym="nats-server",m1=process.platform==="win32"?`${ym}.exe`:ym,wm="HDB",p1=/^[^\s.,*>]+$/,qN="__request__",S1=a(e=>`${e}.${qN}`,"REQUEST_SUBJECT"),T1={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},g1={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},R1={HUB:"hub.pid",LEAF:"leaf.pid"},A1={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},O1={stream_name:"__HARPERDB_WORK_QUEUE__",durable_name:"HDB_WORK_QUEUE",deliver_group:wm,deliver_subject:"__HDB__.WORKQUEUE"},b1={stream_name:"__HARPERDB_SCHEMA_QUEUE__",durable_name:"HDB_SCHEMA_QUEUE",deliver_group:wm,deliver_subject:"HDB.SCHEMAQUEUE"},N1={stream_name:"__HARPERDB_USER_QUEUE__",durable_name:"HDB_USER_QUEUE",deliver_group:wm,deliver_subject:"HDB.USERQUEUE"},y1={SUCCESS:"success",ERROR:"error"},w1={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},I1={TXN:"txn",MSGID:"msgid"},Vo={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},C1={[Vo.ERR]:1,[Vo.WRN]:2,[Vo.INF]:3,[Vo.DBG]:4,[Vo.TRC]:5},D1={debug:"-D",trace:"-DVV"};kN.exports={NATS_SERVER_ZIP:h1,NATS_SERVER_NAME:ym,NATS_BINARY_NAME:m1,PID_FILES:R1,NATS_CONFIG_FILES:g1,SERVER_SUFFIX:A1,WORK_QUEUE_CONSUMER_NAMES:O1,SCHEMA_QUEUE_CONSUMER_NAMES:b1,USER_QUEUE_CONSUMER_NAMES:N1,NATS_TERM_CONSTRAINTS_RX:p1,REQUEST_SUFFIX:qN,UPDATE_REMOTE_RESPONSE_STATUSES:y1,CLUSTER_STATUS_STATUSES:w1,REQUEST_SUBJECT:S1,SUBJECT_PREFIXES:I1,MSG_HEADERS:T1,LOG_LEVELS:Vo,LOG_LEVEL_FLAGS:D1,LOG_LEVEL_HIERARCHY:C1}});var $N=T(($ae,VN)=>{"use strict";var L1={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
|
|
1
|
+
"use strict";var cG=Object.create;var Za=Object.defineProperty;var uG=Object.getOwnPropertyDescriptor;var lG=Object.getOwnPropertyNames;var _G=Object.getPrototypeOf,dG=Object.prototype.hasOwnProperty;var a=(e,t)=>Za(e,"name",{value:t,configurable:!0});var Re=(e,t)=>()=>(e&&(t=e(e=0)),t);var g=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),$e=(e,t)=>{for(var r in t)Za(e,r,{get:t[r],enumerable:!0})},BA=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of lG(t))!dG.call(e,s)&&s!==r&&Za(e,s,{get:()=>t[s],enumerable:!(n=uG(t,s))||n.enumerable});return e};var x=(e,t,r)=>(r=e!=null?cG(_G(e)):{},BA(t||!e||!e.__esModule?Za(r,"default",{value:e,enumerable:!0}):r,e)),se=e=>BA(Za({},"__esModule",{value:!0}),e);var GA=g((Vie,xA)=>{var fG=require("fast-glob"),{statSync:oh,existsSync:ah,readFileSync:EG,writeFileSync:hG}=require("fs"),{spawnSync:mG,spawn:pG,execFileSync:kie}=require("child_process"),{isMainThread:SG}=require("worker_threads"),{join:Ks,relative:HA}=require("path"),{PACKAGE_ROOT:gn}=U(),{tmpdir:TG,platform:gG}=require("os");require("source-map-support").install();var RG=["resources","server","dataLayer","components"],ec="ts-build",ch,AG=__filename.endsWith("tsBuild.js");if(AG){if(SG){let r;try{oh(Ks(gn,ec)),r=!0}catch{}if(r)for(let n of fG.sync(RG.map(s=>s+"/**/*.ts"),{cwd:gn})){let s=0,i=0;try{s=oh(Ks(gn,n)).mtimeMs-5e3,i=oh(Ks(gn,ec,n.replace(/.ts$/,".js"))).mtimeMs}catch{}if(s>i){console.warn(`TypeScript ${n} is not compiled`+(i?` (TS source file was modified at ${new Date(s)} and compiled file at ${new Date(i)})`:"")+", consider enabling auto-compilation of TypeScript in your IDE), compiling now."),ch=!0;break}}else console.log("TypeScript modules are not compiled, compiling now"),ch=!0;if(ch){let n=Ks(gn,"node_modules/.bin/tsc");gG()==="win32"&&(n+=".cmd");let s=mG(n,{cwd:gn});if(s.stdout.length&&console.log(s.stdout.toString()),s.stderr.length&&console.log(s.stderr.toString()),r){let i=Ks(TG(),"harperdb-tsc.pid"),o;if(ah(i))try{process.kill(+EG(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=pG(n,["--watch"],{cwd:gn,detached:!0,stdio:"ignore"});hG(i,c.pid.toString()),c.unref()}}}}let e=xA.constructor,t=e._findPath;e._findPath=function(r,n,s){if(r.startsWith(".")&&!s&&n.length===1&&n[0].startsWith(gn)&&!n[0].includes("node_modules")){let i=HA(gn,n[0]),o;i.startsWith(ec)?o=Ks(gn,HA(ec,i)):o=Ks(gn,ec,i);let c=Ks(o,r),u=c+".js";if(ah(u))return u;if(c.includes(".")&&ah(c))return c}return t(r,n,s)}}});var U=g((Kie,ZA)=>{"use strict";var en=require("path"),OG=require("fs"),{relative:$ie,join:Yie}=en,{existsSync:bG}=OG;function yG(){let e=__dirname;for(;!bG(en.join(e,"package.json"));){let t=en.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(yG,"getHDBPackageRoot");var Ws=yG(),FA="js",Bl=FA,NG="harperdb-config.yaml",IG="defaultConfig.yaml",wG="hdb",qA=`harperdb.${Bl}`,kA=`customFunctionsServer.${Bl}`,CG=`restartHdb.${Bl}`,lh="HarperDB",vl="Custom Functions",Hl="Clustering Hub",xl="Clustering Leaf",DG="Clustering Ingest Service",LG="Clustering Reply Service",MG="foreground.pid",UG="hdb.pid",PG="data",vG={HDB:lh,CLUSTERING_HUB:Hl,CLUSTERING_LEAF:xl,CLUSTERING_INGEST_SERVICE:DG,CLUSTERING_REPLY_SERVICE:LG,CUSTOM_FUNCTIONS:vl,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"},BG={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},HG={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},xG={harperdb:lh,"clustering hub":Hl,"clustering leaf":xl,"custom functions":vl,custom_functions:vl,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers"},GG={CLUSTERING_HUB_PROC_DESCRIPTOR:Hl,CLUSTERING_LEAF_PROC_DESCRIPTOR:xl},uh={HDB:en.join(Ws,"server/harperdb"),CUSTOM_FUNCTIONS:en.join(Ws,"server/customFunctions"),CLUSTERING_HUB:en.join(Ws,"server/nats"),CLUSTERING_LEAF:en.join(Ws,"server/nats")},FG={HDB:en.join(uh.HDB,qA),CUSTOM_FUNCTIONS:en.join(uh.CUSTOM_FUNCTIONS,kA)},qG={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:en.join(Ws,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:en.join(Ws,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:en.join(Ws,"launchServiceScripts/launchUpdateNodes4-0-0.js")},kG={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},VA="support@harperdb.io",VG="customer-success@harperdb.io",$A=1,$G=4141,YA="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",YG="https://www.harperdb.io/product",KG=`For support, please submit a request at ${YA} or contact ${VA}`,KA=`For license support, please contact ${VG}`,WG="None of the specified records were found.",QG="hash attribute not found",zG=`Your current license only supports ${$A} role. ${KA}`,JG="Your current license only supports 3 connections to a node.",XG="127.0.0.1",jG=1,ZG=/^\.$/,eF=/^\.\.$/,tF="U+002E",rF=/\//g,nF="U+002F",sF=/U\+002F/g,iF=/^U\+002E$/,oF=/^U\+002EU\+002E$/,aF="d",cF=999999,uF="*",lF="--max-old-space-size=",_F="system",dF="__hdb_hash",fF=".harperdb",EF=".hdb",hF="keys",mF="hdb_boot_properties.file",pF=".updateConfig.json",SF="SIGTSTP",TF=24,gF=6e4,RF=448,AF="blob",OF="trash",bF="database",yF="schema",NF="transactions",IF=".count",wF="id",CF="PROCESS_NAME",WA={SETTINGS_PATH_KEY:"settings_path"},QA=require("lodash"),DF={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",OPERATIONSAPI_NETWORK_PORT:"OPERATIONSAPI_NETWORK_PORT",CLUSTERING_NODENAME:"CLUSTERING_NODENAME",CLUSTERING_ENABLED:"CLUSTERING_ENABLED",HDB_CONFIG:"HDB_CONFIG",OPERATIONSAPI_NETWORK_SECUREPORT:"OPERATIONSAPI_NETWORK_SECUREPORT",CLUSTERING_PORT:"CLUSTERING_PORT",HDB_ROOT:"HDB_ROOT",SERVER_PORT:"SERVER_PORT",NODE_NAME:"NODE_NAME",CLUSTERING:"CLUSTERING"},LF={HDB_PATH_KEY:"HDB_INTERNAL_PATH",HDB_AUTH_HEADER:"hdb_auth_header",HDB_USER_DATA_KEY:"hdb_user",CHUNK_SIZE:1e3,MAX_CHARACTER_SIZE:250},MF={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},UF={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"},PF={JOB_TABLE_HASH_ATTRIBUTE:"id",NODE_TABLE_HASH_ATTRIBUTE:"name",ATTRIBUTE_TABLE_HASH_ATTRIBUTE:"id",LICENSE_TABLE_HASH_ATTRIBUTE:"license_key",ROLE_TABLE_HASH_ATTRIBUTE:"id",SCHEMA_TABLE_HASH_ATTRIBUTE:"name",TABLE_TABLE_HASH_ATTRIBUTE:"id",USER_TABLE_HASH_ATTRIBUTE:"username",INFO_TABLE_ATTRIBUTE:"info_id"},yr="hdb_internal:",vF={CREATE_SCHEMA:yr+"create_schema",CREATE_TABLE:yr+"create_table",CREATE_ATTRIBUTE:yr+"create_attribute",ADD_USER:yr+"add_user",ALTER_USER:yr+"alter_user",DROP_USER:yr+"drop_user",HDB_NODES:yr+"hdb_nodes",HDB_USERS:yr+"hdb_users",HDB_WORKERS:yr+"hdb_workers",CATCHUP:yr+"catchup",SCHEMA_CATCHUP:yr+"schema_catchup",WORKER_ROOM:yr+"cluster_workers"},BF={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"},HF="060493.ks",xF=".license",GF={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},Z={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"},FF={CSV:".csv",JSON:".json"},qF={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},kF={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},tc={};tc[Z.INSERT]=Z.INSERT;tc[Z.UPDATE]=Z.UPDATE;tc[Z.UPSERT]=Z.UPSERT;tc[Z.DELETE]=Z.DELETE;var xe=Object.create(null);xe[Z.DESCRIBE_ALL]=Z.DESCRIBE_ALL;xe[Z.DESCRIBE_TABLE]=Z.DESCRIBE_TABLE;xe[Z.DESCRIBE_SCHEMA]=Z.DESCRIBE_SCHEMA;xe[Z.READ_LOG]=Z.READ_LOG;xe[Z.ADD_NODE]=Z.ADD_NODE;xe[Z.LIST_USERS]=Z.LIST_USERS;xe[Z.LIST_ROLES]=Z.LIST_ROLES;xe[Z.USER_INFO]=Z.USER_INFO;xe[Z.SQL]=Z.SQL;xe[Z.GET_JOB]=Z.GET_JOB;xe[Z.SEARCH_JOBS_BY_START_DATE]=Z.SEARCH_JOBS_BY_START_DATE;xe[Z.DELETE_FILES_BEFORE]=Z.DELETE_FILES_BEFORE;xe[Z.EXPORT_LOCAL]=Z.EXPORT_LOCAL;xe[Z.EXPORT_TO_S3]=Z.EXPORT_TO_S3;xe[Z.CLUSTER_STATUS]=Z.CLUSTER_STATUS;xe[Z.REMOVE_NODE]=Z.REMOVE_NODE;xe[Z.RESTART]=Z.RESTART;xe[Z.CUSTOM_FUNCTIONS_STATUS]=Z.CUSTOM_FUNCTIONS_STATUS;xe[Z.GET_CUSTOM_FUNCTIONS]=Z.GET_CUSTOM_FUNCTIONS;xe[Z.GET_CUSTOM_FUNCTION]=Z.GET_CUSTOM_FUNCTION;xe[Z.SET_CUSTOM_FUNCTION]=Z.SET_CUSTOM_FUNCTION;xe[Z.DROP_CUSTOM_FUNCTION]=Z.DROP_CUSTOM_FUNCTION;xe[Z.ADD_CUSTOM_FUNCTION_PROJECT]=Z.ADD_CUSTOM_FUNCTION_PROJECT;xe[Z.DROP_CUSTOM_FUNCTION_PROJECT]=Z.DROP_CUSTOM_FUNCTION_PROJECT;xe[Z.PACKAGE_CUSTOM_FUNCTION_PROJECT]=Z.PACKAGE_CUSTOM_FUNCTION_PROJECT;xe[Z.DEPLOY_CUSTOM_FUNCTION_PROJECT]=Z.DEPLOY_CUSTOM_FUNCTION_PROJECT;var VF={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"},$F={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},zA={HDB_ROOT_KEY:"HDB_ROOT",SERVER_PORT_KEY:"SERVER_PORT",CERT_KEY:"CERTIFICATE",PRIVATE_KEY_KEY:"PRIVATE_KEY",HTTP_SECURE_ENABLED_KEY:"HTTPS_ON",CORS_ENABLED_KEY:"CORS_ON",CORS_WHITELIST_KEY:"CORS_WHITELIST",LOG_LEVEL_KEY:"LOG_LEVEL",LOGGER_KEY:"LOGGER",LOG_PATH_KEY:"LOG_PATH",LOG_ROTATE:"LOG_ROTATE",LOG_ROTATE_MAX_SIZE:"LOG_ROTATE_MAX_SIZE",LOG_ROTATE_RETAIN:"LOG_ROTATE_RETAIN",LOG_ROTATE_COMPRESS:"LOG_ROTATE_COMPRESS",LOG_ROTATE_DATE_FORMAT:"LOG_ROTATE_DATE_FORMAT",LOG_ROTATE_ROTATE_MODULE:"LOG_ROTATE_ROTATE_MODULE",LOG_ROTATE_WORKER_INTERVAL:"LOG_ROTATE_WORKER_INTERVAL",LOG_ROTATE_ROTATE_INTERVAL:"LOG_ROTATE_ROTATE_INTERVAL",LOG_ROTATE_TIMEZONE:"LOG_ROTATE_TIMEZONE",LOG_DAILY_ROTATE_KEY:"LOG_DAILY_ROTATE",LOG_MAX_DAILY_FILES_KEY:"LOG_MAX_DAILY_FILES",PROPS_ENV_KEY:"NODE_ENV",SETTINGS_PATH_KEY:"settings_path",CLUSTERING_PORT_KEY:"CLUSTERING_PORT",CLUSTERING_NODE_NAME_KEY:"NODE_NAME",CLUSTERING_ENABLED_KEY:"CLUSTERING",ALLOW_SELF_SIGNED_SSL_CERTS:"ALLOW_SELF_SIGNED_SSL_CERTS",MAX_HDB_PROCESSES:"MAX_HDB_PROCESSES",INSTALL_USER:"install_user",CLUSTERING_USER_KEY:"CLUSTERING_USER",MAX_CLUSTERING_PROCESSES:"MAX_CLUSTERING_PROCESSES",SERVER_TIMEOUT_KEY:"SERVER_TIMEOUT_MS",SERVER_KEEP_ALIVE_TIMEOUT_KEY:"SERVER_KEEP_ALIVE_TIMEOUT",SERVER_HEADERS_TIMEOUT_KEY:"SERVER_HEADERS_TIMEOUT",DISABLE_TRANSACTION_LOG_KEY:"DISABLE_TRANSACTION_LOG",OPERATION_TOKEN_TIMEOUT_KEY:"OPERATION_TOKEN_TIMEOUT",REFRESH_TOKEN_TIMEOUT_KEY:"REFRESH_TOKEN_TIMEOUT",CUSTOM_FUNCTIONS_ENABLED_KEY:"CUSTOM_FUNCTIONS",CUSTOM_FUNCTIONS_PORT_KEY:"CUSTOM_FUNCTIONS_PORT",CUSTOM_FUNCTIONS_DIRECTORY_KEY:"CUSTOM_FUNCTIONS_DIRECTORY",MAX_CUSTOM_FUNCTION_PROCESSES:"MAX_CUSTOM_FUNCTION_PROCESSES",LOG_TO_FILE:"LOG_TO_FILE",LOG_TO_STDSTREAMS:"LOG_TO_STDSTREAMS",RUN_IN_FOREGROUND:"RUN_IN_FOREGROUND",LOCAL_STUDIO_ON:"LOCAL_STUDIO_ON",STORAGE_WRITE_ASYNC:"STORAGE_WRITE_ASYNC"},YF=QA.invert(zA),KF={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"},w={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_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",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",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_PATH:"storage_path",STORAGE_AUDIT_PATH:"storage_audit_path",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"},JA={settings_path:WA.SETTINGS_PATH_KEY,hdb_root_key:w.ROOTPATH,hdb_root:w.ROOTPATH,rootpath:w.ROOTPATH,server_port_key:w.OPERATIONSAPI_NETWORK_PORT,server_port:w.OPERATIONSAPI_NETWORK_PORT,cert_key:w.TLS_CERTIFICATE,certificate:w.TLS_CERTIFICATE,private_key_key:w.TLS_PRIVATEKEY,private_key:w.TLS_PRIVATEKEY,http_secure_enabled_key:w.OPERATIONSAPI_NETWORK_HTTPS,https_on:w.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:w.OPERATIONSAPI_NETWORK_CORS,cors_on:w.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:w.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:w.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:w.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:w.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:w.LOGGING_LEVEL,log_level:w.LOGGING_LEVEL,log_path_key:w.LOGGING_ROOT,log_path:w.LOGGING_ROOT,clustering_node_name_key:w.CLUSTERING_NODENAME,node_name:w.CLUSTERING_NODENAME,clustering_enabled_key:w.CLUSTERING_ENABLED,clustering:w.CLUSTERING_ENABLED,max_http_threads:w.THREADS_COUNT,max_hdb_processes:w.THREADS_COUNT,server_timeout_key:w.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:w.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:w.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:w.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:w.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:w.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:w.LOGGING_AUDITLOG,disable_transaction_log:w.LOGGING_AUDITLOG,operation_token_timeout_key:w.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:w.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:w.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:w.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:w.HTTP_PORT,custom_functions_port:w.HTTP_PORT,custom_functions_directory_key:w.COMPONENTSROOT,custom_functions_directory:w.COMPONENTSROOT,max_custom_function_processes:w.THREADS_COUNT,log_to_file:w.LOGGING_FILE,log_to_stdstreams:w.LOGGING_STDSTREAMS,local_studio_on:w.LOCALSTUDIO_ENABLED,clustering_port:w.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:w.CLUSTERING_USER,clustering_enabled:w.CLUSTERING_ENABLED,clustering_hubserver_cluster_name:w.CLUSTERING_HUBSERVER_CLUSTER_NAME,clustering_hubserver_cluster_network_port:w.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_hubserver_cluster_network_routes:w.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,clustering_hubserver_leafnodes_network_port:w.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT,clustering_hubserver_network_port:w.CLUSTERING_HUBSERVER_NETWORK_PORT,clustering_leafserver_network_port:w.CLUSTERING_LEAFSERVER_NETWORK_PORT,clustering_leafserver_network_routes:w.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,clustering_leafserver_streams_maxage:w.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE,clustering_leafserver_streams_maxbytes:w.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES,clustering_leafserver_streams_maxconsumemsgs:w.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS,clustering_leafserver_streams_maxingestthreads:w.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS,clustering_leafserver_streams_maxmsgs:w.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS,clustering_leafserver_streams_path:w.CLUSTERING_LEAFSERVER_STREAMS_PATH,clustering_nodename:w.CLUSTERING_NODENAME,clustering_tls_certificate:w.CLUSTERING_TLS_CERTIFICATE,clustering_tls_privatekey:w.CLUSTERING_TLS_PRIVATEKEY,clustering_tls_certificateauthority:w.CLUSTERING_TLS_CERT_AUTH,clustering_tls_insecure:w.CLUSTERING_TLS_INSECURE,clustering_tls_verify:w.CLUSTERING_TLS_VERIFY,clustering_loglevel:w.CLUSTERING_LOGLEVEL,clustering_republishmessages:w.CLUSTERING_REPUBLISHMESSAGES,clustering_databaselevel:w.CLUSTERING_DATABASELEVEL,customfunctions_network_port:w.HTTP_PORT,customfunctions_tls_certificate:w.TLS_CERTIFICATE,customfunctions_network_cors:w.HTTP_CORS,customfunctions_network_corsaccesslist:w.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:w.HTTP_HEADERSTIMEOUT,customfunctions_network_https:w.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:w.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:w.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:w.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:w.HTTP_TIMEOUT,http_threads:w.THREADS_COUNT,threads:w.THREADS_COUNT,threads_count:w.THREADS_COUNT,threads_debug:w.THREADS_DEBUG,threads_debug_startingport:w.THREADS_DEBUG_STARTINGPORT,threads_debug_port:w.THREADS_DEBUG_PORT,threads_debug_host:w.THREADS_DEBUG_HOST,threads_debug_waitfordebugger:w.THREADS_DEBUG_WAITFORDEBUGGER,threads_maxheapmemory:w.THREADS_MAXHEAPMEMORY,http_session_affinity:w.HTTP_SESSIONAFFINITY,http_compressionthreshold:w.HTTP_COMPRESSIONTHRESHOLD,http_cors:w.HTTP_CORS,http_corsaccesslist:w.HTTP_CORSACCESSLIST,http_headerstimeout:w.HTTP_HEADERSTIMEOUT,http_keepalivetimeout:w.HTTP_KEEPALIVETIMEOUT,http_timeout:w.HTTP_TIMEOUT,http_port:w.HTTP_PORT,http_secureport:w.HTTP_SECUREPORT,http_mtls:w.HTTP_MTLS,http_mtls_user:w.HTTP_MTLS_USER,http_mtls_required:w.HTTP_MTLS_REQUIRED,customfunctions_processes:w.THREADS_COUNT,customfunctions_root:w.COMPONENTSROOT,localstudio_enabled:w.LOCALSTUDIO_ENABLED,logging_file:w.LOGGING_FILE,logging_level:w.LOGGING_LEVEL,logging_root:w.LOGGING_ROOT,logging_rotation_enabled:w.LOGGING_ROTATION_ENABLED,logging_rotation_compress:w.LOGGING_ROTATION_COMPRESS,logging_rotation_interval:w.LOGGING_ROTATION_INTERVAL,logging_rotation_maxsize:w.LOGGING_ROTATION_MAXSIZE,logging_rotation_path:w.LOGGING_ROTATION_PATH,logging_stdstreams:w.LOGGING_STDSTREAMS,logging_auditlog:w.LOGGING_AUDITLOG,logging_auditretention:w.LOGGING_AUDITRETENTION,logging_auditauthevents_logfailed:w.LOGGING_AUDITAUTHEVENTS_LOGFAILED,logging_auditauthevents_logsuccessful:w.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL,operationsapi_authentication_operationtokentimeout:w.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operationsapi_authentication_refreshtokentimeout:w.AUTHENTICATION_REFRESHTOKENTIMEOUT,operationsapi_network_cors:w.OPERATIONSAPI_NETWORK_CORS,operationsapi_network_corsaccesslist:w.OPERATIONSAPI_NETWORK_CORSACCESSLIST,operationsapi_network_headerstimeout:w.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,operationsapi_network_https:w.OPERATIONSAPI_NETWORK_HTTPS,operationsapi_network_keepalivetimeout:w.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,operationsapi_network_port:w.OPERATIONSAPI_NETWORK_PORT,operationsapi_network_domainsocket:w.OPERATIONSAPI_NETWORK_DOMAINSOCKET,operationsapi_network_secureport:w.OPERATIONSAPI_NETWORK_SECUREPORT,operationsapi_tls_certificate:w.OPERATIONSAPI_TLS_CERTIFICATE,operationsapi_tls_privatekey:w.OPERATIONSAPI_TLS_PRIVATEKEY,operationsapi_tls_certificateauthority:w.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY,operationsapi_network_timeout:w.OPERATIONSAPI_NETWORK_TIMEOUT,operationsapi_root:w.ROOTPATH,databases:w.DATABASES,storage_path:w.STORAGE_PATH,ignorescripts:w.IGNORE_SCRIPTS,mqtt_network_port:w.MQTT_NETWORK_PORT,mqtt_websocket:w.MQTT_WEBSOCKET,mqtt_network_secureport:w.MQTT_NETWORK_SECUREPORT,mqtt_network_mtls:w.MQTT_NETWORK_MTLS,mqtt_network_mtls_certificateAuthority:w.MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY,mqtt_network_mtls_user:w.MQTT_NETWORK_MTLS_USER,mqtt_network_mtls_required:w.MQTT_NETWORK_MTLS_REQUIRED,mqtt_requireauthentication:w.MQTT_REQUIREAUTHENTICATION,analytics_aggregatePeriod:w.ANALYTICS_AGGREGATEPERIOD,authentication_authorizelocal:w.AUTHENTICATION_AUTHORIZELOCAL,authentication_cachettl:w.AUTHENTICATION_CACHETTL,authentication_enablesessions:w.AUTHENTICATION_ENABLESESSIONS,authentication_operationtokentimeout:w.AUTHENTICATION_OPERATIONTOKENTIMEOUT,authentication_refreshtokentimeout:w.AUTHENTICATION_REFRESHTOKENTIMEOUT,componentsroot:w.COMPONENTSROOT,tls_certificate:w.TLS_CERTIFICATE,tls_privatekey:w.TLS_PRIVATEKEY,tls_certificateauthority:w.TLS_CERTIFICATEAUTHORITY,tls_ciphers:w.TLS_CIPHERS};for(let e in w){let t=w[e];JA[t.toLowerCase()]=t}var WF={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},QF={csv_file_load:"csv_file_load",csv_data_load:Z.CSV_DATA_LOAD,csv_url_load:Z.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"},zF={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"},JF={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},XF={VERSION_DEFAULT:"2.2.0"},jF={DEVELOPMENT:8192,DEFAULT:512},ZF={IDENTIFY:"identify",AUTHENTICATE:"authenticate",AUTHENTICATE_OK:"authenticated",AUTHENTICATE_FAIL:"authenticate_fail",CONNECTION:"connection",CONNECT:"connect",CATCHUP_REQUEST:"catchup_request",CATCHUP_RESPONSE:"catchup",CONFIRM_MSG:"confirm_msg",ERROR:"error",DISCONNECT:"disconnect",SCHEMA_UPDATE_REQ:"schema_update_request",SCHEMA_UPDATE_RES:"schema_update_response",RECONNECT_ATTEMPT:"reconnect_attempt",CONNECT_ERROR:"connect_error",MESSAGE:"msg",VERSION_MISMATCH:"version_mismatch",DIRECTION_CHANGE:"direction_change"},eq={1e3:"SUCCESSFUL_SHUTDOWN",1001:"CLOSE_GOING_AWAY",1002:"CLOSE_PROTOCOL_ERROR",1003:"CLOSE_UNSUPPORTED",1005:"CLOSE_NO_STATUS",1006:"CLOSE_ABNORMAL",1007:"UNSUPPORTED_PAYLOAD",1008:"POLICY_VIOLATION",1009:"CLOSE_TOO_LARGE",1010:"MANDATORY_EXTENSION",1011:"SERVER_ERROR",1012:"SERVICE_RESTART",1013:"SERVER_BUSY",1014:"BAD_GATEWAY",1015:"HANDSHAKE_FAIL",4141:"LICENSE_LIMIT_REACHED"},tq={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST"},XA={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},rq=Symbol("metadata"),nq="__clustering__",sq=Object.values(XA),iq=15984864e5,jA={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},oq=QA.invert(jA),aq={GET_CLUSTER_STATUS:"GET_CLUSTER_STATUS",CLUSTER_STATUS_RESPONSE:"CLUSTER_STATUS_RESPONSE",ERROR_RESPONSE:"ERROR",ADD_USER:"ADD_USER",ALTER_USER:"ALTER_USER",DROP_USER:"DROP_USER",HDB_OPERATION:"HDB_OPERATION",ADD_NODE:"ADD_NODE",UPDATE_NODE:"UPDATE_NODE",REMOVE_NODE:"REMOVE_NODE",HDB_USERS_MSG:"HDB_USERS_MSG",HDB_WORKERS:"HDB_WORKERS",HDB_TRANSACTION:"HDB_TRANSACTION"},cq=111,uq=`\r
|
|
2
|
+
`,lq={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},_q=["*","%"],dq="unauthorized_access",fq="func_val",Eq={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},hq={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},mq={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",NATS_CONSUMER_UPDATE:"nats_consumer_update"},pq={HDB_CORE:"hdb_core",CUSTOM_FUNCTIONS:"custom_functions"},Sq={HTTP:"http"},Tq={STOPPED:"stopped",ONLINE:"online"},gq="3.x.x",Rq={SUCCESS:"success",FAILURE:"failure"},Aq={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"};ZA.exports={LOCAL_HARPERDB_OPERATIONS:xe,HDB_SUPPORT_ADDRESS:VA,HDB_SUPPORT_URL:YA,HDB_PRICING_URL:YG,SUPPORT_HELP_MSG:KG,LICENSE_HELP_MSG:KA,HDB_PROC_NAME:qA,HDB_PROC_DESCRIPTOR:lh,CLUSTERING_LEAF_PROC_DESCRIPTOR:xl,CLUSTERING_HUB_PROC_DESCRIPTOR:Hl,SYSTEM_SCHEMA_NAME:_F,HASH_FOLDER_NAME:dF,HDB_HOME_DIR_NAME:fF,UPDATE_FILE_NAME:pF,LICENSE_KEY_DIR_NAME:hF,BOOT_PROPS_FILE_NAME:mF,JOB_TYPE_ENUM:QF,JOB_STATUS_ENUM:GF,SYSTEM_TABLE_NAMES:UF,SYSTEM_TABLE_HASH_ATTRIBUTES:PF,OPERATIONS_ENUM:Z,VALID_S3_FILE_TYPES:FF,S3_BUCKET_AUTH_KEYS:qF,VALID_SQL_OPS_ENUM:kF,GEO_CONVERSION_ENUM:$F,HDB_SETTINGS_NAMES:zA,HDB_SETTINGS_NAMES_REVERSE_LOOKUP:YF,SERVICE_ACTIONS_ENUM:VF,CLUSTER_MESSAGE_TYPE_ENUM:zF,CLUSTER_CONNECTION_DIRECTION_ENUM:JF,CLUSTER_EVENTS_DEFS_ENUM:ZF,PERIOD_REGEX:ZG,DOUBLE_PERIOD_REGEX:eF,UNICODE_PERIOD:tF,FORWARD_SLASH_REGEX:rF,UNICODE_FORWARD_SLASH:nF,ESCAPED_FORWARD_SLASH_REGEX:sF,ESCAPED_PERIOD_REGEX:iF,ESCAPED_DOUBLE_PERIOD_REGEX:oF,REG_KEY_FILE_NAME:HF,RESTART_TIMEOUT_MS:gF,HDB_FILE_PERMISSIONS:RF,DATABASES_DIR_NAME:bF,LEGACY_DATABASES_DIR_NAME:yF,TRANSACTIONS_DIR_NAME:NF,LIMIT_COUNT_NAME:IF,ID_ATTRIBUTE_STRING:wF,INSERT_MODULE_ENUM:LF,UPGRADE_JSON_FIELD_NAMES_ENUM:MF,RESTART_CODE:SF,RESTART_CODE_NUM:TF,CLUSTER_OPERATIONS:tc,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:BF,HDB_INTERNAL_SC_CHANNEL_PREFIX:yr,INTERNAL_SC_CHANNELS:vF,CLUSTERING_MESSAGE_TYPES:aq,HDB_FILE_SUFFIX:EF,BLOB_FOLDER_NAME:AF,HDB_TRASH_DIR:OF,ORIGINATOR_SET_VALUE:cq,LICENSE_VALUES:XF,RAM_ALLOCATION_ENUM:jF,TIME_STAMP_NAMES_ENUM:XA,TIME_STAMP_NAMES:sq,PERMS_UPDATE_RELEASE_TIMESTAMP:iq,SEARCH_NOT_FOUND_MESSAGE:WG,SEARCH_ATTRIBUTE_NOT_FOUND:QG,LICENSE_ROLE_DENIED_RESPONSE:zG,LICENSE_MAX_CONNS_REACHED:JG,BASIC_LICENSE_MAX_NON_CU_ROLES:$A,BASIC_LICENSE_CLUSTER_CONNECTION_LIMIT_WS_ERROR_CODE:$G,VALUE_SEARCH_COMPARATORS:jA,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:oq,LICENSE_FILE_NAME:xF,WEBSOCKET_CLOSE_CODE_DESCRIPTION_LOOKUP:eq,NEW_LINE:uq,BASIC_LICENSE_MAX_CLUSTER_USER_ROLES:jG,MOMENT_DAYS_TAG:aF,API_TURNOVER_SEC:cF,LOOPBACK:XG,CODE_EXTENSION:Bl,WILDCARD_SEARCH_VALUE:uF,NODE_ERROR_CODES:tq,JAVASCRIPT_EXTENSION:FA,PERMS_CRUD_ENUM:lq,UNAUTHORIZED_PERMISSION_NAME:dq,SEARCH_WILDCARDS:_q,FUNC_VAL:fq,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:Eq,JWT_ENUM:hq,CLUSTERING_FLAG:nq,ITC_EVENT_TYPES:mq,CUSTOM_FUNCTION_PROC_NAME:kA,CUSTOM_FUNCTION_PROC_DESCRIPTOR:vl,SERVICES:pq,THREAD_TYPES:Sq,MEM_SETTING_KEY:lF,HDB_RESTART_SCRIPT:CG,PROCESS_DESCRIPTORS:vG,SERVICE_SERVERS:FG,SERVICE_SERVERS_CWD:uh,PROCESS_DESCRIPTORS_VALIDATE:xG,LAUNCH_SERVICE_SCRIPTS:qG,LOG_LEVELS:HG,PROCESS_NAME_ENV_PROP:CF,LOG_NAMES:BG,PM2_PROCESS_STATUSES:Tq,CONFIG_PARAM_MAP:JA,CONFIG_PARAMS:w,HDB_CONFIG_FILE:NG,HDB_DEFAULT_CONFIG_FILE:IG,ROLE_TYPES_ENUM:kG,BOOT_PROP_PARAMS:WA,INSTALL_PROMPTS:DF,HDB_ROOT_DIR_NAME:wG,CLUSTERING_PROCESSES:GG,FOREGROUND_PID_FILE:MG,PACKAGE_ROOT:Ws,PRE_4_0_0_VERSION:gq,DATABASES_PARAM_CONFIG:WF,METADATA_PROPERTY:rq,AUTH_AUDIT_STATUS:Rq,AUTH_AUDIT_TYPES:Aq,HDB_PID_FILE:UG,DEFAULT_DATABASE_NAME:PG,LEGACY_CONFIG_PARAMS:KF};GA()});var _h=g((Qie,rO)=>{"use strict";var eO=require("minimist");rO.exports=Oq;function Oq(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=tO(process.env),n=tO(eO(process.argv))):(r=process.env,n=eO(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(Oq,"assignCMDENVVariables");function tO(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(tO,"objKeysToLowerCase")});var K=g((Jie,Sh)=>{"use strict";var wi=require("fs-extra"),{workerData:bq,threadId:yq}=require("worker_threads"),Es=require("path"),iO=require("yaml"),oO=require("properties-reader"),gt=U(),nO=_h(),Nq=require("os"),{PACKAGE_ROOT:fh}=U(),{_assignPackageExport:Iq}=require("../../index"),nc={};for(let e in console)nc[e]||(nc[e]=console[e]);var rr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},aO={STDOUT:"stdOut",STDERR:"stdErr"},wq=Es.join(fh,"logs"),Cq=Es.join(fh,"config/yaml/",gt.HDB_DEFAULT_CONFIG_FILE),Dq=1e4,ds,$n,tr,Gl,Fl,sc,Po,rc;rc===void 0&&cO();Sh.exports={notify:_O,fatal:dO,error:ic,warn:ph,info:ql,debug:mh,trace:hh,setLogLevel:Hq,log_level:tr,loggerWithTag:Lq,suppressLogging:Mq,initLogSettings:cO,setupConsoleLogging:uO,logCustomLevel:vq,closeLogFile:Eh,getLogFilePath:()=>sc,OUTPUTS:aO,AuthAuditLog:Fq};Iq("logger",Sh.exports);function cO(e=!1){try{if(rc===void 0||e){Eh();let t=Bq(),r=nO(["ROOTPATH"]);try{rc=oO(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!wi.pathExistsSync(Es.join(r.ROOTPATH,gt.HDB_CONFIG_FILE)))throw n}({level:tr,config_log_path:Fl,to_file:ds,to_stream:$n}=xq(r.ROOTPATH?Es.join(r.ROOTPATH,gt.HDB_CONFIG_FILE):rc.get("settings_path"))),Gl=gt.LOG_NAMES.HDB,sc=Es.join(Fl,Gl)}}catch(t){if(rc=void 0,t.code===gt.NODE_ERROR_CODES.ENOENT){let r=nO(Object.keys(gt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=gt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let u=r[o];if(c===gt.CONFIG_PARAMS.LOGGING_LEVEL){tr=u;continue}if(c===gt.CONFIG_PARAMS.LOGGING_STDSTREAMS){$n=u;continue}c===gt.CONFIG_PARAMS.LOGGING_FILE&&(ds=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=Gq();ds=ds===void 0?s:ds,ds=sO(ds),$n=$n===void 0?i:$n,$n=sO($n),tr=tr===void 0?n:tr,Fl=wq,Gl=gt.LOG_NAMES.INSTALL,sc=Es.join(Fl,Gl);return}throw ic("Error initializing log settings"),ic(t),t}process.env.DEV_MODE&&($n=!0),uO()}a(cO,"initLogSettings");var dh=!0;function uO(){Uo("error",ic),Uo("warn",ph),Uo("log",ql),Uo("info",ql),Uo("debug",mh),Uo("trace",hh)}a(uO,"setupConsoleLogging");function Uo(e,t){console[e]=function(...r){if(dh&&t(...r),!/PM2 log:|App \[/.test(r[0]))return nc[e](...r)}}a(Uo,"logConsole");function Lq(e){let t={tagName:e.replace(/ /g,"-")};return{notify:r(_O),fatal:r(dO),error:r(ic),warn:r(ph),info:r(ql),debug:r(mh),trace:r(hh)};function r(n){return function(...s){return n(t,...s)}}}a(Lq,"loggerWithTag");function Mq(e){try{dh=!1,e()}finally{dh=!0}}a(Mq,"suppressLogging");var Uq=bq?.name?.replace(/ /g,"-")||"main";function hs(e,t){let r=new Date(Date.now()).toISOString(),n="",s=t.length,i=s-1,o=[e],c=0,u;for(typeof t[0]=="object"&&(t[0]?.tagName?(o.push(t[0]?.tagName),c++):t[0]?.serviceName&&(u=t[0]?.serviceName,c++)),o.unshift(u||Uq+"/"+yq);c<s;c++){let _=t[c];_ instanceof Error&&_.stack?n+=_.stack:typeof _=="object"?n+=JSON.stringify(_):n+=_,c<i&&(n+=" ")}return`${r} [${o.join("] [")}]: ${n}
|
|
3
|
+
`}a(hs,"createLogRecord");function oc(e){ds&&lO(e),$n&&process.stdout.write(e)}a(oc,"logStdOut");function kl(e){ds&&lO(e),$n&&process.stderr.write(e)}a(kl,"logStdErr");function lO(e){Pq(),Po?wi.appendFileSync(Po,e):nc.log(e)}a(lO,"logToFile");function Eh(){try{wi.closeSync(Po)}catch{}Po=null}a(Eh,"closeLogFile");function Pq(){if(!Po){try{if(!sc)debugger;Po=wi.openSync(sc,"a")}catch(e){nc.error(e)}setTimeout(()=>{Eh()},Dq).unref()}}a(Pq,"openLogFile");function ql(...e){rr[tr]<=rr.info&&oc(hs("info",e))}a(ql,"info");function hh(...e){rr[tr]<=rr.trace&&oc(hs("trace",e))}a(hh,"trace");function ic(...e){rr[tr]<=rr.error&&kl(hs("error",e))}a(ic,"error");function mh(...e){rr[tr]<=rr.debug&&oc(hs("debug",e))}a(mh,"debug");function _O(...e){rr[tr]<=rr.notify&&oc(hs("notify",e))}a(_O,"notify");function dO(...e){rr[tr]<=rr.fatal&&kl(hs("fatal",e))}a(dO,"fatal");function ph(...e){rr[tr]<=rr.warn&&kl(hs("warn",e))}a(ph,"warn");function vq(e,t,...r){t===aO.STDERR?kl(hs(e,r)):oc(hs(e,r))}a(vq,"logCustomLevel");function Bq(){let e;try{e=Nq.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=Es.join(e,gt.HDB_HOME_DIR_NAME,gt.BOOT_PROPS_FILE_NAME);return wi.existsSync(t)||(t=Es.join(fh,"utility/hdb_boot_properties.file")),t}a(Bq,"getPropsFilePath");function Hq(e){tr=e}a(Hq,"setLogLevel");function sO(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(sO,"autoCastBoolean");function xq(e){try{if(e.includes("config/settings.js")){let o=oO(e);return{level:o.get(gt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:Es.dirname(o.get(gt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(gt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(gt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=iO.parseDocument(wi.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===gt.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(xq,"getLogConfig");function Gq(){try{let e=iO.parseDocument(wi.readFileSync(Cq,"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(Gq,"getDefaultConfig");function Fq(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(Fq,"AuthAuditLog")});var EO=g((jie,fO)=>{"use strict";var qq=require("util"),kq=require("path"),Vq=require("child_process"),$q=qq.promisify(Vq.execFile),Yq=1e3*1e3*10;fO.exports={findPs:Kq};async function Kq(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await $q("ps",["wwxo",`pid,${r}`],{maxBuffer:Yq});for(let s of n.trim().split(`
|
|
4
|
+
`).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:kq.basename(n.comm),cmd:n.args,ppid:Number.parseInt(n.ppid,10),uid:Number.parseInt(n.uid,10),cpu:Number.parseFloat(n["%cpu"]),memory:Number.parseFloat(n["%mem"])}))}a(Kq,"findPs")});var _t=g((eoe,mO)=>{"use strict";var Wq="__dbis__",Qq="__txns__",zq="__environment_name__",Jq="__dbi_defintion__",Xq={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"},jq=["__createdtime__","__updatedtime__"],Zq="\uFFFF",hO={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},ek=Object.values(hO);mO.exports={AUDIT_STORE_NAME:Qq,INTERNAL_DBIS_NAME:Wq,DBI_DEFINITION_NAME:Jq,SEARCH_TYPES:Xq,TIMESTAMP_NAMES:jq,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:zq,TRANSACTIONS_DBI_NAMES_ENUM:hO,TRANSACTIONS_DBIS:ek,OVERFLOW_MARKER:Zq}});var Nr=g((toe,yO)=>{"use strict";var pO=U(),SO=_t(),TO={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},gO=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),RO={500:gO("There was an error processing your request."),400:"Invalid request"},tk=RO[TO.INTERNAL_SERVER_ERROR],rk={OP_NOT_SUPPORTED_FOR_FS:e=>`${e} is not available for this instance because it uses the File System data store.`,MISSING_VALUE:e=>`${e} is missing.`,INVALID_VALUE:e=>`${e} is invalid.`,NOT_FOUND:e=>`${e} not found.`},nk={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},sk={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:e=>`There was an error downloading '${e}'.`,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:e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,INVALID_FILE_EXT_ERR:e=>`Error selecting correct parser - valid file type not found in json - ${e}`,MAX_FILE_SIZE_ERR:(e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:e=>`There was an error downloading '${e}' from AWS.`,WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},ik={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 ${SO.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${SO.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"},ok={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${pO.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes.`,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 ${pO.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},AO={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"},ak={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:e=>`Operation '${e}' is restricted to 'super_user' roles`,OP_NOT_FOUND:e=>`Operation '${e}' 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:(e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,USER_HAS_NO_PERMS:e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},ck={ATTR_PERM_MISSING:(e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:(e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a 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:e=>`Invalid attribute '${e}' in 'attribute_permissions'`,INVALID_PERM_KEY:e=>`Invalid table permission key value '${e}'`,INVALID_ATTR_PERM_KEY:e=>`Invalid attribute permission key value '${e}'`,INVALID_ROLE_JSON_KEYS:e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,MISMATCHED_TABLE_ATTR_PERMS:e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,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:e=>`A role with name '${e}' already exists`,ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:e=>`Your role does not have permission to view database metadata for '${e}'`,SCHEMA_TABLE_PERM_ERROR:(e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:e=>`Value for '${e}' permission must be a boolean`,STRUCTURE_USER_ROLE_TYPE_ERROR:e=>`Value for '${e}' permission must be a boolean or Array`,SU_CU_ROLE_NO_PERMS_ALLOWED:e=>`Roles with '${e}' set to true cannot have other permissions set.`,SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:e=>`Missing table ${e.toUpperCase()} permission`,TABLE_PERM_NOT_BOOLEAN:e=>`Table ${e.toUpperCase()} permission must be a boolean`},uk={ATTR_NOT_FOUND:(e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,ATTR_EXISTS_ERR:(e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:e=>`Invalid table ${JSON.stringify(e)}`,SCHEMA_NOT_FOUND:e=>`database '${e}' does not exist`,SCHEMA_EXISTS_ERR:e=>`database '${e}' already exists`,TABLE_EXISTS_ERR:(e,t)=>`Table '${t}' already exists in '${e}'`,SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:(e,t)=>`Table '${e}.${t}' does not exist`,TABLE_REQUIRED_ERR:"table is required"},lk={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},_k={ALTER_USER_DUP_ROLES:e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,ALTER_USER_ROLE_NOT_FOUND:e=>`Update failed. Requested '${e}' role not found.`,DUP_ROLES_FOUND:e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,ROLE_NAME_NOT_FOUND:e=>`${e} role not found`,USER_ALREADY_EXISTS:e=>`User ${e} already exists`,USER_NOT_EXIST:e=>`User ${e} does not exist`},OO={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`},bO={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:e=>`ITC server received invalid event type: ${e}`},dk={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."},fk={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},Ek={...AO,...sk,...rk,...ak,...ck,...uk,...lk,..._k,...ok,...OO,...bO,...dk,...fk,...nk};yO.exports={CHECK_LOGS_WRAPPER:gO,HDB_ERROR_MSGS:Ek,DEFAULT_ERROR_MSGS:RO,DEFAULT_ERROR_RESP:tk,HTTP_STATUS_CODES:TO,LMDB_ERRORS_ENUM:ik,AUTHENTICATION_ERROR_MSGS:AO,VALIDATION_ERROR_MSGS:OO,ITC_ERRORS:bO}});var ne=g((noe,wO)=>{"use strict";var vo=Nr(),hk=K(),mk=U(),Vl=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,NO),this.statusCode=n||vo.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(vo.DEFAULT_ERROR_MSGS[n]?vo.DEFAULT_ERROR_MSGS[n]:vo.DEFAULT_ERROR_MSGS[vo.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&&hk[s](i)}},Th=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}},gh=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function NO(e,t,r,n=mk.LOG_LEVELS.ERROR,s=null,i=!1){if(IO(e))return e;let o=new Vl(e,t,r,n,s);return i&&delete o.stack,o}a(NO,"handleHDBError");function IO(e){return e.__proto__.constructor.name===Vl.name}a(IO,"isHDBError");wO.exports={isHDBError:IO,handleHDBError:NO,ClientError:Th,ServerError:gh,hdb_errors:vo}});var Qe=g((ioe,vO)=>{"use strict";var _c=U(),pk=z(),nr=re(),dc=require("path"),Sk=require("minimist"),CO=require("fs-extra"),DO=require("lodash");nr.initSync();var{CONFIG_PARAMS:Qs,DATABASES_PARAM_CONFIG:ac,SYSTEM_SCHEMA_NAME:$l}=_c,cc,uc,lc;function LO(){if(cc!==void 0)return cc;if(nr.getHdbBasePath()!==void 0)return cc=nr.get(Qs.STORAGE_PATH)||dc.join(nr.getHdbBasePath(),_c.DATABASES_DIR_NAME),cc}a(LO,"getBaseSchemaPath");function MO(){if(uc!==void 0)return uc;if(nr.getHdbBasePath()!==void 0)return uc=PO($l),uc}a(MO,"getSystemSchemaPath");function UO(){if(lc!==void 0)return lc;if(nr.getHdbBasePath()!==void 0)return lc=nr.get(_c.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||dc.join(nr.getHdbBasePath(),_c.TRANSACTIONS_DIR_NAME),lc}a(UO,"getTransactionAuditStoreBasePath");function Tk(e,t){let r=nr.get(Qs.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||dc.join(UO(),e.toString())}a(Tk,"getTransactionAuditStorePath");function PO(e,t){e=e.toString(),t=t&&t.toString();let r=nr.get(_c.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||dc.join(LO(),e)}a(PO,"getSchemaPath");function gk(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,Sk(process.argv));let n=r[Qs.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!pk.isObject(n))throw o;i=n}for(let o of i){let c=o[$l];if(!c)continue;let u=nr.get(Qs.DATABASES);u=u??{};let _=c?.tables?.[t]?.[ac.PATH];if(_)return DO.set(u,[$l,ac.TABLES,t,ac.PATH],_),nr.setProperty(Qs.DATABASES,u),_;let l=c?.[ac.PATH];if(l)return DO.set(u,[$l,ac.PATH],l),nr.setProperty(Qs.DATABASES,u),l}}let s=r[Qs.STORAGE_PATH.toUpperCase()];if(s){if(!CO.pathExistsSync(s))throw new Error(s+" does not exist");let i=dc.join(s,e);return CO.mkdirsSync(i),nr.setProperty(Qs.STORAGE_PATH,s),i}return MO()}a(gk,"initSystemSchemaPaths");function Rk(){cc=void 0,uc=void 0,lc=void 0}a(Rk,"resetPaths");vO.exports={getBaseSchemaPath:LO,getSystemSchemaPath:MO,getTransactionAuditStorePath:Tk,getTransactionAuditStoreBasePath:UO,getSchemaPath:PO,initSystemSchemaPaths:gk,resetPaths:Rk}});var Ir=g((uoe,FO)=>{"use strict";var Ak=Nr().LMDB_ERRORS_ENUM,aoe=require("lmdb"),Ok=_t(),coe=require("buffer").Buffer,{OVERFLOW_MARKER:BO,MAX_SEARCH_KEY_LENGTH:Yl}=Ok,HO=["number","string","symbol","boolean","bigint"];function bk(e){if(e=e?.primaryStore||e,!e)throw new Error(Ak.ENV_REQUIRED)}a(bk,"validateEnv");function yk(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(yk,"stringifyData");function Nk(e){return e instanceof Date?e.valueOf():e}a(Nk,"convertKeyValueToWrite");function Ik(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(HO.includes(typeof e))return e.length>Yl?[e.slice(0,Yl)+BO]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(HO.includes(typeof i))i.length>Yl?r.push(i.slice(0,Yl)+BO):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(Ik,"getIndexedValues");var Kl=0,xO=0;function GO(){xO=Date.now()-performance.now()}a(GO,"adjustStartTime");GO();var wk=6e4;setInterval(GO,wk).unref();function Ck(){let e=performance.now()+xO;return e>Kl?(Kl=e,e):(Kl+=488e-6,Kl)}a(Ck,"getNextMonotonicTime");FO.exports={validateEnv:bk,stringifyData:yk,convertKeyValueToWrite:Nk,getNextMonotonicTime:Ck,getIndexedValues:Ik}});var qO,Rn,Rh,fc=Re(()=>{qO=require("events"),Rn=class extends qO.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;[Symbol.asyncIterator](){let t=new Rh;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(){return this.queue?.shift()}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)}},Rh=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});var Ci={};$e(Ci,{server:()=>je});var kO,je,sr=Re(()=>{kO=require("../../index"),je={};(0,kO._assignPackageExport)("server",je)});var bh={};$e(bh,{loadGQLSchema:()=>Mk,start:()=>Oh,startOnMainThread:()=>Lk});function Oh({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:u,NamedTypeNode:_,StringValueNode:l}=await import("graphql"),d=o(new c(r.toString(),s)),f=new Map,E=[],h;for(let S of d.definitions)switch(S.kind){case u.OBJECT_TYPE_DEFINITION:let H=function(P){if(P.kind==="NonNullType"){let J=H(P.type);return J.nullable=!1,J}if(P.kind==="ListType")return{type:"array",elements:H(P.type)};let B={type:P.name?.value};return Object.defineProperty(B,"location",{value:P.loc.startToken}),B};a(H,"getProperty");let T=S.name.value,b=[],R={table:null,database:null,properties:b};f.set(T,R);for(let P of S.directives){if(P.name.value==="table"){for(let k of P.arguments)R[k.name.value]=k.value.value;R.schema&&(R.database=R.schema),R.table||(R.table=T),R.audit&&(R.audit=R.audit!=="false"),R.attributes=R.properties,E.push(R)}if(P.name.value==="sealed"&&(R.sealed=!0),P.name.value==="export"){R.export=!0;for(let k of P.arguments)k.name.value==="name"&&(R.export={name:k.value.value})}}let L=!1;for(let P of S.fields){let k=H(P.type);k.name=P.name.value,b.push(k);for(let B of P.directives)if(B.name.value==="primaryKey")L?console.warn("Can not define two attributes as a primary key"):(k.isPrimaryKey=!0,L=!0);else if(B.name.value==="indexed")k.indexed=!0;else if(B.name.value==="relationship"){let J={};for(let Q of B.arguments)J[Q.name.value]=Q.value.value;k.relationship=J}else if(B.name.value==="createdTime")k.assignCreatedTime=!0;else if(B.name.value==="updatedTime")k.assignUpdatedTime=!0;else if(B.name.value==="expiresAt")k.expiresAt=!0;else if(B.name.value==="allow"){let J=k.authorizedRoles=[];for(let Q of B.arguments)Q.name.value==="role"&&J.push(Q.value.value)}}R.type=T,T==="Query"&&(h=R)}function p(S){let T=f.get(S.type);T?(Object.defineProperty(S,"properties",{value:T.properties}),Object.defineProperty(S,"definition",{value:T})):S.type==="array"?p(S.elements):Dk.includes(S.type)||(0,VO.getWorkerIndex)()===0&&console.error(`The type ${S.type} is unknown at line ${S.location.line}, column ${S.location.column}, in ${s}`)}a(p,"connectPropertyType");for(let S of f.values())for(let T of S.properties)p(T);for(let S of E)S.tableClass=e(S),S.export&&(S.export.name===""?i.set((0,Ah.dirname)(n),S.tableClass):i.set((0,Ah.dirname)(n)+"/"+(S.export.name||S.type),S.tableClass))}}var Ah,VO,Dk,Lk,Mk,$O=Re(()=>{Ah=require("path");Ae();VO=x(Ze()),Dk=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];a(Oh,"start");Lk=Oh,Mk=Oh({ensureTable:at}).handleFile});async function Wl(e){return Uk?(Ec||(Ec=Pk(Bk)),(await(await Ec).import(e)).namespace):import(e)}async function Pk(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),Ec=new Compartment({console,Math,Date,fetch:vk,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,KO.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Gt,tables:wr,databases:et})}};let n=await(0,YO.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),Ec}function vk(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 Bk(){return{Resource:Gt,tables:wr}}var YO,KO,Uk,Ec,yh=Re(()=>{An();Ae();YO=require("fs/promises"),KO=require("path"),Uk=!1;a(Wl,"secureImport");a(Pk,"getCompartment");a(vk,"secureOnlyFetch");a(Bk,"getGlobalVars")});var Ih={};$e(Ih,{handleFile:()=>Hk});async function Hk(e,t,r,n){let s=new Map,i=(0,WO.pathToFileURL)(r).toString(),o=await Wl(i);u(o.default)&&n.set((0,Nh.dirname)(t),o.default),c(o,(0,Nh.dirname)(t));function c(_,l){for(let d in _){let f=_[d];u(f)?n.set(l+"/"+d,f):typeof f=="object"&&c(f,l+"/"+d)}}a(c,"recurseForResources");function u(_){return typeof _=="function"&&(_.get||_.put||_.post||_.delete)}return a(u,"isResource"),s}var WO,Nh,QO=Re(()=>{WO=require("url");yh();Nh=require("path");a(Hk,"handleFile")});var Ch={};$e(Ch,{start:()=>xk});function xk({resources:e}){e.set("login",wh),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var wh,zO=Re(()=>{An();a(xk,"start");wh=class extends Gt{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 rb={};$e(rb,{parse:()=>Lh,streamAsJSON:()=>hc,stringify:()=>Di});function hc(e){return new Dh({value:e})}function JO(e){return console.error(e),JSON.stringify(e.toString())}function XO(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Di(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===eb)return tb(e);if(t.resolution)return t.resolution.then(()=>Di(e));throw t}}function tb(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+=tb(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Di(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Lh(e){return qk.test(e)?Gk.parse(e):JSON.parse(e)}var jO,ZO,Gk,Fk,eb,Dh,qk,Mh=Re(()=>{jO=require("stream"),ZO=x(require("json-bigint-fixes")),Gk=(0,ZO.default)({useNativeBigInt:!0}),Fk=1e4,eb={};BigInt.prototype.toJSON=function(){throw eb};a(hc,"streamAsJSON");Dh=class extends jO.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(;;)if(o=i.next(),o.then&&(yield o.then(c=>(o=c,""))),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),JO)}catch(s){yield JO(s)}else yield Di(t)}else yield Di(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);XO(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>Fk?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 XO(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(JO,"handleError");a(XO,"when");a(Di,"stringify");a(tb,"jsStringify");qk=/-?\d{16,}/;a(Lh,"parse")});var hb=g((yoe,Eb)=>{"use strict";var Uh=require("recursive-iterator"),kk=require("alasql"),Ph=require("clone"),nb=z(),{handleHDBError:sb,hdb_errors:Vk}=ne(),{HDB_ERROR_MSGS:ib,HTTP_STATUS_CODES:ob}=Vk,{getDatabases:$k}=(Ae(),se(Fe)),Yk=["DISTINCT_ARRAY"],ab=Symbol("validateTables"),vh=Symbol("validateTable"),boe=Symbol("getAllColumns"),cb=Symbol("validateAllColumns"),Ql=Symbol("findColumn"),ub=Symbol("validateOrderBy"),mc=Symbol("validateSegment"),Bh=Symbol("validateColumn"),lb=Symbol("setColumnsForTable"),_b=Symbol("checkColumnsForAsterisk"),db=Symbol("validateGroupBy"),fb=Symbol("hasColumns"),Hh=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[ab](),this[_b](),this[cb]()}[ab](){if(this[fb]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[vh](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[vh](t.table)})}}[fb](){let t=!1,r=new Uh(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[vh](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=$k();if(!r[t.databaseid])throw sb(new Error,ib.SCHEMA_NOT_FOUND(t.databaseid),ob.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw sb(new Error,ib.TABLE_NOT_FOUND(t.databaseid,t.tableid),ob.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Ph(s);i.table=Ph(t),this.attributes.push(i)})}[Ql](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)}[_b](){let t=new Uh(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[lb](r.tableid)}[lb](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new kk.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[cb](){this[mc](this.statement.columns,!1),this[mc](this.statement.joins,!1),this[mc](this.statement.where,!1),this[db](this.statement.group,!1),this[mc](this.statement.order,!0)}[mc](t,r){if(!t)return;let n=new Uh(t),s=[];for(let{node:i,path:o}of n)!nb.isEmpty(i)&&!nb.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[ub](i):s.push(this[Bh](i)));return s}[db](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&Yk.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Ph(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Ql](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[Ql](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`}[ub](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[Bh](t)}[Bh](t){let r=this[Ql](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]}};Eb.exports=Hh});var pb=g((Ioe,mb)=>{"use strict";var xh=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")}};mb.exports=xh});var Tb=g((Coe,Sb)=>{"use strict";var Gh=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};Sb.exports=Gh});var Ob={};$e(Ob,{HAS_EXPIRATION:()=>Wh,LAST_TIMESTAMP_PLACEHOLDER:()=>Tc,LOCAL_TIMESTAMP:()=>Kk,METADATA:()=>pc,NO_TIMESTAMP:()=>qh,PENDING_LOCAL_TIME:()=>Qh,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>Kh,RecordEncoder:()=>$h,TIMESTAMP_ASSIGN_LAST:()=>Qk,TIMESTAMP_ASSIGN_NEW:()=>Rb,TIMESTAMP_ASSIGN_PREVIOUS:()=>Ab,TIMESTAMP_PLACEHOLDER:()=>zl,TIMESTAMP_RECORD_PREVIOUS:()=>kh,fromResource:()=>Zl,getUpdateRecord:()=>zh,handleLocalTimeForGets:()=>e_});function Jk(){return Sc[0]=Sc[0]^64,Wk.getFloat64(0)}function Zl(e){Yh=!0;try{return e()}finally{Yh=!1}}function e_(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),u=c?.value,_=u?.[pc];return _>=0&&(c.metadataFlags=_,c.localTime=u.localTime,c.value=u.value,u.expiresAt>0&&(c.expiresAt=u.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[pc]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let u=c.value,_=u[pc];return _>=0&&(c.metadataFlags=_,c.localTime=u.localTime,c.value=u.value,u.expiresAt>0&&(c.expiresAt=u.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){if(this.timerTracked||(this.timerTracked=!0,Li.push(new WeakRef(this))),!Yh)try{throw new Error("Read transaction used outside of resource")}catch(u){this.readStack=u.stack}o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let u=0;u<Li.length;u++){let _=Li[u].deref();(!_||_.isDone||_.isCommitted)&&Li.splice(u--,1)}},i.prototype.done.isTracked=!0}return e}function zh(e,t,r){return function(n,s,i,o,c=-1,u,_,l,d="put",f,E){if(f||u==null?Bo=i?.localTime?kh|Ab:qh:Bo=u?i?.localTime?kh|16384:Rb|16384:qh,l>0&&(c|=Wh),Xl=c,Vh=l,i?.version===o&&u===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Bo>0},p;try{f&&(h.ifVersion=p=i?.version??null);let S=e.put(n,s,h);if(u){let T=_?.user?.username;if(E&&(Jl=e.encoder.encode(E)),f&&i?.localTime){let b=i?.localTime,R=r.get(b);if(R){let L=Dt(R).previousLocalTime;return r.put(b,jl(o,t,n,L,T,d,Jl),{ifVersion:p}),S}}r.put(Tc,jl(o,t,n,i?.localTime?1:0,T,d,Jl),{append:d!=="invalidate",instructedWrite:!0,ifVersion:p})}return S}catch(S){throw S.message+=" id: "+n+" options: "+h,S}}}var gb,Fh,zl,Tc,Kh,Kk,pc,Sc,Wk,qh,Rb,Qk,Ab,kh,Wh,Qh,zk,Jl,Bo,Xl,Vh,$h,Moe,Yh,Li,Ho=Re(()=>{gb=require("msgpackr");Mi();Fh=x(K()),zl=new Uint8Array([1,1,1,1,4,64,0,0]),Tc=new Uint8Array([1,1,1,1,1,0,0,0]),Kh=new Uint8Array([1,1,1,1,3,64,0,0]),Kk=Symbol("local-timestamp"),pc=Symbol("metadata"),Sc=new Uint8Array(8),Wk=new DataView(Sc.buffer,0,8),qh=0,Rb=0,Qk=1,Ab=3,kh=4,Wh=16,Qh=1,Bo=0,Xl=-1,Vh=0,$h=class extends gb.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(n,s){if(Bo||Xl>=0){let i=0,o=Bo;o&&(i+=8,Bo=0);let c=Xl,u=Vh;c>=0&&(i+=2,Xl=-1,u&&(i+=8,Vh=0));let _=zk=r.call(this,n,s|2048|i);Jl=_.subarray((_.start||0)+i,_.end);let l=_.start||0;return o&&(zl[4]=o,zl[5]=o>>8,_.set(zl,l),l+=8),c>=0&&(_[l++]=c,_[l++]=0,u&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(l,u)),_}else return r.call(this,n,s)}}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,u;if(i===2){if(t.copy)t.copy(Sc,0,c),c+=8;else for(let d=0;d<8;d++)Sc[d]=t[c++];u=Jk(),i=t[c]}let _;i<32&&(o=i,c+=2,o&Wh&&(_=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8));let l=super.decode(t.subarray(c,s),s-c);return{localTime:u,value:l,[pc]:o,expiresAt:_}}return super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(Jk,"getTimestamp");Moe=Map.prototype.get;a(Zl,"fromResource");a(e_,"handleLocalTimeForGets");Li=[];setInterval(()=>{for(let e=0;e<Li.length;e++){let t=Li[e].deref();!t||t.isDone||t.isCommitted?Li.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Fh.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Fh.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(zh,"getUpdateRecord")});var t_=g((Poe,bb)=>{"use strict";var Xh=re(),jh=U(),{RecordEncoder:Xk}=(Ho(),se(Ob));Xh.initSync();var jk=Xh.get(jh.CONFIG_PARAMS.STORAGE_COMPRESSION),Zk=Xh.get(jh.CONFIG_PARAMS.STORAGE_CACHING)!==!1,eV=jh.UPDATES_PROPERTY,Jh=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.compression=jk&&r&&{startingOffset:32},this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=Zk&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:Xk},this.alwaysLazyProperty=n=>n===eV)}};bb.exports=Jh});var n_=g((Boe,Nb)=>{"use strict";var xo=re(),gc=U();xo.initSync();var tV=xo.get(gc.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||xo.get(gc.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||xo.get(gc.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",yb=xo.get(gc.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC),rV=xo.get(gc.CONFIG_PARAMS.STORAGE_NOREADAHEAD),r_=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=1e3,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.noSync=tV,this.noFSAccess=!0,yb!==void 0&&(this.overlappingSync=yb),this.noReadAhead=rV}};Nb.exports=r_;r_.MAX_DBS=1e4});var Ye=g((xoe,Bb)=>{"use strict";var em=require("lmdb"),On=require("fs-extra"),Cr=require("path"),s_=Ir(),Cb=K(),ir=Nr().LMDB_ERRORS_ENUM,i_=Tb(),tm=t_(),Db=n_(),zs=_t(),Ib=U(),{table:nV,resetDatabases:sV}=(Ae(),se(Fe)),wb=re(),bn=zs.INTERNAL_DBIS_NAME,Lb=zs.DBI_DEFINITION_NAME,iV="data.mdb",oV="lock.mdb",Rc=".mdb",aV="-lock",Zh=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=tn(t,r),this.key_type=this.dbi[zs.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[zs.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new em.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function o_(e,t){if(e===void 0)throw new Error(ir.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(ir.ENV_NAME_REQUIRED)}a(o_,"pathEnvNameValidation");async function rm(e,t,r=!0){try{await On.access(e)}catch(n){throw n.code==="ENOENT"?new Error(ir.INVALID_BASE_PATH):n}try{let n=Cr.join(e,t+Rc);return await On.access(n,On.constants.R_OK|On.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await On.access(Cr.join(e,t,iV),On.constants.R_OK|On.constants.F_OK),Cr.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(ir.INVALID_ENVIRONMENT)}else throw new Error(ir.INVALID_ENVIRONMENT);throw n}}a(rm,"validateEnvironmentPath");function a_(e,t){if(s_.validateEnv(e),t===void 0)throw new Error(ir.DBI_NAME_REQUIRED)}a(a_,"validateEnvDBIName");async function cV(e,t,r=!1,n=!1){o_(e,t);let s=Cr.basename(e);t=t.toString();let i=wb.get(Ib.CONFIG_PARAMS.DATABASES);i||wb.setProperty(Ib.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await rm(e,t,n),Mb(e,t,r)}catch(o){if(o.message===ir.INVALID_ENVIRONMENT){let c=Cr.join(e,t);await On.mkdirp(n?c:e);let u=new Db(n?c:c+Rc,!1),_=em.open(u);_.dbis=Object.create(null);let l=new tm(!1);_.openDB(bn,l),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=nm(e,t,r);return _[zs.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=_,_}throw o}}a(cV,"createEnvironment");async function uV(e,t,r,n=!0){o_(e,t),t=t.toString();let s=Cr.join(e,t);return nV({table:t,database:Cr.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(uV,"copyEnvironment");async function Mb(e,t,r=!1){o_(e,t),t=t.toString();let n=nm(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 rm(e,t),i=Cr.join(e,t+Rc),o=s!=i,c=new Db(s,o),u=em.open(c);u.dbis=Object.create(null);let _=Pb(u);for(let l=0;l<_.length;l++)tn(u,_[l]);return u[zs.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=u,u}a(Mb,"openEnvironment");async function lV(e,t,r=!1){o_(e,t),t=t.toString();let n=Cr.join(e,t+Rc),s=await rm(e,t);if(global.lmdb_map!==void 0){let i=nm(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await Ub(o),delete global.lmdb_map[i]}}await On.remove(s),await On.remove(s===n?s+aV:Cr.join(Cr.dirname(s),oV))}a(lV,"deleteEnvironment");async function Ub(e){s_.validateEnv(e);let t=e[zs.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(Ub,"closeEnvironment");function nm(e,t,r=!1){let s=`${Cr.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(nm,"getCachedEnvironmentName");function _V(e){s_.validateEnv(e);let t=Object.create(null),r=tn(e,bn);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==bn)try{t[n]=Object.assign(new i_,s)}catch{Cb.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(_V,"listDBIDefinitions");function Pb(e){s_.validateEnv(e);let t=[],r=tn(e,bn);for(let{key:n}of r.getRange({start:!1}))n!==bn&&t.push(n);return t}a(Pb,"listDBIs");function dV(e,t){let n=tn(e,bn).getEntry(t),s=new i_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{Cb.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(dV,"getDBIDefinition");function vb(e,t,r,n=!r){if(a_(e,t),t=t.toString(),t===bn)throw new Error(ir.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return tn(e,t)}catch(s){if(s.message===ir.DBI_DOES_NOT_EXIST){let i=new tm(r,n===!0),o=e.openDB(t,i),c=new i_(r===!0,n);return o[Lb]=c,tn(e,bn).putSync(t,c),e.dbis[t]=o,o}throw s}}a(vb,"createDBI");function tn(e,t){if(a_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==bn?r=dV(e,t):r=new i_,r===void 0)throw new Error(ir.DBI_DOES_NOT_EXIST);let n;try{let s=new tm(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(ir.DBI_DOES_NOT_EXIST):s}return n[Lb]=r,e.dbis[t]=n,n}a(tn,"openDBI");function fV(e,t){a_(e,t),t=t.toString();let r=tn(e,t),n=r.getStats();return r[zs.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(fV,"statDBI");async function EV(e,t){try{let r=Cr.join(e,t+Rc);return(await On.stat(r)).size}catch{throw new Error(ir.INVALID_ENVIRONMENT)}}a(EV,"environmentDataSize");function hV(e,t){if(a_(e,t),t=t.toString(),t===bn)throw new Error(ir.CANNOT_DROP_INTERNAL_DBIS_NAME);tn(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],tn(e,bn).removeSync(t)}a(hV,"dropDBI");function mV(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{tn(e,i)}catch(o){if(o.message===ir.DBI_DOES_NOT_EXIST)vb(e,i,i!==t,i===t),n=!0;else throw o}}n&&sV()}a(mV,"initializeDBIs");Bb.exports={openDBI:tn,openEnvironment:Mb,createEnvironment:cV,listDBIs:Pb,listDBIDefinitions:_V,createDBI:vb,dropDBI:hV,statDBI:fV,deleteEnvironment:lV,initializeDBIs:mV,TransactionCursor:Zh,environmentDataSize:EV,copyEnvironment:uV,closeEnvironment:Ub}});var xb=g((Foe,Hb)=>{"use strict";var sm=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};Hb.exports=sm});var Fb=g((koe,Gb)=>{"use strict";var im=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}};Gb.exports=im});var kb=g(($oe,qb)=>{"use strict";var om=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};qb.exports=om});var Go=g((zoe,Yb)=>{"use strict";var pV=Ye(),SV=xb(),TV=Fb(),gV=kb(),Yn=Ir(),Ac=Nr().LMDB_ERRORS_ENUM,RV=_t(),ms=U(),AV=z(),OV=require("uuid"),Koe=require("lmdb"),{handleHDBError:bV,hdb_errors:yV}=ne(),{OVERFLOW_MARKER:Woe,MAX_SEARCH_KEY_LENGTH:Qoe}=RV,Vb=re();Vb.initSync();var c_=Vb.get(ms.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),am=ms.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Ui=ms.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function NV(e,t,r,n,s=Yn.getNextMonotonicTime()){_m(e,t,r,n),cm(e,t,r);let i=new SV,o=[],c=[];for(let u=0;u<n.length;u++){let _=n[u];$b(_,!0,s);let l=IV(e,t,r,_),d=_[t];o.push(l),c.push(d)}return um(o,c,n,i,s)}a(NV,"insertRecords");function IV(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 l=c([[{}]]);Array.isArray(l)&&(c=l[0][ms.FUNC_VAL],n[o]=c)}let u=Yn.getIndexedValues(c),_=e.dbis[o];if(u){c_&&_.prefetch(u.map(l=>({key:l,value:s})),u_);for(let l=0,d=u.length;l<d;l++)_.put(u[l],s)}}c_&&e.dbis[t].prefetch([s],u_),e.dbis[t].put(s,n,n[Ui])})}a(IV,"insertRecord");function wV(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(wV,"removeSkippedRecords");function $b(e,t,r){let n=r>0;(n||!Number.isInteger(e[Ui]))&&(e[Ui]=r||(r=Yn.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[am]))&&(e[am]=r||Yn.getNextMonotonicTime()):delete e[am]}a($b,"setTimestamps");function cm(e,t,r){r.indexOf(ms.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(ms.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(ms.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(ms.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),pV.initializeDBIs(e,t,r)}a(cm,"initializeTransaction");async function CV(e,t,r,n,s=Yn.getNextMonotonicTime()){_m(e,t,r,n),cm(e,t,r);let i=new TV,o=[],c=[],u=[];for(let _=0;_<n.length;_++){let l=n[_],d=l[t],f;try{f=lm(e,t,l,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(_);continue}c.push(f),u.push(d)}return um(c,u,n,i,s,o)}a(CV,"updateRecords");async function DV(e,t,r,n,s=Yn.getNextMonotonicTime()){try{_m(e,t,r,n)}catch(u){throw bV(u,u.message,yV.HTTP_STATUS_CODES.BAD_REQUEST)}cm(e,t,r);let i=new gV,o=[],c=[];for(let u=0;u<n.length;u++){let _=n[u],l;AV.isEmpty(_[t])?(l=OV.v4(),_[t]=l):l=_[t];let d=lm(e,t,_,l,i,!1,s);o.push(d),c.push(l)}return um(o,c,n,i,s)}a(DV,"upsertRecords");async function um(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,u=o.length;c<u;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||Yn.getNextMonotonicTime(),wV(r,i),n}a(um,"finalizeWrite");function lm(e,t,r,n,s,i=!1,o){let c=e.dbis[t],u=c.getEntry(n),_=u?.value,l=_;if(!_){if(i)return!1;_={}}if($b(r,!l,o),Number.isInteger(r[Ui])&&_[Ui]>r[Ui])return!1;l&&s.original_records.push(_);let d,f=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let p=r[h],S=e.dbis[h];if(S===void 0)continue;let T=_[h];if(typeof p=="function"){let R=p([[_]]);Array.isArray(R)&&(p=R[0][ms.FUNC_VAL],r[h]=p)}if(p===T)continue;let b=Yn.getIndexedValues(T);if(b){c_&&S.prefetch(b.map(R=>({key:R,value:n})),u_);for(let R=0,L=b.length;R<L;R++)S.remove(b[R],n)}if(b=Yn.getIndexedValues(p),b){c_&&S.prefetch(b.map(R=>({key:R,value:n})),u_);for(let R=0,L=b.length;R<L;R++)S.put(b[R],n)}}let E=Object.assign({},_,r);c.put(n,E,E[Ui])},"do_put");return u?d=c.ifVersion(n,u.version,f):d=c.ifNoExists(n,f),d.then(E=>E?!0:lm(e,t,r,n,s,i,o))}a(lm,"updateUpsertRecord");function LV(e,t,r){if(Yn.validateEnv(e),t===void 0)throw new Error(Ac.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Ac.WRITE_ATTRIBUTES_REQUIRED):new Error(Ac.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(LV,"validateBasic");function _m(e,t,r,n){if(LV(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Ac.RECORDS_REQUIRED):new Error(Ac.RECORDS_MUST_BE_ARRAY)}a(_m,"validateWrite");function u_(){}a(u_,"noop");Yb.exports={insertRecords:NV,updateRecords:CV,upsertRecords:DV}});var Pi=g((Xoe,MV)=>{MV.exports={hdb_table:{hash_attribute:"id",name:"hdb_table",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"name"},{attribute:"hash_attribute"},{attribute:"schema"},{attribute:"residence"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_attribute:{hash_attribute:"id",name:"hdb_attribute",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"schema"},{attribute:"table"},{attribute:"attribute"},{attribute:"schema_table"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_schema:{hash_attribute:"name",name:"hdb_schema",schema:"system",residence:["*"],attributes:[{attribute:"name"},{attribute:"createddate"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metric"}]},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 Wn=g((joe,Qb)=>{"use strict";var Wb=z(),Kb=U(),Fo=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Kn=require("joi"),Js={schema_format:{pattern:Fo,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},UV=Kn.alternatives(Kn.string().min(1).max(Js.schema_length.maximum).pattern(Fo).messages({"string.pattern.base":"{:#label} "+Js.schema_format.message}),Kn.number(),Kn.array()).required(),PV=Kn.alternatives(Kn.string().min(1).max(Js.schema_length.maximum).pattern(Fo).messages({"string.pattern.base":"{:#label} "+Js.schema_format.message}),Kn.number()),vV=Kn.alternatives(Kn.string().min(1).max(Js.schema_length.maximum).pattern(Fo).messages({"string.pattern.base":"{:#label} "+Js.schema_format.message}),Kn.number()).required();function BV(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Js.schema_length.maximum?`'${e}' maximum of 250 characters`:Fo.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(BV,"checkValidTable");function HV(e,t){return Wb.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(HV,"validateSchemaExists");function xV(e,t){let r=t.state.ancestors[0].schema;return Wb.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(xV,"validateTableExists");function GV(e,t){return e.toLowerCase()===Kb.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${Kb.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(GV,"validateSchemaName");Qb.exports={common_validators:Js,schema_regex:Fo,hdb_schema_table:UV,validateSchemaExists:HV,validateTableExists:xV,validateSchemaName:GV,checkValidTable:BV,hdb_database:PV,hdb_table:vV}});var tt=g((eae,zb)=>{"use strict";var or=require("validate.js");or.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||or.validators.type.checks[t](e)?null:` must be a '${t}' value`};or.validators.type.checks={Object:function(e){return or.isObject(e)&&!or.isArray(e)},Array:or.isArray,Integer:or.isInteger,Number:or.isNumber,String:or.isString,Date:or.isDate,Boolean:function(e){return typeof e=="boolean"}};or.validators.hasValidFileExt=function(e,t){return or.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};zb.exports={validateObject:FV,validateObjectAsync:qV,validateBySchema:kV};function FV(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=or(e,t,{format:"flat"});return r?new Error(r):null}a(FV,"validateObject");async function qV(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await or.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(qV,"validateObjectAsync");function kV(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(kV,"validateBySchema")});var l_=g((rae,Jb)=>{var{common_validators:Qn}=Wn(),bc=tt(),Oc="is required",dt={database:{presence:!1,format:Qn.schema_format,length:Qn.schema_length},schema:{presence:!1,format:Qn.schema_format,length:Qn.schema_length},table:{presence:!0,format:Qn.schema_format,length:Qn.schema_length},attribute:{presence:!0,format:Qn.schema_format,length:Qn.schema_length},hash_attribute:{presence:!0,format:Qn.schema_format,length:Qn.schema_length}};function yc(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(yc,"makeAttributesStrings");function VV(e){return e=yc(e),dt.table.presence=!1,dt.attribute.presence=!1,dt.hash_attribute.presence=!1,bc.validateObject(e,dt)}a(VV,"schema_object");function $V(e){return e=yc(e),dt.table.presence={message:Oc},dt.attribute.presence=!1,dt.hash_attribute.presence=!1,bc.validateObject(e,dt)}a($V,"table_object");function YV(e){return e=yc(e),dt.table.presence={message:Oc},dt.attribute.presence=!1,bc.validateObject(e,dt)}a(YV,"create_table_object");function KV(e){return e=yc(e),dt.table.presence={message:Oc},dt.attribute.presence={message:Oc},dt.hash_attribute.presence=!1,bc.validateObject(e,dt)}a(KV,"attribute_object");function WV(e){return e=yc(e),dt.table.presence={message:Oc},dt.attribute.presence=!1,dt.hash_attribute.presence=!1,bc.validateObject(e,dt)}a(WV,"describe_table");function QV(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(QV,"validateTableResidence");Jb.exports={schema_object:VV,create_table_object:YV,table_object:$V,attribute_object:KV,describe_table:WV,validateTableResidence:QV}});var jb=g((sae,Xb)=>{"use strict";var zV=require("uuid"),dm=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||zV.v4(),this.schema_table=`${this.schema}.${this.table}`}};Xb.exports=dm});var __=g((oae,Zb)=>{"use strict";var JV=jb(),fm=class extends JV{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}};Zb.exports=fm});var ty=g((cae,ey)=>{"use strict";ey.exports=jV;var XV="inserted";function jV(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===XV?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(jV,"returnObject")});var d_=g((lae,oy)=>{"use strict";var ZV=U(),Em=Ye(),e$=Go(),{getSystemSchemaPath:t$,getSchemaPath:r$}=Qe(),n$=Pi(),s$=l_(),i$=__(),o$=ty(),{handleHDBError:ry,hdb_errors:sy}=ne(),ny=z(),{HTTP_STATUS_CODES:a$}=sy,hm=n$.hdb_attribute,iy=[];for(let e=0;e<hm.attributes.length;e++)iy.push(hm.attributes[e].attribute);var c$="inserted";oy.exports=u$;async function u$(e){let t=s$.attribute_object(e);if(t)throw ry(new Error,t.message,sy.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&ny.checkGlobalSchemaTable(e.schema,e.table);if(r)throw ry(new Error,r,a$.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=ny.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 i$(e.schema,e.table,e.attribute,e.id);try{let i=await Em.openEnvironment(r$(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}`);Em.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await Em.openEnvironment(t$(),ZV.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:u}=await e$.insertRecords(o,hm.hash_attribute,iy,[s]);return o$(c$,c,{records:[s]},u)}catch(i){throw i}}a(u$,"lmdbCreateAttribute")});var pm=g((dae,cy)=>{var{hdb_table:l$,hdb_database:ay}=Wn(),_$=tt(),mm=require("joi"),d$={undefined:"undefined",null:"null"},f$=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||d$[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"),E$=mm.object({database:ay,schema:ay,table:l$,records:mm.array().items(mm.object().custom(f$)).required()});cy.exports=function(e){return _$.validateBySchema(e,E$)}});var Nc=g((hae,ly)=>{"use strict";var ps=z(),uy=K(),Eae=pm(),{getDatabases:h$}=(Ae(),se(Fe)),{ClientError:vi}=ne();ly.exports=m$;function m$(e){if(ps.isEmpty(e))throw new vi("invalid update parameters defined.");if(ps.isEmptyOrZeroLength(e.schema))throw new vi("invalid schema specified.");if(ps.isEmptyOrZeroLength(e.table))throw new vi("invalid table specified.");if(!Array.isArray(e.records))throw new vi("records must be an array");let t=h$()[e.schema]?.[e.table];if(ps.isEmpty(t))throw new vi(`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&&ps.isEmptyOrZeroLength(o[r]))throw uy.error("a valid hash attribute must be provided with update record:",o),new vi("a valid hash attribute must be provided with update record, check log for more info");if(!ps.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw uy.error(`a valid hash value must be provided with ${e.operation} record:`,o),new vi(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!ps.isEmpty(o[r])&&o[r]!==""&&n.has(ps.autoCast(o[r]))&&(o.skip=!0),n.add(ps.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(m$,"insertUpdateValidate")});var Ic=g((pae,_y)=>{"use strict";var p$=U().OPERATIONS_ENUM,Sm=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=p$.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};_y.exports=Sm});var wc=g((gae,fy)=>{"use strict";var Tae=Ic(),f_=U(),Tm=z(),dy=K(),S$=require("uuid"),{handleHDBError:E_,hdb_errors:T$}=ne(),{HDB_ERROR_MSGS:h_,HTTP_STATUS_CODES:m_}=T$;fy.exports=g$;function g$(e,t,r){for(let s=0;s<t.length;s++)R$(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];A$(i,r,e.operation)}}a(g$,"processRows");function R$(e){if(Buffer.byteLength(String(e))>f_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw E_(new Error,h_.ATTR_NAME_LENGTH_ERR(e),m_.BAD_REQUEST,void 0,void 0,!0);if(Tm.isEmptyOrZeroLength(e)||Tm.isEmpty(e.trim()))throw E_(new Error,h_.ATTR_NAME_NULLISH_ERR,m_.BAD_REQUEST,void 0,void 0,!0)}a(R$,"validateAttribute");function A$(e,t,r){if(!e.hasOwnProperty(t)||Tm.isEmptyOrZeroLength(e[t])){if(r===f_.OPERATIONS_ENUM.INSERT||r===f_.OPERATIONS_ENUM.UPSERT){e[t]=S$.v4();return}throw dy.error("Update transaction aborted due to record with no hash value:",e),E_(new Error,h_.RECORD_MISSING_HASH_ERR,m_.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>f_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw dy.error(e),E_(new Error,h_.HASH_VAL_LENGTH_ERR,m_.BAD_REQUEST,void 0,void 0,!0)}a(A$,"validateHash")});var hy=g((Aae,Ey)=>{"use strict";var gm=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};Ey.exports=gm});var Sy=g((bae,py)=>{"use strict";var Rm=Ye(),O$=K(),my=Nr().LMDB_ERRORS_ENUM;py.exports=b$;async function b$(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 Rm.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==my.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await Rm.closeEnvironment(global.lmdb_map[n]),await Rm.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==my.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){O$.error(t)}}a(b$,"cleanLMDBMap")});var Ss=g((Nae,Ay)=>{"use strict";var Cc=require("crypto"),y$=re(),{CONFIG_PARAMS:N$}=U(),gy="aes-256-cbc",I$=32,w$=16,Am=64,Ry=32,C$=Am+Ry,Ty=new Map;Ay.exports={encrypt:D$,decrypt:L$,createNatsTableStreamName:M$};function D$(e){let t=Cc.randomBytes(I$),r=Cc.randomBytes(w$),n=Cc.createCipheriv(gy,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(D$,"encrypt");function L$(e){let t=e.substr(0,Am),r=e.substr(Am,Ry),n=e.substr(C$,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=Cc.createDecipheriv(gy,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(L$,"decrypt");function M$(e,t){let r=y$.get(N$.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=Ty.get(r);return n||(n=Cc.createHash("md5").update(r).digest("hex"),Ty.set(r,n)),n}a(M$,"createNatsTableStreamName")});var Bi=g((Cae,by)=>{"use strict";var wae=Dr(),p_=K(),Oy=l_(),U$=Ss(),S_=z(),{handleHDBError:T_,hdb_errors:P$}=ne(),{HDB_ERROR_MSGS:g_,HTTP_STATUS_CODES:Om}=P$,v$=re();v$.initSync();var{getDatabases:bm}=(Ae(),se(Fe));by.exports={describeAll:B$,describeTable:R_,describeSchema:H$};async function B$(e){try{let t=S_.isEmptyOrZeroLength(e),r,n;t||(r=e.hdb_user.role.permission,n=r.super_user||r.cluster_user);let s=bm(),i={},o={},c=[],u=e?.exact_count;for(let l in s){i[l]=!0,!t&&!n&&(o[l]=e.hdb_user.role.permission[l].describe);let d=s[l];for(let f in d)try{let E;if(t||n)E=await R_({schema:l,table:f,exact_count:u});else if(r&&r[l].describe&&r[l].tables[f].describe){let h=r[l].tables[f].attribute_permissions;E=await R_({schema:l,table:f,exact_count:u},h)}E&&c.push(E)}catch(E){p_.error(E)}}let _={};for(let l in c)t||n?(_[c[l].schema]==null&&(_[c[l].schema]={}),_[c[l].schema][c[l].name]=c[l],i[c[l].schema]&&delete i[c[l].schema]):o[c[l].schema]&&(_[c[l].schema]==null&&(_[c[l].schema]={}),_[c[l].schema][c[l].name]=c[l],i[c[l].schema]&&delete i[c[l].schema]);for(let l in i)t||n?_[l]={}:o[l]&&(_[l]={});return _}catch(t){return p_.error("Got an error in describeAll"),p_.error(t),T_(new Error,g_.DESCRIBE_ALL_ERR)}}a(B$,"describeAll");async function R_(e,t){S_.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=Oy.describe_table(e);if(i)throw i;let c=bm()[r];if(!c)throw T_(new Error,g_.SCHEMA_NOT_FOUND(e.schema),Om.NOT_FOUND);let u=c[n];if(!u)throw T_(new Error,g_.TABLE_NOT_FOUND(e.schema,e.table),Om.NOT_FOUND);function _(f){l.push(Object.assign({},{attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(E=>({type:E.type,name:E.name})):void 0}))}a(_,"pushAtt");let l=[];if(s){let f={};s.forEach(E=>{E.describe&&(f[E.attribute_name]=!0)}),u.attributes.forEach(E=>{f[E.name]&&_(E)})}else u.attributes?.forEach(f=>_(f));let d={schema:r,name:u.tableName,hash_attribute:u.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:u.audit,schema_defined:u.schemaDefined,attributes:l};d.clustering_stream_name=U$.createNatsTableStreamName(d.schema,d.name);try{let f=u.getRecordCount({exactCount:e.exact_count==="true"});d.record_count=f.recordCount,d.estimated_record_range=f.estimatedRange;let E=u.auditStore;if(E)for(let h of E.getKeys({reverse:!0,limit:1}))d.last_updated_record=h[0];if(!d.last_updated_record&&u.indices.__updatedtime__)for(let h of u.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))d.last_updated_record=h}catch(f){p_.warn(`unable to stat table dbi due to ${f}`)}return d}a(R_,"descTable");async function H$(e){S_.transformReq(e);let t=Oy.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=bm()[n];if(!i)throw T_(new Error,g_.SCHEMA_NOT_FOUND(e.schema),Om.NOT_FOUND);let o={};for(let c in i){let u;if(r&&r.tables[c]&&(u=r.tables[c]),S_.isEmpty(u)||u.describe){let _=await R_({schema:e.schema,table:c,exact_count:e.exact_count},u?u.attribute_permissions:null);_&&(o[_.name]=_)}}return o}a(H$,"describeSchema")});var Xs=g((Uae,Cy)=>{var x$=Pi(),{callbackify:Ny,promisify:G$}=require("util"),{getDatabases:Iy}=(Ae(),se(Fe));Cy.exports={setSchemaDataToGlobal:yy,getTableSchema:F$,getSystemSchema:q$,setSchemaDataToGlobalAsync:G$(yy)};var wy=Bi(),Lae=Ny(wy.describeAll),Mae=Ny(wy.describeTable);function yy(e){global.hdb_schema=Iy(),e&&e()}a(yy,"setSchemaDataToGlobal");function F$(e,t,r){let n=Iy()[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(F$,"getTableSchema");function q$(){return x$}a(q$,"getSystemSchema")});var rn=g((vae,Uy)=>{"use strict";var O_=pm(),Ft=z(),k$=require("util"),b_=yn(),V$=Xs(),Dy=K(),{handleHDBError:Hi,hdb_errors:$$}=ne(),{HTTP_STATUS_CODES:xi}=$$,Y$=k$.promisify(V$.getTableSchema),K$="updated",Ly="inserted",My="upserted";Uy.exports={insert:Q$,update:z$,upsert:J$,validation:W$,flush:X$};async function W$(e){if(Ft.isEmpty(e))throw new Error("invalid update parameters defined.");if(Ft.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Ft.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await Y$(e.schema,e.table),r=O_(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&&Ft.isEmptyOrZeroLength(c[n]))throw Dy.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(!Ft.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw Dy.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Ft.isEmpty(c[n])&&c[n]!==""&&s.has(Ft.autoCast(c[n]))&&(c.skip=!0),s.add(Ft.autoCast(c[n]));for(let u in c)i[u]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(W$,"validation");async function Q$(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=O_(e);if(t)throw Hi(new Error,t.message,xi.BAD_REQUEST);Ft.transformReq(e);let r=Ft.checkSchemaTableExist(e.schema,e.table);if(r)throw Hi(new Error,r,xi.BAD_REQUEST);let n=await b_.createRecords(e);return A_(Ly,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(Q$,"insertData");async function z$(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=O_(e);if(t)throw Hi(new Error,t.message,xi.BAD_REQUEST);Ft.transformReq(e);let r=Ft.checkSchemaTableExist(e.schema,e.table);if(r)throw Hi(new Error,r,xi.BAD_REQUEST);let n=await b_.updateRecords(e);return Ft.isEmpty(n.existing_rows)?A_(K$,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):A_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(z$,"updateData");async function J$(e){if(e.operation!=="upsert")throw Hi(new Error,"invalid operation, must be upsert",xi.INTERNAL_SERVER_ERROR);let t=O_(e);if(t)throw Hi(new Error,t.message,xi.BAD_REQUEST);Ft.transformReq(e);let r=Ft.checkSchemaTableExist(e.schema,e.table);if(r)throw Hi(new Error,r,xi.BAD_REQUEST);let n=await b_.upsertRecords(e);return A_(My,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(J$,"upsertData");function A_(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===Ly?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===My?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(A_,"returnObject");function X$(e){return Ft.transformReq(e),b_.flush(e.schema,e.table)}a(X$,"flush")});var Nm=g((Hae,By)=>{var j$=tt(),ym=require("joi"),{hdb_table:Z$,hdb_database:Py}=Wn(),vy={schema:Py,database:Py,table:Z$},e1={date:ym.date().iso().required()},t1={timestamp:ym.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};By.exports=function(e,t){let r=t==="timestamp"?{...vy,...t1}:{...vy,...e1},n=ym.object(r);return j$.validateBySchema(e,n)}});var Gy=g((xae,xy)=>{var r1=tt(),Im=require("joi"),{hdb_table:n1,hdb_database:Hy}=Wn(),s1=Im.object({schema:Hy,database:Hy,table:n1,hash_values:Im.array().required(),ids:Im.array()});xy.exports=function(e){return r1.validateBySchema(e,s1)}});var qy=g((Gae,Fy)=>{"use strict";var wm=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}},Cm=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}},Dm=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};Fy.exports={InsertObject:wm,NoSQLSeachObject:Cm,DeleteResponseObject:Dm}});var qi=g((qae,Ky)=>{"use strict";var Vy=Nm(),i1=Gy(),Gi=z(),ky=require("moment"),$y=K(),{promisify:o1,callbackify:a1}=require("util"),Fi=U(),c1=Xs(),Lm=o1(c1.getTableSchema),Mm=yn(),{DeleteResponseObject:u1}=qy(),{handleHDBError:js,hdb_errors:l1}=ne(),{HDB_ERROR_MSGS:y_,HTTP_STATUS_CODES:Zs}=l1,_1="records successfully deleted",d1=a1(Yy);Ky.exports={delete:d1,deleteRecord:Yy,deleteFilesBefore:f1,deleteAuditLogsBefore:E1};async function f1(e){let t=Vy(e,"date");if(t)throw js(t,t.message,Zs.BAD_REQUEST,void 0,void 0,!0);if(Gi.transformReq(e),!ky(e.date,ky.ISO_8601).isValid())throw js(new Error,y_.INVALID_DATE,Zs.BAD_REQUEST,Fi.LOG_LEVELS.ERROR,y_.INVALID_DATE,!0);let n=Gi.checkSchemaTableExist(e.schema,e.table);if(n)throw js(new Error,n,Zs.NOT_FOUND,Fi.LOG_LEVELS.ERROR,n,!0);let s=await Mm.deleteRecordsBefore(e);if(await Lm(e.schema,e.table),$y.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(f1,"deleteFilesBefore");async function E1(e){let t=Vy(e,"timestamp");if(t)throw js(t,t.message,Zs.BAD_REQUEST,void 0,void 0,!0);if(Gi.transformReq(e),isNaN(e.timestamp))throw js(new Error,y_.INVALID_VALUE("Timestamp"),Zs.BAD_REQUEST,Fi.LOG_LEVELS.ERROR,y_.INVALID_VALUE("Timestamp"),!0);let r=Gi.checkSchemaTableExist(e.schema,e.table);if(r)throw js(new Error,r,Zs.NOT_FOUND,Fi.LOG_LEVELS.ERROR,r,!0);let n=await Mm.deleteAuditLogsBefore(e);return await Lm(e.schema,e.table),$y.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(E1,"deleteAuditLogsBefore");async function Yy(e){e.ids&&(e.hash_values=e.ids);let t=i1(e);if(t)throw js(t,t.message,Zs.BAD_REQUEST,void 0,void 0,!0);Gi.transformReq(e);let r=Gi.checkSchemaTableExist(e.schema,e.table);if(r)throw js(new Error,r,Zs.NOT_FOUND,Fi.LOG_LEVELS.ERROR,r,!0);try{await Lm(e.schema,e.table);let n=await Mm.deleteRecords(e);return Gi.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${_1}`),n}catch(n){if(n.message===Fi.SEARCH_NOT_FOUND_MESSAGE){let s=new u1;return s.message=Fi.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(Yy,"deleteRecord")});var N_=g((Vae,zy)=>{var h1=require("crypto"),Wy=9;function m1(e){let t=S1(Wy),r=Qy(e+t);return t+r}a(m1,"createHash");function p1(e,t){let r=e?.substr(0,Wy),n=r+Qy(t+r);return e===n}a(p1,"validateHash");function S1(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,n="";for(let s=0;s<e;s++){let i=Math.floor(Math.random()*r);n+=t[i]}return n}a(S1,"generateSalt");function Qy(e){return h1.createHash("md5").update(e).digest("hex")}a(Qy,"md5");zy.exports={hash:m1,validate:p1}});var Xy=g((Yae,Jy)=>{var Um=tt(),Kt={username:{presence:!0,format:"[\\w\\-\\_]+",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 T1(e){return Kt.password.presence=!0,Kt.username.presence=!0,Kt.role.presence=!0,Kt.active.presence=!0,Um.validateObject(e,Kt)}a(T1,"addUserValidation");function g1(e){return Kt.password.presence=!1,Kt.username.presence=!0,Kt.role.presence=!1,Kt.active.presence=!1,Um.validateObject(e,Kt)}a(g1,"alterUserValidation");function R1(e){return Kt.password.presence=!1,Kt.username.presence=!0,Kt.role.presence=!1,Kt.active.presence=!1,Um.validateObject(e,Kt)}a(R1,"dropUserValidation");Jy.exports={addUserValidation:T1,alterUserValidation:g1,dropUserValidation:R1}});var rt=g((Qae,Zy)=>{"use strict";var{platform:Wae}=require("os"),A1="nats-server.zip",Pm="nats-server",O1=process.platform==="win32"?`${Pm}.exe`:Pm,b1=/^[^\s.,*>]+$/,jy="__request__",y1=a(e=>`${e}.${jy}`,"REQUEST_SUBJECT"),N1={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},I1={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},w1={HUB:"hub.pid",LEAF:"leaf.pid"},C1={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},D1={SUCCESS:"success",ERROR:"error"},L1={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},M1={TXN:"txn",MSGID:"msgid"},qo={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},U1={[qo.ERR]:1,[qo.WRN]:2,[qo.INF]:3,[qo.DBG]:4,[qo.TRC]:5},P1={debug:"-D",trace:"-DVV"};Zy.exports={NATS_SERVER_ZIP:A1,NATS_SERVER_NAME:Pm,NATS_BINARY_NAME:O1,PID_FILES:w1,NATS_CONFIG_FILES:I1,SERVER_SUFFIX:C1,NATS_TERM_CONSTRAINTS_RX:b1,REQUEST_SUFFIX:jy,UPDATE_REMOTE_RESPONSE_STATUSES:D1,CLUSTER_STATUS_STATUSES:L1,REQUEST_SUBJECT:y1,SUBJECT_PREFIXES:M1,MSG_HEADERS:N1,LOG_LEVELS:qo,LOG_LEVEL_FLAGS:P1,LOG_LEVEL_HIERARCHY:U1}});var tN=g((Jae,eN)=>{"use strict";var v1={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
|
|
5
5
|
`),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
|
|
6
|
-
`)},U1="certificate.pem",M1="privateKey.pem",P1="ca.pem";VN.exports={CERTIFICATE_VALUES:L1,CERTIFICATE_PEM_NAME:U1,PRIVATEKEY_PEM_NAME:M1,CA_PEM_NAME:P1}});var Cm=T((Kae,zN)=>{"use strict";var QN=require("fs-extra"),se=require("joi"),v1=require("os"),{boolean:Ne,string:ir,number:At,array:Im}=se.types(),{totalmem:YN}=require("os"),Vi=require("path"),B1=Q(),R_=J(),Yae=$N(),KN=P(),H1=rt(),WN="log",x1="components",F1="Invalid logging.rotation.maxSize unit. Available units are G, M or K",G1="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",q1="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",k1="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",V1="rootPath config parameter is undefined",$1="clustering.enabled config parameter is undefined",$i=At.min(0).required(),A_=Im.items({host:ir.required(),port:$i}).empty(null),Wn;zN.exports={configValidator:Y1,routesValidator:X1,route_constraints:A_};function Y1(e){if(Wn=e.rootPath,R_.isEmpty(Wn))throw V1;let t=Ne.required(),r=At.min(0).max(1e3).empty(null).default(J1),n=ir.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(Mc),s=ir.optional().empty(null),i=ir.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),o=se.string().empty(null).default(Mc),c=se.custom(W1).empty(null).default(Mc),u=e.clustering?.enabled;if(R_.isEmpty(u))throw $1;let _;return u===!0?_=se.object({enabled:t,hubServer:se.object({cluster:se.object({name:se.required().empty(null),network:se.object({port:$i,routes:A_}).required()}).required(),leafNodes:se.object({network:se.object({port:$i}).required()}).required(),network:se.object({port:$i}).required()}).required(),leafServer:se.object({network:se.object({port:$i,routes:A_}).required(),streams:se.object({maxAge:At.min(120).allow(null).optional(),maxBytes:At.min(1).allow(null).optional(),maxMsgs:At.min(1).allow(null).optional(),path:o}).required()}).required(),logLevel:se.valid("error","warn","info","debug","trace"),nodeName:i,republishMessages:Ne.optional(),databaseLevel:Ne.optional(),tls:se.object({certificate:s,certificateAuthority:s,privateKey:s,insecure:Ne.required(),verify:Ne.optional()}),user:ir.optional().empty(null)}).required():_=se.object({enabled:t,tls:se.object({certificate:s,certificateAuthority:s,privateKey:s,insecure:Ne.required()})}).required(),se.object({authentication:se.object({authorizeLocal:Ne,cacheTTL:At.required(),enableSessions:Ne}),analytics:se.object({aggregatePeriod:At}),componentsRoot:n.optional(),clustering:_,localStudio:se.object({enabled:t}).required(),logging:se.object({auditAuthEvents:se.object({logFailed:Ne,logSuccessful:Ne}),file:Ne.required(),level:se.valid("notify","fatal","error","warn","info","debug","trace"),rotation:se.object({enabled:Ne.optional(),compress:Ne.optional(),interval:ir.custom(z1).optional().empty(null),maxSize:ir.custom(Q1).optional().empty(null),path:ir.optional().empty(null).default(Mc)}).required(),root:n,stdStreams:Ne.required(),auditLog:Ne.required()}).required(),operationsApi:se.object({network:se.object({cors:Ne.optional(),corsAccessList:Im.optional(),headersTimeout:At.min(1).optional(),keepAliveTimeout:At.min(1).optional(),port:At.optional().empty(null),domainSocket:se.optional().empty("hdb/operations-server").default(Mc),securePort:At.optional().empty(null),timeout:At.min(1).optional()}).optional(),tls:se.object({certificate:s,certificateAuthority:s,privateKey:s})}).required(),rootPath:ir.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:se.object({network:se.object({port:$i,securePort:$i,mtls:se.alternatives([Ne.optional(),se.object({user:ir.optional(),certificateAuthority:s,required:Ne.optional()})])}).required(),webSocket:Ne.optional(),requireAuthentication:Ne.optional()}),http:se.object({compressionThreshold:At.optional(),cors:Ne.optional(),corsAccessList:Im.optional(),headersTimeout:At.min(1).optional(),port:At.min(0).optional().empty(null),securePort:At.min(0).optional().empty(null),mtls:se.alternatives([Ne.optional(),se.object({user:ir.optional(),certificateAuthority:s,required:Ne.optional()})])}).required(),threads:se.alternatives(r.optional(),se.object({count:r.optional(),debug:se.alternatives(Ne.optional(),se.object({startingPort:At.min(1).optional(),host:ir.optional(),waitForDebugger:Ne.optional()})),maxHeapMemory:At.min(0).optional()})),storage:se.object({writeAsync:Ne.required(),overlappingSync:Ne.optional(),caching:Ne.optional(),compression:Ne.optional(),noReadAhead:Ne.optional(),path:c,prefetchWrites:Ne.optional()}).required(),ignoreScripts:Ne.optional(),tls:se.object({certificate:s.optional(),certificateAuthority:s.optional(),privateKey:s.optional(),ciphers:ir.optional()})}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(Y1,"configValidator");function K1(e){return QN.existsSync(e)?null:`Specified path ${e} does not exist.`}a(K1,"doesPathExist");function W1(e,t){se.assert(e,ir.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=K1(e);if(r)return t.message(r)}a(W1,"validatePath");function Q1(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(F1);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(q1):e}a(Q1,"validateRotationMaxSize");function z1(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(G1);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(k1):e}a(z1,"validateRotationInterval");function J1(e,t){let r=t.state.path.join("."),n=v1.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||YN();return i=Math.round(Math.min(i,YN())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),B1.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(J1,"setDefaultThreads");function Mc(e,t){let r=t.state.path.join(".");if(!R_.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(R_.isEmpty(Wn))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Vi.join(Wn,x1);case"logging.root":return Vi.join(Wn,WN);case"clustering.leafServer.streams.path":return Vi.join(Wn,"clustering","leaf");case"storage.path":let n=Vi.join(Wn,KN.LEGACY_DATABASES_DIR_NAME);return QN.existsSync(n)?n:Vi.join(Wn,KN.DATABASES_DIR_NAME);case"logging.rotation.path":return Vi.join(Wn,WN);case"operationsApi.network.domainSocket":return r==null?null:Vi.join(Wn,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Mc,"setDefaultRoot");function X1(e){let t=se.object({routes:A_});return H1.validateBySchema({routes:e},t)}a(X1,"routesValidator")});var Lr=T((zae,sy)=>{"use strict";var Dr=P(),Ut=J(),Ot=Q(),{configValidator:j1,routesValidator:JN}=Cm(),or=require("fs-extra"),Z1=require("yaml"),Nn=require("path"),eY=require("is-number"),jN=require("properties-reader"),tY=require("lodash"),{handleHDBError:rY}=re(),{HTTP_STATUS_CODES:nY,HDB_ERROR_MSGS:O_}=Nr(),Qae=require("minimist"),{server:sY}=(rr(),ne(Di)),{DATABASES_PARAM_CONFIG:Pc,CONFIG_PARAMS:Cr,CONFIG_PARAM_MAP:yn}=Dr,iY="Unable to get config value because config is uninitialized",oY="Config successfully initialized",aY="Error backing up config file",cY="Empty parameter sent to getConfigValue",ZN=Nn.join(Dr.PACKAGE_ROOT,"config","yaml",Dr.HDB_DEFAULT_CONFIG_FILE),uY="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",XN={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"},b_,bt,N_;sy.exports={createConfigFile:lY,getDefaultConfig:_Y,getConfigValue:ty,initConfig:Lm,flattenConfig:$o,updateConfigValue:ry,updateConfigObject:fY,getConfiguration:mY,setConfiguration:pY,readConfigFile:Mm,getClusteringRoutes:SY,initOldConfig:ny,getConfigFromFile:TY,getConfigFilePath:Yi,addConfig:gY,deleteConfigFromFile:RY,getConfigObj:AY};function lY(e){let t=ei(ZN);b_=$o(t.toJSON());let r;for(let o in e){let c=yn[o.toLowerCase()];if(c===Cr.DATABASES){r=e[o];continue}if(!c&&o.endsWith("_package")&&(c=o),c!==void 0){let u=c.split("_"),_=Dm(c,e[o]);c==="rootPath"&&_?.endsWith("/")&&(_=_.slice(0,-1));try{t.setIn([...u],_)}catch(l){Ot.error(l)}}}r&&ey(t,r),Um(t);let n=t.toJSON();bt=$o(n);let s=t.getIn(["rootPath"]),i=Nn.join(s,Dr.HDB_CONFIG_FILE);or.createFileSync(i),or.writeFileSync(i,String(t)),Ot.trace(`Config file written to ${i}`)}a(lY,"createConfigFile");function ey(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Ut.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(Pc.TABLES))for(let i in n[s][Pc.TABLES])for(let o in n[s][Pc.TABLES][i]){let c=n[s][Pc.TABLES][i][o],u=[Cr.DATABASES,s,Pc.TABLES,i,o];e.hasIn(u)?e.setIn(u,c):e.addIn(u,c)}else for(let i in n[s]){let o=n[s][i],c=[Cr.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){Ot.error("Error parsing schemas CLI/env config arguments",n)}}a(ey,"setSchemasConfig");function _Y(e){if(b_===void 0){let r=ei(ZN);b_=$o(r.toJSON())}let t=yn[e.toLowerCase()];if(t!==void 0)return b_[t.toLowerCase()]}a(_Y,"getDefaultConfig");function ty(e){if(e==null){Ot.error(cY);return}if(bt===void 0){Ot.trace(iY);return}let t=yn[e.toLowerCase()];if(t!==void 0)return bt[t.toLowerCase()]}a(ty,"getConfigValue");function Yi(e=Ut.getPropsFilePath()){let t=Ut.getEnvCliRootPath();return t?Nn.join(t,Dr.HDB_CONFIG_FILE):jN(e).get(Dr.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY)}a(Yi,"getConfigFilePath");function Lm(e=!1){if(bt===void 0||e){let t;if(!Ut.noBootFile()){t=Ut.getPropsFilePath();try{or.accessSync(t,or.constants.F_OK|or.constants.R_OK)}catch(i){throw Ot.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Yi(t),n;if(r.includes("config/settings.js"))try{ny(r);return}catch(i){if(i.code!==Dr.NODE_ERROR_CODES.ENOENT)throw i}try{n=ei(r)}catch(i){if(i.code===Dr.NODE_ERROR_CODES.ENOENT){Ot.trace(`HarperDB config file not found at ${r}.
|
|
7
|
-
This can occur during early stages of install where the config file has not yet been created`);return}else throw Ot.error(i),new Error(`Error reading HarperDB config file at ${r}`)}dY(n,r),Um(n);let s=n.toJSON();if(sY.config=s,bt=$o(s),bt.logging_rotation_rotate)for(let i in XN)bt[i]&&Ot.error(`Config ${XN[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);Ot.trace(oY)}}a(Lm,"initConfig");function dY(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Nn.join(r,"database")),n=!0),e.hasIn(["clustering","leafServer","streams","path"])||(e.setIn(["clustering","leafServer","streams","path"],Nn.join(r,"clustering","leaf")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Nn.join(r,"log")),n=!0),e.hasIn(["clustering","tls","verify"])||(e.setIn(["clustering","tls","verify"],!0),n=!0),n&&(Ot.trace("Updating config file with missing config params"),or.writeFileSync(t,String(e)))}a(dY,"checkForUpdatedConfig");function Um(e){let t=e.toJSON();t.componentsRoot=t.componentsRoot??t?.customFunctions?.root,t?.http?.threads&&(t.threads=t?.http?.threads);let r=j1(t);if(r.error)throw O_.CONFIG_VALIDATION(r.error.message);typeof r.value.threads=="object"?e.setIn(["threads","count"],r.value.threads.count):e.setIn(["threads"],r.value.threads),e.setIn(["componentsRoot"],r.value.componentsRoot),e.setIn(["logging","root"],r.value.logging.root),e.setIn(["storage","path"],r.value.storage.path),e.setIn(["logging","rotation","path"],r.value.logging.rotation.path),e.setIn(["clustering","leafServer","streams","path"],r.value.clustering.leafServer.streams?.path),e.setIn(["operationsApi","network","domainSocket"],r.value?.operationsApi?.network?.domainSocket)}a(Um,"validateConfig");function fY(e,t){bt===void 0&&(bt={});let r=yn[e.toLowerCase()];if(r===void 0){Ot.trace(`Unable to update config object because config param '${e}' does not exist`);return}bt[r.toLowerCase()]=t}a(fY,"updateConfigObject");function ry(e,t,r=void 0,n=!1,s=!1,i=!1){bt===void 0&&Lm();let o=ty(yn.hdb_root),c=Nn.join(o,Dr.HDB_CONFIG_FILE),u=ei(c),_;if(r===void 0&&e.toLowerCase()===Cr.DATABASES)_=t;else if(r===void 0){let f;if(i)f=e;else if(f=yn[e.toLowerCase()],f===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let E=f.split("_"),h=Dm(f,t);u.setIn([...E],h)}else for(let f in r){let E=yn[f.toLowerCase()];if(E===Cr.HTTP_SECUREPORT&&r[f]===bt[Cr.HTTP_PORT]?.toString()&&u.setIn(["http","port"],null),E===Cr.OPERATIONSAPI_NETWORK_SECUREPORT&&r[f]===bt[Cr.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&u.setIn(["operationsApi","network","port"],null),E===Cr.DATABASES){_=r[f];continue}if(E?.startsWith("threads_")){let h=u.getIn(["threads"]);h>=0&&(u.deleteIn(["threads"]),u.setIn(["threads","count"],h))}if(!E&&f.endsWith("_package")&&(E=f),E!==void 0){let h=E.split("_"),S=Dr.LEGACY_CONFIG_PARAMS[f.toUpperCase()];S&&S.startsWith("customFunctions")&&u.hasIn(S.split("_"))&&(E=S,h=S.split("_"));let p=Dm(E,r[f]);E==="rootPath"&&p?.endsWith("/")&&(p=p.slice(0,-1));try{h.length>1&&typeof u.getIn(h.slice(0,-1))=="boolean"&&u.deleteIn(h.slice(0,-1)),u.setIn([...h],p)}catch(R){Ot.error(R)}}}_&&ey(u,_),Um(u);let l=u.getIn(["rootPath"]),d=Nn.join(l,Dr.HDB_CONFIG_FILE);n===!0&&EY(c,l),or.writeFileSync(d,String(u)),s&&(bt=$o(u.toJSON())),Ot.trace(`Config parameter: ${e} updated with value: ${t}`)}a(ry,"updateConfigValue");function EY(e,t){try{let r=Nn.join(t,"backup",`${Dr.HDB_CONFIG_FILE}.bak`);or.copySync(e,r),Ot.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){Ot.error(aY),Ot.error(r)}}a(EY,"backupConfigFile");var hY=["databases"];function $o(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network=Object.assign({},e.http,e.operationsApi.network)),e?.operationsApi&&(e.operationsApi.tls=Object.assign({},e.tls,e.operationsApi.tls)),N_=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])&&!hY.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let u=i+"_"+c;!Cr[u.toUpperCase()]&&yn[u]&&(s[yn[u].toLowerCase()]=o[c]),s[u]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a($o,"flattenConfig");function Dm(e,t){if(e===Cr.CLUSTERING_NODENAME||e===Cr.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(eY(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Ut.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 Ut.autoCast(t)}a(Dm,"castConfigValue");function mY(){let e=Ut.getPropsFilePath(),t=Yi(e);return ei(t).toJSON()}a(mY,"getConfiguration");async function pY(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return ry(void 0,void 0,s,!0),uY}catch(i){throw typeof i=="string"||i instanceof String?rY(i,i,nY.BAD_REQUEST,void 0,void 0,!0):i}}a(pY,"setConfiguration");function Mm(){let e=Ut.getPropsFilePath();try{or.accessSync(e,or.constants.F_OK|or.constants.R_OK)}catch(n){if(!Ut.noBootFile())throw Ot.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Yi(e);return ei(t).toJSON()}a(Mm,"readConfigFile");function ei(e){return Z1.parseDocument(or.readFileSync(e,"utf8"),{simpleKeys:!0})}a(ei,"parseYamlDoc");function SY(){let e=Mm(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Ut.isEmptyOrZeroLength(t)?[]:t;let r=JN(t);if(r)throw O_.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Ut.isEmptyOrZeroLength(n)?[]:n;let s=JN(n);if(s)throw O_.CONFIG_VALIDATION(s.message);if(!Ut.isEmptyOrZeroLength(n)&&!Ut.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Ut.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw O_.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(SY,"getClusteringRoutes");function ny(e){let t=jN(e);bt={};for(let r in yn){let n=t.get(r.toUpperCase());if(Ut.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=yn[r].toLowerCase();s===Cr.LOGGING_ROOT?bt[s]=Nn.dirname(n):bt[s]=n}return bt}a(ny,"initOldConfig");function TY(e){let t=Mm();return tY.get(t,e.replaceAll("_","."))}a(TY,"getConfigFromFile");async function gY(e,t){let r=ei(Yi());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await or.writeFile(Yi(),String(r))}a(gY,"addConfig");function RY(e){let t=Yi(Ut.getPropsFilePath()),r=ei(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Nn.join(n,Dr.HDB_CONFIG_FILE);or.writeFileSync(s,String(r))}a(RY,"deleteConfigFromFile");function AY(){return N_||(Lm(),N_)}a(AY,"getConfigObj")});var oy=T((Xae,iy)=>{"use strict";var y_=P(),w_=class{static{a(this,"BaseLicense")}constructor(t=0,r=y_.RAM_ALLOCATION_ENUM.DEFAULT,n=y_.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},Pm=class extends w_{static{a(this,"ExtendedLicense")}constructor(t=0,r=y_.RAM_ALLOCATION_ENUM.DEFAULT,n=y_.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};iy.exports={BaseLicense:w_,ExtendedLicense:Pm}});var Ki=T((Zae,dy)=>{"use strict";var Ko=require("fs-extra"),cy=g_(),uy=require("crypto"),OY=require("moment"),bY=require("uuid").v4,Wt=Q(),Bm=require("path"),NY=J(),ti=P(),{totalmem:ay}=require("os"),yY=oy().ExtendedLicense,Yo="invalid license key format",wY="061183",IY="mofi25",CY="aes-256-cbc",DY=16,LY=32,ly=te();ly.initSync();var vm;dy.exports={validateLicense:_y,generateFingerPrint:MY,licenseSearch:Fm,getLicense:BY,checkMemoryLimit:HY};function Hm(){return Bm.join(ly.getHdbBasePath(),ti.LICENSE_KEY_DIR_NAME,ti.LICENSE_FILE_NAME)}a(Hm,"getLicenseDirPath");function UY(){let e=Hm();return Bm.join(e,ti.LICENSE_FILE_NAME)}a(UY,"getLicenseFilePath");function xm(){let e=Hm();return Bm.join(e,ti.REG_KEY_FILE_NAME)}a(xm,"getFingerPrintFilePath");async function MY(){let e=xm();try{return await Ko.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await PY();throw Wt.error(`Error writing fingerprint file to ${e}`),Wt.error(t),new Error("There was an error generating the fingerprint")}}a(MY,"generateFingerPrint");async function PY(){let e=bY(),t=cy.hash(e),r=xm();try{await Ko.mkdirp(Hm()),await Ko.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Wt.error(`Error writing fingerprint file to ${r}`),Wt.error(n),new Error("There was an error generating the fingerprint")}return t}a(PY,"writeFingerprint");function _y(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:ti.RAM_ALLOCATION_ENUM.DEFAULT,version:ti.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Wt.error("empty license key passed to validate."),r;let n=xm(),s=!1;try{s=Ko.statSync(n)}catch(i){Wt.error(i)}if(s){let i;try{i=Ko.readFileSync(n,"utf8")}catch{Wt.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(IY),c=o[1];c=Buffer.concat([Buffer.from(c)],DY);let u=Buffer.concat([Buffer.from(i)],LY),_=uy.createDecipheriv(CY,u,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let l=null;try{l=_.update(o[0],"hex","utf8"),l.trim(),l+=_.final("utf8")}catch{let E=vY(o[0],i);if(E)l=E;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Yo),Wt.error(Yo),new Error(Yo)}let d;if(isNaN(l))try{d=JSON.parse(l),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(Yo),Wt.error(Yo),new Error(Yo)}else r.exp_date=l;r.exp_date<OY().valueOf()&&(r.valid_date=!1),cy.validate(o[1],`${wY}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||Wt.error("Invalid licence"),r}a(_y,"validateLicense");function vY(e,t){try{let r=uy.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Wt.warn("Check old license failed")}}a(vY,"checkOldLicense");function Fm(){let e=new yY,t=[];try{t=Ko.readFileSync(UY(),"utf-8").split(ti.NEW_LINE)}catch(r){r.code==="ENOENT"?Wt.info("no license file found"):Wt.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(NY.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=_y(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){Wt.error("There was an error parsing the license string."),Wt.error(s),e.ram_allocation=ti.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return vm=e,e}a(Fm,"licenseSearch");async function BY(){return vm||await Fm(),vm}a(BY,"getLicense");function HY(){let e=Fm().ram_allocation,t=process.constrainedMemory?.()||ay();if(t=Math.round(Math.min(t,ay())/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(HY,"checkMemoryLimit")});var tn=T((sce,Iy)=>{"use strict";var my="username is required",py="nothing to update, must supply active, role or password to update",Sy="password cannot be an empty string",Ty="If role is specified, it cannot be empty.",gy="active must be true or false";Iy.exports={addUser:KY,alterUser:WY,dropUser:zY,getSuperUser:ZY,userInfo:JY,listUsers:C_,listUsersExternal:XY,setUsersToGlobal:Qo,findAndValidateUser:yy,getClusterUser:eK,USERNAME_REQUIRED:my,ALTERUSER_NOTHING_TO_UPDATE:py,EMPTY_PASSWORD:Sy,EMPTY_ROLE:Ty,ACTIVE_BOOLEAN:gy};var Ry=en(),xY=ki(),km=g_(),Ay=GN(),Oy=Zr(),Vm=Ts(),Ur=J(),by=require("validate.js"),Se=Q(),{promisify:FY}=require("util"),$m=Ss(),fy=P(),Ey=nt(),GY=Lr(),tce=te(),rce=Ki(),qY=vi(),{table:nce}=(Re(),ne(Ge)),{handleHDBError:Qn,hdb_errors:kY}=re(),{HTTP_STATUS_CODES:zn,AUTHENTICATION_ERROR_MSGS:Gm,HDB_ERROR_MSGS:Wo}=kY,{UserEventMsg:Ym}=wn(),qm=require("lodash"),{server:Km}=(rr(),ne(Di)),VY=Q();Km.getUser=(e,t)=>yy(e,t,t!=null);var Ny={username:!0,active:!0,role:!0,password:!0},hy=new Map,I_=Oy.searchByValue,$Y=Oy.searchByHash,YY=FY(xY.delete);async function KY(e){let t=by.cleanAttributes(e,Ny),r=Ay.addUserValidation(t);if(r)throw Qn(new Error,r.message,zn.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await I_(n),s=s&&Array.from(s)}catch(u){throw Se.error("There was an error searching for a role in add user"),Se.error(u),u}if(!s||s.length<1)throw Qn(new Error,Wo.ROLE_NAME_NOT_FOUND(t.role),zn.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Qn(new Error,Wo.DUP_ROLES_FOUND(t.role),zn.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=$m.encrypt(t.password)),t.password=km.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await Ry.insert(i)}catch(u){throw Se.error("There was an error searching for a user."),Se.error(u),u}Se.debug(o);try{await Qo()}catch(u){throw Se.error("Got an error setting users to global"),Se.error(u),u}if(o.skipped_hashes.length===1)throw Qn(new Error,Wo.USER_ALREADY_EXISTS(t.username),zn.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],Vm.signalUserChange(new Ym(process.pid)),`${c.username} successfully added`}a(KY,"addUser");async function WY(e){let t=by.cleanAttributes(e,Ny);if(Ur.isEmptyOrZeroLength(t.username))throw new Error(my);if(Ur.isEmptyOrZeroLength(t.password)&&Ur.isEmptyOrZeroLength(t.role)&&Ur.isEmptyOrZeroLength(t.active))throw new Error(py);if(!Ur.isEmpty(t.password)&&Ur.isEmptyOrZeroLength(t.password.trim()))throw new Error(Sy);if(!Ur.isEmpty(t.active)&&!Ur.isBoolean(t.active))throw new Error(gy);let r=QY(t.username);if(!Ur.isEmpty(t.password)&&!Ur.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=$m.encrypt(t.password)),t.password=km.hash(t.password)),t.role==="")throw new Error(Ty);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await I_(i)||[])}catch(c){throw Se.error("Got an error searching for a role."),Se.error(c),c}if(!o||o.length===0){let c=Wo.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Se.error(c),Qn(new Error,c,zn.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Wo.ALTER_USER_DUP_ROLES(t.role);throw Se.error(c),Qn(new Error,c,zn.CONFLICT,void 0,void 0,!0)}t.role=o[0].id}let n={operation:"update",schema:"system",table:"hdb_user",records:[t]},s;try{s=await Ry.update(n)}catch(i){throw Se.error("Error during update."),Se.error(i),i}try{await Qo()}catch(i){throw Se.error("Got an error setting users to global"),Se.error(i),i}return Vm.signalUserChange(new Ym(process.pid)),s}a(WY,"alterUser");function QY(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(QY,"isClusterUser");async function zY(e){try{let t=Ay.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Ur.isEmpty(global.hdb_users.get(e.username)))throw Qn(new Error,Wo.USER_NOT_EXIST(e.username),zn.NOT_FOUND,void 0,void 0,!0);let n;try{n=await YY(r)}catch(s){throw Se.error("Got an error deleting a user."),Se.error(s),s}Se.debug(n);try{await Qo()}catch(s){throw Se.error("Got an error setting users to global."),Se.error(s),s}return Vm.signalUserChange(new Ym(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(zY,"dropUser");async function JY(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=qm.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await $Y(r)}catch(s){throw Se.error("Got an error searching for a role."),Se.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Se.error(r),r}return t}a(JY,"userInfo");async function XY(){let e;try{e=await C_()}catch(t){throw Se.error("Got an error listing users."),Se.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(XY,"listUsersExternal");async function C_(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await I_(e)}catch(o){throw Se.error("Got an error searching for roles."),Se.error(o),o}let r={};for(let o of t)r[o.id]=qm.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await I_(n)}catch(o){throw Se.error("Got an error searching for users."),Se.error(o),o}let i=new Map;for(let o of s)o=qm.cloneDeep(o),o.role=r[o.role],jY(o.role),i.set(o.username,o);return i}catch(e){throw Se.error("got an error listing users"),Se.error(e),Ur.errorizeMessage(e)}return null}a(C_,"listUsers");function jY(e){try{if(!e){Se.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(qY)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Se.error("Got an error trying to set system permissions."),Se.error(t)}}a(jY,"appendSystemTablesToRole");async function Qo(){try{let e=await C_();global.hdb_users=e}catch(e){throw Se.error(e),e}}a(Qo,"setUsersToGlobal");async function yy(e,t,r=!0){global.hdb_users||await Qo();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Qn(new Error,Gm.GENERIC_AUTH_FAIL,zn.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Qn(new Error,Gm.USER_INACTIVE,zn.UNAUTHORIZED,void 0,void 0,!0);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(hy.get(t)===n.password)return s;if(km.validate(n.password,t))hy.set(t,n.password);else throw Qn(new Error,Gm.GENERIC_AUTH_FAIL,zn.UNAUTHORIZED,void 0,void 0,!0)}return s}a(yy,"findAndValidateUser");async function ZY(){global.hdb_users||await Qo();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(ZY,"getSuperUser");async function eK(){let e=await C_(),t=GY.getConfigFromFile(fy.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Ur.isEmpty(r)&&r?.role?.role===fy.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=$m.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+Ey.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+Ey.SERVER_SUFFIX.ADMIN,r}a(eK,"getClusterUser");var wy=[];Km.invalidateUser=function(e){for(let t of wy)try{t(e)}catch(r){VY.error("Error invalidating user",r)}};Km.onInvalidatedUser=function(e){wy.push(e)}});var Bc=T((cce,Uy)=>{"use strict";var Wi=Q(),Mr=P(),tK=aN(),oce=Xs(),ace=Hi(),rK=tn(),{validateEvent:Cy}=wn(),vc=bn(),nK=require("process"),{resetDatabases:sK}=(Re(),ne(Ge)),iK={[Mr.ITC_EVENT_TYPES.SCHEMA]:oK,[Mr.ITC_EVENT_TYPES.USER]:Ly};async function oK(e){let t=Cy(e);if(t){Wi.error(t);return}Wi.trace("ITC schemaHandler received schema event:",e),await tK(e.message),await aK(e.message)}a(oK,"schemaHandler");async function aK(e){try{vc.resetReadTxn(Mr.SYSTEM_SCHEMA_NAME,Mr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),vc.resetReadTxn(Mr.SYSTEM_SCHEMA_NAME,Mr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),vc.resetReadTxn(Mr.SYSTEM_SCHEMA_NAME,Mr.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=sK();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Wi.error(t)}}a(aK,"syncSchemaMetadata");var Dy=[];async function Ly(e){try{try{vc.resetReadTxn(Mr.SYSTEM_SCHEMA_NAME,Mr.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),vc.resetReadTxn(Mr.SYSTEM_SCHEMA_NAME,Mr.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Wi.warn(r)}let t=Cy(e);if(t){Wi.error(t);return}Wi.trace(`ITC userHandler ${Mr.HDB_ITC_CLIENT_PREFIX}${nK.pid} received user event:`,e),await rK.setUsersToGlobal();for(let r of Dy)r()}catch(t){Wi.error(t)}}a(Ly,"userHandler");Ly.addListener=function(e){Dy.push(e)};Uy.exports=iK});var wn=T((Ece,Py)=>{"use strict";var lce=Q(),Wm=J(),cK=P(),{ITC_ERRORS:Hc}=Nr(),{parentPort:_ce,threadId:uK,isMainThread:lK,workerData:dce}=require("worker_threads"),{onMessageFromWorkers:_K,broadcast:fce,broadcastWithAcknowledgement:dK}=et();Py.exports={sendItcEvent:fK,validateEvent:My,SchemaEventMsg:EK,UserEventMsg:hK};var D_;_K(async(e,t)=>{D_=D_||Bc(),My(e),D_[e.type]&&await D_[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function fK(e){return!lK&&e.message&&(e.message.originator=uK),dK(e)}a(fK,"sendItcEvent");function My(e){if(typeof e!="object")return Hc.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||Wm.isEmpty(e.type))return Hc.MISSING_TYPE;if(!e.hasOwnProperty("message")||Wm.isEmpty(e.message))return Hc.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||Wm.isEmpty(e.message.originator))return Hc.MISSING_ORIGIN;if(cK.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Hc.INVALID_EVENT(e.type)}a(My,"validateEvent");function EK(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(EK,"SchemaEventMsg");function hK(e){this.originator=e}a(hK,"UserEventMsg")});var Ts=T((pce,xy)=>{"use strict";var vy=P(),mce=J(),L_=Q(),By=sN(),zo,{sendItcEvent:Hy}=wn();function mK(e){try{L_.trace("signalSchemaChange called with message:",e),zo=zo||Bc();let t=new By(vy.ITC_EVENT_TYPES.SCHEMA,e);return zo.schema(t),Hy(t)}catch(t){L_.error(t)}}a(mK,"signalSchemaChange");function pK(e){try{L_.trace("signalUserChange called with message:",e),zo=zo||Bc();let t=new By(vy.ITC_EVENT_TYPES.USER,e);return zo.user(t),Hy(t)}catch(t){L_.error(t)}}a(pK,"signalUserChange");xy.exports={signalSchemaChange:mK,signalUserChange:pK}});var U_=T((Tce,Gy)=>{"use strict";var Fy=J(),SK=P(),TK=Q(),gK=u_(),RK=c_(),AK=Ts(),{SchemaEventMsg:OK}=wn(),bK="already exists in";Gy.exports=NK;async function NK(e,t,r){if(Fy.isEmptyOrZeroLength(r))return r;let n=[];Fy.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 yK(e,t.schema,t.name,i)})),s}a(NK,"lmdbCheckForNewAttributes");async function yK(e,t,r,n){let s=new RK(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await wK(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(bK))TK.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(yK,"createNewAttribute");async function wK(e){let t;return t=await gK(e),AK.signalSchemaChange(new OK(process.pid,SK.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(wK,"createAttribute")});var Jo=T((Rce,qy)=>{"use strict";var Qm=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}};qy.exports=Qm});var Vy=T((Oce,ky)=>{"use strict";var IK=Jo(),CK=P().OPERATIONS_ENUM,zm=class extends IK{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(CK.INSERT,r,n,s,i),this.records=t}};ky.exports=zm});var Yy=T((Nce,$y)=>{"use strict";var DK=Jo(),LK=P().OPERATIONS_ENUM,Jm=class extends DK{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(LK.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};$y.exports=Jm});var Wy=T((wce,Ky)=>{"use strict";var UK=Jo(),MK=P().OPERATIONS_ENUM,Xm=class extends UK{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(MK.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};Ky.exports=Xm});var zy=T((Cce,Qy)=>{"use strict";var PK=Jo(),vK=P().OPERATIONS_ENUM,jm=class extends PK{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(vK.DELETE,n,s,t,i),this.original_records=r}};Qy.exports=jm});var xc=T((Uce,Zy)=>{"use strict";var Lce=require("path"),Jy=Ke(),BK=Vy(),HK=Yy(),xK=Wy(),FK=zy(),Xo=dt(),Xy=J(),{CONFIG_PARAMS:GK}=P(),jy=te();jy.initSync();var M_=P().OPERATIONS_ENUM,{getTransactionAuditStorePath:qK}=ze();Zy.exports=kK;async function kK(e,t){if(jy.get(GK.LOGGING_AUDITLOG)===!1)return;let r=qK(e.schema,e.table),n=await Jy.openEnvironment(r,e.table,!0),s=VK(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){Jy.initializeDBIs(n,Xo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Xo.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Xo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Xo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),Xy.isEmpty(s.user_name)||n.dbis[Xo.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Xo.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(kK,"writeTransaction");function VK(e,t){let r=Xy.isEmpty(e.hdb_user)?void 0:e.hdb_user.username;if(e.operation===M_.INSERT)return new BK(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===M_.UPDATE)return new HK(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===M_.UPSERT)return new xK(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===M_.DELETE)return new FK(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(VK,"createTransactionObject")});var Zm=T((vce,ew)=>{"use strict";var $K=yc(),Pce=wc(),Fc=P(),YK=Lc(),KK=qo().insertRecords,WK=Ke(),QK=Q(),zK=U_(),{getSchemaPath:JK}=ze(),XK=xc();ew.exports=jK;async function jK(e){try{let{schema_table:t,attributes:r}=$K(e);YK(e,r,t.hash_attribute),e.schema!==Fc.SYSTEM_SCHEMA_NAME&&(r.includes(Fc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Fc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Fc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Fc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await zK(e.hdb_auth_header,t,r),s=JK(e.schema,e.table),i=await WK.openEnvironment(s,e.table),o=await KK(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await XK(e,o)}catch(c){QK.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(jK,"lmdbCreateRecords")});var nw=T((Hce,rw)=>{"use strict";var tw=P(),ZK=Zm(),eW=wc(),tW=require("fs-extra"),{getSchemaPath:rW}=ze();rw.exports=nW;async function nW(e){let t=[{name:e.schema,createddate:Date.now()}],r=new eW(tw.SYSTEM_SCHEMA_NAME,tw.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await ZK(r),await tW.mkdirp(rW(e.schema))}a(nW,"lmdbCreateSchema")});var iw=T((Fce,sw)=>{"use strict";var ep=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}};sw.exports=ep});var uw=T(($ce,cw)=>{"use strict";var ow=Ke(),tp=yr(),rp=Nr().LMDB_ERRORS_ENUM,sW=dt(),aw=Q(),qce=J(),iW=require("lmdb"),oW=iw(),aW=P(),{OVERFLOW_MARKER:kce,MAX_SEARCH_KEY_LENGTH:Vce}=sW,cW=aW.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function uW(e,t,r,n){if(tp.validateEnv(e),t===void 0)throw new Error(rp.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(rp.IDS_REQUIRED):new Error(rp.IDS_MUST_BE_ITERABLE);try{let s=ow.listDBIs(e);ow.initializeDBIs(e,t,s);let i=new oW,o,c=[],u=[];for(let f=0,E=r.length;f<E;f++)try{o=r[f];let h=e.dbis[t].get(o);if(!h||n&&h[cW]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,iW.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let p=0;p<s.length;p++){let R=s[p];if(!h.hasOwnProperty(R)||R===t)continue;let A=e.dbis[R],g=h[R];if(g!=null)try{let v=tp.getIndexedValues(g);if(v)for(let H=0,M=v.length;H<M;H++)A.remove(v[H],o)}catch{aw.warn(`cannot delete from attribute: ${R}, ${g}:${o}`)}}});c.push(S),u.push(o),i.original_records.push(h)}catch(h){aw.warn(h),i.skipped.push(o)}let _=[],l=await Promise.all(c);for(let f=0,E=l.length;f<E;f++)l[f]===!0?i.deleted.push(u[f]):(i.skipped.push(u[f]),_.push(f));let d=0;for(let f=0;f<_.length;f++){let E=_[f];i.original_records.splice(E-d,1),d++}return i.txn_time=tp.getNextMonotonicTime(),i}catch(s){throw s}}a(uW,"deleteRecords");cw.exports={deleteRecords:uW}});var Gc=T((Kce,_w)=>{"use strict";var jo=J(),lW=uw(),_W=Ke(),{getSchemaPath:dW}=ze(),fW=xc(),EW=Q();_w.exports=hW;async function hW(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(jo.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(jo.isEmptyOrZeroLength(e.hash_values)&&!jo.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let u=e.records[c][n];jo.isEmpty(u)||e.hash_values.push(u)}}if(jo.isEmptyOrZeroLength(e.hash_values))return lw([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(jo.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=dW(e.schema,e.table),i=await _W.openEnvironment(s,e.table),o=await lW.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await fW(e,o)}catch(c){EW.error(`unable to write transaction due to ${c.message}`)}return lw(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(hW,"lmdbDeleteRecords");function lw(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(lw,"createDeleteResponse")});var sp=T((zce,dw)=>{"use strict";var mW=P(),Qce=yr();function np(e,t){let r=Object.create(null);if(t.length===1&&mW.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(np,"parseRow");function pW(e,t,r,n){let s=np(r,e);n.push(s)}a(pW,"searchAll");function SW(e,t,r,n){let s=np(r,e);n[t]=s}a(SW,"searchAllToMap");function TW(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(TW,"iterateDBI");function Qi(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(Qi,"pushResults");function gW(e,t,r,n,s,i){t.toString().endsWith(e)&&Qi(t,r,n,s,i)}a(gW,"endsWith");function RW(e,t,r,n,s,i){t.toString().includes(e)&&Qi(t,r,n,s,i)}a(RW,"contains");function AW(e,t,r,n,s,i){t>e&&Qi(t,r,n,s,i)}a(AW,"greaterThanCompare");function OW(e,t,r,n,s,i){t>=e&&Qi(t,r,n,s,i)}a(OW,"greaterThanEqualCompare");function bW(e,t,r,n,s,i){t<e&&Qi(t,r,n,s,i)}a(bW,"lessThanCompare");function NW(e,t,r,n,s,i){t<=e&&Qi(t,r,n,s,i)}a(NW,"lessThanEqualCompare");dw.exports={parseRow:np,searchAll:pW,searchAllToMap:SW,iterateDBI:TW,endsWith:gW,contains:RW,greaterThanCompare:AW,greaterThanEqualCompare:OW,lessThanCompare:bW,lessThanEqualCompare:NW,pushResults:Qi}});var Zo=T((eue,Tw)=>{"use strict";var ri=Ke(),Xce=Q(),Pr=yr(),P_=dt(),ut=Nr().LMDB_ERRORS_ENUM,jce=J(),yW=P(),v_=sp(),{parseRow:wW}=v_,Zce=require("lmdb"),{OVERFLOW_MARKER:fw,MAX_SEARCH_KEY_LENGTH:IW}=P_;function Ew(e,t,r,n=!1,s=void 0,i=void 0){return zi(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(Ew,"iterateFullIndex");function qc(e,t,r,n,s,i=!1,o=void 0,c=void 0,u=!1,_=!1){return zi(e,t,r,(l,d,f,E)=>{let A={transaction:l,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!u:!_,exclusiveStart:i===!0?_:u};return E===r?(A.values=!1,d.getRange(A).map(g=>({value:g}))):d.getRange(A)})}a(qc,"iterateRangeBetween");function zi(e,t,r,n){let s=e.database||e,i=ri.openDBI(s,r);i[P_.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&ri.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(zi,"setupTransaction");function hw(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(fw)){if(!s)if(r)s=ri.openDBI(e,r);else{let u=ri.listDBIs(e);for(let _=0,l=u.length;_<l&&(s=ri.openDBI(e,u[_]),!s[P_.DBI_DEFINITION_NAME].is_hash_attribute);_++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(hw,"getOverflowCheck");function CW(e,t,r,n=!1,s=void 0,i=void 0){if(Pr.validateEnv(e),t===void 0)throw new Error(ut.HASH_ATTRIBUTE_REQUIRED);return zi(e,t,t,(o,c,u)=>(B_(r),r=kc(u,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(_=>wW(_.value,r))))}a(CW,"searchAll");function DW(e,t,r,n=!1,s=void 0,i=void 0){if(Pr.validateEnv(e),t===void 0)throw new Error(ut.HASH_ATTRIBUTE_REQUIRED);B_(r),r=kc(e.database||e,r);let o=new Map;for(let{key:c,value:u}of Ew(e,t,t,n,s,i))o.set(c,v_.parseRow(u,r));return o}a(DW,"searchAllToMap");function LW(e,t,r=!1,n=void 0,s=void 0){if(Pr.validateEnv(e),t===void 0)throw new Error(ut.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=Ew(e,void 0,t,r,n,s),c=o.transaction,u=hw(c.database,c,void 0,t);for(let{key:_,value:l}of o){let d=u(_,l);i[d]===void 0&&(i[d]=[]),i[d].push(l)}return i}a(LW,"iterateDBI");function UW(e,t){if(Pr.validateEnv(e),t===void 0)throw new Error(ut.HASH_ATTRIBUTE_REQUIRED);return ri.statDBI(e,t).entryCount}a(UW,"countAll");function MW(e,t,r,n,s=!1,i=void 0,o=void 0){return ni(e,r,n),zi(e,t,r,(c,u,_,l)=>(n=Pr.convertKeyValueToWrite(n),l===r?u.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:u.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(MW,"equals");function PW(e,t,r){return ni(e,t,r),ri.openDBI(e,t).getValuesCount(r)}a(PW,"count");function vW(e,t,r,n,s=!1,i=void 0,o=void 0){return ni(e,r,n),zi(e,null,r,(c,u)=>{n=Pr.convertKeyValueToWrite(n);let _=!0;typeof n=="number"&&(_=!1);let l;if(s===!0){let d;for(let f of u.getKeys({transaction:c,start:n}))if(!f.startsWith(n)){d=f;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),l=u.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(f=>{let{key:E}=f;if(E!==d){if(E.toString().startsWith(n))return f;if(_===!0)return l.DONE}}),l.filter(f=>f)}else return l=u.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(_===!0)return l.DONE}),_?l:l.filter(d=>d)})}a(vW,"startsWith");function BW(e,t,r,n,s=!1,i=void 0,o=void 0){return mw(e,t,r,n,s,i,o,!0)}a(BW,"endsWith");function mw(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return ni(e,r,n),zi(e,null,r,(u,_,l,d)=>{let f=hw(l,u,d,r);return o=Number.isInteger(o)?o:0,_.getKeys({transaction:u,end:s?!1:void 0,reverse:s}).flatMap(E=>{let h=E.toString();return h.endsWith(fw)?_.getValues(E,{transaction:u}).map(S=>{let p=f(E,S);if(c?p.endsWith(n):p.includes(n))return{key:p,value:S}}).filter(S=>S):(c?h.endsWith(n):h.includes(n))?_[P_.DBI_DEFINITION_NAME].is_hash_attribute?{key:E,value:E}:_.getValues(E,{transaction:u}).map(S=>({key:E,value:S})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(mw,"contains");function HW(e,t,r,n,s=!1,i=void 0,o=void 0){ni(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),qc(e,t,r,n,u,s,i,o,!0,!1)}a(HW,"greaterThan");function xW(e,t,r,n,s=!1,i=void 0,o=void 0){ni(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),qc(e,t,r,n,u,s,i,o,!1,!1)}a(xW,"greaterThanEqual");function FW(e,t,r,n,s=!1,i=void 0,o=void 0){ni(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),qc(e,t,r,u,n,s,i,o,!1,!0)}a(FW,"lessThan");function GW(e,t,r,n,s=!1,i=void 0,o=void 0){ni(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),qc(e,t,r,u,n,s,i,o,!1,!1)}a(GW,"lessThanEqual");function qW(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Pr.validateEnv(e),r===void 0)throw new Error(ut.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(ut.START_VALUE_REQUIRED);if(s===void 0)throw new Error(ut.END_VALUE_REQUIRED);if(n=Pr.convertKeyValueToWrite(n),s=Pr.convertKeyValueToWrite(s),n>s)throw new Error(ut.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return qc(e,t,r,n,s,i,o,c)}a(qW,"between");function kW(e,t,r,n){Pr.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(ut.HASH_ATTRIBUTE_REQUIRED);if(B_(r),r=kc(s,r),n===void 0)throw new Error(ut.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=v_.parseRow(c,r)),o}a(kW,"searchByHash");function VW(e,t,r){Pr.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(ut.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ut.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(VW,"checkHashExists");function $W(e,t,r,n,s=[]){return Sw(e,t,r,n,s),pw(e,t,r,n,s).map(i=>i[1])}a($W,"batchSearchByHash");function YW(e,t,r,n,s=[]){Sw(e,t,r,n,s);let i=new Map;for(let[o,c]of pw(e,t,r,n,s))i.set(o,c);return i}a(YW,"batchSearchByHashToMap");function pw(e,t,r,n,s=[]){return zi(e,t,t,(i,o,c)=>{r=kc(c,r);let u=r.length<3;return n.map(_=>{let l=c.dbis[t].get(_,{transaction:i,lazy:u});if(l)return[_,v_.parseRow(l,r)];s.push(_)}).filter(_=>_)})}a(pw,"batchHashSearch");function Sw(e,t,r,n,s){if(Pr.validateEnv(e),t===void 0)throw new Error(ut.HASH_ATTRIBUTE_REQUIRED);if(B_(r),n==null)throw new Error(ut.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(ut.IDS_MUST_BE_ITERABLE)}a(Sw,"initializeBatchSearchByHash");function B_(e){if(!Array.isArray(e))throw e===void 0?new Error(ut.FETCH_ATTRIBUTES_REQUIRED):new Error(ut.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(B_,"validateFetchAttributes");function ni(e,t,r){if(Pr.validateEnv(e),t===void 0)throw new Error(ut.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ut.SEARCH_VALUE_REQUIRED);if(r?.length>IW)throw new Error(ut.SEARCH_VALUE_TOO_LARGE)}a(ni,"validateComparisonFunctions");function kc(e,t){return t.length===1&&yW.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=ri.listDBIs(e)),t}a(kc,"setGetWholeRowAttributes");Tw.exports={searchAll:CW,searchAllToMap:DW,count:PW,countAll:UW,equals:MW,startsWith:vW,endsWith:BW,contains:mw,searchByHash:kW,setGetWholeRowAttributes:kc,batchSearchByHash:$W,batchSearchByHashToMap:YW,checkHashExists:VW,iterateDBI:LW,greaterThan:HW,greaterThanEqual:xW,lessThan:FW,lessThanEqual:GW,between:qW}});var ea=T((rue,bw)=>{var gw=require("lodash"),Rw=rt(),fe=require("joi"),KW=J(),{hdb_schema_table:Vc,checkValidTable:Aw,hdb_table:Ow,hdb_database:H_}=Yn(),{handleHDBError:WW,hdb_errors:QW}=re(),{getDatabases:zW}=(Re(),ne(Ge)),{HTTP_STATUS_CODES:JW}=QW,XW=fe.object({database:H_,schema:H_,table:Ow,search_attribute:Vc,search_value:fe.any().required(),get_attributes:fe.array().min(1).items(fe.alternatives(Vc,fe.object())).optional(),desc:fe.bool(),limit:fe.number().integer().min(1),offset:fe.number().integer().min(0)}),jW=fe.object({database:H_,schema:H_,table:Ow,operator:fe.string().valid("and","or").default("and").lowercase(),offset:fe.number().integer().min(0),limit:fe.number().integer().min(1),get_attributes:fe.array().min(1).items(fe.alternatives(Vc,fe.object())).optional(),sort:fe.object({attribute:fe.alternatives(Vc,fe.array().min(1)),descending:fe.bool().optional()}).optional(),conditions:fe.array().min(1).items(fe.alternatives(fe.object({operator:fe.string().valid("and","or").default("and").lowercase(),conditions:fe.array()}),fe.object({search_attribute:fe.alternatives(Vc,fe.array().min(1)),search_type:fe.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:fe.when("search_type",{switch:[{is:"equals",then:fe.any()},{is:"between",then:fe.array().items(fe.alternatives([fe.string(),fe.number()])).length(2)}],otherwise:fe.alternatives(fe.string(),fe.number())}).required()}))).required()});bw.exports=function(e,t){let r=null;switch(t){case"value":r=Rw.validateBySchema(e,XW);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(Aw("database",e.schema)),i(Aw("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=Rw.validateBySchema(e,jW);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=KW.checkGlobalSchemaTable(e.schema,e.table);if(s)return WW(new Error,s,JW.NOT_FOUND);let o=zW()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let u=a(l=>{for(let d=0,f=l.conditions.length;d<f;d++){let E=l.conditions[d];E.conditions?u(E):c.push(E.search_attribute)}},"addConditions");t==="conditions"&&u(e);let _=gw.filter(c,l=>l!=="*"&&l.attribute!=="*"&&!Array.isArray(l)&&!gw.some(o,d=>d===l||d.attribute===l||d.attribute===l.attribute));if(_&&_.length>0){let l=_.join(", ");return l=l.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${l}'`)}}return r}});var ip=T((sue,Nw)=>{"use strict";var ZW=Ke(),eQ=ea(),{getSchemaPath:tQ}=ze();Nw.exports=rQ;function rQ(e){let t=eQ(e,"hashes");if(t)throw t;let r=tQ(e.schema,e.table);return ZW.openEnvironment(r,e.table)}a(rQ,"initialize")});var op=T((oue,yw)=>{"use strict";var nQ=Zo(),sQ=ip();yw.exports=iQ;async function iQ(e){let t=await sQ(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return nQ.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(iQ,"lmdbGetDataByHash")});var ta=T((cue,ww)=>{"use strict";var ap=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};ww.exports=ap});var Cw=T((_ue,Iw)=>{"use strict";var lue=ta(),oQ=Zo(),aQ=ip();Iw.exports=cQ;async function cQ(e){let t=await aQ(e),r=global.hdb_schema[e.schema][e.table];return oQ.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(cQ,"lmdbSearchByHash")});var Jn=T((fue,Dw)=>{"use strict";var cp=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,u=!1,_=void 0,l=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=u,this.limit=_,this.offset=l}};Dw.exports=cp});var x_=T((hue,Bw)=>{"use strict";var Qt=Zo(),uQ=Ke(),lQ=J(),Ee=dt(),Ji=P(),_Q=vi(),Lw=Nr().LMDB_ERRORS_ENUM,{getSchemaPath:dQ}=ze(),gs=Ji.SEARCH_WILDCARDS;async function fQ(e,t,r){let n;e.schema===Ji.SYSTEM_SCHEMA_NAME?n=_Q[e.table]:n=global.hdb_schema[e.schema][e.table];let s=vw(e,n.hash_attribute,r,t);return Mw(e,s,n.hash_attribute,r)}a(fQ,"prepSearch");async function Mw(e,t,r,n){let s=dQ(e.schema,e.table),i=await uQ.openEnvironment(s,e.table),o=Pw(i,e,t,r),c=o.transaction||i;if([Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,Ee.SEARCH_TYPES.SEARCH_ALL,Ee.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(EQ(e,r)===!1){let l=e.search_attribute;if(l===r)return n?Uw(o,()=>!0):o.map(f=>({[r]:f.key}));let d=a(f=>({[r]:f.value,[l]:f.key}),"toObject");return n?Uw(o,d):o.map(d)}let _=e.search_attribute===r?o.map(l=>l.key):o.map(l=>l.value);return n===!0?Qt.batchSearchByHashToMap(c,r,e.get_attributes,_):Qt.batchSearchByHash(c,r,e.get_attributes,_)}a(Mw,"executeSearch");function Pw(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:u}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,u=Number.isInteger(u)?u:void 0,r){case Ee.SEARCH_TYPES.EQUALS:s=Qt.equals(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.CONTAINS:s=Qt.contains(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.ENDS_WITH:case Ee.SEARCH_TYPES._ENDS_WITH:s=Qt.endsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.STARTS_WITH:case Ee.SEARCH_TYPES._STARTS_WITH:s=Qt.startsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Qt.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Qt.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ee.SEARCH_TYPES.SEARCH_ALL:return Qt.searchAll(e,n,t.get_attributes,o,c,u);case Ee.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Qt.searchAllToMap(e,n,t.get_attributes,o,c,u);case Ee.SEARCH_TYPES.BETWEEN:s=Qt.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,u);break;case Ee.SEARCH_TYPES.GREATER_THAN:case Ee.SEARCH_TYPES._GREATER_THAN:s=Qt.greaterThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.GREATER_THAN_EQUAL:case Ee.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Qt.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.LESS_THAN:case Ee.SEARCH_TYPES._LESS_THAN:s=Qt.lessThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.LESS_THAN_EQUAL:case Ee.SEARCH_TYPES._LESS_THAN_EQUAL:s=Qt.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;default:return Object.create(null)}return s}a(Pw,"searchByType");function Uw(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(Uw,"createMapFromIterable");function EQ(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(EQ,"checkToFetchMore");function vw(e,t,r,n){if(lQ.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),gs.indexOf(s)>-1)return r===!0?Ee.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Ee.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(gs[0])<0&&s.indexOf(gs[1])<0)return c===!0?r===!0?Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:Ee.SEARCH_TYPES.EQUALS;if(gs.indexOf(i)>=0&&gs.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),Ee.SEARCH_TYPES.CONTAINS;if(gs.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Ee.SEARCH_TYPES.ENDS_WITH;if(gs.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),Ee.SEARCH_TYPES.STARTS_WITH;if(s.includes(gs[0])||s.includes(gs[1]))return Ee.SEARCH_TYPES.EQUALS;throw new Error(Lw.UNKNOWN_SEARCH_TYPE)}else switch(n){case Ji.VALUE_SEARCH_COMPARATORS.BETWEEN:return Ee.SEARCH_TYPES.BETWEEN;case Ji.VALUE_SEARCH_COMPARATORS.GREATER:return Ee.SEARCH_TYPES.GREATER_THAN;case Ji.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Ee.SEARCH_TYPES.GREATER_THAN_EQUAL;case Ji.VALUE_SEARCH_COMPARATORS.LESS:return Ee.SEARCH_TYPES.LESS_THAN;case Ji.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Ee.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(Lw.UNKNOWN_SEARCH_TYPE)}}a(vw,"createSearchTypeFromSearchObject");Bw.exports={executeSearch:Mw,createSearchTypeFromSearchObject:vw,prepSearch:fQ,searchByType:Pw}});var xw=T((Sue,Hw)=>{"use strict";var pue=Jn(),hQ=ea(),mQ=J(),pQ=P(),SQ=x_();Hw.exports=TQ;function TQ(e,t){if(!mQ.isEmpty(t)&&pQ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=hQ(e,"value");if(n)throw n;return SQ.prepSearch(e,t,!0)}a(TQ,"lmdbGetDataByValue")});var $c=T((Rue,Fw)=>{"use strict";var gue=Jn(),gQ=ea(),RQ=J(),AQ=P(),OQ=x_();Fw.exports=bQ;async function bQ(e,t){if(!RQ.isEmpty(t)&&AQ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=gQ(e,"value");if(n)throw n;return OQ.prepSearch(e,t,!1)}a(bQ,"lmdbSearchByValue")});var qw=T((bue,Gw)=>{"use strict";var Oue=dt(),up=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}},lp=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},_p=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};Gw.exports={SearchByConditionsObject:up,SearchCondition:lp,SortAttribute:_p}});var Kw=T((Iue,Yw)=>{"use strict";var yue=qw().SearchByConditionsObject,NQ=Jn(),yQ=ea(),dp=Zo(),F_=dt(),{Resource:wue}=(Rn(),ne(fp)),$w=x_(),wQ=sp(),IQ=require("lodash"),{getSchemaPath:CQ}=ze(),kw=Ke(),{handleHDBError:DQ,hdb_errors:LQ}=re(),{HTTP_STATUS_CODES:UQ}=LQ,MQ=1e8;Yw.exports=PQ;async function PQ(e){let t=yQ(e,"conditions");if(t)throw DQ(t,t.message,UQ.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=CQ(e.schema,e.table),n=await kw.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let _ of e.conditions)kw.openDBI(n,_.search_attribute);let i=IQ.sortBy(e.conditions,_=>{if(_.estimated_count===void 0){let l=_.search_type;l===F_.SEARCH_TYPES.EQUALS?_.estimated_count=dp.count(n,_.search_attribute,_.search_value):l===F_.SEARCH_TYPES.CONTAINS||l===F_.SEARCH_TYPES.ENDS_WITH?_.estimated_count=1/0:_.estimated_count=MQ}return _.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await Vw(o,e,i[0],s.hash_attribute),u;if(!e.operator||e.operator.toLowerCase()==="and"){let _=n.dbis[s.hash_attribute],l=i.slice(1).map($w.filterByType),d=l.length,f=dp.setGetWholeRowAttributes(n,e.get_attributes);u=c.map(E=>_.get(E,{transaction:o,lazy:!0})),d>0&&(u=u.filter(E=>{for(let h=0;h<d;h++)if(!l[h](E))return!1;return!0})),(e.offset||e.limit!==void 0)&&(u=u.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),u=u.map(E=>wQ.parseRow(E,f))}else{for(let d=1;d<i.length;d++){let f=i[d],E=await Vw(o,e,f,s.hash_attribute);c=c.concat(E)}let _=new Set,l=e.offset||0;c=c.filter(d=>_.has(d)?!1:(_.add(d),!0)).slice(l,e.limit&&e.limit+l),u=dp.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return u.onDone=()=>{o.done()},u}a(PQ,"lmdbSearchByConditions");async function Vw(e,t,r,n){let s=new NQ(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===F_.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,$w.searchByType(e,s,i,n).map(o=>o.value)}a(Vw,"executeConditionSearch")});var Yc=T((Due,Ww)=>{"use strict";var vQ=P().OPERATIONS_ENUM,Ep=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=vQ.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Ww.exports=Ep});var hp=T((Uue,tI)=>{"use strict";var Xw=Jn(),jw=Yc(),Zw=$c(),eI=Gc(),ar=P(),Qw=J(),zw=Ke(),{getTransactionAuditStorePath:BQ,getSchemaPath:HQ}=ze(),Jw=Q();tI.exports=xQ;async function xQ(e){try{if(Qw.isEmpty(global.hdb_schema[e.schema])||Qw.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await FQ(e),await GQ(e);let t=HQ(e.schema,e.table);try{await zw.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Jw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=BQ(e.schema,e.table);await zw.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Jw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(xQ,"lmdbDropTable");async function FQ(e){let t=new Xw(ar.SYSTEM_SCHEMA_NAME,ar.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,ar.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[ar.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Zw(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 jw(ar.SYSTEM_SCHEMA_NAME,ar.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await eI(s)}a(FQ,"deleteAttributesFromSystem");async function GQ(e){let t=new Xw(ar.SYSTEM_SCHEMA_NAME,ar.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,ar.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[ar.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,ar.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,ar.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Zw(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 jw(ar.SYSTEM_SCHEMA_NAME,ar.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await eI(s)}catch(i){throw i}}a(GQ,"dropTableFromSystem")});var nI=T((Pue,rI)=>{"use strict";var qQ=require("fs-extra"),kQ=Jn(),VQ=ta(),$Q=Yc(),YQ=hp(),KQ=Gc(),WQ=op(),QQ=$c(),Rs=P(),{getSchemaPath:zQ}=ze(),{handleHDBError:JQ,hdb_errors:XQ}=re(),{HDB_ERROR_MSGS:jQ,HTTP_STATUS_CODES:ZQ}=XQ;rI.exports=ez;async function ez(e){let t;try{t=await tz(e.schema);let r=new kQ(Rs.SYSTEM_SCHEMA_NAME,Rs.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await QQ(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await YQ(c)}catch(u){if(u.message!=="invalid environment")throw u}}let s=new $Q(Rs.SYSTEM_SCHEMA_NAME,Rs.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await KQ(s);let i=zQ(t);await qQ.remove(i)}catch(r){throw r}}a(ez,"lmdbDropSchema");async function tz(e){let t=new VQ(Rs.SYSTEM_SCHEMA_NAME,Rs.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await WQ(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw JQ(new Error,jQ.SCHEMA_NOT_FOUND(e),ZQ.NOT_FOUND,void 0,void 0,!0);return n}a(tz,"validateDropSchema")});var pp=T((Bue,sI)=>{"use strict";var mp=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};sI.exports=mp});var oI=T((Fue,iI)=>{"use strict";var rz=require("fs-extra"),G_=Ke(),{getTransactionAuditStorePath:nz}=ze(),Sp=dt(),xue=pp();iI.exports=sz;async function sz(e){let t;try{let r=nz(e.schema,e.table);await rz.mkdirp(r),t=await G_.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{G_.createDBI(t,Sp.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),G_.createDBI(t,Sp.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),G_.createDBI(t,Sp.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(sz,"createTransactionsAuditEnvironment")});var lI=T((que,uI)=>{"use strict";var Tp=P(),aI=Ke(),iz=qo(),{getSystemSchemaPath:oz,getSchemaPath:az}=ze(),cz=vi(),uz=u_(),gp=c_(),lz=Q(),_z=oI(),Ap=cz.hdb_table,cI=[];for(let e=0;e<Ap.attributes.length;e++)cI.push(Ap.attributes[e].attribute);uI.exports=dz;async function dz(e,t){let r=az(t.schema,t.table),n=new gp(t.schema,t.table,Tp.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new gp(t.schema,t.table,Tp.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new gp(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await aI.createEnvironment(r,t.table),e!==void 0){let o=await aI.openEnvironment(oz(),Tp.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await iz.insertRecords(o,Ap.hash_attribute,cI,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await Rp(n),await Rp(s),await Rp(i)}await _z(t)}catch(o){throw o}}a(dz,"lmdbCreateTable");async function Rp(e){try{await uz(e)}catch(t){lz.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Rp,"createAttribute")});var dI=T((Vue,_I)=>{"use strict";var fz=yc(),Ez=Lc(),hz=U_(),Kc=P(),mz=qo().updateRecords,pz=Ke(),{getSchemaPath:Sz}=ze(),Tz=xc(),gz=Q();_I.exports=Rz;async function Rz(e){try{let{schema_table:t,attributes:r}=fz(e);Ez(e,r,t.hash_attribute),e.schema!==Kc.SYSTEM_SCHEMA_NAME&&(r.includes(Kc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Kc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Kc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Kc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await hz(e.hdb_auth_header,t,r),s=Sz(e.schema,e.table),i=await pz.openEnvironment(s,e.table),o=await mz(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await Tz(e,o)}catch(c){gz.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(Rz,"lmdbUpdateRecords")});var EI=T((Yue,fI)=>{"use strict";var Az=P().OPERATIONS_ENUM,Op=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Az.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};fI.exports=Op});var mI=T((Que,hI)=>{"use strict";var Wue=EI(),Oz=yc(),bz=Lc(),Nz=U_(),Wc=P(),yz=qo().upsertRecords,wz=Ke(),{getSchemaPath:Iz}=ze(),Cz=xc(),Dz=Q(),{handleHDBError:Lz,hdb_errors:Uz}=re();hI.exports=Mz;async function Mz(e){let t;try{t=Oz(e)}catch(u){throw Lz(u,u.message,Uz.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;bz(e,n,r.hash_attribute),e.schema!==Wc.SYSTEM_SCHEMA_NAME&&(n.includes(Wc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(Wc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(Wc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(Wc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await Nz(e.hdb_auth_header,r,n),i=Iz(e.schema,e.table),o=await wz.openEnvironment(i,e.table),c=await yz(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await Cz(e,c)}catch(u){Dz.error(`unable to write transaction due to ${u.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(Mz,"lmdbUpsertRecords")});var SI=T((Jue,pI)=>{"use strict";var bp=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};pI.exports=bp});var gI=T((jue,TI)=>{"use strict";var Np=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}};TI.exports=Np});var OI=T((tle,AI)=>{"use strict";var yp=Ke(),{getTransactionAuditStorePath:Pz}=ze(),ele=SI(),Qc=dt(),vz=J(),RI=gI(),Bz=require("util").promisify,Hz=Bz(setTimeout),xz=1e4,Fz=100;AI.exports=Gz;async function Gz(e){let t=Pz(e.schema,e.table),r=await yp.openEnvironment(t,e.table,!0),n=yp.listDBIs(r);yp.initializeDBIs(r,Qc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new RI;do s=await qz(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 Hz(Fz);while(s.transactions_deleted>0);return i}a(Gz,"deleteAuditLogsBefore");async function qz(e,t){let r=new RI;try{let n=e.dbis[Qc.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[Qc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];vz.isEmpty(c)||(s=e.dbis[Qc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let u=0;u<o.hash_values.length;u++)s=e.dbis[Qc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[u],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>xz)break}return await s,r}catch(n){throw n}}a(qz,"deleteTransactions")});var NI=T((nle,bI)=>{"use strict";var wp=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};bI.exports=wp});var wI=T((ole,yI)=>{"use strict";var kz=Jn(),Vz=Yc(),ile=NI(),Xn=P(),$z=J(),Ip=Ke(),Yz=vi(),Kz=$c(),Wz=Gc(),{getSchemaPath:Qz}=ze();yI.exports=zz;async function zz(e,t=!0){let r;e.schema===Xn.SYSTEM_SCHEMA_NAME?r=Yz[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await Xz(e),s=Qz(e.schema,e.table),i=await Ip.openEnvironment(s,e.table);return t===!0&&await Jz(e,i,r.hash_attribute),Ip.dropDBI(i,e.attribute),n}a(zz,"lmdbDropAttribute");async function Jz(e,t,r){let n=Ip.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:u}of n.getRange({start:!1,versions:!0})){let _={};for(let l in c)l!==i&&(_[l]=c[l]);s=t.dbis[r].put(o,_,u)}await s}a(Jz,"removeAttributeFromAllObjects");async function Xz(e){let t=new kz(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Xn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Xn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Xn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await Kz(t)).filter(o=>o[Xn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if($z.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Xn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new Vz(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Wz(i)}a(Xz,"dropAttributeFromSystem")});var MI=T((ule,UI)=>{"use strict";var Cp=Ke(),ra=dt(),cle=yr(),Dp=P(),II=J(),{getTransactionAuditStorePath:jz}=ze(),Zz=Zo(),q_=Jo(),eJ=Q();UI.exports=tJ;async function tJ(e){let t=jz(e.schema,e.table),r=await Cp.openEnvironment(t,e.table,!0),n=Cp.listDBIs(r);Cp.initializeDBIs(r,ra.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Dp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return CI(r,e.search_values);case Dp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,nJ(r,e.search_values,s);case Dp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return rJ(r,e.search_values);default:return CI(r)}}a(tJ,"readAuditLog");function CI(e,t=[0,Date.now()]){II.isEmpty(t[0])&&(t[0]=0),II.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[ra.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 q_,s))}a(CI,"searchTransactionsByTimestamp");function rJ(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[ra.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,LI(e,i))}return Object.fromEntries(r)}a(rJ,"searchTransactionsByUsername");function nJ(e,t,r){let n=new Map;for(let c=0,u=t.length;c<u;c++){let _=t[c],l=Zz.equals(e,ra.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ra.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,_);for(let{value:d}of l){let f=Number(d);n.has(f)?n.get(f).push(_.toString()):n.set(f,[_.toString()])}}let s=Array.from(n.keys()),i=LI(e,s),o=new Map;for(let c=0;c<i.length;c++){let u=i[c],_=u.timestamp,l=n.get(_);DI(u,"records",r,l,o),DI(u,"original_records",r,l,o)}return Object.fromEntries(o)}a(nJ,"searchTransactionsByHashValues");function DI(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],u=c[r].toString();if(n.indexOf(u)>=0)if(s.has(u)){let _=s.get(u),l=_[_.length-1];if(l.timestamp===i)l[t]=[c];else{let d=new q_(e.operation,e.user_name,i,void 0);d[t]=[c],_.push(d)}}else{let _=new q_(e.operation,e.user_name,i,void 0);_[t]=[c],s.set(u,[_])}}}a(DI,"loopRecords");function LI(e,t){let r=[];try{let n=e.dbis[ra.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 q_,i);r.push(o)}}catch(i){eJ.warn(i)}return r}catch(n){throw n}}a(LI,"batchSearchTransactions")});var vI=T((fle,PI)=>{"use strict";var{getSchemaPath:_le}=ze(),dle=Ke(),{database:sJ}=(Re(),ne(Ge));PI.exports={writeTransaction:iJ};async function iJ(e,t,r){return sJ({database:e,table:t}).transaction(r)}a(iJ,"writeTransaction")});var FI=T((hle,xI)=>{"use strict";var{getSchemaPath:BI}=ze(),HI=Ke();xI.exports={flush:oJ,resetReadTxn:aJ};async function oJ(e,t){return(await HI.openEnvironment(BI(e,t),t.toString())).flushed}a(oJ,"flush");async function aJ(e,t){try{(await HI.openEnvironment(BI(e,t),t.toString())).resetReadTxn()}catch{}}a(aJ,"resetReadTxn")});var VI=T((ple,kI)=>{"use strict";var{Readable:cJ}=require("stream"),{getDatabases:uJ}=(Re(),ne(Ge)),{readSync:lJ,openSync:_J,createReadStream:GI}=require("fs"),{open:dJ}=require("lmdb"),qI=jl(),fJ=e_(),{AUDIT_STORE_OPTIONS:EJ}=(Mi(),ne($I)),{INTERNAL_DBIS_NAME:hJ,AUDIT_STORE_NAME:mJ}=dt();kI.exports=SJ;var Lp=32768,pJ=100;async function SJ(e){let t=e.database||e.schema||"data",r=uJ()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let _=r[s[0]];if(!_)throw new Error(`Can not find table ${s[0]}`);let l=_.dbisDB,d=dJ({noSync:!0,maxDbs:fJ.MAX_DBS}),f,E=d.openDB(hJ,new qI(!1)),h=l.useReadTransaction(),S=0,p=a(async function(A,g){g.encoding="binary",g.encoder=void 0;let v=d.openDB(A,g),H=l.openDB(A,g);for(let{key:M,version:U,value:Y}of H.getRange({transaction:h,versions:H.useVersions}))f=v.put(M,Y,U),S++%pJ===0&&(await new Promise(K=>setTimeout(K,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:A,value:g}of l.getRange({transaction:h,start:!1}))if(s.some(v=>A.startsWith?.(v+"/"))){E.put(A,g);let[,v]=A.split("/"),H=!v,M=new qI(!H,H);await p(A,M)}e.include_audit&&await p(mJ,Object.assign({},EJ)),await f;let R=GI(d.path);return R.headers=u(),R.on("close",()=>{h.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=_J(o.path);return o.transaction(()=>{let _=Buffer.alloc(Lp);lJ(c,_,0,Lp),o.resetReadTxn();let l=o.useReadTransaction();l.renew();let d=GI(null,{fd:c,start:Lp}),f=new cJ.from(async function*(){yield _;for await(let E of d)l.openTimer&&(l.openTimer=0),yield E;l.done()}());return f.headers=u(),f});function u(){let _=new Map;return _.set("content-type","application/octet-stream"),_.set("content-disposition",`attachment; filename="${t}"`),_.set("date",n),_}}a(SJ,"getBackup")});var WI=T((Tle,KI)=>{"use strict";var TJ=Q(),{handleHDBError:gJ}=re(),RJ=ab(),AJ=u_(),OJ=Zm(),bJ=nw(),NJ=Gc(),yJ=op(),wJ=Cw(),IJ=xw(),CJ=$c(),DJ=Kw(),LJ=nI(),UJ=lI(),MJ=dI(),PJ=mI(),vJ=OI(),BJ=hp(),HJ=wI(),xJ=MI(),FJ=vI(),YI=FI(),GJ=VI(),Up=class extends RJ{static{a(this,"LMDBBridge")}async searchByConditions(t){return DJ(t)}async getDataByHash(t){return await yJ(t)}async searchByHash(t){return await wJ(t)}async getDataByValue(t,r){return await IJ(t,r)}async searchByValue(t){return await CJ(t)}async createSchema(t){return await bJ(t)}async dropSchema(t){return await LJ(t)}async createTable(t,r){return await UJ(t,r)}async dropTable(t){return await BJ(t)}async createAttribute(t){return await AJ(t)}async createRecords(t){return await OJ(t)}async updateRecords(t){return await MJ(t)}async upsertRecords(t){try{return await PJ(t)}catch(r){throw gJ(r,null,null,TJ.ERR,r)}}async deleteRecords(t){return await NJ(t)}async dropAttribute(t){return await HJ(t)}async deleteAuditLogsBefore(t){return await vJ(t)}async readAuditLog(t){return await xJ(t)}writeTransaction(t,r,n){return FJ.writeTransaction(t,r,n)}flush(t,r){return YI.flush(t,r)}resetReadTxn(t,r){return YI.resetReadTxn(t,r)}getBackup(t){return GJ(t)}};KI.exports=Up});function YJ(){$J=setInterval(function(){for(let e of Mp)if(e.stale){let t=e[Ae]?.url;JI.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},VJ).unref()}var Pp,zI,JI,qJ,Mp,kJ,zc,QI,Xi,k_,VJ,$J,vp=ge(()=>{Pp=x(yr()),zI=x(re()),JI=x(Q());Rn();Fo();qJ=100,Mp=new Set,kJ=25e3,Xi=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;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.readTxnsUsed=1,Jl(()=>{this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxn.openTimer&&(this.readTxn.openTimer=0)}),Mp.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),Jl(()=>{this.readTxn.use()}),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(Mp.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(zc&&performance.now()-QI>kJ)throw new zI.ServerError("Outstanding write transactions have too long of queue, please try again later",503);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=t.timestamp||(0,Pp.getNextMonotonicTime)());let n=t.retries||0;if(this.validated<this.writes.length)try{let l=this.validated;this.validated=this.writes.length;for(let f=l;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let d;for(let f=l;f<this.validated;f++){let E=this.writes[f];E&&(E.before||E.beforeIntermediate)&&(d=!0)}if(d)return(async()=>{try{for(let f=0;f<2;f++){let E;for(let h=l;h<this.validated;h++){let S=this.writes[h];if(!S)continue;let p=S[f===0?"before":"beforeIntermediate"];if(p){let R=p();E?E.push?E.push(R):E=[E,R]:E=R}}E&&await(E.push?Promise.all(E):E)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(l){throw this.abort(),l}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(l=>l);let c=a(l=>{l.commit(r,l.entry,n)},"doWrite"),u=a(()=>{let l=this.writes[o++];if(l)if(l.key){n>0&&(l.entry=l.store.getEntry(l.key));let d=l.store.ifVersion(l.key,l.entry?.version??null,u);s=s||d}else u();else for(let d of this.writes)c(d)},"nextCondition");if(this.writes.length<qJ>>n?u():s=this.writes[0].store.transaction(()=>{for(let l of this.writes)l.entry=l.store.getEntry(l.key),c(l);return!0}),s)return zc||(zc=s,QI=performance.now(),zc.then(()=>{zc=null})),s.then(l=>l?(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))):(t?t.retries=n+1:t={retries:1},this.commit(t)));let _={txnTime:r};if(this.next){let l=this.next?.commit(t);if(l?.then)return l?.then(d=>({txnTime:r,next:d}));_.next=l}return _}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},k_=class extends Xi{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,Pp.getNextMonotonicTime)())}getReadTxn(){}},VJ=3e4;a(YJ,"startMonitoringTxns");YJ()});function Je(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 Xi;e.timestamp&&(n.timestamp=e.timestamp),n[Ae]=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 u=n.commit({letItLinger:r?.letItLinger});return u.then?u.then(()=>c):c}function o(c){throw n.abort({}),c}}var XI,ji=ge(()=>{XI=require("../../index");Rn();vp();a(Je,"transaction");(0,XI._assignPackageExport)("transaction",Je);Je.commit=function(e){let t=(e[Ae]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Je.abort=function(e){let t=(e[Ae]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var oC={};Ye(oC,{ResourceBridge:()=>xp});function Fp({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 ZI(e,t){let r=jn(e),n=Fp(e,r);if(!r)throw new In.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},o;Je(i,()=>new Promise(_=>o=_));let c=e.ids||e.hash_values,u=0;return{[Symbol.asyncIterator](){return{async next(){if(u<c.length){let _=c[u++],l=await r.get({id:_,lazy:s,select:n},i);return l=l&&$_(l),t?{value:{key:_,value:l}}:{value:l}}else return o(),{done:!0}},return(_){return o(),{value:_,done:!0}},throw(_){return o(),{done:!0}}}}}}function jn(e){let t=e.database||e.schema||WJ,r=Cn()[t];if(!r)throw(0,In.handleHDBError)(new Error,KJ.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function eC(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*tC(e,t,r){let n;for await(let s of e.getHistory(t,r)){let i=s.type;i==="put"&&(i="upsert");let{id:o,version:c,value:u}=s;n?.timestamp===c?(n.hash_values.push(o),n.records.push(u)):(n&&(yield n),n={operation:i,user_name:s.user,timestamp:c,hash_values:[o],records:[u]})}n&&(yield n)}var rC,V_,In,nC,sC,Dn,Bp,Hp,iC,KJ,WJ,QJ,zJ,jI,xp,aC=ge(()=>{"use strict";rC=x(WI()),V_=x(ea()),In=x(re());Re();nC=x(yc()),sC=x(Lc()),Dn=x(P()),Bp=x(Ts()),Hp=x(wn()),iC=x(J());ji();Y_();({HDB_ERROR_MSGS:KJ}=In.hdb_errors),WJ="data",QJ=1e4,zJ=10,xp=class extends rC.default{static{a(this,"ResourceBridge")}constructor(t){super(t),jI=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,V_.default)(t,"conditions");if(r)throw(0,In.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=jn(t);if(!n)throw new In.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:Fp(t,n),sort:t.sort,allowFullScan:!0})}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 In.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}]}ct({database:r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await jn(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=jn(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,u)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,u,()=>r.primaryStore.put(o,c,u)).then(_=>{if(!_){let{value:l,version:d}=r.primaryStore.getEntry(o);return i(o,l,d)}})),"deleteRecord");for(let{key:o,value:c,version:u}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,u),await new Promise(_=>setImmediate(_));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){jn(t).dropTable()}createSchema(t){return Jc({database:t.schema,table:null}),Bp.signalSchemaChange(new Hp.SchemaEventMsg(process.pid,Dn.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Gp(t.schema),Bp.signalSchemaChange(new Hp.SchemaEventMsg(process.pid,Dn.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,jI.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,nC.default)(t);(0,sC.default)(t,n,r.primaryKey);let s,i=Cn()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt};return Je(o,async c=>{if(!i.schemaDefined){s=[];for(let l of n)i.attributes.find(f=>f.name==l)||s.push(l);s.length>0&&await i.addAttributes(s.map(l=>({name:l,indexed:!0})))}let u=[],_=[];for(let l of t.records){let d=await i.get(l[i.primaryKey],o);if(t.requires_existing&&!d||t.requires_no_existing&&d){_.push(l[i.primaryKey]);continue}d&&(d=$_(d));for(let f in l)if(Object.prototype.hasOwnProperty.call(l,f)){let E=l[f];if(typeof E=="function")try{let h=E([[d]]);Array.isArray(h)&&(E=h[0].func_val,l[f]=E)}catch(h){throw h.message+="Trying to set key "+f+" on object"+JSON.stringify(l),h}}if(d)for(let f in d)Object.prototype.hasOwnProperty.call(l,f)||(l[f]=d[f]);await i.put(l,o),u.push(l[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:u,new_attributes:s,skipped_hashes:_}})}async deleteRecords(t){let r=Cn()[t.schema][t.table],n={user:t.hdb_user};return Je(n,async s=>{let i=t.hash_values||t.records.map(u=>u[r.primaryKey]),o=[],c=[];for(let u of i)await r.delete(u,n)?o.push(u):c.push(u);return eC(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Cn()[t.schema][t.table];if(!r.createdTimeProperty)throw new In.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:Dn.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,u=[],_=a(async()=>{let l=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:u});i.push(...l.deleted_hashes),o.push(...l.skipped_hashes),await(0,iC.async_set_timeout)(zJ),u=[],s=!0},"chunkDelete");for await(let l of n)u.push(l[r.primaryKey]),c++,c%QJ===0&&await _();return u.length>0&&await _(),s?eC(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,V_.default)(t,"hashes");if(r)throw r;return ZI(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of ZI(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Dn.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,V_.default)(t,"value");if(n)throw n;let s=jn(t);if(!s)throw new In.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===Dn.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:Fp(t,s)})}async getDataByValue(t,r){let n=new Map,s=jn(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){jn({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return jn(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=jn(t),n={};switch(t.search_type){case Dn.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case Dn.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of tC(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return tC(r,t.search_values?.[0],t.search_values?.[1])}}};a(Fp,"getSelect");a(ZI,"getRecords");a(jn,"getTable");a(eC,"createDeleteResponse");a(tC,"groupRecordsInHistory")});var bn=T((vle,cC)=>{"use strict";var{ResourceBridge:JJ}=(aC(),ne(oC)),XJ=te();XJ.initSync();var K_;function jJ(){return K_||(K_=new JJ,K_)}a(jJ,"getBridge");cC.exports=jJ()});var dC=T((Hle,_C)=>{"use strict";var uC=require("lodash"),Xc=require("mathjs"),ZJ=require("jsonata"),lC=J();_C.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?uC.uniqWith(e,uC.isEqual):e,searchJSON:e2,mad:jc.bind(null,Xc.mad),mean:jc.bind(null,Xc.mean),mode:jc.bind(null,Xc.mode),prod:jc.bind(null,Xc.prod),median:jc.bind(null,Xc.median)};function jc(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(jc,"aggregateFunction");function e2(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(lC.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),lC.isEmpty(this.__ala__.res[r])){let n=ZJ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(e2,"searchJSON")});var EC=T((Fle,fC)=>{"use strict";var Et=require("moment"),qp="YYYY-MM-DDTHH:mm:ss.SSSZZ";Et.suppressDeprecationWarnings=!0;fC.exports={current_date:()=>Et().utc().format("YYYY-MM-DD"),current_time:()=>Et().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return Et(e).utc().format("YYYY");case"month":return Et(e).utc().format("MM");case"day":return Et(e).utc().format("DD");case"hour":return Et(e).utc().format("HH");case"minute":return Et(e).utc().format("mm");case"second":return Et(e).utc().format("ss");case"millisecond":return Et(e).utc().format("SSS");default:break}},date:e=>Et(e).utc().format(qp),date_format:(e,t)=>Et(e).utc().format(t),date_add:(e,t,r)=>Et(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>Et(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=Et(e).utc(),s=Et(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>Et().utc().valueOf(),get_server_time:()=>Et().format(qp),offset_utc:(e,t)=>Et(e).utc().utcOffset(t).format(qp)}});var SC=T((Gle,pC)=>{"use strict";var t2=require("@turf/area"),r2=require("@turf/length"),n2=require("@turf/circle"),s2=require("@turf/difference"),i2=require("@turf/distance"),o2=require("@turf/boolean-contains"),a2=require("@turf/boolean-equal"),c2=require("@turf/boolean-disjoint"),u2=require("@turf/helpers"),hC=P(),me=J(),As=Q();pC.exports={geoArea:l2,geoLength:_2,geoCircle:d2,geoDifference:f2,geoDistance:mC,geoNear:E2,geoContains:h2,geoEqual:m2,geoCrosses:p2,geoConvert:S2};function l2(e){if(me.isEmpty(e))return NaN;typeof e=="string"&&(e=me.autoCastJSON(e));try{return t2.default(e)}catch(t){return As.trace(t,e),NaN}}a(l2,"geoArea");function _2(e,t){if(me.isEmpty(e))return NaN;typeof e=="string"&&(e=me.autoCastJSON(e));try{return r2.default(e,{units:t||"kilometers"})}catch(r){return As.trace(r,e),NaN}}a(_2,"geoLength");function d2(e,t,r){if(me.isEmpty(e))return NaN;if(me.isEmpty(t))return NaN;typeof e=="string"&&(e=me.autoCastJSON(e));try{return n2.default(e,t,{units:r||"kilometers"})}catch(n){return As.trace(n,e,t),NaN}}a(d2,"geoCircle");function f2(e,t){if(me.isEmpty(e))return NaN;if(me.isEmpty(t))return NaN;typeof e=="string"&&(e=me.autoCastJSON(e)),typeof t=="string"&&(t=me.autoCastJSON(t));try{return s2(e,t)}catch(r){return As.trace(r,e,t),NaN}}a(f2,"geoDifference");function mC(e,t,r){if(me.isEmpty(e))return NaN;if(me.isEmpty(t))return NaN;typeof e=="string"&&(e=me.autoCastJSON(e)),typeof t=="string"&&(t=me.autoCastJSON(t));try{return i2.default(e,t,{units:r||"kilometers"})}catch(n){return As.trace(n,e,t),NaN}}a(mC,"geoDistance");function E2(e,t,r,n){if(me.isEmpty(e)||me.isEmpty(t))return!1;if(me.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=me.autoCastJSON(e)),typeof t=="string"&&(t=me.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return mC(e,t,n)<=r}catch(s){return As.trace(s,e,t),!1}}a(E2,"geoNear");function h2(e,t){if(me.isEmpty(e)||me.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=me.autoCastJSON(e)),typeof t=="string"&&(t=me.autoCastJSON(t));try{return o2.default(e,t)}catch(r){return As.trace(r,e,t),!1}}a(h2,"geoContains");function m2(e,t){if(me.isEmpty(e)||me.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=me.autoCastJSON(e)),typeof t=="string"&&(t=me.autoCastJSON(t));try{return a2.default(e,t)}catch(r){return As.trace(r,e,t),!1}}a(m2,"geoEqual");function p2(e,t){if(me.isEmpty(e)||me.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=me.autoCastJSON(e)),typeof t=="string"&&(t=me.autoCastJSON(t));try{return!c2.default(e,t)}catch(r){return As.trace(r,e,t),!1}}a(p2,"geoCrosses");function S2(e,t,r){if(me.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(me.isEmpty(t))throw new Error("geo_type is required");if(me.isEmpty(hC.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(hC.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=me.autoCastJSON(e)),u2[t](e,r)}a(S2,"geoConvert")});var W_=T((kle,TC)=>{var Zi=dC(),vr=EC(),Zn=SC();TC.exports=e=>{e.aggr.mad=e.aggr.MAD=Zi.mad,e.aggr.mean=e.aggr.MEAN=Zi.mean,e.aggr.mode=e.aggr.MODE=Zi.mode,e.aggr.prod=e.aggr.PROD=Zi.prod,e.aggr.median=e.aggr.MEDIAN=Zi.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Zi.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Zi.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=vr.current_date,e.fn.current_time=e.fn.CURRENT_TIME=vr.current_time,e.fn.extract=e.fn.EXTRACT=vr.extract,e.fn.date=e.fn.DATE=vr.date,e.fn.date_format=e.fn.DATE_FORMAT=vr.date_format,e.fn.date_add=e.fn.DATE_ADD=vr.date_add,e.fn.date_sub=e.fn.DATE_SUB=vr.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=vr.date_diff,e.fn.now=e.fn.NOW=vr.now,e.fn.offset_utc=e.fn.OFFSET_UTC=vr.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=vr.get_server_time,e.fn.getdate=e.fn.GETDATE=vr.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=vr.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Zn.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Zn.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Zn.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Zn.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Zn.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Zn.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Zn.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Zn.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Zn.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Zn.geoNear}});var OC=T((Vle,AC)=>{"use strict";var Zc=require("lodash"),cr=require("alasql");cr.options.cache=!1;var T2=W_(),gC=require("clone"),Q_=require("recursive-iterator"),le=Q(),Ce=J(),na=bn(),g2=P(),{hdb_errors:R2}=re(),{getDatabases:RC}=(Re(),ne(Ge)),A2="IS NULL",Ln="There was a problem performing this search. Please check the logs and try again.";T2(cr);var kp=class{static{a(this,"SQLSearch")}constructor(t,r){if(Ce.isEmpty(t))throw le.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(),Ce.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Ce.isEmptyOrZeroLength(n))return le.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw le.error("Error thrown from checkEmptySQL in SQLSearch class method search."),le.error(n),new Error(Ln)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw le.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),le.error(n),new Error(Ln)}if(Object.keys(this.data).length===0)return le.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw le.error("Error thrown from processJoins in SQLSearch class method search."),le.error(n),new Error(Ln)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw le.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),le.error(n),new Error(Ln)}try{return t=await this._finalSQL(),t}catch(n){throw le.error("Error thrown from finalSQL in SQLSearch class method search."),le.error(n),new Error(Ln)}}_getColumns(){let t=new Q_(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(gC(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=Zc.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=RC()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Ce.isEmpty(this.statement.where)){le.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new Q_(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Ce.isEmpty(r)&&r.right)if(Ce.isNotEmptyAndHasValue(r.right.value)){let n=Ce.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new cr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Ce.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new cr.yy.LogicValue({value:i}):n instanceof cr.yy.StringValue&&Ce.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new cr.yy.NumValue({value:i}))});if(t){le.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new Q_(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(!Ce.isEmpty(g2.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Ce.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Ce.isEmptyOrZeroLength(r.left.columnid)||Ce.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(Ce.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"=":!Ce.isEmpty(r.right.value)||!Ce.isEmpty(r.left.value)?n.add(Ce.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let u=Array.isArray(r.right)?r.right:r.left;for(let _=0;_<u.length;_++)if(u[_].value)n.add(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(Ce.isEmptyOrZeroLength(this.all_table_attributes)&&Ce.isEmptyOrZeroLength(this.statement.from)&&Ce.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&&Zc.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(Ce.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Ce.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(Ce.isEmptyOrZeroLength(this.all_table_attributes)&&!Ce.isEmptyOrZeroLength(this.columns.columns))return t;if(Ce.isEmptyOrZeroLength(this.all_table_attributes)&&Ce.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await cr.promise(r)}catch(r){throw le.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),le.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(gC(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(Ce.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(A2)>-1&&this.tables.forEach(s=>{let i={columnid:RC()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=Zc.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]},u=!1,_=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(u=!0),!Ce.isEmpty(this.exact_search_values[_])&&!this.exact_search_values[_].ignore&&!Ce.isEmptyOrZeroLength(this.exact_search_values[_].values))if(u)try{c.hash_values=Array.from(this.exact_search_values[_].values);let l=await na.getDataByHash(c);for(let d of c.hash_values)l.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(l){throw le.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),le.error(l),new Error(Ln)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[_].values).map(async l=>{let d=Object.assign({},c);d.search_value=l;let f=await na.getDataByValue(d);for(let[E,h]of f)this.data[i].__merged_data[E]?this._updateMergedAttribute(i,E,s.attribute,h[s.attribute]):(this.data[i].__merged_data[E]=[...n[i]],this._updateMergedAttribute(i,E,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,E))}))}catch(l){throw le.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),le.error(l),new Error(Ln)}else if(!Ce.isEmpty(this.comparator_search_values[_])&&!this.comparator_search_values[_].ignore&&!Ce.isEmptyOrZeroLength(this.comparator_search_values[_].comparators))try{let l=this.comparator_search_values[_].comparators;for(let d=0,f=l.length;d<f;d++){let E=l[d];c.search_attribute=E.attribute,c.search_value=E.search_value;let h=await na.getDataByValue(c,E.operation);if(u)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,p]of h)this.data[i].__merged_data[S]?this._updateMergedAttribute(i,S,s.attribute,p[s.attribute]):(this.data[i].__merged_data[S]=[...n[i]],this._updateMergedAttribute(i,S,s.attribute,p[s.attribute]),this._setMergedHashAttribute(i,S))}}catch(l){throw le.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),le.error(l),new Error(Ln)}else try{c.search_attribute=s.attribute,c.search_value="*";let l=await na.getDataByValue(c);if(u)for(let[d]of l)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,f]of l)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,f[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,f[s.attribute]),this._setMergedHashAttribute(i,d))}catch(l){throw le.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),le.error(l),new Error(Ln)}}}_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 cr.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 cr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new cr.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 cr.yy.FuncValue:new cr.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(E=>{E.joinmode&&E.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(E.table);let h=E.joinmode+" JOIN ? AS "+(E.as?E.as:E.table.tableid);E.on&&(h+=" ON "+E.on.toString()),i.push(h),t.push(Object.values(this.data[`${E.table.databaseid_orig}_${E.table.as?E.table.as_orig:E.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(E=>{let h=this.data[`${E.databaseid_orig}_${E.as?E.as_orig:E.tableid_orig}`].__hash_name,S=E.as?E.as_orig:E.tableid_orig;o.push({key:`'${S}.${h}'`,schema:E.databaseid_orig,table:E.as?E.as_orig:E.tableid_orig,keys:new Set}),r.push(`${E.as?E.as:E.tableid}.\`${h}\` AS "${S}.${h}"`),c[E.as?E.as_orig:E.tableid_orig]=this.data[`${E.databaseid_orig}_${E.as?E.as_orig:E.tableid_orig}`].__merged_attributes});let u=this.statement.where?"WHERE "+this.statement.where:"";u=u.replace(/NOT\(NULL\)/g,"NOT NULL");let _="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(_="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(E=>{E.is_func?r.push(E.initial_select_column.toString()):E.initial_select_column.tableid?r.push(`${E.initial_select_column.tableid}.${E.initial_select_column.columnid} AS ${E.expression.columnid}`):r.push(`${E.initial_select_column.columnid} AS ${E.expression.columnid}`)}));let l="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(l=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let f=[];try{let E=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${u} ${_} ${l} ${d}`,h=this._convertColumnsToIndexes(E,s);f=await cr.promise(h,t),t=null}catch(E){throw le.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),le.error(E),new Error("There was a problem processing the data.")}if(f&&f.length>0){for(let E=0,h=f.length;E<h;E++){let S=f[E];o.forEach(p=>{S[p.key]!==null&&S[p.key]!==void 0&&p.keys.add(S[p.key])})}o.forEach(E=>{let h=Object.keys(this.data[`${E.schema}_${E.table}`].__merged_data),S=Zc.difference(h,[...E.keys].map(p=>p.toString()));for(let p=0,R=S.length;p<R;p++){let A=S[p];delete this.data[`${E.schema}_${E.table}`].__merged_data[A]}})}return{existing_attributes:c,joined_length:f?f.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new Q_(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=Zc.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 le.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),le.error(i),new Error(Ln)}}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 l in i)o.push(i[l][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},u=await na.getDataByHash(c),_=s.columns.length;for(let l=0,d=o.length;l<d;l++){let f=o[l],E=u.get(f);for(let h=0;h<_;h++){let S=s.columns[h],p=E[S]===void 0?null:E[S];this.data[n].__merged_data[f].push(p)}}}}catch(r){throw le.error("Error thrown from getDataByHash function in SQLSearch class method getData."),le.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,u=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===u}).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();le.trace(`Final SQL: ${s}`),n=await cr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),le.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw le.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),le.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 le.error(R2.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),le.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 u=s[i],_=new RegExp(`${u}.\`${o}\``,"g"),l=`${u}.[${c}]`;n=n.replace(_,l)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let u=new RegExp(`\`${o}\``,"g"),_=`[${c}]`;n=n.replace(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 na.getDataByValue(i);for(let[c,u]of o)this.data[s].__merged_data[c]||(u[n.attribute]===void 0&&(u[n.attribute]=null),this.data[s].__merged_data[c]=Object.assign({},r[s])),this.data[s].__merged_data[c][t[n.attribute]]=u[n.attribute]??null}catch(o){throw le.error("There was an error when processing this SQL operation. Check your logs"),le.error(o),new Error(Ln)}}return Object.values(Object.values(this.data)[0].__merged_data)}};AC.exports=kp});var Zr=T((Yle,bC)=>{"use strict";var O2=ib();bC.exports={searchByConditions:N2,searchByHash:y2,searchByValue:w2,search:I2};var Vp=bn(),{transformReq:$p}=J(),b2=OC();async function N2(e){return $p(e),Vp.searchByConditions(e)}a(N2,"searchByConditions");async function y2(e){$p(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of Vp.searchByHash(e))r&&t.push(r);return t}a(y2,"searchByHash");async function w2(e){$p(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of Vp.searchByValue(e))t.push(r);return t}a(w2,"searchByValue");function I2(e,t){try{let r=new O2(e);r.validate(),new b2(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(I2,"search")});var z_=T((Wle,NC)=>{"use strict";var C2=bn();NC.exports={writeTransaction:D2};function D2(e,t,r){return C2.writeTransaction(e,t,r)}a(D2,"writeTransaction")});var CC=T((Jle,IC)=>{"use strict";var L2=Zr(),U2=Xs(),yC=Q(),M2=en(),zle=z_(),P2=require("clone"),Kp=require("alasql"),v2=W_(),wC=require("util"),B2=wC.promisify(U2.getTableSchema),H2=wC.promisify(L2.search),x2=P(),Yp=J();v2(Kp);IC.exports={update:G2};var F2="There was a problem performing this update. Please check the logs and try again.";async function G2({statement:e,hdb_user:t}){let r=await B2(e.table.databaseid,e.table.tableid),n=q2(e.columns);Yp.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=P2(s),c=Yp.isEmpty(i)?"":` WHERE ${i.toString()}`,u=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,_=Kp.parse(u).statements[0],l=await H2(_),d=k2(n,l);return V2(o,d,t)}a(G2,"update");function q2(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=Kp.compile(`SELECT ${r.expression.toString()} AS [${x2.FUNC_VAL}] FROM ?`)}),t}catch(t){throw yC.error(t),new Error(F2)}}a(q2,"createUpdateRecord");function k2(e,t){return Yp.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(k2,"buildUpdateRecords");async function V2(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await M2.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){yC.error(`Error delete new_attributes from update response: ${i}`)}return s}a(V2,"updateRecords")});var LC=T((e_e,DC)=>{var $2=require("alasql"),Y2=Zr(),K2=Q(),W2=bn(),Qp=require("util"),Wp=J(),Q2=P(),z2=Xs(),jle=z_(),Zle=en(),J2="record",X2="successfully deleted",j2=Qp.callbackify(r4),Z2=Qp.promisify(Y2.search),e4=Qp.promisify(z2.getTableSchema);DC.exports={convertDelete:j2};function t4(e){return`${e.deleted_hashes.length} ${J2}${e.deleted_hashes.length===1?"":"s"} ${X2}`}a(t4,"generateReturnMessage");async function r4({statement:e,hdb_user:t}){let r=await e4(e.table.databaseid,e.table.tableid);Wp.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=Wp.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=$2.parse(o).statements[0],u={operation:Q2.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{u.records=await Z2(c);let _=await W2.deleteRecords(u);return Wp.isEmptyOrZeroLength(_.message)&&(_.message=t4(_)),delete _.txn_time,_}catch(_){throw K2.error(_),_.hdb_code?_.message:_}}a(r4,"convertDelete")});var BC=T((r_e,vC)=>{"use strict";var n4=Hi(),{hdb_errors:UC}=re(),{getDatabases:MC}=(Re(),ne(Ge));vC.exports={checkSchemaExists:PC,checkSchemaTableExists:s4,schema_describe:n4};async function PC(e){if(!MC()[e])return UC.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(PC,"checkSchemaExists");async function s4(e,t){let r=await PC(e);if(r)return r;if(!MC()[e][t])return UC.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(s4,"checkSchemaTableExists")});var eu=T((s_e,i4)=>{i4.exports={name:"harperdb",version:"4.3.0-beta.7",description:"HarperDB is a distributed SQL & NoSQL data platform focused on speed, flexibility, and ease of use.",keywords:["database","sql","nosql","api","distributed","cloud","enterprise","Fastify","NATS"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.1","nats-server":"2.10.1"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive",build:"eslint -c ./.eslintbuild bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",pretty:"eslint --fix bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test"},dependencies:{"@aws-sdk/abort-controller":"3.374.0","@aws-sdk/client-s3":"3.477.0","@aws-sdk/lib-storage":"3.477.0","@endo/static-module-record":"^1.0.0","@fastify/autoload":"5.7.1","@fastify/compress":"~6.5.0","@fastify/cors":"~8.5.0","@fastify/static":"~6.11.2","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.5.4",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.1",fastify:"~4.25.1","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.8.1","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.11.0","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.6",jsonwebtoken:"9.0.2",lmdb:"2.10.0-beta.3",lodash:"4.17.21",mathjs:"11.11.2",minimist:"1.2.8",mkcert:"1.5.1",moment:"2.29.4","mqtt-packet":"~8.2.1",msgpackr:"1.10.1",nats:"2.17.0",needle:"3.2.0","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.1",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.3.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^0.18.0","serve-static":"1.15.0",ses:"1.0.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.21.20","tar-fs":"2.1.1",ulidx:"0.5.0",uuid:"9.0.1","validate.js":"0.13.1",ws:"8.15.1",yaml:"2.3.4"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"latest","@typescript-eslint/eslint-plugin":"^5.55.0","@typescript-eslint/parser":"^5.55.0",axios:"1.6.2",chai:"4.3.7","chai-integer":"0.1.0",esbuild:"^0.19.1",eslint:"8.22.0","eslint-config-prettier":"8.3.0","eslint-plugin-prettier":"3.4.1","eslint-plugin-radar":"0.2.1",eventsource:"^2.0.2","hook-std":"3.0.0","intercept-stdout":"0.1.2",mocha:"^10.2.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.7",newman:"5.3.2","newman-reporter-html":"1.0.5","newman-reporter-htmlextra":"^1.22.11","newman-reporter-teamcity":"^0.1.12","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"2.8.4",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.3.3","why-is-node-still-running":"^1.0.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},"newman-reporter-html":{newman:"5.3.2"},alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","utf-8-validate":"^5.0.10"}}});var iu={};Ye(iu,{addAnalyticsListener:()=>su,recordAction:()=>Br,recordActionBinary:()=>rn,setAnalyticsEnabled:()=>o4});function o4(e){YC=e}function Br(e,t,r,n,s){if(!YC)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=j_.get(i);if(o)if(typeof e=="number"){let c=o.values,u=c.index++;if(u>=c.length){let _=c;o.values=c=new Float32Array(u*2),c.set(_),c.index=u+1}c[u]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},j_.set(i,o)}J_||a4()}function rn(e,t,r,n,s){Br(!!e,t,r,n,s)}function su(e){QC.push(e)}function a4(){J_=performance.now(),setTimeout(async()=>{let e=performance.now()-J_;J_=0;let t=[],r={time:Date.now(),period:e,threadId:eo.threadId,metrics:t};for(let[s,i]of j_){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,u=0,_=[],l;for(let d of zC){let f=Math.floor(c*d),E=o[f-1];if(f>u){let h=f-u;if(E===l){let S=_[_.length-1];typeof S=="number"?_[_.length-1]={value:S,count:1+h}:S.count+=h}else _.push(h>1?{value:E,count:h}:E),l=E;u=f}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:_,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 JC()}let n=process.memoryUsage();t.push({metric:"memory",threadId:eo.threadId,byThread:!0,...n});for(let s of QC)s(t);j_=new Map,eo.parentPort?eo.parentPort.postMessage({type:WC,report:r}):ZC({report:r})},KC).unref()}async function c4(e,t=6e4){let r=Xp(),n=XC(),s=new Promise(S=>{let p=performance.now();setImmediate(()=>{let R=performance.now();R-p>5e3&&(0,tu.warn)("Unusually high event queue latency on the main thread of "+Math.round(R-p)+"ms"),p=performance.now()}),n.primaryStore.prefetch([1],()=>{let R=performance.now();R-p>5e3&&(0,tu.warn)("Unusually high task queue latency on the main thread of "+Math.round(R-p)+"ms"),S(R-p)})}),i;for(let S of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(S.value?.time){i=S.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,u=new Map,_=[],l;for(let{key:S,value:p}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!p)continue;if(o){if(S>o+t)break}else o=S;l=S;let{metrics:R,threadId:A}=p;for(let g of R||[]){let{path:v,method:H,type:M,metric:U,count:Y,total:K,distribution:V,threads:ce,...de}=g;Y||(Y=1);let xe=U+(v?"-"+v:"");H!==void 0&&(xe+="-"+H),M!==void 0&&(xe+="-"+M);let ae=c.get(xe);if(ae){if(ae.threads){let Ve=ae.threads[A];if(Ve)ae=Ve;else{ae.threads[A]=Object.assign({},de);continue}}ae.count||(ae.count=1);let Oe=ae.count;for(let Ve in de){let Fn=de[Ve];typeof Fn=="number"&&(ae[Ve]=(ae[Ve]*Oe+Fn*Y)/(Oe+Y))}ae.count+=Y,K>=0&&(ae.total+=K,ae.ratio=ae.total/ae.count)}else ae=Object.assign({period:t},g),delete ae.distribution,c.set(xe,ae),ae.byThread&&(ae.threads=[],ae.threads[A]=Object.assign({},de),_.push(ae));if(V){V=V.map(Ve=>typeof Ve=="number"?{value:Ve,count:1}:Ve);let Oe=u.get(xe);Oe?Oe.push(...V):u.set(xe,V)}}await JC()}for(let S of _){let{path:p,method:R,type:A,metric:g,count:v,total:H,distribution:M,threads:U,...Y}=S;U=U.filter(K=>K);for(let K in Y){if(typeof S[K]!="number")continue;let V=0;for(let ce of U){let de=ce[K];typeof de=="number"&&(V+=de)}S[K]=V}S.count=U.length,delete S.threads,delete S.byThread}for(let[S,p]of u){let R=c.get(S);p.sort((Ve,Fn)=>Ve.value>Fn.value?1:-1);let A=R.count-1,g=[],v=0,H=0,M;for(let Ve of zC){let Fn=A*Ve;for(;v<Fn;)M=p[H++],v+=M.count,H===1&&v--;let Mo=p[H>1?H-2:0];M||(M=p[0]),g.push(M.value-(M.value-Mo.value)*(v-Fn)/M.count)}let[U,Y,K,V,ce,de,xe,ae,Oe]=g;Object.assign(R,{p1:U,p10:Y,p25:K,median:V,p75:ce,p90:de,p95:xe,p99:ae,p999:Oe})}let d;for(let[S,p]of c)p.id=(0,X_.getNextMonotonicTime)(),p.time=l,n.primaryStore.put(p.id,p,{append:!0}).then(R=>{R||n.primaryStore.put(p.id,p)}),d=!0;let f=Date.now(),{idle:E,active:h}=performance.eventLoopUtilization();if(d||h*10>E){let S=(0,X_.getNextMonotonicTime)(),p={id:S,metric:"main-thread-utilization",idle:E-HC,active:h-xC,taskQueueLatency:await s,time:f,...process.memoryUsage()};n.primaryStore.put(S,p,{append:!0}).then(R=>{R||n.primaryStore.put(S,p)})}HC=E,xC=h}async function FC(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function Xp(){return GC||(GC=ct({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function XC(){return qC||(qC=ct({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function _4(){jC=!0;let e=(0,nu.get)(Jp.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await c4(KC,e),await FC(Xp(),u4),await FC(XC(),l4)},Math.min(e/2,2147483647)).unref()}function ZC(e,t){let r=e.report;r.threadId=t?.threadId||eo.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(kC+=n.mean*n.count);r.totalBytesProcessed=kC,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(VC.get(t))}),VC.set(t,t.performance.eventLoopUtilization())),r.id=(0,X_.getNextMonotonicTime)(),Xp().primaryStore.put(r.id,r),jC||_4(),d4&&(eD=E4(r))}async function E4(e){if(await eD,!si){let r=(0,ru.dirname)((0,tu.getLogFilePath)());try{si=await(0,zp.open)((0,ru.join)(r,"analytics.log"),"r+")}catch{si=await(0,zp.open)((0,ru.join)(r,"analytics.log"),"w+")}}let t=(await si.stat()).size;if(t>f4){let r=Buffer.alloc(t);await si.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await si.write(r,{position:0}),await si.truncate(r.length),t=r.length}await si.write(JSON.stringify(e)+`
|
|
8
|
-
`,t)}var
|
|
6
|
+
`)},B1="certificate.pem",H1="privateKey.pem",x1="ca.pem";eN.exports={CERTIFICATE_VALUES:v1,CERTIFICATE_PEM_NAME:B1,PRIVATEKEY_PEM_NAME:H1,CA_PEM_NAME:x1}});var Bm=g((jae,oN)=>{"use strict";var iN=require("fs-extra"),ie=require("joi"),G1=require("os"),{boolean:ye,string:ar,number:Rt,array:vm}=ie.types(),{totalmem:rN}=require("os"),ki=require("path"),F1=K(),I_=z(),Xae=tN(),nN=U(),q1=tt(),sN="log",k1="components",V1="Invalid logging.rotation.maxSize unit. Available units are G, M or K",$1="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",Y1="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",K1="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",W1="rootPath config parameter is undefined",Q1="clustering.enabled config parameter is undefined",Vi=Rt.min(0).required(),w_=vm.items({host:ar.required(),port:Vi}).empty(null),zn;oN.exports={configValidator:z1,routesValidator:tY,route_constraints:w_};function z1(e){if(zn=e.rootPath,I_.isEmpty(zn))throw W1;let t=ye.required(),r=Rt.min(0).max(1e3).empty(null).default(eY),n=ar.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(Dc),s=ar.optional().empty(null),i=ar.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),o=ie.string().empty(null).default(Dc),c=ie.custom(X1).empty(null).default(Dc),u=e.clustering?.enabled;if(I_.isEmpty(u))throw Q1;let _;return u===!0?_=ie.object({enabled:t,hubServer:ie.object({cluster:ie.object({name:ie.required().empty(null),network:ie.object({port:Vi,routes:w_}).required()}).required(),leafNodes:ie.object({network:ie.object({port:Vi}).required()}).required(),network:ie.object({port:Vi}).required()}).required(),leafServer:ie.object({network:ie.object({port:Vi,routes:w_}).required(),streams:ie.object({maxAge:Rt.min(120).allow(null).optional(),maxBytes:Rt.min(1).allow(null).optional(),maxMsgs:Rt.min(1).allow(null).optional(),path:o}).required()}).required(),logLevel:ie.valid("error","warn","info","debug","trace"),nodeName:i,republishMessages:ye.optional(),databaseLevel:ye.optional(),tls:ie.object({certificate:s,certificateAuthority:s,privateKey:s,insecure:ye.required(),verify:ye.optional()}),user:ar.optional().empty(null)}).required():_=ie.object({enabled:t,tls:ie.object({certificate:s,certificateAuthority:s,privateKey:s,insecure:ye.required()})}).required(),ie.object({authentication:ie.object({authorizeLocal:ye,cacheTTL:Rt.required(),enableSessions:ye}),analytics:ie.object({aggregatePeriod:Rt}),componentsRoot:n.optional(),clustering:_,localStudio:ie.object({enabled:t}).required(),logging:ie.object({auditAuthEvents:ie.object({logFailed:ye,logSuccessful:ye}),file:ye.required(),level:ie.valid("notify","fatal","error","warn","info","debug","trace"),rotation:ie.object({enabled:ye.optional(),compress:ye.optional(),interval:ar.custom(Z1).optional().empty(null),maxSize:ar.custom(j1).optional().empty(null),path:ar.optional().empty(null).default(Dc)}).required(),root:n,stdStreams:ye.required(),auditLog:ye.required()}).required(),operationsApi:ie.object({network:ie.object({cors:ye.optional(),corsAccessList:vm.optional(),headersTimeout:Rt.min(1).optional(),keepAliveTimeout:Rt.min(1).optional(),port:Rt.optional().empty(null),domainSocket:ie.optional().empty("hdb/operations-server").default(Dc),securePort:Rt.optional().empty(null),timeout:Rt.min(1).optional()}).optional(),tls:ie.object({certificate:s,certificateAuthority:s,privateKey:s})}).required(),rootPath:ar.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:ie.object({network:ie.object({port:Vi,securePort:Vi,mtls:ie.alternatives([ye.optional(),ie.object({user:ar.optional(),certificateAuthority:s,required:ye.optional()})])}).required(),webSocket:ye.optional(),requireAuthentication:ye.optional()}),http:ie.object({compressionThreshold:Rt.optional(),cors:ye.optional(),corsAccessList:vm.optional(),headersTimeout:Rt.min(1).optional(),port:Rt.min(0).optional().empty(null),securePort:Rt.min(0).optional().empty(null),mtls:ie.alternatives([ye.optional(),ie.object({user:ar.optional(),certificateAuthority:s,required:ye.optional()})])}).required(),threads:ie.alternatives(r.optional(),ie.object({count:r.optional(),debug:ie.alternatives(ye.optional(),ie.object({startingPort:Rt.min(1).optional(),host:ar.optional(),waitForDebugger:ye.optional()})),maxHeapMemory:Rt.min(0).optional()})),storage:ie.object({writeAsync:ye.required(),overlappingSync:ye.optional(),caching:ye.optional(),compression:ye.optional(),noReadAhead:ye.optional(),path:c,prefetchWrites:ye.optional()}).required(),ignoreScripts:ye.optional(),tls:ie.object({certificate:s.optional(),certificateAuthority:s.optional(),privateKey:s.optional(),ciphers:ar.optional()})}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(z1,"configValidator");function J1(e){return iN.existsSync(e)?null:`Specified path ${e} does not exist.`}a(J1,"doesPathExist");function X1(e,t){ie.assert(e,ar.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=J1(e);if(r)return t.message(r)}a(X1,"validatePath");function j1(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(V1);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(Y1):e}a(j1,"validateRotationMaxSize");function Z1(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message($1);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(K1):e}a(Z1,"validateRotationInterval");function eY(e,t){let r=t.state.path.join("."),n=G1.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||rN();return i=Math.round(Math.min(i,rN())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),F1.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(eY,"setDefaultThreads");function Dc(e,t){let r=t.state.path.join(".");if(!I_.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(I_.isEmpty(zn))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return ki.join(zn,k1);case"logging.root":return ki.join(zn,sN);case"clustering.leafServer.streams.path":return ki.join(zn,"clustering","leaf");case"storage.path":let n=ki.join(zn,nN.LEGACY_DATABASES_DIR_NAME);return iN.existsSync(n)?n:ki.join(zn,nN.DATABASES_DIR_NAME);case"logging.rotation.path":return ki.join(zn,sN);case"operationsApi.network.domainSocket":return r==null?null:ki.join(zn,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Dc,"setDefaultRoot");function tY(e){let t=ie.object({routes:w_});return q1.validateBySchema({routes:e},t)}a(tY,"routesValidator")});var Ur=g((tce,hN)=>{"use strict";var Mr=U(),Lt=z(),At=K(),{configValidator:rY,routesValidator:aN}=Bm(),cr=require("fs-extra"),nY=require("yaml"),Nn=require("path"),sY=require("is-number"),uN=require("properties-reader"),iY=require("lodash"),{handleHDBError:oY}=ne(),{HTTP_STATUS_CODES:aY,HDB_ERROR_MSGS:C_}=Nr(),ece=require("minimist"),{server:cY}=(sr(),se(Ci)),{DATABASES_PARAM_CONFIG:Lc,CONFIG_PARAMS:Lr,CONFIG_PARAM_MAP:In}=Mr,uY="Unable to get config value because config is uninitialized",lY="Config successfully initialized",_Y="Error backing up config file",dY="Empty parameter sent to getConfigValue",lN=Nn.join(Mr.PACKAGE_ROOT,"config","yaml",Mr.HDB_DEFAULT_CONFIG_FILE),fY="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",cN={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"},D_,Ot,L_;hN.exports={createConfigFile:EY,getDefaultConfig:hY,getConfigValue:dN,initConfig:xm,flattenConfig:ko,updateConfigValue:fN,updateConfigObject:pY,getConfiguration:gY,setConfiguration:RY,readConfigFile:Fm,getClusteringRoutes:AY,initOldConfig:EN,getConfigFromFile:OY,getConfigFilePath:$i,addConfig:bY,deleteConfigFromFile:yY,getConfigObj:NY};function EY(e){let t=ei(lN);D_=ko(t.toJSON());let r;for(let o in e){let c=In[o.toLowerCase()];if(c===Lr.DATABASES){r=e[o];continue}if(!c&&o.endsWith("_package")&&(c=o),c!==void 0){let u=c.split("_"),_=Hm(c,e[o]);c==="rootPath"&&_?.endsWith("/")&&(_=_.slice(0,-1));try{t.setIn([...u],_)}catch(l){At.error(l)}}}r&&_N(t,r),Gm(t);let n=t.toJSON();Ot=ko(n);let s=t.getIn(["rootPath"]),i=Nn.join(s,Mr.HDB_CONFIG_FILE);cr.createFileSync(i),cr.writeFileSync(i,String(t)),At.trace(`Config file written to ${i}`)}a(EY,"createConfigFile");function _N(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Lt.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(Lc.TABLES))for(let i in n[s][Lc.TABLES])for(let o in n[s][Lc.TABLES][i]){let c=n[s][Lc.TABLES][i][o],u=[Lr.DATABASES,s,Lc.TABLES,i,o];e.hasIn(u)?e.setIn(u,c):e.addIn(u,c)}else for(let i in n[s]){let o=n[s][i],c=[Lr.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){At.error("Error parsing schemas CLI/env config arguments",n)}}a(_N,"setSchemasConfig");function hY(e){if(D_===void 0){let r=ei(lN);D_=ko(r.toJSON())}let t=In[e.toLowerCase()];if(t!==void 0)return D_[t.toLowerCase()]}a(hY,"getDefaultConfig");function dN(e){if(e==null){At.error(dY);return}if(Ot===void 0){At.trace(uY);return}let t=In[e.toLowerCase()];if(t!==void 0)return Ot[t.toLowerCase()]}a(dN,"getConfigValue");function $i(e=Lt.getPropsFilePath()){let t=Lt.getEnvCliRootPath();return t?Nn.join(t,Mr.HDB_CONFIG_FILE):uN(e).get(Mr.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY)}a($i,"getConfigFilePath");function xm(e=!1){if(Ot===void 0||e){let t;if(!Lt.noBootFile()){t=Lt.getPropsFilePath();try{cr.accessSync(t,cr.constants.F_OK|cr.constants.R_OK)}catch(i){throw At.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=$i(t),n;if(r.includes("config/settings.js"))try{EN(r);return}catch(i){if(i.code!==Mr.NODE_ERROR_CODES.ENOENT)throw i}try{n=ei(r)}catch(i){if(i.code===Mr.NODE_ERROR_CODES.ENOENT){At.trace(`HarperDB config file not found at ${r}.
|
|
7
|
+
This can occur during early stages of install where the config file has not yet been created`);return}else throw At.error(i),new Error(`Error reading HarperDB config file at ${r}`)}mY(n,r),Gm(n);let s=n.toJSON();if(cY.config=s,Ot=ko(s),Ot.logging_rotation_rotate)for(let i in cN)Ot[i]&&At.error(`Config ${cN[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);At.trace(lY)}}a(xm,"initConfig");function mY(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Nn.join(r,"database")),n=!0),e.hasIn(["clustering","leafServer","streams","path"])||(e.setIn(["clustering","leafServer","streams","path"],Nn.join(r,"clustering","leaf")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Nn.join(r,"log")),n=!0),e.hasIn(["clustering","tls","verify"])||(e.setIn(["clustering","tls","verify"],!0),n=!0),n&&(At.trace("Updating config file with missing config params"),cr.writeFileSync(t,String(e)))}a(mY,"checkForUpdatedConfig");function Gm(e){let t=e.toJSON();t.componentsRoot=t.componentsRoot??t?.customFunctions?.root,t?.http?.threads&&(t.threads=t?.http?.threads);let r=rY(t);if(r.error)throw C_.CONFIG_VALIDATION(r.error.message);typeof r.value.threads=="object"?e.setIn(["threads","count"],r.value.threads.count):e.setIn(["threads"],r.value.threads),e.setIn(["componentsRoot"],r.value.componentsRoot),e.setIn(["logging","root"],r.value.logging.root),e.setIn(["storage","path"],r.value.storage.path),e.setIn(["logging","rotation","path"],r.value.logging.rotation.path),e.setIn(["clustering","leafServer","streams","path"],r.value.clustering.leafServer.streams?.path),e.setIn(["operationsApi","network","domainSocket"],r.value?.operationsApi?.network?.domainSocket)}a(Gm,"validateConfig");function pY(e,t){Ot===void 0&&(Ot={});let r=In[e.toLowerCase()];if(r===void 0){At.trace(`Unable to update config object because config param '${e}' does not exist`);return}Ot[r.toLowerCase()]=t}a(pY,"updateConfigObject");function fN(e,t,r=void 0,n=!1,s=!1,i=!1){Ot===void 0&&xm();let o=dN(In.hdb_root),c=Nn.join(o,Mr.HDB_CONFIG_FILE),u=ei(c),_;if(r===void 0&&e.toLowerCase()===Lr.DATABASES)_=t;else if(r===void 0){let f;if(i)f=e;else if(f=In[e.toLowerCase()],f===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let E=f.split("_"),h=Hm(f,t);u.setIn([...E],h)}else for(let f in r){let E=In[f.toLowerCase()];if(E===Lr.HTTP_SECUREPORT&&r[f]===Ot[Lr.HTTP_PORT]?.toString()&&u.setIn(["http","port"],null),E===Lr.OPERATIONSAPI_NETWORK_SECUREPORT&&r[f]===Ot[Lr.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&u.setIn(["operationsApi","network","port"],null),E===Lr.DATABASES){_=r[f];continue}if(E?.startsWith("threads_")){let h=u.getIn(["threads"]);h>=0&&(u.deleteIn(["threads"]),u.setIn(["threads","count"],h))}if(!E&&f.endsWith("_package")&&(E=f),E!==void 0){let h=E.split("_"),p=Mr.LEGACY_CONFIG_PARAMS[f.toUpperCase()];p&&p.startsWith("customFunctions")&&u.hasIn(p.split("_"))&&(E=p,h=p.split("_"));let S=Hm(E,r[f]);E==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof u.getIn(h.slice(0,-1))=="boolean"&&u.deleteIn(h.slice(0,-1)),u.setIn([...h],S)}catch(T){At.error(T)}}}_&&_N(u,_),Gm(u);let l=u.getIn(["rootPath"]),d=Nn.join(l,Mr.HDB_CONFIG_FILE);n===!0&&SY(c,l),cr.writeFileSync(d,String(u)),s&&(Ot=ko(u.toJSON())),At.trace(`Config parameter: ${e} updated with value: ${t}`)}a(fN,"updateConfigValue");function SY(e,t){try{let r=Nn.join(t,"backup",`${Mr.HDB_CONFIG_FILE}.bak`);cr.copySync(e,r),At.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){At.error(_Y),At.error(r)}}a(SY,"backupConfigFile");var TY=["databases"];function ko(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network=Object.assign({},e.http,e.operationsApi.network)),e?.operationsApi&&(e.operationsApi.tls=Object.assign({},e.tls,e.operationsApi.tls)),L_=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])&&!TY.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let u=i+"_"+c;!Lr[u.toUpperCase()]&&In[u]&&(s[In[u].toLowerCase()]=o[c]),s[u]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(ko,"flattenConfig");function Hm(e,t){if(e===Lr.CLUSTERING_NODENAME||e===Lr.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(sY(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Lt.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 Lt.autoCast(t)}a(Hm,"castConfigValue");function gY(){let e=Lt.getPropsFilePath(),t=$i(e);return ei(t).toJSON()}a(gY,"getConfiguration");async function RY(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return fN(void 0,void 0,s,!0),fY}catch(i){throw typeof i=="string"||i instanceof String?oY(i,i,aY.BAD_REQUEST,void 0,void 0,!0):i}}a(RY,"setConfiguration");function Fm(){let e=Lt.getPropsFilePath();try{cr.accessSync(e,cr.constants.F_OK|cr.constants.R_OK)}catch(n){if(!Lt.noBootFile())throw At.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=$i(e);return ei(t).toJSON()}a(Fm,"readConfigFile");function ei(e){return nY.parseDocument(cr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(ei,"parseYamlDoc");function AY(){let e=Fm(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Lt.isEmptyOrZeroLength(t)?[]:t;let r=aN(t);if(r)throw C_.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Lt.isEmptyOrZeroLength(n)?[]:n;let s=aN(n);if(s)throw C_.CONFIG_VALIDATION(s.message);if(!Lt.isEmptyOrZeroLength(n)&&!Lt.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Lt.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw C_.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(AY,"getClusteringRoutes");function EN(e){let t=uN(e);Ot={};for(let r in In){let n=t.get(r.toUpperCase());if(Lt.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=In[r].toLowerCase();s===Lr.LOGGING_ROOT?Ot[s]=Nn.dirname(n):Ot[s]=n}return Ot}a(EN,"initOldConfig");function OY(e){let t=Fm();return iY.get(t,e.replaceAll("_","."))}a(OY,"getConfigFromFile");async function bY(e,t){let r=ei($i());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await cr.writeFile($i(),String(r))}a(bY,"addConfig");function yY(e){let t=$i(Lt.getPropsFilePath()),r=ei(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Nn.join(n,Mr.HDB_CONFIG_FILE);cr.writeFileSync(s,String(r))}a(yY,"deleteConfigFromFile");function NY(){return L_||(xm(),L_)}a(NY,"getConfigObj")});var pN=g((nce,mN)=>{"use strict";var M_=U(),U_=class{static{a(this,"BaseLicense")}constructor(t=0,r=M_.RAM_ALLOCATION_ENUM.DEFAULT,n=M_.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},qm=class extends U_{static{a(this,"ExtendedLicense")}constructor(t=0,r=M_.RAM_ALLOCATION_ENUM.DEFAULT,n=M_.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};mN.exports={BaseLicense:U_,ExtendedLicense:qm}});var Yi=g((ice,ON)=>{"use strict";var $o=require("fs-extra"),TN=N_(),gN=require("crypto"),IY=require("moment"),wY=require("uuid").v4,Wt=K(),Vm=require("path"),CY=z(),ti=U(),{totalmem:SN}=require("os"),DY=pN().ExtendedLicense,Vo="invalid license key format",LY="061183",MY="mofi25",UY="aes-256-cbc",PY=16,vY=32,RN=re();RN.initSync();var km;ON.exports={validateLicense:AN,generateFingerPrint:HY,licenseSearch:Km,getLicense:FY,checkMemoryLimit:qY};function $m(){return Vm.join(RN.getHdbBasePath(),ti.LICENSE_KEY_DIR_NAME,ti.LICENSE_FILE_NAME)}a($m,"getLicenseDirPath");function BY(){let e=$m();return Vm.join(e,ti.LICENSE_FILE_NAME)}a(BY,"getLicenseFilePath");function Ym(){let e=$m();return Vm.join(e,ti.REG_KEY_FILE_NAME)}a(Ym,"getFingerPrintFilePath");async function HY(){let e=Ym();try{return await $o.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await xY();throw Wt.error(`Error writing fingerprint file to ${e}`),Wt.error(t),new Error("There was an error generating the fingerprint")}}a(HY,"generateFingerPrint");async function xY(){let e=wY(),t=TN.hash(e),r=Ym();try{await $o.mkdirp($m()),await $o.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Wt.error(`Error writing fingerprint file to ${r}`),Wt.error(n),new Error("There was an error generating the fingerprint")}return t}a(xY,"writeFingerprint");function AN(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:ti.RAM_ALLOCATION_ENUM.DEFAULT,version:ti.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Wt.error("empty license key passed to validate."),r;let n=Ym(),s=!1;try{s=$o.statSync(n)}catch(i){Wt.error(i)}if(s){let i;try{i=$o.readFileSync(n,"utf8")}catch{Wt.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(MY),c=o[1];c=Buffer.concat([Buffer.from(c)],PY);let u=Buffer.concat([Buffer.from(i)],vY),_=gN.createDecipheriv(UY,u,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let l=null;try{l=_.update(o[0],"hex","utf8"),l.trim(),l+=_.final("utf8")}catch{let E=GY(o[0],i);if(E)l=E;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Vo),Wt.error(Vo),new Error(Vo)}let d;if(isNaN(l))try{d=JSON.parse(l),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(Vo),Wt.error(Vo),new Error(Vo)}else r.exp_date=l;r.exp_date<IY().valueOf()&&(r.valid_date=!1),TN.validate(o[1],`${LY}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||Wt.error("Invalid licence"),r}a(AN,"validateLicense");function GY(e,t){try{let r=gN.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Wt.warn("Check old license failed")}}a(GY,"checkOldLicense");function Km(){let e=new DY,t=[];try{t=$o.readFileSync(BY(),"utf-8").split(ti.NEW_LINE)}catch(r){r.code==="ENOENT"?Wt.info("no license file found"):Wt.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(CY.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=AN(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){Wt.error("There was an error parsing the license string."),Wt.error(s),e.ram_allocation=ti.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return km=e,e}a(Km,"licenseSearch");async function FY(){return km||await Km(),km}a(FY,"getLicense");function qY(){let e=Km().ram_allocation,t=process.constrainedMemory?.()||SN();if(t=Math.round(Math.min(t,SN())/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(qY,"checkMemoryLimit")});var nn=g((lce,GN)=>{"use strict";var IN="username is required",wN="nothing to update, must supply active, role or password to update",CN="password cannot be an empty string",DN="If role is specified, it cannot be empty.",LN="active must be true or false";GN.exports={addUser:JY,alterUser:XY,dropUser:ZY,getSuperUser:nK,userInfo:eK,listUsers:v_,listUsersExternal:tK,setUsersToGlobal:Ko,findAndValidateUser:HN,getClusterUser:sK,USERNAME_REQUIRED:IN,ALTERUSER_NOTHING_TO_UPDATE:wN,EMPTY_PASSWORD:CN,EMPTY_ROLE:DN,ACTIVE_BOOLEAN:LN};var MN=rn(),kY=qi(),zm=N_(),UN=Xy(),PN=Dr(),Jm=Ts(),Pr=z(),vN=require("validate.js"),Se=K(),{promisify:VY}=require("util"),Xm=Ss(),bN=U(),yN=rt(),$Y=Ur(),ace=re(),cce=Yi(),YY=Pi(),{table:uce}=(Ae(),se(Fe)),{handleHDBError:Jn,hdb_errors:KY}=ne(),{HTTP_STATUS_CODES:Xn,AUTHENTICATION_ERROR_MSGS:Wm,HDB_ERROR_MSGS:Yo}=KY,{UserEventMsg:jm}=wn(),Qm=require("lodash"),{server:Zm}=(sr(),se(Ci)),WY=K();Zm.getUser=(e,t)=>HN(e,t,t!=null);var BN={username:!0,active:!0,role:!0,password:!0},NN=new Map,P_=PN.searchByValue,QY=PN.searchByHash,zY=VY(kY.delete);async function JY(e){let t=vN.cleanAttributes(e,BN),r=UN.addUserValidation(t);if(r)throw Jn(new Error,r.message,Xn.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await P_(n),s=s&&Array.from(s)}catch(u){throw Se.error("There was an error searching for a role in add user"),Se.error(u),u}if(!s||s.length<1)throw Jn(new Error,Yo.ROLE_NAME_NOT_FOUND(t.role),Xn.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Jn(new Error,Yo.DUP_ROLES_FOUND(t.role),Xn.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=Xm.encrypt(t.password)),t.password=zm.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await MN.insert(i)}catch(u){throw Se.error("There was an error searching for a user."),Se.error(u),u}Se.debug(o);try{await Ko()}catch(u){throw Se.error("Got an error setting users to global"),Se.error(u),u}if(o.skipped_hashes.length===1)throw Jn(new Error,Yo.USER_ALREADY_EXISTS(t.username),Xn.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],Jm.signalUserChange(new jm(process.pid)),`${c.username} successfully added`}a(JY,"addUser");async function XY(e){let t=vN.cleanAttributes(e,BN);if(Pr.isEmptyOrZeroLength(t.username))throw new Error(IN);if(Pr.isEmptyOrZeroLength(t.password)&&Pr.isEmptyOrZeroLength(t.role)&&Pr.isEmptyOrZeroLength(t.active))throw new Error(wN);if(!Pr.isEmpty(t.password)&&Pr.isEmptyOrZeroLength(t.password.trim()))throw new Error(CN);if(!Pr.isEmpty(t.active)&&!Pr.isBoolean(t.active))throw new Error(LN);let r=jY(t.username);if(!Pr.isEmpty(t.password)&&!Pr.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=Xm.encrypt(t.password)),t.password=zm.hash(t.password)),t.role==="")throw new Error(DN);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await P_(i)||[])}catch(c){throw Se.error("Got an error searching for a role."),Se.error(c),c}if(!o||o.length===0){let c=Yo.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Se.error(c),Jn(new Error,c,Xn.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Yo.ALTER_USER_DUP_ROLES(t.role);throw Se.error(c),Jn(new Error,c,Xn.CONFLICT,void 0,void 0,!0)}t.role=o[0].id}let n={operation:"update",schema:"system",table:"hdb_user",records:[t]},s;try{s=await MN.update(n)}catch(i){throw Se.error("Error during update."),Se.error(i),i}try{await Ko()}catch(i){throw Se.error("Got an error setting users to global"),Se.error(i),i}return Jm.signalUserChange(new jm(process.pid)),s}a(XY,"alterUser");function jY(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(jY,"isClusterUser");async function ZY(e){try{let t=UN.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Pr.isEmpty(global.hdb_users.get(e.username)))throw Jn(new Error,Yo.USER_NOT_EXIST(e.username),Xn.NOT_FOUND,void 0,void 0,!0);let n;try{n=await zY(r)}catch(s){throw Se.error("Got an error deleting a user."),Se.error(s),s}Se.debug(n);try{await Ko()}catch(s){throw Se.error("Got an error setting users to global."),Se.error(s),s}return Jm.signalUserChange(new jm(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(ZY,"dropUser");async function eK(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=Qm.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await QY(r)}catch(s){throw Se.error("Got an error searching for a role."),Se.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Se.error(r),r}return t}a(eK,"userInfo");async function tK(){let e;try{e=await v_()}catch(t){throw Se.error("Got an error listing users."),Se.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(tK,"listUsersExternal");async function v_(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await P_(e)}catch(o){throw Se.error("Got an error searching for roles."),Se.error(o),o}let r={};for(let o of t)r[o.id]=Qm.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await P_(n)}catch(o){throw Se.error("Got an error searching for users."),Se.error(o),o}let i=new Map;for(let o of s)o=Qm.cloneDeep(o),o.role=r[o.role],rK(o.role),i.set(o.username,o);return i}catch(e){throw Se.error("got an error listing users"),Se.error(e),Pr.errorizeMessage(e)}return null}a(v_,"listUsers");function rK(e){try{if(!e){Se.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(YY)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Se.error("Got an error trying to set system permissions."),Se.error(t)}}a(rK,"appendSystemTablesToRole");async function Ko(){try{let e=await v_();global.hdb_users=e}catch(e){throw Se.error(e),e}}a(Ko,"setUsersToGlobal");async function HN(e,t,r=!0){global.hdb_users||await Ko();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Jn(new Error,Wm.GENERIC_AUTH_FAIL,Xn.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Jn(new Error,Wm.USER_INACTIVE,Xn.UNAUTHORIZED,void 0,void 0,!0);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(NN.get(t)===n.password)return s;if(zm.validate(n.password,t))NN.set(t,n.password);else throw Jn(new Error,Wm.GENERIC_AUTH_FAIL,Xn.UNAUTHORIZED,void 0,void 0,!0)}return s}a(HN,"findAndValidateUser");async function nK(){global.hdb_users||await Ko();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(nK,"getSuperUser");async function sK(){let e=await v_(),t=$Y.getConfigFromFile(bN.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Pr.isEmpty(r)&&r?.role?.role===bN.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=Xm.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+yN.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+yN.SERVER_SUFFIX.ADMIN,r}a(sK,"getClusterUser");var xN=[];Zm.invalidateUser=function(e){for(let t of xN)try{t(e)}catch(r){WY.error("Error invalidating user",r)}};Zm.onInvalidatedUser=function(e){xN.push(e)}});var Uc=g((Ece,VN)=>{"use strict";var Ki=K(),vr=U(),iK=Sy(),dce=Xs(),fce=Bi(),oK=nn(),{validateEvent:FN}=wn(),Mc=yn(),aK=require("process"),{resetDatabases:cK}=(Ae(),se(Fe)),uK={[vr.ITC_EVENT_TYPES.SCHEMA]:lK,[vr.ITC_EVENT_TYPES.USER]:kN};async function lK(e){let t=FN(e);if(t){Ki.error(t);return}Ki.trace("ITC schemaHandler received schema event:",e),await iK(e.message),await _K(e.message)}a(lK,"schemaHandler");async function _K(e){try{Mc.resetReadTxn(vr.SYSTEM_SCHEMA_NAME,vr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Mc.resetReadTxn(vr.SYSTEM_SCHEMA_NAME,vr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Mc.resetReadTxn(vr.SYSTEM_SCHEMA_NAME,vr.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=cK();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Ki.error(t)}}a(_K,"syncSchemaMetadata");var qN=[];async function kN(e){try{try{Mc.resetReadTxn(vr.SYSTEM_SCHEMA_NAME,vr.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Mc.resetReadTxn(vr.SYSTEM_SCHEMA_NAME,vr.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Ki.warn(r)}let t=FN(e);if(t){Ki.error(t);return}Ki.trace(`ITC userHandler ${vr.HDB_ITC_CLIENT_PREFIX}${aK.pid} received user event:`,e),await oK.setUsersToGlobal();for(let r of qN)r()}catch(t){Ki.error(t)}}a(kN,"userHandler");kN.addListener=function(e){qN.push(e)};VN.exports=uK});var wn=g((gce,YN)=>{"use strict";var mce=K(),ep=z(),dK=U(),{ITC_ERRORS:Pc}=Nr(),{parentPort:pce,threadId:fK,isMainThread:EK,workerData:Sce}=require("worker_threads"),{onMessageFromWorkers:hK,broadcast:Tce,broadcastWithAcknowledgement:mK}=Ze();YN.exports={sendItcEvent:pK,validateEvent:$N,SchemaEventMsg:SK,UserEventMsg:TK};var B_;hK(async(e,t)=>{B_=B_||Uc(),$N(e),B_[e.type]&&await B_[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function pK(e){return!EK&&e.message&&(e.message.originator=fK),mK(e)}a(pK,"sendItcEvent");function $N(e){if(typeof e!="object")return Pc.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||ep.isEmpty(e.type))return Pc.MISSING_TYPE;if(!e.hasOwnProperty("message")||ep.isEmpty(e.message))return Pc.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||ep.isEmpty(e.message.originator))return Pc.MISSING_ORIGIN;if(dK.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Pc.INVALID_EVENT(e.type)}a($N,"validateEvent");function SK(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(SK,"SchemaEventMsg");function TK(e){this.originator=e}a(TK,"UserEventMsg")});var Ts=g((Oce,zN)=>{"use strict";var KN=U(),Ace=z(),H_=K(),WN=hy(),Wo,{sendItcEvent:QN}=wn();function gK(e){try{H_.trace("signalSchemaChange called with message:",e),Wo=Wo||Uc();let t=new WN(KN.ITC_EVENT_TYPES.SCHEMA,e);return Wo.schema(t),QN(t)}catch(t){H_.error(t)}}a(gK,"signalSchemaChange");function RK(e){try{H_.trace("signalUserChange called with message:",e),Wo=Wo||Uc();let t=new WN(KN.ITC_EVENT_TYPES.USER,e);return Wo.user(t),QN(t)}catch(t){H_.error(t)}}a(RK,"signalUserChange");zN.exports={signalSchemaChange:gK,signalUserChange:RK}});var x_=g((yce,XN)=>{"use strict";var JN=z(),AK=U(),OK=K(),bK=d_(),yK=__(),NK=Ts(),{SchemaEventMsg:IK}=wn(),wK="already exists in";XN.exports=CK;async function CK(e,t,r){if(JN.isEmptyOrZeroLength(r))return r;let n=[];JN.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 DK(e,t.schema,t.name,i)})),s}a(CK,"lmdbCheckForNewAttributes");async function DK(e,t,r,n){let s=new yK(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await LK(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(wK))OK.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(DK,"createNewAttribute");async function LK(e){let t;return t=await bK(e),NK.signalSchemaChange(new IK(process.pid,AK.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(LK,"createAttribute")});var Qo=g((Ice,jN)=>{"use strict";var tp=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}};jN.exports=tp});var eI=g((Cce,ZN)=>{"use strict";var MK=Qo(),UK=U().OPERATIONS_ENUM,rp=class extends MK{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(UK.INSERT,r,n,s,i),this.records=t}};ZN.exports=rp});var rI=g((Lce,tI)=>{"use strict";var PK=Qo(),vK=U().OPERATIONS_ENUM,np=class extends PK{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(vK.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};tI.exports=np});var sI=g((Uce,nI)=>{"use strict";var BK=Qo(),HK=U().OPERATIONS_ENUM,sp=class extends BK{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(HK.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};nI.exports=sp});var oI=g((vce,iI)=>{"use strict";var xK=Qo(),GK=U().OPERATIONS_ENUM,ip=class extends xK{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(GK.DELETE,n,s,t,i),this.original_records=r}};iI.exports=ip});var vc=g((xce,lI)=>{"use strict";var Hce=require("path"),aI=Ye(),FK=eI(),qK=rI(),kK=sI(),VK=oI(),zo=_t(),cI=z(),{CONFIG_PARAMS:$K}=U(),uI=re();uI.initSync();var G_=U().OPERATIONS_ENUM,{getTransactionAuditStorePath:YK}=Qe();lI.exports=KK;async function KK(e,t){if(uI.get($K.LOGGING_AUDITLOG)===!1)return;let r=YK(e.schema,e.table),n=await aI.openEnvironment(r,e.table,!0),s=WK(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){aI.initializeDBIs(n,zo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,zo.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[zo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[zo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),cI.isEmpty(s.user_name)||n.dbis[zo.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[zo.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(KK,"writeTransaction");function WK(e,t){let r=cI.isEmpty(e.hdb_user)?void 0:e.hdb_user.username;if(e.operation===G_.INSERT)return new FK(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===G_.UPDATE)return new qK(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===G_.UPSERT)return new kK(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===G_.DELETE)return new VK(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(WK,"createTransactionObject")});var op=g((qce,_I)=>{"use strict";var QK=Nc(),Fce=Ic(),Bc=U(),zK=wc(),JK=Go().insertRecords,XK=Ye(),jK=K(),ZK=x_(),{getSchemaPath:eW}=Qe(),tW=vc();_I.exports=rW;async function rW(e){try{let{schema_table:t,attributes:r}=QK(e);zK(e,r,t.hash_attribute),e.schema!==Bc.SYSTEM_SCHEMA_NAME&&(r.includes(Bc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Bc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Bc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Bc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await ZK(e.hdb_auth_header,t,r),s=eW(e.schema,e.table),i=await XK.openEnvironment(s,e.table),o=await JK(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await tW(e,o)}catch(c){jK.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(rW,"lmdbCreateRecords")});var EI=g((Vce,fI)=>{"use strict";var dI=U(),nW=op(),sW=Ic(),iW=require("fs-extra"),{getSchemaPath:oW}=Qe();fI.exports=aW;async function aW(e){let t=[{name:e.schema,createddate:Date.now()}],r=new sW(dI.SYSTEM_SCHEMA_NAME,dI.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await nW(r),await iW.mkdirp(oW(e.schema))}a(aW,"lmdbCreateSchema")});var mI=g((Yce,hI)=>{"use strict";var ap=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}};hI.exports=ap});var gI=g((Jce,TI)=>{"use strict";var pI=Ye(),cp=Ir(),up=Nr().LMDB_ERRORS_ENUM,cW=_t(),SI=K(),Wce=z(),uW=require("lmdb"),lW=mI(),_W=U(),{OVERFLOW_MARKER:Qce,MAX_SEARCH_KEY_LENGTH:zce}=cW,dW=_W.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function fW(e,t,r,n){if(cp.validateEnv(e),t===void 0)throw new Error(up.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(up.IDS_REQUIRED):new Error(up.IDS_MUST_BE_ITERABLE);try{let s=pI.listDBIs(e);pI.initializeDBIs(e,t,s);let i=new lW,o,c=[],u=[];for(let f=0,E=r.length;f<E;f++)try{o=r[f];let h=e.dbis[t].get(o);if(!h||n&&h[dW]>n){i.skipped.push(o);continue}let p=e.dbis[t].ifVersion(o,uW.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let S=0;S<s.length;S++){let T=s[S];if(!h.hasOwnProperty(T)||T===t)continue;let b=e.dbis[T],R=h[T];if(R!=null)try{let L=cp.getIndexedValues(R);if(L)for(let H=0,P=L.length;H<P;H++)b.remove(L[H],o)}catch{SI.warn(`cannot delete from attribute: ${T}, ${R}:${o}`)}}});c.push(p),u.push(o),i.original_records.push(h)}catch(h){SI.warn(h),i.skipped.push(o)}let _=[],l=await Promise.all(c);for(let f=0,E=l.length;f<E;f++)l[f]===!0?i.deleted.push(u[f]):(i.skipped.push(u[f]),_.push(f));let d=0;for(let f=0;f<_.length;f++){let E=_[f];i.original_records.splice(E-d,1),d++}return i.txn_time=cp.getNextMonotonicTime(),i}catch(s){throw s}}a(fW,"deleteRecords");TI.exports={deleteRecords:fW}});var Hc=g((jce,AI)=>{"use strict";var Jo=z(),EW=gI(),hW=Ye(),{getSchemaPath:mW}=Qe(),pW=vc(),SW=K();AI.exports=TW;async function TW(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Jo.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Jo.isEmptyOrZeroLength(e.hash_values)&&!Jo.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let u=e.records[c][n];Jo.isEmpty(u)||e.hash_values.push(u)}}if(Jo.isEmptyOrZeroLength(e.hash_values))return RI([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Jo.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=mW(e.schema,e.table),i=await hW.openEnvironment(s,e.table),o=await EW.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await pW(e,o)}catch(c){SW.error(`unable to write transaction due to ${c.message}`)}return RI(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(TW,"lmdbDeleteRecords");function RI(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(RI,"createDeleteResponse")});var _p=g((tue,OI)=>{"use strict";var gW=U(),eue=Ir();function lp(e,t){let r=Object.create(null);if(t.length===1&&gW.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(lp,"parseRow");function RW(e,t,r,n){let s=lp(r,e);n.push(s)}a(RW,"searchAll");function AW(e,t,r,n){let s=lp(r,e);n[t]=s}a(AW,"searchAllToMap");function OW(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(OW,"iterateDBI");function Wi(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(Wi,"pushResults");function bW(e,t,r,n,s,i){t.toString().endsWith(e)&&Wi(t,r,n,s,i)}a(bW,"endsWith");function yW(e,t,r,n,s,i){t.toString().includes(e)&&Wi(t,r,n,s,i)}a(yW,"contains");function NW(e,t,r,n,s,i){t>e&&Wi(t,r,n,s,i)}a(NW,"greaterThanCompare");function IW(e,t,r,n,s,i){t>=e&&Wi(t,r,n,s,i)}a(IW,"greaterThanEqualCompare");function wW(e,t,r,n,s,i){t<e&&Wi(t,r,n,s,i)}a(wW,"lessThanCompare");function CW(e,t,r,n,s,i){t<=e&&Wi(t,r,n,s,i)}a(CW,"lessThanEqualCompare");OI.exports={parseRow:lp,searchAll:RW,searchAllToMap:AW,iterateDBI:OW,endsWith:bW,contains:yW,greaterThanCompare:NW,greaterThanEqualCompare:IW,lessThanCompare:wW,lessThanEqualCompare:CW,pushResults:Wi}});var Xo=g((oue,DI)=>{"use strict";var ri=Ye(),nue=K(),Br=Ir(),F_=_t(),ct=Nr().LMDB_ERRORS_ENUM,sue=z(),DW=U(),q_=_p(),{parseRow:LW}=q_,iue=require("lmdb"),{OVERFLOW_MARKER:bI,MAX_SEARCH_KEY_LENGTH:MW}=F_;function yI(e,t,r,n=!1,s=void 0,i=void 0){return Qi(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(yI,"iterateFullIndex");function xc(e,t,r,n,s,i=!1,o=void 0,c=void 0,u=!1,_=!1){return Qi(e,t,r,(l,d,f,E)=>{let b={transaction:l,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!u:!_,exclusiveStart:i===!0?_:u};return E===r?(b.values=!1,d.getRange(b).map(R=>({value:R}))):d.getRange(b)})}a(xc,"iterateRangeBetween");function Qi(e,t,r,n){let s=e.database||e,i=ri.openDBI(s,r);i[F_.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&ri.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(Qi,"setupTransaction");function NI(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(bI)){if(!s)if(r)s=ri.openDBI(e,r);else{let u=ri.listDBIs(e);for(let _=0,l=u.length;_<l&&(s=ri.openDBI(e,u[_]),!s[F_.DBI_DEFINITION_NAME].is_hash_attribute);_++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(NI,"getOverflowCheck");function UW(e,t,r,n=!1,s=void 0,i=void 0){if(Br.validateEnv(e),t===void 0)throw new Error(ct.HASH_ATTRIBUTE_REQUIRED);return Qi(e,t,t,(o,c,u)=>(k_(r),r=Gc(u,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(_=>LW(_.value,r))))}a(UW,"searchAll");function PW(e,t,r,n=!1,s=void 0,i=void 0){if(Br.validateEnv(e),t===void 0)throw new Error(ct.HASH_ATTRIBUTE_REQUIRED);k_(r),r=Gc(e.database||e,r);let o=new Map;for(let{key:c,value:u}of yI(e,t,t,n,s,i))o.set(c,q_.parseRow(u,r));return o}a(PW,"searchAllToMap");function vW(e,t,r=!1,n=void 0,s=void 0){if(Br.validateEnv(e),t===void 0)throw new Error(ct.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=yI(e,void 0,t,r,n,s),c=o.transaction,u=NI(c.database,c,void 0,t);for(let{key:_,value:l}of o){let d=u(_,l);i[d]===void 0&&(i[d]=[]),i[d].push(l)}return i}a(vW,"iterateDBI");function BW(e,t){if(Br.validateEnv(e),t===void 0)throw new Error(ct.HASH_ATTRIBUTE_REQUIRED);return ri.statDBI(e,t).entryCount}a(BW,"countAll");function HW(e,t,r,n,s=!1,i=void 0,o=void 0){return ni(e,r,n),Qi(e,t,r,(c,u,_,l)=>(n=Br.convertKeyValueToWrite(n),l===r?u.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:u.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(HW,"equals");function xW(e,t,r){return ni(e,t,r),ri.openDBI(e,t).getValuesCount(r)}a(xW,"count");function GW(e,t,r,n,s=!1,i=void 0,o=void 0){return ni(e,r,n),Qi(e,null,r,(c,u)=>{n=Br.convertKeyValueToWrite(n);let _=!0;typeof n=="number"&&(_=!1);let l;if(s===!0){let d;for(let f of u.getKeys({transaction:c,start:n}))if(!f.startsWith(n)){d=f;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),l=u.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(f=>{let{key:E}=f;if(E!==d){if(E.toString().startsWith(n))return f;if(_===!0)return l.DONE}}),l.filter(f=>f)}else return l=u.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(_===!0)return l.DONE}),_?l:l.filter(d=>d)})}a(GW,"startsWith");function FW(e,t,r,n,s=!1,i=void 0,o=void 0){return II(e,t,r,n,s,i,o,!0)}a(FW,"endsWith");function II(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return ni(e,r,n),Qi(e,null,r,(u,_,l,d)=>{let f=NI(l,u,d,r);return o=Number.isInteger(o)?o:0,_.getKeys({transaction:u,end:s?!1:void 0,reverse:s}).flatMap(E=>{let h=E.toString();return h.endsWith(bI)?_.getValues(E,{transaction:u}).map(p=>{let S=f(E,p);if(c?S.endsWith(n):S.includes(n))return{key:S,value:p}}).filter(p=>p):(c?h.endsWith(n):h.includes(n))?_[F_.DBI_DEFINITION_NAME].is_hash_attribute?{key:E,value:E}:_.getValues(E,{transaction:u}).map(p=>({key:E,value:p})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(II,"contains");function qW(e,t,r,n,s=!1,i=void 0,o=void 0){ni(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),xc(e,t,r,n,u,s,i,o,!0,!1)}a(qW,"greaterThan");function kW(e,t,r,n,s=!1,i=void 0,o=void 0){ni(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),xc(e,t,r,n,u,s,i,o,!1,!1)}a(kW,"greaterThanEqual");function VW(e,t,r,n,s=!1,i=void 0,o=void 0){ni(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),xc(e,t,r,u,n,s,i,o,!1,!0)}a(VW,"lessThan");function $W(e,t,r,n,s=!1,i=void 0,o=void 0){ni(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),xc(e,t,r,u,n,s,i,o,!1,!1)}a($W,"lessThanEqual");function YW(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Br.validateEnv(e),r===void 0)throw new Error(ct.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(ct.START_VALUE_REQUIRED);if(s===void 0)throw new Error(ct.END_VALUE_REQUIRED);if(n=Br.convertKeyValueToWrite(n),s=Br.convertKeyValueToWrite(s),n>s)throw new Error(ct.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return xc(e,t,r,n,s,i,o,c)}a(YW,"between");function KW(e,t,r,n){Br.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(ct.HASH_ATTRIBUTE_REQUIRED);if(k_(r),r=Gc(s,r),n===void 0)throw new Error(ct.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=q_.parseRow(c,r)),o}a(KW,"searchByHash");function WW(e,t,r){Br.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(ct.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ct.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(WW,"checkHashExists");function QW(e,t,r,n,s=[]){return CI(e,t,r,n,s),wI(e,t,r,n,s).map(i=>i[1])}a(QW,"batchSearchByHash");function zW(e,t,r,n,s=[]){CI(e,t,r,n,s);let i=new Map;for(let[o,c]of wI(e,t,r,n,s))i.set(o,c);return i}a(zW,"batchSearchByHashToMap");function wI(e,t,r,n,s=[]){return Qi(e,t,t,(i,o,c)=>{r=Gc(c,r);let u=r.length<3;return n.map(_=>{let l=c.dbis[t].get(_,{transaction:i,lazy:u});if(l)return[_,q_.parseRow(l,r)];s.push(_)}).filter(_=>_)})}a(wI,"batchHashSearch");function CI(e,t,r,n,s){if(Br.validateEnv(e),t===void 0)throw new Error(ct.HASH_ATTRIBUTE_REQUIRED);if(k_(r),n==null)throw new Error(ct.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(ct.IDS_MUST_BE_ITERABLE)}a(CI,"initializeBatchSearchByHash");function k_(e){if(!Array.isArray(e))throw e===void 0?new Error(ct.FETCH_ATTRIBUTES_REQUIRED):new Error(ct.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(k_,"validateFetchAttributes");function ni(e,t,r){if(Br.validateEnv(e),t===void 0)throw new Error(ct.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ct.SEARCH_VALUE_REQUIRED);if(r?.length>MW)throw new Error(ct.SEARCH_VALUE_TOO_LARGE)}a(ni,"validateComparisonFunctions");function Gc(e,t){return t.length===1&&DW.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=ri.listDBIs(e)),t}a(Gc,"setGetWholeRowAttributes");DI.exports={searchAll:UW,searchAllToMap:PW,count:xW,countAll:BW,equals:HW,startsWith:GW,endsWith:FW,contains:II,searchByHash:KW,setGetWholeRowAttributes:Gc,batchSearchByHash:QW,batchSearchByHashToMap:zW,checkHashExists:WW,iterateDBI:vW,greaterThan:qW,greaterThanEqual:kW,lessThan:VW,lessThanEqual:$W,between:YW}});var jo=g((cue,vI)=>{var LI=require("lodash"),MI=tt(),fe=require("joi"),JW=z(),{hdb_schema_table:Fc,checkValidTable:UI,hdb_table:PI,hdb_database:V_}=Wn(),{handleHDBError:XW,hdb_errors:jW}=ne(),{getDatabases:ZW}=(Ae(),se(Fe)),{HTTP_STATUS_CODES:eQ}=jW,tQ=fe.object({database:V_,schema:V_,table:PI,search_attribute:Fc,search_value:fe.any().required(),get_attributes:fe.array().min(1).items(fe.alternatives(Fc,fe.object())).optional(),desc:fe.bool(),limit:fe.number().integer().min(1),offset:fe.number().integer().min(0)}),rQ=fe.object({database:V_,schema:V_,table:PI,operator:fe.string().valid("and","or").default("and").lowercase(),offset:fe.number().integer().min(0),limit:fe.number().integer().min(1),get_attributes:fe.array().min(1).items(fe.alternatives(Fc,fe.object())).optional(),sort:fe.object({attribute:fe.alternatives(Fc,fe.array().min(1)),descending:fe.bool().optional()}).optional(),conditions:fe.array().min(1).items(fe.alternatives(fe.object({operator:fe.string().valid("and","or").default("and").lowercase(),conditions:fe.array()}),fe.object({search_attribute:fe.alternatives(Fc,fe.array().min(1)),search_type:fe.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:fe.when("search_type",{switch:[{is:"equals",then:fe.any()},{is:"between",then:fe.array().items(fe.alternatives([fe.string(),fe.number()])).length(2)}],otherwise:fe.alternatives(fe.string(),fe.number())}).required()}))).required()});vI.exports=function(e,t){let r=null;switch(t){case"value":r=MI.validateBySchema(e,tQ);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(UI("database",e.schema)),i(UI("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=MI.validateBySchema(e,rQ);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=JW.checkGlobalSchemaTable(e.schema,e.table);if(s)return XW(new Error,s,eQ.NOT_FOUND);let o=ZW()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let u=a(l=>{for(let d=0,f=l.conditions.length;d<f;d++){let E=l.conditions[d];E.conditions?u(E):c.push(E.search_attribute)}},"addConditions");t==="conditions"&&u(e);let _=LI.filter(c,l=>l!=="*"&&l.attribute!=="*"&&!Array.isArray(l)&&!LI.some(o,d=>d===l||d.attribute===l||d.attribute===l.attribute));if(_&&_.length>0){let l=_.join(", ");return l=l.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${l}'`)}}return r}});var dp=g((lue,BI)=>{"use strict";var nQ=Ye(),sQ=jo(),{getSchemaPath:iQ}=Qe();BI.exports=oQ;function oQ(e){let t=sQ(e,"hashes");if(t)throw t;let r=iQ(e.schema,e.table);return nQ.openEnvironment(r,e.table)}a(oQ,"initialize")});var fp=g((due,HI)=>{"use strict";var aQ=Xo(),cQ=dp();HI.exports=uQ;async function uQ(e){let t=await cQ(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return aQ.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(uQ,"lmdbGetDataByHash")});var Zo=g((Eue,xI)=>{"use strict";var Ep=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};xI.exports=Ep});var FI=g((pue,GI)=>{"use strict";var mue=Zo(),lQ=Xo(),_Q=dp();GI.exports=dQ;async function dQ(e){let t=await _Q(e),r=global.hdb_schema[e.schema][e.table];return lQ.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(dQ,"lmdbSearchByHash")});var jn=g((Tue,qI)=>{"use strict";var hp=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,u=!1,_=void 0,l=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=u,this.limit=_,this.offset=l}};qI.exports=hp});var $_=g((Rue,WI)=>{"use strict";var Qt=Xo(),fQ=Ye(),EQ=z(),Ee=_t(),zi=U(),hQ=Pi(),kI=Nr().LMDB_ERRORS_ENUM,{getSchemaPath:mQ}=Qe(),gs=zi.SEARCH_WILDCARDS;async function pQ(e,t,r){let n;e.schema===zi.SYSTEM_SCHEMA_NAME?n=hQ[e.table]:n=global.hdb_schema[e.schema][e.table];let s=KI(e,n.hash_attribute,r,t);return $I(e,s,n.hash_attribute,r)}a(pQ,"prepSearch");async function $I(e,t,r,n){let s=mQ(e.schema,e.table),i=await fQ.openEnvironment(s,e.table),o=YI(i,e,t,r),c=o.transaction||i;if([Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,Ee.SEARCH_TYPES.SEARCH_ALL,Ee.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(SQ(e,r)===!1){let l=e.search_attribute;if(l===r)return n?VI(o,()=>!0):o.map(f=>({[r]:f.key}));let d=a(f=>({[r]:f.value,[l]:f.key}),"toObject");return n?VI(o,d):o.map(d)}let _=e.search_attribute===r?o.map(l=>l.key):o.map(l=>l.value);return n===!0?Qt.batchSearchByHashToMap(c,r,e.get_attributes,_):Qt.batchSearchByHash(c,r,e.get_attributes,_)}a($I,"executeSearch");function YI(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:u}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,u=Number.isInteger(u)?u:void 0,r){case Ee.SEARCH_TYPES.EQUALS:s=Qt.equals(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.CONTAINS:s=Qt.contains(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.ENDS_WITH:case Ee.SEARCH_TYPES._ENDS_WITH:s=Qt.endsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.STARTS_WITH:case Ee.SEARCH_TYPES._STARTS_WITH:s=Qt.startsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Qt.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Qt.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ee.SEARCH_TYPES.SEARCH_ALL:return Qt.searchAll(e,n,t.get_attributes,o,c,u);case Ee.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Qt.searchAllToMap(e,n,t.get_attributes,o,c,u);case Ee.SEARCH_TYPES.BETWEEN:s=Qt.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,u);break;case Ee.SEARCH_TYPES.GREATER_THAN:case Ee.SEARCH_TYPES._GREATER_THAN:s=Qt.greaterThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.GREATER_THAN_EQUAL:case Ee.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Qt.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.LESS_THAN:case Ee.SEARCH_TYPES._LESS_THAN:s=Qt.lessThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.LESS_THAN_EQUAL:case Ee.SEARCH_TYPES._LESS_THAN_EQUAL:s=Qt.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;default:return Object.create(null)}return s}a(YI,"searchByType");function VI(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(VI,"createMapFromIterable");function SQ(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(SQ,"checkToFetchMore");function KI(e,t,r,n){if(EQ.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),gs.indexOf(s)>-1)return r===!0?Ee.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Ee.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(gs[0])<0&&s.indexOf(gs[1])<0)return c===!0?r===!0?Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:Ee.SEARCH_TYPES.EQUALS;if(gs.indexOf(i)>=0&&gs.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),Ee.SEARCH_TYPES.CONTAINS;if(gs.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Ee.SEARCH_TYPES.ENDS_WITH;if(gs.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),Ee.SEARCH_TYPES.STARTS_WITH;if(s.includes(gs[0])||s.includes(gs[1]))return Ee.SEARCH_TYPES.EQUALS;throw new Error(kI.UNKNOWN_SEARCH_TYPE)}else switch(n){case zi.VALUE_SEARCH_COMPARATORS.BETWEEN:return Ee.SEARCH_TYPES.BETWEEN;case zi.VALUE_SEARCH_COMPARATORS.GREATER:return Ee.SEARCH_TYPES.GREATER_THAN;case zi.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Ee.SEARCH_TYPES.GREATER_THAN_EQUAL;case zi.VALUE_SEARCH_COMPARATORS.LESS:return Ee.SEARCH_TYPES.LESS_THAN;case zi.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Ee.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(kI.UNKNOWN_SEARCH_TYPE)}}a(KI,"createSearchTypeFromSearchObject");WI.exports={executeSearch:$I,createSearchTypeFromSearchObject:KI,prepSearch:pQ,searchByType:YI}});var zI=g((bue,QI)=>{"use strict";var Oue=jn(),TQ=jo(),gQ=z(),RQ=U(),AQ=$_();QI.exports=OQ;function OQ(e,t){if(!gQ.isEmpty(t)&&RQ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=TQ(e,"value");if(n)throw n;return AQ.prepSearch(e,t,!0)}a(OQ,"lmdbGetDataByValue")});var qc=g((Iue,JI)=>{"use strict";var Nue=jn(),bQ=jo(),yQ=z(),NQ=U(),IQ=$_();JI.exports=wQ;async function wQ(e,t){if(!yQ.isEmpty(t)&&NQ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=bQ(e,"value");if(n)throw n;return IQ.prepSearch(e,t,!1)}a(wQ,"lmdbSearchByValue")});var jI=g((Due,XI)=>{"use strict";var Cue=_t(),mp=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}},pp=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Sp=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};XI.exports={SearchByConditionsObject:mp,SearchCondition:pp,SortAttribute:Sp}});var nw=g((Pue,rw)=>{"use strict";var Mue=jI().SearchByConditionsObject,CQ=jn(),DQ=jo(),Tp=Xo(),Y_=_t(),{Resource:Uue}=(An(),se(gp)),tw=$_(),LQ=_p(),MQ=require("lodash"),{getSchemaPath:UQ}=Qe(),ZI=Ye(),{handleHDBError:PQ,hdb_errors:vQ}=ne(),{HTTP_STATUS_CODES:BQ}=vQ,HQ=1e8;rw.exports=xQ;async function xQ(e){let t=DQ(e,"conditions");if(t)throw PQ(t,t.message,BQ.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=UQ(e.schema,e.table),n=await ZI.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let _ of e.conditions)ZI.openDBI(n,_.search_attribute);let i=MQ.sortBy(e.conditions,_=>{if(_.estimated_count===void 0){let l=_.search_type;l===Y_.SEARCH_TYPES.EQUALS?_.estimated_count=Tp.count(n,_.search_attribute,_.search_value):l===Y_.SEARCH_TYPES.CONTAINS||l===Y_.SEARCH_TYPES.ENDS_WITH?_.estimated_count=1/0:_.estimated_count=HQ}return _.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await ew(o,e,i[0],s.hash_attribute),u;if(!e.operator||e.operator.toLowerCase()==="and"){let _=n.dbis[s.hash_attribute],l=i.slice(1).map(tw.filterByType),d=l.length,f=Tp.setGetWholeRowAttributes(n,e.get_attributes);u=c.map(E=>_.get(E,{transaction:o,lazy:!0})),d>0&&(u=u.filter(E=>{for(let h=0;h<d;h++)if(!l[h](E))return!1;return!0})),(e.offset||e.limit!==void 0)&&(u=u.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),u=u.map(E=>LQ.parseRow(E,f))}else{for(let d=1;d<i.length;d++){let f=i[d],E=await ew(o,e,f,s.hash_attribute);c=c.concat(E)}let _=new Set,l=e.offset||0;c=c.filter(d=>_.has(d)?!1:(_.add(d),!0)).slice(l,e.limit&&e.limit+l),u=Tp.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return u.onDone=()=>{o.done()},u}a(xQ,"lmdbSearchByConditions");async function ew(e,t,r,n){let s=new CQ(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===Y_.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,tw.searchByType(e,s,i,n).map(o=>o.value)}a(ew,"executeConditionSearch")});var kc=g((Bue,sw)=>{"use strict";var GQ=U().OPERATIONS_ENUM,Rp=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=GQ.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};sw.exports=Rp});var Ap=g((xue,dw)=>{"use strict";var cw=jn(),uw=kc(),lw=qc(),_w=Hc(),ur=U(),iw=z(),ow=Ye(),{getTransactionAuditStorePath:FQ,getSchemaPath:qQ}=Qe(),aw=K();dw.exports=kQ;async function kQ(e){try{if(iw.isEmpty(global.hdb_schema[e.schema])||iw.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await VQ(e),await $Q(e);let t=qQ(e.schema,e.table);try{await ow.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")aw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=FQ(e.schema,e.table);await ow.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")aw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(kQ,"lmdbDropTable");async function VQ(e){let t=new cw(ur.SYSTEM_SCHEMA_NAME,ur.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,ur.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[ur.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await lw(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 uw(ur.SYSTEM_SCHEMA_NAME,ur.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await _w(s)}a(VQ,"deleteAttributesFromSystem");async function $Q(e){let t=new cw(ur.SYSTEM_SCHEMA_NAME,ur.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,ur.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[ur.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,ur.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,ur.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await lw(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 uw(ur.SYSTEM_SCHEMA_NAME,ur.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await _w(s)}catch(i){throw i}}a($Q,"dropTableFromSystem")});var Ew=g((Fue,fw)=>{"use strict";var YQ=require("fs-extra"),KQ=jn(),WQ=Zo(),QQ=kc(),zQ=Ap(),JQ=Hc(),XQ=fp(),jQ=qc(),Rs=U(),{getSchemaPath:ZQ}=Qe(),{handleHDBError:ez,hdb_errors:tz}=ne(),{HDB_ERROR_MSGS:rz,HTTP_STATUS_CODES:nz}=tz;fw.exports=sz;async function sz(e){let t;try{t=await iz(e.schema);let r=new KQ(Rs.SYSTEM_SCHEMA_NAME,Rs.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await jQ(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await zQ(c)}catch(u){if(u.message!=="invalid environment")throw u}}let s=new QQ(Rs.SYSTEM_SCHEMA_NAME,Rs.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await JQ(s);let i=ZQ(t);await YQ.remove(i)}catch(r){throw r}}a(sz,"lmdbDropSchema");async function iz(e){let t=new WQ(Rs.SYSTEM_SCHEMA_NAME,Rs.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await XQ(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw ez(new Error,rz.SCHEMA_NOT_FOUND(e),nz.NOT_FOUND,void 0,void 0,!0);return n}a(iz,"validateDropSchema")});var bp=g((kue,hw)=>{"use strict";var Op=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};hw.exports=Op});var pw=g((Yue,mw)=>{"use strict";var oz=require("fs-extra"),K_=Ye(),{getTransactionAuditStorePath:az}=Qe(),yp=_t(),$ue=bp();mw.exports=cz;async function cz(e){let t;try{let r=az(e.schema,e.table);await oz.mkdirp(r),t=await K_.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{K_.createDBI(t,yp.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),K_.createDBI(t,yp.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),K_.createDBI(t,yp.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(cz,"createTransactionsAuditEnvironment")});var Rw=g((Wue,gw)=>{"use strict";var Np=U(),Sw=Ye(),uz=Go(),{getSystemSchemaPath:lz,getSchemaPath:_z}=Qe(),dz=Pi(),fz=d_(),Ip=__(),Ez=K(),hz=pw(),Cp=dz.hdb_table,Tw=[];for(let e=0;e<Cp.attributes.length;e++)Tw.push(Cp.attributes[e].attribute);gw.exports=mz;async function mz(e,t){let r=_z(t.schema,t.table),n=new Ip(t.schema,t.table,Np.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Ip(t.schema,t.table,Np.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Ip(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Sw.createEnvironment(r,t.table),e!==void 0){let o=await Sw.openEnvironment(lz(),Np.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await uz.insertRecords(o,Cp.hash_attribute,Tw,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await wp(n),await wp(s),await wp(i)}await hz(t)}catch(o){throw o}}a(mz,"lmdbCreateTable");async function wp(e){try{await fz(e)}catch(t){Ez.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(wp,"createAttribute")});var Ow=g((zue,Aw)=>{"use strict";var pz=Nc(),Sz=wc(),Tz=x_(),Vc=U(),gz=Go().updateRecords,Rz=Ye(),{getSchemaPath:Az}=Qe(),Oz=vc(),bz=K();Aw.exports=yz;async function yz(e){try{let{schema_table:t,attributes:r}=pz(e);Sz(e,r,t.hash_attribute),e.schema!==Vc.SYSTEM_SCHEMA_NAME&&(r.includes(Vc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Vc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Vc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Vc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await Tz(e.hdb_auth_header,t,r),s=Az(e.schema,e.table),i=await Rz.openEnvironment(s,e.table),o=await gz(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await Oz(e,o)}catch(c){bz.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(yz,"lmdbUpdateRecords")});var yw=g((Xue,bw)=>{"use strict";var Nz=U().OPERATIONS_ENUM,Dp=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Nz.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};bw.exports=Dp});var Iw=g((ele,Nw)=>{"use strict";var Zue=yw(),Iz=Nc(),wz=wc(),Cz=x_(),$c=U(),Dz=Go().upsertRecords,Lz=Ye(),{getSchemaPath:Mz}=Qe(),Uz=vc(),Pz=K(),{handleHDBError:vz,hdb_errors:Bz}=ne();Nw.exports=Hz;async function Hz(e){let t;try{t=Iz(e)}catch(u){throw vz(u,u.message,Bz.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;wz(e,n,r.hash_attribute),e.schema!==$c.SYSTEM_SCHEMA_NAME&&(n.includes($c.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push($c.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes($c.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push($c.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await Cz(e.hdb_auth_header,r,n),i=Mz(e.schema,e.table),o=await Lz.openEnvironment(i,e.table),c=await Dz(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await Uz(e,c)}catch(u){Pz.error(`unable to write transaction due to ${u.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(Hz,"lmdbUpsertRecords")});var Cw=g((rle,ww)=>{"use strict";var Lp=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};ww.exports=Lp});var Lw=g((sle,Dw)=>{"use strict";var Mp=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}};Dw.exports=Mp});var Pw=g((ale,Uw)=>{"use strict";var Up=Ye(),{getTransactionAuditStorePath:xz}=Qe(),ole=Cw(),Yc=_t(),Gz=z(),Mw=Lw(),Fz=require("util").promisify,qz=Fz(setTimeout),kz=1e4,Vz=100;Uw.exports=$z;async function $z(e){let t=xz(e.schema,e.table),r=await Up.openEnvironment(t,e.table,!0),n=Up.listDBIs(r);Up.initializeDBIs(r,Yc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new Mw;do s=await Yz(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 qz(Vz);while(s.transactions_deleted>0);return i}a($z,"deleteAuditLogsBefore");async function Yz(e,t){let r=new Mw;try{let n=e.dbis[Yc.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[Yc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Gz.isEmpty(c)||(s=e.dbis[Yc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let u=0;u<o.hash_values.length;u++)s=e.dbis[Yc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[u],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>kz)break}return await s,r}catch(n){throw n}}a(Yz,"deleteTransactions")});var Bw=g((ule,vw)=>{"use strict";var Pp=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};vw.exports=Pp});var xw=g((dle,Hw)=>{"use strict";var Kz=jn(),Wz=kc(),_le=Bw(),Zn=U(),Qz=z(),vp=Ye(),zz=Pi(),Jz=qc(),Xz=Hc(),{getSchemaPath:jz}=Qe();Hw.exports=Zz;async function Zz(e,t=!0){let r;e.schema===Zn.SYSTEM_SCHEMA_NAME?r=zz[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await t2(e),s=jz(e.schema,e.table),i=await vp.openEnvironment(s,e.table);return t===!0&&await e2(e,i,r.hash_attribute),vp.dropDBI(i,e.attribute),n}a(Zz,"lmdbDropAttribute");async function e2(e,t,r){let n=vp.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:u}of n.getRange({start:!1,versions:!0})){let _={};for(let l in c)l!==i&&(_[l]=c[l]);s=t.dbis[r].put(o,_,u)}await s}a(e2,"removeAttributeFromAllObjects");async function t2(e){let t=new Kz(Zn.SYSTEM_SCHEMA_NAME,Zn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Zn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Zn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Zn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await Jz(t)).filter(o=>o[Zn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(Qz.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Zn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new Wz(Zn.SYSTEM_SCHEMA_NAME,Zn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Xz(i)}a(t2,"dropAttributeFromSystem")});var $w=g((hle,Vw)=>{"use strict";var Bp=Ye(),ea=_t(),Ele=Ir(),Hp=U(),Gw=z(),{getTransactionAuditStorePath:r2}=Qe(),n2=Xo(),W_=Qo(),s2=K();Vw.exports=i2;async function i2(e){let t=r2(e.schema,e.table),r=await Bp.openEnvironment(t,e.table,!0),n=Bp.listDBIs(r);Bp.initializeDBIs(r,ea.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Hp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return Fw(r,e.search_values);case Hp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,a2(r,e.search_values,s);case Hp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return o2(r,e.search_values);default:return Fw(r)}}a(i2,"readAuditLog");function Fw(e,t=[0,Date.now()]){Gw.isEmpty(t[0])&&(t[0]=0),Gw.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[ea.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 W_,s))}a(Fw,"searchTransactionsByTimestamp");function o2(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[ea.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,kw(e,i))}return Object.fromEntries(r)}a(o2,"searchTransactionsByUsername");function a2(e,t,r){let n=new Map;for(let c=0,u=t.length;c<u;c++){let _=t[c],l=n2.equals(e,ea.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ea.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,_);for(let{value:d}of l){let f=Number(d);n.has(f)?n.get(f).push(_.toString()):n.set(f,[_.toString()])}}let s=Array.from(n.keys()),i=kw(e,s),o=new Map;for(let c=0;c<i.length;c++){let u=i[c],_=u.timestamp,l=n.get(_);qw(u,"records",r,l,o),qw(u,"original_records",r,l,o)}return Object.fromEntries(o)}a(a2,"searchTransactionsByHashValues");function qw(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],u=c[r].toString();if(n.indexOf(u)>=0)if(s.has(u)){let _=s.get(u),l=_[_.length-1];if(l.timestamp===i)l[t]=[c];else{let d=new W_(e.operation,e.user_name,i,void 0);d[t]=[c],_.push(d)}}else{let _=new W_(e.operation,e.user_name,i,void 0);_[t]=[c],s.set(u,[_])}}}a(qw,"loopRecords");function kw(e,t){let r=[];try{let n=e.dbis[ea.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 W_,i);r.push(o)}}catch(i){s2.warn(i)}return r}catch(n){throw n}}a(kw,"batchSearchTransactions")});var Kw=g((Tle,Yw)=>{"use strict";var{getSchemaPath:ple}=Qe(),Sle=Ye(),{database:c2}=(Ae(),se(Fe));Yw.exports={writeTransaction:u2};async function u2(e,t,r){return c2({database:e,table:t}).transaction(r)}a(u2,"writeTransaction")});var Jw=g((Rle,zw)=>{"use strict";var{getSchemaPath:Ww}=Qe(),Qw=Ye();zw.exports={flush:l2,resetReadTxn:_2};async function l2(e,t){return(await Qw.openEnvironment(Ww(e,t),t.toString())).flushed}a(l2,"flush");async function _2(e,t){try{(await Qw.openEnvironment(Ww(e,t),t.toString())).resetReadTxn()}catch{}}a(_2,"resetReadTxn")});var eC=g((Ole,Zw)=>{"use strict";var{Readable:d2}=require("stream"),{getDatabases:f2}=(Ae(),se(Fe)),{readSync:E2,openSync:h2,createReadStream:Xw}=require("fs"),{open:m2}=require("lmdb"),jw=t_(),p2=n_(),{AUDIT_STORE_OPTIONS:S2}=(Mi(),se(tC)),{INTERNAL_DBIS_NAME:T2,AUDIT_STORE_NAME:g2}=_t();Zw.exports=A2;var xp=32768,R2=100;async function A2(e){let t=e.database||e.schema||"data",r=f2()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let _=r[s[0]];if(!_)throw new Error(`Can not find table ${s[0]}`);let l=_.dbisDB,d=m2({noSync:!0,maxDbs:p2.MAX_DBS}),f,E=d.openDB(T2,new jw(!1)),h=l.useReadTransaction(),p=0,S=a(async function(b,R){R.encoding="binary",R.encoder=void 0;let L=d.openDB(b,R),H=l.openDB(b,R);for(let{key:P,version:k,value:B}of H.getRange({transaction:h,versions:H.useVersions}))f=L.put(P,B,k),p++%R2===0&&(await new Promise(J=>setTimeout(J,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:b,value:R}of l.getRange({transaction:h,start:!1}))if(s.some(L=>b.startsWith?.(L+"/"))){E.put(b,R);let[,L]=b.split("/"),H=!L,P=new jw(!H,H);await S(b,P)}e.include_audit&&await S(g2,Object.assign({},S2)),await f;let T=Xw(d.path);return T.headers=u(),T.on("close",()=>{h.done(),d.close()}),T}let o=r[Object.keys(r)[0]].primaryStore,c=h2(o.path);return o.transaction(()=>{let _=Buffer.alloc(xp);E2(c,_,0,xp),o.resetReadTxn();let l=o.useReadTransaction();l.renew();let d=Xw(null,{fd:c,start:xp}),f=new d2.from(async function*(){yield _;for await(let E of d)l.openTimer&&(l.openTimer=0),yield E;l.done()}());return f.headers=u(),f});function u(){let _=new Map;return _.set("content-type","application/octet-stream"),_.set("content-disposition",`attachment; filename="${t}"`),_.set("date",n),_}}a(A2,"getBackup")});var sC=g((yle,nC)=>{"use strict";var O2=K(),{handleHDBError:b2}=ne(),y2=pb(),N2=d_(),I2=op(),w2=EI(),C2=Hc(),D2=fp(),L2=FI(),M2=zI(),U2=qc(),P2=nw(),v2=Ew(),B2=Rw(),H2=Ow(),x2=Iw(),G2=Pw(),F2=Ap(),q2=xw(),k2=$w(),V2=Kw(),rC=Jw(),$2=eC(),Gp=class extends y2{static{a(this,"LMDBBridge")}async searchByConditions(t){return P2(t)}async getDataByHash(t){return await D2(t)}async searchByHash(t){return await L2(t)}async getDataByValue(t,r){return await M2(t,r)}async searchByValue(t){return await U2(t)}async createSchema(t){return await w2(t)}async dropSchema(t){return await v2(t)}async createTable(t,r){return await B2(t,r)}async dropTable(t){return await F2(t)}async createAttribute(t){return await N2(t)}async createRecords(t){return await I2(t)}async updateRecords(t){return await H2(t)}async upsertRecords(t){try{return await x2(t)}catch(r){throw b2(r,null,null,O2.ERR,r)}}async deleteRecords(t){return await C2(t)}async dropAttribute(t){return await q2(t)}async deleteAuditLogsBefore(t){return await G2(t)}async readAuditLog(t){return await k2(t)}writeTransaction(t,r,n){return V2.writeTransaction(t,r,n)}flush(t,r){return rC.flush(t,r)}resetReadTxn(t,r){return rC.resetReadTxn(t,r)}getBackup(t){return $2(t)}};nC.exports=Gp});function z2(){Q2=setInterval(function(){for(let e of Fp)if(e.stale){let t=e[Oe]?.url;aC.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},W2).unref()}var qp,oC,aC,Y2,Fp,K2,Kc,iC,Ji,Q_,W2,Q2,kp=Re(()=>{qp=x(Ir()),oC=x(ne()),aC=x(K());An();Ho();Y2=100,Fp=new Set,K2=25e3,Ji=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;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.readTxnsUsed=1,Zl(()=>{this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxn.openTimer&&(this.readTxn.openTimer=0)}),Fp.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),Zl(()=>{this.readTxn.use()}),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(Fp.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(Kc&&performance.now()-iC>K2)throw new oC.ServerError("Outstanding write transactions have too long of queue, please try again later",503)}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=t.timestamp||(0,qp.getNextMonotonicTime)());let n=t.retries||0;if(this.validated<this.writes.length)try{let l=this.validated;this.validated=this.writes.length;for(let f=l;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let d;for(let f=l;f<this.validated;f++){let E=this.writes[f];E&&(E.before||E.beforeIntermediate)&&(d=!0)}if(d)return(async()=>{try{for(let f=0;f<2;f++){let E;for(let h=l;h<this.validated;h++){let p=this.writes[h];if(!p)continue;let S=p[f===0?"before":"beforeIntermediate"];if(S){let T=S();E?E.push?E.push(T):E=[E,T]:E=T}}E&&await(E.push?Promise.all(E):E)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(l){throw this.abort(),l}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(l=>l);let c=a(l=>{l.commit(r,l.entry,n)},"doWrite"),u=a(()=>{let l=this.writes[o++];if(l)if(l.key){n>0&&(l.entry=l.store.getEntry(l.key));let d=l.store.ifVersion(l.key,l.entry?.version??null,u);s=s||d}else u();else for(let d of this.writes)c(d)},"nextCondition");if(this.writes.length<Y2>>n?u():s=this.writes[0].store.transaction(()=>{for(let l of this.writes)l.entry=l.store.getEntry(l.key),c(l);return!0}),s)return Kc||(Kc=s,iC=performance.now(),Kc.then(()=>{Kc=null})),s.then(l=>l?(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))):(t?t.retries=n+1:t={retries:1},this.commit(t)));let _={txnTime:r};if(this.next){let l=this.next?.commit(t);if(l?.then)return l?.then(d=>({txnTime:r,next:d}));_.next=l}return _}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},Q_=class extends Ji{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,qp.getNextMonotonicTime)())}getReadTxn(){}},W2=3e4;a(z2,"startMonitoringTxns");z2()});function ze(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 Ji;e.timestamp&&(n.timestamp=e.timestamp),n[Oe]=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 u=n.commit({letItLinger:r?.letItLinger});return u.then?u.then(()=>c):c}function o(c){throw n.abort({}),c}}var cC,Xi=Re(()=>{cC=require("../../index");An();kp();a(ze,"transaction");(0,cC._assignPackageExport)("transaction",ze);ze.commit=function(e){let t=(e[Oe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};ze.abort=function(e){let t=(e[Oe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var pC={};$e(pC,{ResourceBridge:()=>Yp});function Kp({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 lC(e,t){let r=es(e),n=Kp(e,r);if(!r)throw new Cn.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},o;ze(i,()=>new Promise(_=>o=_));let c=e.ids||e.hash_values,u=0;return{[Symbol.asyncIterator](){return{async next(){if(u<c.length){let _=c[u++],l=await r.get({id:_,lazy:s,select:n},i);return l=l&&J_(l),t?{value:{key:_,value:l}}:{value:l}}else return o(),{done:!0}},return(_){return o(),{value:_,done:!0}},throw(_){return o(),{done:!0}}}}}}function es(e){let t=e.database||e.schema||X2,r=Dn()[t];if(!r)throw(0,Cn.handleHDBError)(new Error,J2.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function _C(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*dC(e,t,r){let n;for await(let s of e.getHistory(t,r)){let i=s.type;i==="put"&&(i="upsert");let{id:o,version:c,value:u}=s;n?.timestamp===c?(n.hash_values.push(o),n.records.push(u)):(n&&(yield n),n={operation:i,user_name:s.user,timestamp:c,hash_values:[o],records:[u]})}n&&(yield n)}var fC,z_,Cn,EC,hC,Ln,Vp,$p,mC,J2,X2,j2,Z2,uC,Yp,SC=Re(()=>{"use strict";fC=x(sC()),z_=x(jo()),Cn=x(ne());Ae();EC=x(Nc()),hC=x(wc()),Ln=x(U()),Vp=x(Ts()),$p=x(wn()),mC=x(z());Xi();X_();({HDB_ERROR_MSGS:J2}=Cn.hdb_errors),X2="data",j2=1e4,Z2=10,Yp=class extends fC.default{static{a(this,"ResourceBridge")}constructor(t){super(t),uC=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,z_.default)(t,"conditions");if(r)throw(0,Cn.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=es(t);if(!n)throw new Cn.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:Kp(t,n),sort:t.sort,allowFullScan:!0})}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 Cn.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}]}at({database:r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await es(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=es(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,u)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,u,()=>r.primaryStore.put(o,c,u)).then(_=>{if(!_){let{value:l,version:d}=r.primaryStore.getEntry(o);return i(o,l,d)}})),"deleteRecord");for(let{key:o,value:c,version:u}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,u),await new Promise(_=>setImmediate(_));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){es(t).dropTable()}createSchema(t){return Wc({database:t.schema,table:null}),Vp.signalSchemaChange(new $p.SchemaEventMsg(process.pid,Ln.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Wp(t.schema),Vp.signalSchemaChange(new $p.SchemaEventMsg(process.pid,Ln.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,uC.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,EC.default)(t);(0,hC.default)(t,n,r.primaryKey);let s,i=Dn()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt};return ze(o,async c=>{if(!i.schemaDefined){s=[];for(let l of n)i.attributes.find(f=>f.name==l)||s.push(l);s.length>0&&await i.addAttributes(s.map(l=>({name:l,indexed:!0})))}let u=[],_=[];for(let l of t.records){let d=await i.get(l[i.primaryKey],o);if(t.requires_existing&&!d||t.requires_no_existing&&d){_.push(l[i.primaryKey]);continue}d&&(d=J_(d));for(let f in l)if(Object.prototype.hasOwnProperty.call(l,f)){let E=l[f];if(typeof E=="function")try{let h=E([[d]]);Array.isArray(h)&&(E=h[0].func_val,l[f]=E)}catch(h){throw h.message+="Trying to set key "+f+" on object"+JSON.stringify(l),h}}if(d)for(let f in d)Object.prototype.hasOwnProperty.call(l,f)||(l[f]=d[f]);await i.put(l,o),u.push(l[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:u,new_attributes:s,skipped_hashes:_}})}async deleteRecords(t){let r=Dn()[t.schema][t.table],n={user:t.hdb_user};return ze(n,async s=>{let i=t.hash_values||t.records.map(u=>u[r.primaryKey]),o=[],c=[];for(let u of i)await r.delete(u,n)?o.push(u):c.push(u);return _C(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Dn()[t.schema][t.table];if(!r.createdTimeProperty)throw new Cn.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:Ln.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,u=[],_=a(async()=>{let l=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:u});i.push(...l.deleted_hashes),o.push(...l.skipped_hashes),await(0,mC.async_set_timeout)(Z2),u=[],s=!0},"chunkDelete");for await(let l of n)u.push(l[r.primaryKey]),c++,c%j2===0&&await _();return u.length>0&&await _(),s?_C(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,z_.default)(t,"hashes");if(r)throw r;return lC(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of lC(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Ln.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,z_.default)(t,"value");if(n)throw n;let s=es(t);if(!s)throw new Cn.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===Ln.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:Kp(t,s)})}async getDataByValue(t,r){let n=new Map,s=es(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){es({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return es(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=es(t),n={};switch(t.search_type){case Ln.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case Ln.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of dC(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return dC(r,t.search_values?.[0],t.search_values?.[1])}}};a(Kp,"getSelect");a(lC,"getRecords");a(es,"getTable");a(_C,"createDeleteResponse");a(dC,"groupRecordsInHistory")});var yn=g((qle,TC)=>{"use strict";var{ResourceBridge:eJ}=(SC(),se(pC)),tJ=re();tJ.initSync();var j_;function rJ(){return j_||(j_=new eJ,j_)}a(rJ,"getBridge");TC.exports=rJ()});var OC=g((Vle,AC)=>{"use strict";var gC=require("lodash"),Qc=require("mathjs"),nJ=require("jsonata"),RC=z();AC.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?gC.uniqWith(e,gC.isEqual):e,searchJSON:sJ,mad:zc.bind(null,Qc.mad),mean:zc.bind(null,Qc.mean),mode:zc.bind(null,Qc.mode),prod:zc.bind(null,Qc.prod),median:zc.bind(null,Qc.median)};function zc(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(zc,"aggregateFunction");function sJ(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(RC.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),RC.isEmpty(this.__ala__.res[r])){let n=nJ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(sJ,"searchJSON")});var yC=g((Yle,bC)=>{"use strict";var ft=require("moment"),Qp="YYYY-MM-DDTHH:mm:ss.SSSZZ";ft.suppressDeprecationWarnings=!0;bC.exports={current_date:()=>ft().utc().format("YYYY-MM-DD"),current_time:()=>ft().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return ft(e).utc().format("YYYY");case"month":return ft(e).utc().format("MM");case"day":return ft(e).utc().format("DD");case"hour":return ft(e).utc().format("HH");case"minute":return ft(e).utc().format("mm");case"second":return ft(e).utc().format("ss");case"millisecond":return ft(e).utc().format("SSS");default:break}},date:e=>ft(e).utc().format(Qp),date_format:(e,t)=>ft(e).utc().format(t),date_add:(e,t,r)=>ft(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>ft(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=ft(e).utc(),s=ft(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>ft().utc().valueOf(),get_server_time:()=>ft().format(Qp),offset_utc:(e,t)=>ft(e).utc().utcOffset(t).format(Qp)}});var CC=g((Kle,wC)=>{"use strict";var iJ=require("@turf/area"),oJ=require("@turf/length"),aJ=require("@turf/circle"),cJ=require("@turf/difference"),uJ=require("@turf/distance"),lJ=require("@turf/boolean-contains"),_J=require("@turf/boolean-equal"),dJ=require("@turf/boolean-disjoint"),fJ=require("@turf/helpers"),NC=U(),me=z(),As=K();wC.exports={geoArea:EJ,geoLength:hJ,geoCircle:mJ,geoDifference:pJ,geoDistance:IC,geoNear:SJ,geoContains:TJ,geoEqual:gJ,geoCrosses:RJ,geoConvert:AJ};function EJ(e){if(me.isEmpty(e))return NaN;typeof e=="string"&&(e=me.autoCastJSON(e));try{return iJ.default(e)}catch(t){return As.trace(t,e),NaN}}a(EJ,"geoArea");function hJ(e,t){if(me.isEmpty(e))return NaN;typeof e=="string"&&(e=me.autoCastJSON(e));try{return oJ.default(e,{units:t||"kilometers"})}catch(r){return As.trace(r,e),NaN}}a(hJ,"geoLength");function mJ(e,t,r){if(me.isEmpty(e))return NaN;if(me.isEmpty(t))return NaN;typeof e=="string"&&(e=me.autoCastJSON(e));try{return aJ.default(e,t,{units:r||"kilometers"})}catch(n){return As.trace(n,e,t),NaN}}a(mJ,"geoCircle");function pJ(e,t){if(me.isEmpty(e))return NaN;if(me.isEmpty(t))return NaN;typeof e=="string"&&(e=me.autoCastJSON(e)),typeof t=="string"&&(t=me.autoCastJSON(t));try{return cJ(e,t)}catch(r){return As.trace(r,e,t),NaN}}a(pJ,"geoDifference");function IC(e,t,r){if(me.isEmpty(e))return NaN;if(me.isEmpty(t))return NaN;typeof e=="string"&&(e=me.autoCastJSON(e)),typeof t=="string"&&(t=me.autoCastJSON(t));try{return uJ.default(e,t,{units:r||"kilometers"})}catch(n){return As.trace(n,e,t),NaN}}a(IC,"geoDistance");function SJ(e,t,r,n){if(me.isEmpty(e)||me.isEmpty(t))return!1;if(me.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=me.autoCastJSON(e)),typeof t=="string"&&(t=me.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return IC(e,t,n)<=r}catch(s){return As.trace(s,e,t),!1}}a(SJ,"geoNear");function TJ(e,t){if(me.isEmpty(e)||me.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=me.autoCastJSON(e)),typeof t=="string"&&(t=me.autoCastJSON(t));try{return lJ.default(e,t)}catch(r){return As.trace(r,e,t),!1}}a(TJ,"geoContains");function gJ(e,t){if(me.isEmpty(e)||me.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=me.autoCastJSON(e)),typeof t=="string"&&(t=me.autoCastJSON(t));try{return _J.default(e,t)}catch(r){return As.trace(r,e,t),!1}}a(gJ,"geoEqual");function RJ(e,t){if(me.isEmpty(e)||me.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=me.autoCastJSON(e)),typeof t=="string"&&(t=me.autoCastJSON(t));try{return!dJ.default(e,t)}catch(r){return As.trace(r,e,t),!1}}a(RJ,"geoCrosses");function AJ(e,t,r){if(me.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(me.isEmpty(t))throw new Error("geo_type is required");if(me.isEmpty(NC.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(NC.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=me.autoCastJSON(e)),fJ[t](e,r)}a(AJ,"geoConvert")});var Z_=g((Qle,DC)=>{var ji=OC(),Hr=yC(),ts=CC();DC.exports=e=>{e.aggr.mad=e.aggr.MAD=ji.mad,e.aggr.mean=e.aggr.MEAN=ji.mean,e.aggr.mode=e.aggr.MODE=ji.mode,e.aggr.prod=e.aggr.PROD=ji.prod,e.aggr.median=e.aggr.MEDIAN=ji.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=ji.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=ji.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Hr.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Hr.current_time,e.fn.extract=e.fn.EXTRACT=Hr.extract,e.fn.date=e.fn.DATE=Hr.date,e.fn.date_format=e.fn.DATE_FORMAT=Hr.date_format,e.fn.date_add=e.fn.DATE_ADD=Hr.date_add,e.fn.date_sub=e.fn.DATE_SUB=Hr.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Hr.date_diff,e.fn.now=e.fn.NOW=Hr.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Hr.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Hr.get_server_time,e.fn.getdate=e.fn.GETDATE=Hr.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Hr.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=ts.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=ts.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=ts.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=ts.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=ts.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=ts.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=ts.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=ts.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=ts.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=ts.geoNear}});var PC=g((zle,UC)=>{"use strict";var Jc=require("lodash"),lr=require("alasql");lr.options.cache=!1;var OJ=Z_(),LC=require("clone"),ed=require("recursive-iterator"),le=K(),we=z(),ta=yn(),bJ=U(),{hdb_errors:yJ}=ne(),{getDatabases:MC}=(Ae(),se(Fe)),NJ="IS NULL",Mn="There was a problem performing this search. Please check the logs and try again.";OJ(lr);var zp=class{static{a(this,"SQLSearch")}constructor(t,r){if(we.isEmpty(t))throw le.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 le.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw le.error("Error thrown from checkEmptySQL in SQLSearch class method search."),le.error(n),new Error(Mn)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw le.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),le.error(n),new Error(Mn)}if(Object.keys(this.data).length===0)return le.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw le.error("Error thrown from processJoins in SQLSearch class method search."),le.error(n),new Error(Mn)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw le.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),le.error(n),new Error(Mn)}try{return t=await this._finalSQL(),t}catch(n){throw le.error("Error thrown from finalSQL in SQLSearch class method search."),le.error(n),new Error(Mn)}}_getColumns(){let t=new ed(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(LC(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=Jc.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=MC()[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)){le.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new ed(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 lr.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 lr.yy.LogicValue({value:i}):n instanceof lr.yy.StringValue&&we.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new lr.yy.NumValue({value:i}))});if(t){le.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new ed(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(bJ.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 u=Array.isArray(r.right)?r.right:r.left;for(let _=0;_<u.length;_++)if(u[_].value)n.add(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&&Jc.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 lr.promise(r)}catch(r){throw le.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),le.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(LC(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(NJ)>-1&&this.tables.forEach(s=>{let i={columnid:MC()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=Jc.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]},u=!1,_=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(u=!0),!we.isEmpty(this.exact_search_values[_])&&!this.exact_search_values[_].ignore&&!we.isEmptyOrZeroLength(this.exact_search_values[_].values))if(u)try{c.hash_values=Array.from(this.exact_search_values[_].values);let l=await ta.getDataByHash(c);for(let d of c.hash_values)l.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(l){throw le.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),le.error(l),new Error(Mn)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[_].values).map(async l=>{let d=Object.assign({},c);d.search_value=l;let f=await ta.getDataByValue(d);for(let[E,h]of f)this.data[i].__merged_data[E]?this._updateMergedAttribute(i,E,s.attribute,h[s.attribute]):(this.data[i].__merged_data[E]=[...n[i]],this._updateMergedAttribute(i,E,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,E))}))}catch(l){throw le.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),le.error(l),new Error(Mn)}else if(!we.isEmpty(this.comparator_search_values[_])&&!this.comparator_search_values[_].ignore&&!we.isEmptyOrZeroLength(this.comparator_search_values[_].comparators))try{let l=this.comparator_search_values[_].comparators;for(let d=0,f=l.length;d<f;d++){let E=l[d];c.search_attribute=E.attribute,c.search_value=E.search_value;let h=await ta.getDataByValue(c,E.operation);if(u)for(let[p]of h)this.data[i].__merged_data[p]||(this.data[i].__merged_data[p]=[...n[i]],this._setMergedHashAttribute(i,p));else for(let[p,S]of h)this.data[i].__merged_data[p]?this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]):(this.data[i].__merged_data[p]=[...n[i]],this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]),this._setMergedHashAttribute(i,p))}}catch(l){throw le.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),le.error(l),new Error(Mn)}else try{c.search_attribute=s.attribute,c.search_value="*";let l=await ta.getDataByValue(c);if(u)for(let[d]of l)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,f]of l)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,f[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,f[s.attribute]),this._setMergedHashAttribute(i,d))}catch(l){throw le.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),le.error(l),new Error(Mn)}}}_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 lr.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 lr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new lr.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 lr.yy.FuncValue:new lr.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(E=>{E.joinmode&&E.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(E.table);let h=E.joinmode+" JOIN ? AS "+(E.as?E.as:E.table.tableid);E.on&&(h+=" ON "+E.on.toString()),i.push(h),t.push(Object.values(this.data[`${E.table.databaseid_orig}_${E.table.as?E.table.as_orig:E.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(E=>{let h=this.data[`${E.databaseid_orig}_${E.as?E.as_orig:E.tableid_orig}`].__hash_name,p=E.as?E.as_orig:E.tableid_orig;o.push({key:`'${p}.${h}'`,schema:E.databaseid_orig,table:E.as?E.as_orig:E.tableid_orig,keys:new Set}),r.push(`${E.as?E.as:E.tableid}.\`${h}\` AS "${p}.${h}"`),c[E.as?E.as_orig:E.tableid_orig]=this.data[`${E.databaseid_orig}_${E.as?E.as_orig:E.tableid_orig}`].__merged_attributes});let u=this.statement.where?"WHERE "+this.statement.where:"";u=u.replace(/NOT\(NULL\)/g,"NOT NULL");let _="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(_="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(E=>{E.is_func?r.push(E.initial_select_column.toString()):E.initial_select_column.tableid?r.push(`${E.initial_select_column.tableid}.${E.initial_select_column.columnid} AS ${E.expression.columnid}`):r.push(`${E.initial_select_column.columnid} AS ${E.expression.columnid}`)}));let l="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(l=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let f=[];try{let E=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${u} ${_} ${l} ${d}`,h=this._convertColumnsToIndexes(E,s);f=await lr.promise(h,t),t=null}catch(E){throw le.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),le.error(E),new Error("There was a problem processing the data.")}if(f&&f.length>0){for(let E=0,h=f.length;E<h;E++){let p=f[E];o.forEach(S=>{p[S.key]!==null&&p[S.key]!==void 0&&S.keys.add(p[S.key])})}o.forEach(E=>{let h=Object.keys(this.data[`${E.schema}_${E.table}`].__merged_data),p=Jc.difference(h,[...E.keys].map(S=>S.toString()));for(let S=0,T=p.length;S<T;S++){let b=p[S];delete this.data[`${E.schema}_${E.table}`].__merged_data[b]}})}return{existing_attributes:c,joined_length:f?f.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new ed(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=Jc.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 le.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),le.error(i),new Error(Mn)}}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 l in i)o.push(i[l][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},u=await ta.getDataByHash(c),_=s.columns.length;for(let l=0,d=o.length;l<d;l++){let f=o[l],E=u.get(f);for(let h=0;h<_;h++){let p=s.columns[h],S=E[p]===void 0?null:E[p];this.data[n].__merged_data[f].push(S)}}}}catch(r){throw le.error("Error thrown from getDataByHash function in SQLSearch class method getData."),le.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,u=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===u}).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();le.trace(`Final SQL: ${s}`),n=await lr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),le.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw le.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),le.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 le.error(yJ.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),le.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 u=s[i],_=new RegExp(`${u}.\`${o}\``,"g"),l=`${u}.[${c}]`;n=n.replace(_,l)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let u=new RegExp(`\`${o}\``,"g"),_=`[${c}]`;n=n.replace(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 ta.getDataByValue(i);for(let[c,u]of o)this.data[s].__merged_data[c]||(u[n.attribute]===void 0&&(u[n.attribute]=null),this.data[s].__merged_data[c]=Object.assign({},r[s])),this.data[s].__merged_data[c][t[n.attribute]]=u[n.attribute]??null}catch(o){throw le.error("There was an error when processing this SQL operation. Check your logs"),le.error(o),new Error(Mn)}}return Object.values(Object.values(this.data)[0].__merged_data)}};UC.exports=zp});var Dr=g((Xle,vC)=>{"use strict";var IJ=hb();vC.exports={searchByConditions:CJ,searchByHash:DJ,searchByValue:LJ,search:MJ};var Jp=yn(),{transformReq:Xp}=z(),wJ=PC();async function CJ(e){return Xp(e),Jp.searchByConditions(e)}a(CJ,"searchByConditions");async function DJ(e){Xp(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of Jp.searchByHash(e))r&&t.push(r);return t}a(DJ,"searchByHash");async function LJ(e){Xp(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of Jp.searchByValue(e))t.push(r);return t}a(LJ,"searchByValue");function MJ(e,t){try{let r=new IJ(e);r.validate(),new wJ(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(MJ,"search")});var td=g((Zle,BC)=>{"use strict";var UJ=yn();BC.exports={writeTransaction:PJ};function PJ(e,t,r){return UJ.writeTransaction(e,t,r)}a(PJ,"writeTransaction")});var FC=g((r_e,GC)=>{"use strict";var vJ=Dr(),BJ=Xs(),HC=K(),HJ=rn(),t_e=td(),xJ=require("clone"),Zp=require("alasql"),GJ=Z_(),xC=require("util"),FJ=xC.promisify(BJ.getTableSchema),qJ=xC.promisify(vJ.search),kJ=U(),jp=z();GJ(Zp);GC.exports={update:$J};var VJ="There was a problem performing this update. Please check the logs and try again.";async function $J({statement:e,hdb_user:t}){let r=await FJ(e.table.databaseid,e.table.tableid),n=YJ(e.columns);jp.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=xJ(s),c=jp.isEmpty(i)?"":` WHERE ${i.toString()}`,u=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,_=Zp.parse(u).statements[0],l=await qJ(_),d=KJ(n,l);return WJ(o,d,t)}a($J,"update");function YJ(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=Zp.compile(`SELECT ${r.expression.toString()} AS [${kJ.FUNC_VAL}] FROM ?`)}),t}catch(t){throw HC.error(t),new Error(VJ)}}a(YJ,"createUpdateRecord");function KJ(e,t){return jp.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(KJ,"buildUpdateRecords");async function WJ(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await HJ.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){HC.error(`Error delete new_attributes from update response: ${i}`)}return s}a(WJ,"updateRecords")});var kC=g((o_e,qC)=>{var QJ=require("alasql"),zJ=Dr(),JJ=K(),XJ=yn(),tS=require("util"),eS=z(),jJ=U(),ZJ=Xs(),s_e=td(),i_e=rn(),e4="record",t4="successfully deleted",r4=tS.callbackify(o4),n4=tS.promisify(zJ.search),s4=tS.promisify(ZJ.getTableSchema);qC.exports={convertDelete:r4};function i4(e){return`${e.deleted_hashes.length} ${e4}${e.deleted_hashes.length===1?"":"s"} ${t4}`}a(i4,"generateReturnMessage");async function o4({statement:e,hdb_user:t}){let r=await s4(e.table.databaseid,e.table.tableid);eS.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=eS.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=QJ.parse(o).statements[0],u={operation:jJ.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{u.records=await n4(c);let _=await XJ.deleteRecords(u);return eS.isEmptyOrZeroLength(_.message)&&(_.message=i4(_)),delete _.txn_time,_}catch(_){throw JJ.error(_),_.hdb_code?_.message:_}}a(o4,"convertDelete")});var WC=g((c_e,KC)=>{"use strict";var a4=Bi(),{hdb_errors:VC}=ne(),{getDatabases:$C}=(Ae(),se(Fe));KC.exports={checkSchemaExists:YC,checkSchemaTableExists:c4,schema_describe:a4};async function YC(e){if(!$C()[e])return VC.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(YC,"checkSchemaExists");async function c4(e,t){let r=await YC(e);if(r)return r;if(!$C()[e][t])return VC.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(c4,"checkSchemaTableExists")});var Xc=g((l_e,u4)=>{u4.exports={name:"harperdb",version:"4.3.0-beta.8",description:"HarperDB is a distributed SQL & NoSQL data platform focused on speed, flexibility, and ease of use.",keywords:["database","sql","nosql","api","distributed","cloud","enterprise","Fastify","NATS"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.6","nats-server":"2.10.10"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive",build:"eslint -c ./.eslintbuild bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",pretty:"eslint --fix bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test"},dependencies:{"@aws-sdk/abort-controller":"3.374.0","@aws-sdk/client-s3":"3.477.0","@aws-sdk/lib-storage":"3.477.0","@endo/static-module-record":"^1.0.0","@fastify/autoload":"5.7.1","@fastify/compress":"~6.5.0","@fastify/cors":"~8.5.0","@fastify/static":"~6.11.2","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.5.4",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.1",fastify:"~4.25.1","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.8.1","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.11.0","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.6",jsonwebtoken:"9.0.2",lmdb:"2.10.0-beta.4",lodash:"4.17.21",mathjs:"11.11.2",minimist:"1.2.8",mkcert:"1.5.1",moment:"2.29.4","mqtt-packet":"~8.2.1",msgpackr:"1.10.1",nats:"2.19.0",needle:"3.2.0","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.1",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.3.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^0.18.0","serve-static":"1.15.0",ses:"1.0.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.21.20","tar-fs":"2.1.1",ulidx:"0.5.0",uuid:"9.0.1","validate.js":"0.13.1",ws:"8.15.1",yaml:"2.3.4"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"latest","@typescript-eslint/eslint-plugin":"^5.55.0","@typescript-eslint/parser":"^5.55.0",axios:"1.6.2",chai:"4.3.7","chai-integer":"0.1.0",esbuild:"^0.19.1",eslint:"8.22.0","eslint-config-prettier":"8.3.0","eslint-plugin-prettier":"3.4.1","eslint-plugin-radar":"0.2.1",eventsource:"^2.0.2","hook-std":"3.0.0","intercept-stdout":"0.1.2",mocha:"^10.2.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.7",newman:"5.3.2","newman-reporter-html":"1.0.5","newman-reporter-htmlextra":"1.22.11","newman-reporter-teamcity":"0.1.12","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"2.8.4",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.3.3","why-is-node-still-running":"^1.0.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},"newman-reporter-html":{newman:"5.3.2"},alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","utf-8-validate":"^5.0.10"}}});var ru={};$e(ru,{addAnalyticsListener:()=>tu,recordAction:()=>xr,recordActionBinary:()=>sn,setAnalyticsEnabled:()=>l4});function l4(e){rD=e}function xr(e,t,r,n,s){if(!rD)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=sd.get(i);if(o)if(typeof e=="number"){let c=o.values,u=c.index++;if(u>=c.length){let _=c;o.values=c=new Float32Array(u*2),c.set(_),c.index=u+1}c[u]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},sd.set(i,o)}rd||_4()}function sn(e,t,r,n,s){xr(!!e,t,r,n,s)}function tu(e){iD.push(e)}function _4(){rd=performance.now(),setTimeout(async()=>{let e=performance.now()-rd;rd=0;let t=[],r={time:Date.now(),period:e,threadId:Zi.threadId,metrics:t};for(let[s,i]of sd){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,u=0,_=[],l;for(let d of oD){let f=Math.floor(c*d),E=o[f-1];if(f>u){let h=f-u;if(E===l){let p=_[_.length-1];typeof p=="number"?_[_.length-1]={value:p,count:1+h}:p.count+=h}else _.push(h>1?{value:E,count:h}:E),l=E;u=f}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:_,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 aD()}let n=process.memoryUsage();t.push({metric:"memory",threadId:Zi.threadId,byThread:!0,...n});for(let s of iD)s(t);sd=new Map,Zi.parentPort?Zi.parentPort.postMessage({type:sD,report:r}):lD({report:r})},nD).unref()}async function d4(e,t=6e4){let r=sS(),n=cD(),s=new Promise(p=>{let S=performance.now();setImmediate(()=>{let T=performance.now();T-S>5e3&&(0,jc.warn)("Unusually high event queue latency on the main thread of "+Math.round(T-S)+"ms"),S=performance.now()}),n.primaryStore.prefetch([1],()=>{let T=performance.now();T-S>5e3&&(0,jc.warn)("Unusually high task queue latency on the main thread of "+Math.round(T-S)+"ms"),p(T-S)})}),i;for(let p of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(p.value?.time){i=p.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,u=new Map,_=[],l;for(let{key:p,value:S}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!S)continue;if(o){if(p>o+t)break}else o=p;l=p;let{metrics:T,threadId:b}=S;for(let R of T||[]){let{path:L,method:H,type:P,metric:k,count:B,total:J,distribution:Q,threads:X,...Te}=R;B||(B=1);let ce=k+(L?"-"+L:"");H!==void 0&&(ce+="-"+H),P!==void 0&&(ce+="-"+P);let de=c.get(ce);if(de){if(de.threads){let Be=de.threads[b];if(Be)de=Be;else{de.threads[b]=Object.assign({},Te);continue}}de.count||(de.count=1);let Le=de.count;for(let Be in Te){let Ct=Te[Be];typeof Ct=="number"&&(de[Be]=(de[Be]*Le+Ct*B)/(Le+B))}de.count+=B,J>=0&&(de.total+=J,de.ratio=de.total/de.count)}else de=Object.assign({period:t},R),delete de.distribution,c.set(ce,de),de.byThread&&(de.threads=[],de.threads[b]=Object.assign({},Te),_.push(de));if(Q){Q=Q.map(Be=>typeof Be=="number"?{value:Be,count:1}:Be);let Le=u.get(ce);Le?Le.push(...Q):u.set(ce,Q)}}await aD()}for(let p of _){let{path:S,method:T,type:b,metric:R,count:L,total:H,distribution:P,threads:k,...B}=p;k=k.filter(J=>J);for(let J in B){if(typeof p[J]!="number")continue;let Q=0;for(let X of k){let Te=X[J];typeof Te=="number"&&(Q+=Te)}p[J]=Q}p.count=k.length,delete p.threads,delete p.byThread}for(let[p,S]of u){let T=c.get(p);S.sort((Be,Ct)=>Be.value>Ct.value?1:-1);let b=T.count-1,R=[],L=0,H=0,P;for(let Be of oD){let Ct=b*Be;for(;L<Ct;)P=S[H++],L+=P.count,H===1&&L--;let Ll=S[H>1?H-2:0];P||(P=S[0]),R.push(P.value-(P.value-Ll.value)*(L-Ct)/P.count)}let[k,B,J,Q,X,Te,ce,de,Le]=R;Object.assign(T,{p1:k,p10:B,p25:J,median:Q,p75:X,p90:Te,p95:ce,p99:de,p999:Le})}let d;for(let[p,S]of c)S.id=(0,nd.getNextMonotonicTime)(),S.time=l,n.primaryStore.put(S.id,S,{append:!0}).then(T=>{T||n.primaryStore.put(S.id,S)}),d=!0;let f=Date.now(),{idle:E,active:h}=performance.eventLoopUtilization();if(d||h*10>E){let p=(0,nd.getNextMonotonicTime)(),S={id:p,metric:"main-thread-utilization",idle:E-QC,active:h-zC,taskQueueLatency:await s,time:f,...process.memoryUsage()};n.primaryStore.put(p,S,{append:!0}).then(T=>{T||n.primaryStore.put(p,S)})}QC=E,zC=h}async function JC(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function sS(){return XC||(XC=at({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function cD(){return jC||(jC=at({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function h4(){uD=!0;let e=(0,eu.get)(nS.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await d4(nD,e),await JC(sS(),f4),await JC(cD(),E4)},Math.min(e/2,2147483647)).unref()}function lD(e,t){let r=e.report;r.threadId=t?.threadId||Zi.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(ZC+=n.mean*n.count);r.totalBytesProcessed=ZC,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(eD.get(t))}),eD.set(t,t.performance.eventLoopUtilization())),r.id=(0,nd.getNextMonotonicTime)(),sS().primaryStore.put(r.id,r),uD||h4(),m4&&(_D=S4(r))}async function S4(e){if(await _D,!si){let r=(0,Zc.dirname)((0,jc.getLogFilePath)());try{si=await(0,rS.open)((0,Zc.join)(r,"analytics.log"),"r+")}catch{si=await(0,rS.open)((0,Zc.join)(r,"analytics.log"),"w+")}}let t=(await si.stat()).size;if(t>p4){let r=Buffer.alloc(t);await si.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await si.write(r,{position:0}),await si.truncate(r.length),t=r.length}await si.write(JSON.stringify(e)+`
|
|
8
|
+
`,t)}var Zi,tD,jc,Zc,rS,nd,eu,nS,sd,rD,rd,nD,sD,iD,oD,QC,zC,aD,f4,E4,XC,jC,uD,ZC,eD,m4,_D,si,p4,Os=Re(()=>{Zi=require("worker_threads"),tD=x(Ze());Ae();jc=x(K()),Zc=require("path"),rS=require("fs/promises"),nd=x(Ir()),eu=x(re()),nS=x(U());sr();(0,eu.initSync)();sd=new Map,rD=(0,eu.get)(nS.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(l4,"setAnalyticsEnabled");a(xr,"recordAction");je.recordAnalytics=xr;a(sn,"recordActionBinary");rd=0,nD=1e3,sD="analytics-report",iD=[];a(tu,"addAnalyticsListener");oD=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(_4,"sendAnalytics");a(d4,"aggregation");QC=0,zC=0,aD=a(()=>new Promise(setImmediate),"rest");a(JC,"cleanup");f4=36e5,E4=31536e6;a(sS,"getRawAnalyticsTable");a(cD,"getAnalyticsTable");(0,tD.setChildListenerByType)(sD,lD);a(h4,"startScheduledTasks");ZC=0,eD=new Map,m4=!1;a(lD,"recordAnalytics");p4=1e6;a(S4,"logAnalytics")});var lS=g((A_e,RD)=>{"use strict";var{decode:T4}=require("msgpackr"),{isMainThread:g_e,parentPort:g4,threadId:R_e}=require("worker_threads"),nu=bt(),ra=rt(),aS=U(),zt=K(),oS=re(),fD=U(),{onMessageByType:R4}=Ze(),ED=Ss(),{recordAction:A4,recordActionBinary:O4}=(Os(),se(ru)),{publishToStream:b4}=nu,{ConsumerEvents:y4}=require("nats"),N4=Dr(),{promisify:I4}=require("util"),hD=I4(setTimeout),ad=1e4,cd,od,w4,C4,mD,su=new Map,na=new Map;RD.exports={initialize:cS,ingestConsumer:uS,setSubscription:D4,setIgnoreOrigin:U4,getDatabaseSubscriptions:M4,updateConsumer:pD};async function cS(){R4(aS.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await pD(n)}),mD=!0,zt.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await nu.getNATSReferences();cd=e,od=e.info.server_name,w4=t,C4=r}a(cS,"initialize");async function pD(e){if(e.status==="start"){let{js:t,jsm:r}=await SD(e.node_domain_name);uS(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=su.get(e.stream_name+e.node_domain_name);t&&(zt.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),su.set(e.stream_name+e.node_domain_name,"close")),na.get(e.node_domain_name)==="failed"&&na.set(e.node_domain_name,"close")}}a(pD,"updateConsumer");var ud=new Map;function D4(e,t,r){let n=ud.get(e);n||ud.set(e,n=new Map),n.set(t,r),mD||cS().then(L4)}a(D4,"setSubscription");async function L4(){let e=await N4.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+ra.SERVER_SUFFIX.LEAF,{js:n,jsm:s}=await SD(r);if(s){for(let i of t.subscriptions)if(i.subscribe===!0){let{schema:o,table:c}=i,u=ED.createNatsTableStreamName(o,c);uS(u,n,s,r)}}}}a(L4,"accessConsumers");async function SD(e){let t,r,n=1;for(;!r;)try{t=await cd.jetstream({domain:e,timeout:6e4}),r=await cd.jetstreamManager({domain:e,timeout:6e4})}catch(s){if(na.get(e)==="close")break;na.set(e,"failed"),n%10===1&&zt.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<ad?n++*100:ad;await hD(i)}return{js:t,jsm:r}}a(SD,"connectToRemoteJS");function M4(){return ud}a(M4,"getDatabaseSubscriptions");var TD;function U4(e){TD=e}a(U4,"setIgnoreOrigin");var gD=100,dD=new Array(gD),id=0;async function uS(e,t,r,n){let{connection:s}=await nu.getNATSReferences();cd=s,od=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,od),zt.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(_){if(na.get(n)==="close")break;o%10===1&&zt.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",_.message),_.code==="404"&&(zt.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await nu.createConsumer(r,e,od,new Date(Date.now()).toISOString()));let l=o++*100<ad?o++*100:ad;await hD(l)}let c=!1,u;for(g4?.on("message",async _=>{let{type:l}=_;l===fD.ITC_EVENT_TYPES.SHUTDOWN&&(c=!0,u&&u.close?.()&&u.close())});!c;){if(su.get(e+n)==="close"||na.get(n)==="close"){su.delete(e+n),c=!0;continue}u=await i.consume({max_messages:oS.get(aS.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100}),su.set(e+n,u);let _=!1;(async()=>{for await(let l of await u.status())if(l.type===y4.HeartbeatsMissed){let d=l.data;zt.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${u.consumer.stream}`),d===2&&(zt.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${u.consumer.stream}`),u.stop(),_=!0)}})();try{for await(let l of u)await dD[id],dD[id]=P4(l).catch(d=>{zt.error(d)}),++id>=gD&&(id=0)}catch(l){l.message==="consumer deleted"?(zt.notify("Nats consumer deleted, closing messages for node:",n,"stream:",u.consumer.stream),await u.close(),c=!0):zt.error("Error consuming clustering ingest, restarting consumer",l)}nu.clearClientCache(),!c&&_&&await cS()}}a(uS,"ingestConsumer");async function P4(e){let t=T4(e.data);A4(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),zt.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=oS.get(aS.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(ra.MSG_HEADERS.TRANSACTED_NODES)&&r.values(ra.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(ra.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!TD),O4(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(ra.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:u,table:_,records:l,hash_values:d,__origin:f,expiresAt:E}=t;zt.trace("processing message:",o,c,_,(l?"records: "+l.map(L=>L?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),zt.trace(`messageProcessor nats msg id: ${e.headers.get(ra.MSG_HEADERS.NATS_MSG_ID)}`);let h;l||(l=d);let p=new Promise(L=>h=L),{timestamp:S,user:T,node_name:b}=f||{},R=ud.get(c)?.get(_);if(!R)throw new Error("Missing table for replication message",_);if(o==="define_schema")t.type=o,R.send(t);else if(l.length===1&&!u)R.send({type:iS(o),value:l[0],id:d?.[0],expiresAt:E,timestamp:S,table:_,onCommit:h,user:T,nodeName:b});else{let L=l.map((H,P)=>({type:iS(o),value:H,expiresAt:E,id:d?.[P],table:_}));for(;u;)L.push({type:iS(u.operation),value:u.record,expiresAt:u.expiresAt,id:u.id,table:u.table}),u=u.next;R.send({type:"transaction",writes:L,table:_,timestamp:S,onCommit:h,user:T,nodeName:b})}oS.get(fD.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&b4(e.subject.split(".").slice(0,-1).join("."),ED.createNatsTableStreamName(c,_),e.headers,e.data),await p}catch(o){zt.error(o)}e.ack()}a(P4,"messageProcessor");function iS(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(iS,"convertOperation")});var bt=g((C_e,xD)=>{"use strict";var Mt=re();Mt.initSync();var v4=require("fs-extra"),B4=require("semver"),au=require("path"),{monotonicFactory:H4}=require("ulidx"),OD=H4(),x4=require("util"),bD=require("child_process"),G4=x4.promisify(bD.exec),F4=bD.spawn,qt=rt(),Ce=U(),ld=z(),Un=K(),_d=Ss(),q4=td(),iu=Ur(),{broadcast:k4,onMessageByType:V4,getWorkerIndex:$4}=Ze(),{isMainThread:yD}=require("worker_threads"),{Encoder:Y4,decode:ES}=require("msgpackr"),ND=new Y4,{isEmpty:no}=ld,ID=nn(),b_e=48*36e11;yD&&V4(Ce.ITC_EVENT_TYPES.RESTART,()=>{_r=void 0,ro=void 0});var{connect:K4,StorageType:W4,RetentionPolicy:Q4,AckPolicy:hS,DeliverPolicy:mS,DiscardPolicy:z4,NatsConnection:y_e,JetStreamManager:N_e,JetStreamClient:I_e,StringCodec:w_e,JSONCodec:J4,createInbox:pS,headers:X4,ErrorCode:AD}=require("nats"),{PACKAGE_ROOT:j4}=U(),Z4=Xc(),{recordAction:e3}=(Os(),se(ru)),wD=J4(),t3="clustering",r3=Z4.engines[qt.NATS_SERVER_NAME],n3=au.join(j4,"dependencies"),fS=au.join(n3,`${process.platform}-${process.arch}`,qt.NATS_BINARY_NAME),_S,dS,ou,eo,to;xD.exports={runCommand:CD,checkNATSServerInstalled:s3,createConnection:SS,getConnection:dd,getJetStreamManager:cu,getJetStream:LD,getNATSReferences:Pn,getServerList:o3,createLocalStream:TS,listStreams:MD,deleteLocalStream:a3,getServerConfig:uu,listRemoteStreams:c3,viewStream:u3,viewStreamIterator:l3,publishToStream:_3,request:E3,reloadNATS:gS,reloadNATSHub:h3,reloadNATSLeaf:m3,extractServerName:f3,requestErrorHandler:p3,createLocalTableStream:BD,createTableStreams:g3,purgeTableStream:HD,purgeSchemaTableStreams:R3,getStreamInfo:A3,updateLocalStreams:b3,closeConnection:i3,getJsmServerName:fd,addNatsMsgHeader:UD,clearClientCache:DD,updateRemoteConsumer:S3,createConsumer:PD,updateConsumerIterator:T3};async function CD(e,t=void 0){let{stdout:r,stderr:n}=await G4(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
9
9
|
`,""));return r.replace(`
|
|
10
|
-
`,"")}a(uD,"runCommand");async function H4(){try{await h4.access(eS)}catch{return!1}let e=await uD(`${eS} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return m4.eq(t,v4)}a(H4,"checkNATSServerInstalled");async function sS(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await iD.getClusterUser();if(so(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}Hr.trace("create nats connection called");let i=await w4({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Gt.get(Pe.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Gt.get(Pe.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Gt.get(Pe.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),Hr.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&Hr.error("Error with Nats client connection, connection closed",o),lD()}),i}a(sS,"createConnection");function lD(){nn=void 0,to=void 0,ro=void 0,no=void 0}a(lD,"clearClientCache");async function x4(){nn&&(await nn.drain(),nn=void 0,to=void 0,ro=void 0,no=void 0)}a(x4,"closeConnection");var nn,no;async function rd(){return no||(no=sS(Gt.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),nn=await no),nn||no}a(rd,"getConnection");async function uu(){if(to)return to;so(nn)&&await rd();let{domain:e}=lu(Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(so(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return to=await nn.jetstreamManager({domain:e,timeout:6e4}),to}a(uu,"getJetStreamManager");async function _D(){if(ro)return ro;so(nn)&&await rd();let{domain:e}=lu(Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(so(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ro=nn.jetstream({domain:e,timeout:6e4}),ro}a(_D,"getJetStream");async function ur(){let e=nn||await rd(),t=to||await uu(),r=ro||await _D();return{connection:e,jsm:t,js:r}}a(ur,"getNATSReferences");async function F4(e){let t=Gt.get(Pe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await iD.getClusterUser(),s=await sS(t,r,n),i=nS(),o=s.subscribe(i),c=[],u,_=(async()=>{for await(let l of o){let d=cD.decode(l.data);d.response_time=Date.now()-u,c.push(d)}})();return u=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 tS.async_set_timeout(e),await o.drain(),await s.close(),await _,c}a(F4,"getServerList");async function iS(e,t){let{jsm:r}=await ur(),n=Gt.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Gt.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Gt.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:oD.File,retention:aD.Limits,subjects:t,discard:I4.Old,max_msgs:s,max_bytes:i,max_age:n})}a(iS,"createLocalStream");async function dD(){let{jsm:e}=await ur(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(dD,"listStreams");async function G4(e){let{jsm:t}=await ur();await t.streams.delete(e)}a(G4,"deleteLocalStream");async function q4(e){let{connection:t}=await ur(),r=[],n=nS(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(cD.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(q4,"listRemoteStreams");async function k4(e,t=void 0,r=void 0){let{jsm:n,js:s}=await ur(),i=rD(),o={durable_name:i,ack_policy:ed.Explicit};t&&(o.deliver_policy=td.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),u=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let _=[];for await(let l of u){let d=rS(l.data),f={nats_timestamp:l.info.timestampNanos,nats_sequence:l.info.streamSequence,entry:d};if(l.headers&&(f.origin=l.headers.get(ye.MSG_HEADERS.ORIGIN)),_.push(f),l.ack(),l.info.pending===0)break}return await c.delete(),_}a(k4,"viewStream");async function*V4(e,t=void 0,r=void 0){let{jsm:n,js:s}=await ur(),i=rD(),o={durable_name:i,ack_policy:ed.Explicit};t&&(o.deliver_policy=td.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),u=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let _ of u){let l=rS(_.data);l[0]||(l=[l]);for(let d of l){let f={nats_timestamp:_.info.timestampNanos,nats_sequence:_.info.streamSequence,entry:d};_.headers&&(f.origin=_.headers.get(ye.MSG_HEADERS.ORIGIN)),yield f}if(_.ack(),_.info.pending===0)break}await c.delete()}a(V4,"viewStreamIterator");async function $4(e,t,r,n){Hr.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=fD(n,r);let{js:s}=await ur(),i=await _u(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:sD.encode(n);try{Hr.trace(`publishToStream publishing to subject: ${o}`),M4(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(u){if(u.code&&u.code.toString()==="503")return pD(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(u.code&&u.code.toString()==="503"){Hr.trace(`publishToStream creating stream: ${t}`);let l=o.split(".");l[2]="*",await iS(t,[o]),await s.publish(o,c,{headers:r})}else throw u}});throw u}}a($4,"publishToStream");function fD(e,t){t===void 0&&(t=D4());let r=Gt.get(Pe.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(ye.MSG_HEADERS.ORIGIN)&&r&&t.append(ye.MSG_HEADERS.ORIGIN,r),t}a(fD,"addNatsMsgHeader");function lu(e){e=e.toLowerCase();let t=cu.join(Gt.get(Pe.CONFIG_PARAMS.ROOTPATH),P4);if(e===Pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return so(Zp)&&(Zp={port:ou.getConfigFromFile(Pe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:ou.getConfigFromFile(Pe.CONFIG_PARAMS.CLUSTERING_NODENAME)+ye.SERVER_SUFFIX.HUB,config_file:ye.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:cu.join(t,ye.PID_FILES.HUB),hdb_nats_path:t}),Zp;if(e===Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return so(jp)&&(jp={port:ou.getConfigFromFile(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:ou.getConfigFromFile(Pe.CONFIG_PARAMS.CLUSTERING_NODENAME)+ye.SERVER_SUFFIX.LEAF,config_file:ye.NATS_CONFIG_FILES.LEAF_SERVER,domain:ou.getConfigFromFile(Pe.CONFIG_PARAMS.CLUSTERING_NODENAME)+ye.SERVER_SUFFIX.LEAF,pid_file_path:cu.join(t,ye.PID_FILES.LEAF),hdb_nats_path:t}),jp;Hr.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(lu,"getServerConfig");async function Y4(e){let{jsm:t}=await ur(),r=await _u();try{await t.streams.add({name:e.stream_name,storage:oD.File,retention:aD.Limits,max_age:N4,max_bytes:y4,subjects:[`${ye.SUBJECT_PREFIXES.TXN}.${e.stream_name}.${r}`]})}catch(n){if(n.code!=="400")throw n}try{await t.consumers.info(e.stream_name,e.durable_name)}catch(n){if(n.code.toString()==="404")await t.consumers.add(e.stream_name,{ack_policy:ed.Explicit,durable_name:e.durable_name,deliver_policy:td.All,max_ack_pending:1e4});else throw n}}a(Y4,"createWorkQueueStream");async function K4(){let{jsm:e}=await ur();(await e.consumers.info(ye.WORK_QUEUE_CONSUMER_NAMES.stream_name,ye.WORK_QUEUE_CONSUMER_NAMES.durable_name)).config.deliver_subject&&(Hr.info("Removing old nats push consumer from ingest stream"),await e.consumers.delete(ye.WORK_QUEUE_CONSUMER_NAMES.stream_name,ye.WORK_QUEUE_CONSUMER_NAMES.durable_name),Hr.info("Adding pull consumer to ingest stream"),await e.consumers.add(ye.WORK_QUEUE_CONSUMER_NAMES.stream_name,{ack_policy:ed.Explicit,durable_name:ye.WORK_QUEUE_CONSUMER_NAMES.durable_name,deliver_policy:td.All,max_ack_pending:1e4}))}a(K4,"updateIngestStreamConsumer");async function ED(e,t,r){let{jsm:n}=await ur(),s=await n.streams.info(t),i=hD(n.prefix),o=r.start_time?r.start_time:new Date(Date.now()).toISOString(),{schema:c,table:u}=r,_=Z_.createNatsTableStreamName(c,u),l=i===e,d,f,E=!1;if(!Array.isArray(s.config.sources)||s.config.sources.length===0)s.config.sources=[];else for(let S=0,p=s.config.sources.length;S<p;S++)if(d=s.config.sources[S],f=S,l&&d.name===_||!l&&d.name===_&&d.external&&d.external.api===`$JS.${e}.API`){E=!0;break}if(E===!0){if(d.opt_start_time===o)return;let S=`txn.${c}.${u}.${e}`;await n.streams.purge(t,{filter:S}),s.config.sources.splice(f,1),await n.streams.update(t,s.config)}let h={name:_,opt_start_time:o,filter_subject:`${ye.SUBJECT_PREFIXES.TXN}.>`};l||(h.external={api:`$JS.${e}.API`,deliver:""}),s.config.sources.push(h),await n.streams.update(t,s.config)}a(ED,"addSourceToWorkStream");function hD(e){return e.split(".")[1]}a(hD,"extractServerName");async function mD(e,t,r){let{jsm:n}=await ur(),{schema:s,table:i}=r,o=`txn.${s}.${i}.${e}`;await n.streams.purge(t,{filter:o});let c=Z_.createNatsTableStreamName(s,i),u=await n.streams.info(t);if(!Array.isArray(u.config.sources)||u.config.sources.length===0)return;let _=u.config.sources.length,l;for(;_--;)if(l=u.config.sources[_],l.name===c&&l.external.api===`$JS.${e}.API`){u.config.sources.splice(_,1);break}await n.streams.update(t,u.config)}a(mD,"removeSourceFromWorkStream");async function W4(e,t,r=6e4,n=nS()){if(!tS.isObject(t))throw new Error("data param must be an object");let s=sD.encode(t),{connection:i}=await ur(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return rS(c.data)}a(W4,"request");function oS(e){return new Promise(async(t,r)=>{let n=g4(eS,["--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(oS,"reloadNATS");async function Q4(){let{pid_file_path:e}=lu(Pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await oS(e)}a(Q4,"reloadNATSHub");async function z4(){let{pid_file_path:e}=lu(Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await oS(e)}a(z4,"reloadNATSLeaf");function J4(e,t,r){let n;switch(e.code){case tD.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case tD.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(J4,"requestErrorHandler");async function X4(e,t){let r=t+ye.SERVER_SUFFIX.LEAF;await pD(async()=>{e.subscribe===!0?await ED(r,ye.WORK_QUEUE_CONSUMER_NAMES.stream_name,e):await mD(r,ye.WORK_QUEUE_CONSUMER_NAMES.stream_name,e)})}a(X4,"updateWorkStream");function pD(e){return R4.writeTransaction(Pe.SYSTEM_SCHEMA_NAME,Pe.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(pD,"exclusiveLock");async function SD(e,t){let r=Z_.createNatsTableStreamName(e,t),n=await _u(),s=t3(e,t,n);await iS(r,[s])}a(SD,"createLocalTableStream");async function j4(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await SD(n,s)}}a(j4,"createTableStreams");async function TD(e,t,r=!1){if(Gt.get(Pe.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=Z_.createNatsTableStreamName(e,t),{jsm:s}=await ur();r?await s.streams.purge(ye.WORK_QUEUE_CONSUMER_NAMES.stream_name):await s.streams.purge(n)}catch(n){if(n.message==="stream not found")Hr.warn(n);else throw n}}a(TD,"purgeTableStream");async function Z4(e,t){if(Gt.get(Pe.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await TD(e,t[r])}a(Z4,"purgeSchemaTableStreams");async function e3(e){return(await uu()).streams.info(e)}a(e3,"getStreamInfo");function t3(e,t,r){return`${ye.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(t3,"createSubjectName");async function _u(){if(au)return au;if(au=(await uu())?.nc?.info?.server_name,au===void 0)throw new Error("Unable to get jetstream manager server name");return au}a(_u,"getJsmServerName");async function r3(){let e=await uu(),t=await _u(),r=await dD();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=n3(n),c=i.split(".");if(!(c[c.length-1]===t&&!o)){if(s.name===ye.SCHEMA_QUEUE_CONSUMER_NAMES.stream_name){let _=`${ye.SCHEMA_QUEUE_CONSUMER_NAMES.deliver_subject}.${t}`;Hr.trace(`Updating stream subject name from: ${i} to: ${_}`),s.subjects[0]=_}else if(s.name===ye.WORK_QUEUE_CONSUMER_NAMES.stream_name){let _=`${ye.WORK_QUEUE_CONSUMER_NAMES.stream_name}.${t}`;Hr.trace(`Updating stream subject name from: ${i} to: ${_}`),s.subjects[0]=_}else{let _=i.split(".");_[_.length-1]=t;let l=_.join(".");Hr.trace(`Updating stream subject name from: ${i} to: ${l}`),s.subjects[0]=l}await e.streams.update(s.name,s)}}}a(r3,"updateLocalStreams");function n3(e){let{config:t}=e,r=!1;if(t.name===ye.SCHEMA_QUEUE_CONSUMER_NAMES.stream_name||t.name===ye.WORK_QUEUE_CONSUMER_NAMES.stream_name)return r;let n=Gt.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Gt.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Gt.get(Pe.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(n3,"updateStreamLimits")});var od=T((R_e,bD)=>{"use strict";var sa=a_(),ia=BC(),s3=Q(),i3=require("uuid").v4,g_e=require("clone"),sd=Ts(),oa=P(),o3=require("util"),ii=bn(),{handleHDBError:lr,hdb_errors:a3}=re(),{HDB_ERROR_MSGS:nd,HTTP_STATUS_CODES:_r}=a3,{SchemaEventMsg:id}=wn(),RD=Nt(),{getDatabases:c3}=(Re(),ne(Ge)),{transformReq:aa}=J();bD.exports={createSchema:u3,createSchemaStructure:AD,createTable:l3,createTableStructure:OD,createAttribute:h3,dropSchema:_3,dropTable:d3,dropAttribute:f3,getBackup:m3};async function u3(e){let t=await AD(e);return sd.signalSchemaChange(new id(process.pid,e.operation,e.schema)),t}a(u3,"createSchema");async function AD(e){let t=sa.schema_object(e);if(t)throw lr(t,t.message,_r.BAD_REQUEST,void 0,void 0,!0);if(aa(e),!await ia.checkSchemaExists(e.schema))throw lr(new Error,nd.SCHEMA_EXISTS_ERR(e.schema),_r.BAD_REQUEST,oa.LOG_LEVELS.ERROR,nd.SCHEMA_EXISTS_ERR(e.schema),!0);return await ii.createSchema(e),`database '${e.schema}' successfully created`}a(AD,"createSchemaStructure");async function l3(e){return aa(e),e.hash_attribute=e.primary_key??e.hash_attribute,await OD(e)}a(l3,"createTable");async function OD(e){let t=sa.create_table_object(e);if(t)throw lr(t,t.message,_r.BAD_REQUEST,void 0,void 0,!0);if(sa.validateTableResidence(e.residence),!await ia.checkSchemaTableExists(e.schema,e.table))throw lr(new Error,nd.TABLE_EXISTS_ERR(e.schema,e.table),_r.BAD_REQUEST,oa.LOG_LEVELS.ERROR,nd.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:i3(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await ii.createTable(n,e);else throw lr(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",_r.BAD_REQUEST);else await ii.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(OD,"createTableStructure");async function _3(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=sa.schema_object(e),n=t??r;if(n)throw lr(n,n.message,_r.BAD_REQUEST,void 0,void 0,!0);aa(e);let s=await ia.checkSchemaExists(e.schema);if(s)throw lr(new Error,s,_r.NOT_FOUND,oa.LOG_LEVELS.ERROR,s,!0);let i=await ia.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);return await ii.dropSchema(e),sd.signalSchemaChange(new id(process.pid,e.operation,e.schema)),await RD.purgeSchemaTableStreams(e.schema,o),`successfully deleted '${e.schema}'`}a(_3,"dropSchema");async function d3(e){let t=sa.table_object(e);if(t)throw lr(t,t.message,_r.BAD_REQUEST,void 0,void 0,!0);aa(e);let r=await ia.checkSchemaTableExists(e.schema,e.table);if(r)throw lr(new Error,r,_r.NOT_FOUND,oa.LOG_LEVELS.ERROR,r,!0);return await ii.dropTable(e),await RD.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(d3,"dropTable");async function f3(e){let t=sa.attribute_object(e);if(t)throw lr(t,t.message,_r.BAD_REQUEST,void 0,void 0,!0);aa(e);let r=await ia.checkSchemaTableExists(e.schema,e.table);if(r)throw lr(new Error,r,_r.NOT_FOUND,oa.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw lr(new Error,"You cannot drop a hash attribute",_r.BAD_REQUEST,void 0,void 0,!0);if(oa.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw lr(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,_r.BAD_REQUEST,void 0,void 0,!0);try{return await ii.dropAttribute(e),E3(e),sd.signalSchemaChange(new id(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw s3.error(`Got an error deleting attribute ${o3.inspect(e)}.`),n}}a(f3,"dropAttribute");function E3(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(E3,"dropAttributeFromGlobal");async function h3(e){aa(e);let t=c3()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw lr(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,_r.BAD_REQUEST,void 0,void 0,!0);return await ii.createAttribute(e),sd.signalSchemaChange(new id(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(h3,"createAttribute");function m3(e){return ii.getBackup(e)}a(m3,"getBackup")});var yD=T((O_e,ND)=>{"use strict";var{OPERATIONS_ENUM:p3}=P(),aS=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=p3.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};ND.exports=aS});var cS=T((y_e,LD)=>{"use strict";var S3=bn(),N_e=yD(),ad=J(),cd=P(),T3=te(),{handleHDBError:wD,hdb_errors:g3}=re(),{HDB_ERROR_MSGS:ID,HTTP_STATUS_CODES:CD}=g3,R3=Object.values(cd.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),DD="To use this operation audit log must be enabled in harperdb-config.yaml";LD.exports=A3;async function A3(e){if(ad.isEmpty(e.schema))throw new Error(ID.SCHEMA_REQUIRED_ERR);if(ad.isEmpty(e.table))throw new Error(ID.TABLE_REQUIRED_ERR);if(!T3.get(cd.CONFIG_PARAMS.LOGGING_AUDITLOG))throw wD(new Error,DD,CD.BAD_REQUEST,cd.LOG_LEVELS.ERROR,DD,!0);let t=ad.checkSchemaTableExist(e.schema,e.table);if(t)throw wD(new Error,t,CD.NOT_FOUND,cd.LOG_LEVELS.ERROR,t,!0);if(!ad.isEmpty(e.search_type)&&R3.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await S3.readAuditLog(e)}a(A3,"readAuditLog")});var MD=T((I_e,UD)=>{"use strict";var{OPERATIONS_ENUM:O3}=P(),uS=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=O3.GET_BACKUP,this.schema=t,this.table=r}};UD.exports=uS});var BD=T((U_e,vD)=>{"use strict";var b3=bn(),D_e=MD(),lS=J(),N3=P(),L_e=te(),{handleHDBError:y3,hdb_errors:w3}=re(),{HDB_ERROR_MSGS:PD,HTTP_STATUS_CODES:I3}=w3;vD.exports=C3;async function C3(e){if(lS.isEmpty(e.schema))throw new Error(PD.SCHEMA_REQUIRED_ERR);if(lS.isEmpty(e.table))throw new Error(PD.TABLE_REQUIRED_ERR);let t=lS.checkSchemaTableExist(e.schema,e.table);if(t)throw y3(new Error,t,I3.NOT_FOUND,N3.LOG_LEVELS.ERROR,t,!0);return await b3.getBackup(read_audit_log_object)}a(C3,"getBackup")});var kD=T((P_e,qD)=>{var oi=require("validate.js"),xD=rt(),ca=P(),{handleHDBError:D3,hdb_errors:L3}=re(),{HDB_ERROR_MSGS:lt,HTTP_STATUS_CODES:U3}=L3,_S=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),M3={STRUCTURE_USER:"structure_user"},HD=Object.values(ca.ROLE_TYPES_ENUM),P3="attribute_permissions",v3="attribute_name",{PERMS_CRUD_ENUM:ua}=ca,B3=[P3,...Object.values(ua)],FD=[ua.READ,ua.INSERT,ua.UPDATE],H3=[v3,...FD];function x3(e){let t=_S();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,GD(e,t)}a(x3,"addRoleValidation");function F3(e){let t=_S();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,GD(e,t)}a(F3,"alterRoleValidation");function G3(e){let t=_S();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,xD.validateObject(e,t)}a(G3,"dropRoleValidation");var q3=["operation","role","id","permission","hdb_user","hdb_auth_header"];function GD(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)q3.includes(n[o])||s.push(n[o]);s.length>0&&ht(lt.INVALID_ROLE_JSON_KEYS(s),r);let i=xD.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{ht(o,r)}),e.permission){let o=k3(e);o&&ht(o,r),HD.forEach(c=>{e.permission[c]&&!oi.isBoolean(e.permission[c])&&ht(lt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(HD.indexOf(o)<0){if(o===M3.STRUCTURE_USER){let u=e.permission[o];if(typeof u=="boolean")continue;if(Array.isArray(u)){for(let _=0,l=u.length;_<l;_++){let d=u[_];global.hdb_schema[d]||ht(lt.SCHEMA_NOT_FOUND(d),r)}continue}ht(lt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){ht(lt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let u in c.tables){let _=c.tables[u];if(!u||!global.hdb_schema[o][u]){ht(lt.TABLE_NOT_FOUND(o,u),r);continue}if(Object.keys(_).forEach(l=>{B3.includes(l)||ht(lt.INVALID_PERM_KEY(l),r,o,u)}),Object.values(ua).forEach(l=>{oi.isDefined(_[l])?oi.isBoolean(_[l])||ht(lt.TABLE_PERM_NOT_BOOLEAN(l),r,o,u):ht(lt.TABLE_PERM_MISSING(l),r,o,u)}),oi.isDefined(_.attribute_permissions)){if(!oi.isArray(_.attribute_permissions)){ht(lt.ATTR_PERMS_NOT_ARRAY,r,o,u);continue}}else{ht(lt.ATTR_PERMS_ARRAY_MISSING,r,o,u);continue}if(_.attribute_permissions){let l=global.hdb_schema[o][u].attributes.map(({attribute:f})=>f),d={read:!1,insert:!1,update:!1};for(let f in _.attribute_permissions){let E=_.attribute_permissions[f];if(Object.keys(E).forEach(S=>{!H3.includes(S)&&S!==ua.DELETE&&ht(lt.INVALID_ATTR_PERM_KEY(S),r,o,u)}),!oi.isDefined(E.attribute_name)){ht(lt.ATTR_PERM_MISSING_NAME,r,o,u);continue}let h=E.attribute_name;if(!l.includes(h)){ht(lt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,u);continue}FD.forEach(S=>{oi.isDefined(E[S])?oi.isBoolean(E[S])||ht(lt.ATTR_PERM_NOT_BOOLEAN(S,h),r,o,u):ht(lt.ATTR_PERM_MISSING(S,h),r,o,u)}),!d.read&&E.read===!0&&(d.read=!0),!d.insert&&E.insert===!0&&(d.insert=!0),!d.update&&E.update===!0&&(d.update=!0)}if(_.read===!1&&d.read===!0||_.insert===!1&&d.insert===!0||_.update===!1&&d.update===!0){let f=`${o}.${u}`;ht(lt.MISMATCHED_TABLE_ATTR_PERMS(f),r,o,u)}}}}return V3(r)}a(GD,"customValidate");qD.exports={addRoleValidation:x3,alterRoleValidation:F3,dropRoleValidation:G3};function k3(e){let{operation:t,permission:r}=e;if(t===ca.OPERATIONS_ENUM.ADD_ROLE||t===ca.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 lt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?ca.ROLE_TYPES_ENUM.SUPER_USER:ca.ROLE_TYPES_ENUM.CLUSTER_USER;return lt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(k3,"validateNoSUPerms");function V3(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:lt.ROLE_PERMS_ERROR,...e};return D3(new Error,n,U3.BAD_REQUEST)}else return null}a(V3,"generateRolePermResponse");function ht(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(ht,"addPermError")});var pS=T((B_e,KD)=>{"use strict";var VD=en(),$D=Zr(),$3=ki(),fS=kD(),ES=Ts(),Y3=require("uuid").v4,K3=require("util"),ud=P(),W3=J(),hS=$D.searchByValue,Q3=$D.searchByHash,z3=K3.promisify($3.delete),J3=Jn(),X3=ta(),{hdb_errors:j3,handleHDBError:io}=re(),{HDB_ERROR_MSGS:YD,HTTP_STATUS_CODES:du}=j3,{UserEventMsg:mS}=wn();KD.exports={addRole:Z3,alterRole:eX,dropRole:tX,listRoles:rX};function dS(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(dS,"scrubRoleDetails");async function Z3(e){let t=fS.addRoleValidation(e);if(t)throw t;e=dS(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 hS(r)||[])}catch(i){throw io(i)}if(n&&n.length>0)throw io(new Error,YD.ROLE_ALREADY_EXISTS(e.role),du.CONFLICT,void 0,void 0,!0);e.id||(e.id=Y3());let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await VD.insert(s),ES.signalUserChange(new mS(process.pid)),e=dS(e),e}a(Z3,"addRole");async function eX(e){let t=fS.alterRoleValidation(e);if(t)throw t;e=dS(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await VD.update(r)}catch(s){throw io(s)}if(n&&n?.message==="updated 0 of 1 records")throw io(new Error,"Invalid role id",du.BAD_REQUEST,void 0,void 0,!0);return await ES.signalUserChange(new mS(process.pid)),e}a(eX,"alterRole");async function tX(e){let t=fS.dropRoleValidation(e);if(t)throw io(new Error,t,du.BAD_REQUEST,void 0,void 0,!0);let r=new X3(ud.SYSTEM_SCHEMA_NAME,ud.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await Q3(r));if(n.length===0)throw io(new Error,YD.ROLE_NOT_FOUND,du.NOT_FOUND,void 0,void 0,!0);let s=new J3(ud.SYSTEM_SCHEMA_NAME,ud.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await hS(s)),o=!1;if(W3.isEmptyOrZeroLength(i)===!1){for(let u=0;u<i.length;u++)if(i[u].active===!0){o=!0;break}}if(o===!0)throw io(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,du.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await z3(c),ES.signalUserChange(new mS(process.pid)),`${n[0].role} successfully deleted`}a(tX,"dropRole");async function rX(){return hS({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(rX,"listRoles")});var JD=T((x_e,zD)=>{"use strict";var nX=te(),ai=require("joi"),sX=rt(),WD=require("moment"),iX=require("fs-extra"),SS=require("path"),oX=require("lodash"),fu=P(),{LOG_LEVELS:oo}=P(),aX="YYYY-MM-DD hh:mm:ss",cX=SS.resolve(__dirname,"../logs");zD.exports=function(e){return sX.validateBySchema(e,uX)};var uX=ai.object({from:ai.custom(QD),until:ai.custom(QD),level:ai.valid(oo.NOTIFY,oo.FATAL,oo.ERROR,oo.WARN,oo.INFO,oo.DEBUG,oo.TRACE),order:ai.valid("asc","desc"),limit:ai.number().min(1),start:ai.number().min(0),log_name:ai.custom(lX)});function QD(e,t){if(WD(e,WD.ISO_8601).format(aX)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(QD,"validateDatetime");function lX(e,t){if(oX.invert(fu.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=nX.get(fu.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?fu.LOG_NAMES.HDB:e,i=s===fu.LOG_NAMES.INSTALL?SS.join(cX,fu.LOG_NAMES.INSTALL):SS.join(n,s);return iX.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(lX,"validateReadLogPath")});var gS=T((G_e,jD)=>{"use strict";var ld=P(),_X=Q(),dX=te(),fX=JD(),TS=require("path"),XD=require("fs-extra"),{once:EX}=require("events"),{handleHDBError:hX,hdb_errors:mX}=re(),{PACKAGE_ROOT:pX}=P(),SX=TS.join(pX,"logs"),TX=1e3,gX=200;jD.exports=RX;async function RX(e){let t=fX(e);if(t)throw hX(t,t.message,mX.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=dX.get(ld.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?ld.LOG_NAMES.HDB:e.log_name,s=n===ld.LOG_NAMES.INSTALL?TS.join(SX,ld.LOG_NAMES.INSTALL):TS.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,u=c?new Date(e.from):void 0,_=e.until!==void 0,l=_?new Date(e.until):void 0,d=e.limit===void 0?TX:e.limit,f=e.order===void 0?void 0:e.order,E=e.start===void 0?0:e.start,h=E+d,S=0;f==="desc"&&!u&&!l&&(S=Math.max(XD.statSync(s).size-(h+5)*gX,0));let p=XD.createReadStream(s,{start:S});p.on("error",M=>{_X.error(M)});let R=0,A=[],g="",v;p.on("data",M=>{let U=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;M=g+M;let Y=0,K;for(;(K=U.exec(M))&&!p.destroyed;){v&&(v.message=M.slice(Y,K.index),H(v));let[V,ce,de]=K,xe=de.split("] ["),ae=xe[0],Oe=xe[1];xe.splice(0,2),v={timestamp:ce,thread:ae,level:Oe,tags:xe,message:""},Y=K.index+V.length}g=M.slice(Y)}),p.on("end",M=>{p.destroyed||v&&(v.message=g.trim(),H(v))}),p.resume();function H(M){let U,Y,K;switch(!0){case(i&&c&&_):U=new Date(M.timestamp),Y=new Date(u),K=new Date(l),M.level===o&&U>=Y&&U<=K&&R<E?R++:M.level===o&&U>=Y&&U<=K&&(ci(M,f,A),R++,R===h&&p.destroy());break;case(i&&c):U=new Date(M.timestamp),Y=new Date(u),M.level===o&&U>=Y&&R<E?R++:M.level===o&&U>=Y&&(ci(M,f,A),R++,R===h&&p.destroy());break;case(i&&_):U=new Date(M.timestamp),K=new Date(l),M.level===o&&U<=K&&R<E?R++:M.level===o&&U<=K&&(ci(M,f,A),R++,R===h&&p.destroy());break;case(c&&_):U=new Date(M.timestamp),Y=new Date(u),K=new Date(l),U>=Y&&U<=K&&R<E?R++:U>=Y&&U<=K&&(ci(M,f,A),R++,R===h&&p.destroy());break;case i:M.level===o&&R<E?R++:M.level===o&&(ci(M,f,A),R++,R===h&&p.destroy());break;case c:U=new Date(M.timestamp),Y=new Date(u),U>=Y&&R<E?R++:U>=Y&&R>=E&&(ci(M,f,A),R++,R===h&&p.destroy());break;case _:U=new Date(M.timestamp),K=new Date(l),U<=K&&R<E?R++:U<=K&&R>=E&&(ci(M,f,A),R++,R===h&&p.destroy());break;default:R<E?R++:(ci(M,f,A),R++,R===h&&p.destroy())}}return a(H,"onLogMessage"),await EX(p,"close"),A}a(RX,"readLog");function ci(e,t,r){t==="desc"?AX(e,r):t==="asc"?OX(e,r):r.push(e)}a(ci,"pushLineToResult");function AX(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(AX,"insertDescending");function OX(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(OX,"insertAscending")});var _d=T((Y_e,rL)=>{"use strict";var RS=require("joi"),{string:Eu,boolean:ZD,date:bX}=RS.types(),NX=rt(),{validateSchemaExists:k_e,validateTableExists:V_e,validateSchemaName:$_e}=Yn(),yX=P(),wX=nt(),eL=te();eL.initSync();var IX=Eu.invalid(eL.get(yX.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(wX.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).required(),tL={operation:Eu.valid("add_node","update_node","set_node_replication"),node_name:IX,subscriptions:RS.array().items({table:Eu.optional(),schema:Eu.optional(),database:Eu.optional(),subscribe:ZD.required(),publish:ZD.required().custom(DX),start_time:bX.iso()}).min(1).required()};function CX(e){return NX.validateBySchema(e,RS.object(tL))}a(CX,"addUpdateNodeValidator");function DX(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(DX,"checkForFalsy");rL.exports={addUpdateNodeValidator:CX,validation_schema:tL}});var sL=T((W_e,nL)=>{var LX=rt(),UX={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};nL.exports=function(e){return LX.validateObject(e,UX)}});var OS=T((Q_e,iL)=>{"use strict";var MX=P().OPERATIONS_ENUM,AS=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=MX.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};iL.exports=AS});var aL=T((J_e,oL)=>{"use strict";var PX={OPERATION:"operation",REFRESH:"refresh"},bS=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},NS=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};oL.exports={JWTTokens:bS,TOKEN_TYPE_ENUM:PX,JWTRSAKeys:NS}});var pu=T((j_e,_L)=>{"use strict";var mu=require("jsonwebtoken"),yS=require("fs-extra"),wS=J(),sn=P(),{handleHDBError:dr,hdb_errors:vX}=re(),{HTTP_STATUS_CODES:fr,AUTHENTICATION_ERROR_MSGS:Er}=vX,hu=Q(),cL=g_(),DS=tn(),BX=en().update,HX=OS(),xX=Ts(),{UserEventMsg:FX}=wn(),ui=te();ui.initSync();var IS=require("path"),{JWTTokens:GX,JWTRSAKeys:qX,TOKEN_TYPE_ENUM:dd}=aL(),kX=ui.get(sn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?ui.get(sn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",VX=ui.get(sn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?ui.get(sn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",fd="RS256",CS;_L.exports={createTokens:$X,validateOperationToken:KX,refreshOperationToken:YX,validateRefreshToken:lL};async function $X(e){if(wS.isEmpty(e)||typeof e!="object")throw dr(new Error,Er.INVALID_AUTH_OBJECT,fr.BAD_REQUEST,void 0,void 0,!0);if(wS.isEmpty(e.username))throw dr(new Error,Er.USERNAME_REQUIRED,fr.BAD_REQUEST,void 0,void 0,!0);if(wS.isEmpty(e.password))throw dr(new Error,Er.PASSWORD_REQUIRED,fr.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await DS.findAndValidateUser(e.username,e.password),!t)throw dr(new Error,Er.INVALID_CREDENTIALS,fr.UNAUTHORIZED,void 0,void 0,!0)}catch(f){throw hu.error(f),dr(new Error,Er.INVALID_CREDENTIALS,fr.UNAUTHORIZED,void 0,void 0,!0)}let r=await Ed(),n=!1,s=!1;t.role&&t.role.permission&&(n=t.role.permission.super_user===!0,s=t.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s},o=await uL(i,r.private_key,r.passphrase),c=await mu.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:VX,algorithm:fd,subject:dd.REFRESH}),u=cL.hash(c),_=new HX(sn.SYSTEM_SCHEMA_NAME,sn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]),l,d;try{l=await BX(_)}catch(f){hu.error(f),d=f}if(d!==void 0||l.skipped_hashes.length>0)throw dr(new Error,Er.REFRESH_TOKEN_SAVE_FAILED,fr.INTERNAL_SERVER_ERROR);return xX.signalUserChange(new FX(process.pid)),new GX(o,c)}a($X,"createTokens");async function uL(e,t,r){return await mu.sign(e,{key:t,passphrase:r},{expiresIn:kX,algorithm:fd,subject:dd.OPERATION})}a(uL,"signOperationToken");async function Ed(){if(CS===void 0)try{let e=IS.join(ui.getHdbBasePath(),sn.LICENSE_KEY_DIR_NAME,sn.JWT_ENUM.JWT_PASSPHRASE_NAME),t=IS.join(ui.getHdbBasePath(),sn.LICENSE_KEY_DIR_NAME,sn.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=IS.join(ui.getHdbBasePath(),sn.LICENSE_KEY_DIR_NAME,sn.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await yS.readFile(e)).toString(),s=(await yS.readFile(t)).toString(),i=(await yS.readFile(r)).toString();CS=new qX(i,s,n)}catch(e){throw hu.error(e),dr(new Error,Er.NO_ENCRYPTION_KEYS,fr.INTERNAL_SERVER_ERROR)}return CS}a(Ed,"getJWTRSAKeys");async function YX(e){if(!e)throw dr(new Error,Er.INVALID_BODY,fr.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw dr(new Error,Er.REFRESH_TOKEN_REQUIRED,fr.BAD_REQUEST,void 0,void 0,!0);await lL(e.refresh_token);let t=await Ed(),r=await mu.decode(e.refresh_token);return{operation_token:await uL({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(YX,"refreshOperationToken");async function KX(e){try{let t=await Ed(),r=await mu.verify(e,t.public_key,{algorithms:fd,subject:dd.OPERATION});return await DS.findAndValidateUser(r.username,void 0,!1)}catch(t){throw hu.warn(t),t.name&&t.name==="TokenExpiredError"?dr(new Error,Er.TOKEN_EXPIRED,fr.FORBIDDEN):dr(new Error,Er.INVALID_TOKEN,fr.UNAUTHORIZED)}}a(KX,"validateOperationToken");async function lL(e){let t;try{let r=await Ed(),n=await mu.verify(e,r.public_key,{algorithms:fd,subject:dd.REFRESH});t=await DS.findAndValidateUser(n.username,void 0,!1)}catch(r){throw hu.warn(r),r.name&&r.name==="TokenExpiredError"?dr(new Error,Er.TOKEN_EXPIRED,fr.FORBIDDEN):dr(new Error,Er.INVALID_TOKEN,fr.UNAUTHORIZED)}if(!cL.validate(t.refresh_token,e))throw dr(new Error,Er.INVALID_TOKEN,fr.UNAUTHORIZED);return t}a(lL,"validateRefreshToken")});var LS=T((tde,EL)=>{"use strict";var WX=sL(),la=require("passport"),QX=require("passport-local").Strategy,zX=require("passport-http").BasicStrategy,JX=require("util"),XX=tn(),fL=JX.callbackify(XX.findAndValidateUser),ede=Nr(),jX=P(),dL=pu();la.use(new QX(function(e,t,r){fL(e,t,r)}));la.use(new zX(function(e,t,r){fL(e,t,r)}));la.serializeUser(function(e,t){t(null,e)});la.deserializeUser(function(e,t){t(null,e)});function ZX(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":la.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===jX.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?dL.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):dL.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:la.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(ZX,"authorize");function ej(e,t){let r=WX(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(ej,"checkPermissions");EL.exports={authorize:ZX,checkPermissions:ej}});var _a=T((nde,hL)=>{"use strict";var US=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},MS=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};hL.exports={Node:US,NodeSubscription:MS}});var pL=T((ide,mL)=>{"use strict";var tj=P().OPERATIONS_ENUM,PS=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=tj.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};mL.exports=PS});var Su=T((ade,SL)=>{"use strict";var vS=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},BS=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)}};SL.exports={RemotePayloadObject:vS,RemotePayloadSubscription:BS}});var gL=T((ude,TL)=>{"use strict";var HS=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}};TL.exports=HS});var OL=T((Ede,AL)=>{"use strict";var rj=gL(),_de=dt(),RL=Ke(),nj=Q(),{getSchemaPath:dde,getTransactionAuditStorePath:fde}=ze(),{getDatabases:sj}=(Re(),ne(Ge));AL.exports=ij;async function ij(e){let t=new rj;try{let r=sj()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats(),i=await RL.environmentDataSize(schema_path,e.name),o=await RL.environmentDataSize(txn_path,e.name);t.schema=e.schema,t.table=e.name,t.table_size=i,t.record_count=n.entryCount,t.transaction_log_size=o,t.transaction_log_record_count=s.entryCount}catch(r){nj.warn(`unable to stat table dbi due to ${r}`)}return t}a(ij,"lmdbGetTableSize")});var NL=T((mde,bL)=>{"use strict";var xS=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}};bL.exports=xS});var da=T((gde,CL)=>{"use strict";var oj=require("fs-extra"),aj=require("path"),zt=require("systeminformation"),li=Q(),cj=Nt(),FS=nt(),md=P(),uj=OL(),IL=Hi(),{getThreadInfo:yL}=et(),zS=te();zS.initSync();var lj=NL(),{openEnvironment:Sde}=Ke(),{getSchemaPath:Tde}=ze(),{database:_j}=(Re(),ne(Ge)),hd;CL.exports={getHDBProcessInfo:VS,getNetworkInfo:YS,getDiskInfo:$S,getMemoryInfo:kS,getCPUInfo:qS,getTimeInfo:GS,getSystemInformation:KS,systemInformation:dj,getTableSize:WS,getMetrics:QS};function GS(){return zt.time()}a(GS,"getTimeInfo");async function qS(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:u,cache:_,...l}=await zt.cpu();l.cpu_speed=await zt.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:f,raw_currentload_irq:E,raw_currentload_nice:h,raw_currentload_system:S,raw_currentload_user:p,cpus:R,...A}=await zt.currentLoad();return A.cpus=[],R.forEach(g=>{let{raw_load:v,raw_load_idle:H,raw_load_irq:M,raw_load_nice:U,raw_load_system:Y,raw_load_user:K,...V}=g;A.cpus.push(V)}),l.current_load=A,l}catch(e){return li.error(`error in getCPUInfo: ${e}`),{}}}a(qS,"getCPUInfo");async function kS(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await zt.mem();return Object.assign(s,process.memoryUsage())}catch(e){return li.error(`error in getMemoryInfo: ${e}`),{}}}a(kS,"getMemoryInfo");async function VS(){let e={core:[],clustering:[]};try{let t=await zt.processes(),r;try{r=Number.parseInt(await oj.readFile(aj.join(zS.get(md.CONFIG_PARAMS.ROOTPATH),md.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===md.NODE_ERROR_CODES.ENOENT)li.error("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB");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 li.error(`error in getHDBProcessInfo: ${t}`),e}}a(VS,"getHDBProcessInfo");async function $S(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await zt.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:u,..._}=await zt.fsStats();return e.read_write=_,e.size=await zt.fsSize(),e}catch(t){return li.error(`error in getDiskInfo: ${t}`),e}}a($S,"getDiskInfo");async function YS(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await zt.networkInterfaceDefault(),e.latency=await zt.inetChecksite("google.com"),(await zt.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:u,ieee8021xAuth:_,ieee8021xState:l,carrier_changes:d,...f}=n;e.interfaces.push(f)}),(await zt.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)}),e}catch(t){return li.error(`error in getNetworkInfo: ${t}`),e}}a(YS,"getNetworkInfo");async function KS(){if(hd!==void 0)return hd;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await zt.osInfo();e=c;let u=await zt.versions("node, npm");return e.node_version=u.node,e.npm_version=u.npm,hd=e,hd}catch(t){return li.error(`error in getSystemInformation: ${t}`),e}}a(KS,"getSystemInformation");async function WS(){let e=[],t=await IL.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await uj(n));return e}a(WS,"getTableSize");async function QS(){let e=await IL.describeAll(),t={};for(let r in e){let n=t[r]={};for(let s in e[r])try{let i=_j({database:r,table:s}),o=i.getStats();o.readers=i.readerList().split(/\n\s+/).slice(1).map(c=>{let[u,_,l]=c.trim().split(" ");return{pid:u,thread:_,txnid:l}}),n[s]=o}catch(i){li.notify(`Error getting stats for table ${s}: ${i}`)}}return t}a(QS,"getMetrics");async function wL(){if(zS.get(md.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{js:e,jsm:t}=await cj.getNATSReferences(),r=await t.streams.info(FS.WORK_QUEUE_CONSUMER_NAMES.stream_name),n=await e.consumers.get(FS.WORK_QUEUE_CONSUMER_NAMES.stream_name,FS.WORK_QUEUE_CONSUMER_NAMES.durable_name),s={ingest:{stream:{...r.state},consumer:{num_ack_pending:n._info.num_ack_pending,num_redelivered:n._info.num_redelivered,num_waiting:n._info.num_waiting,num_pending:n._info.num_pending}}};return r.sources&&(s.ingest.stream.sources=r.sources),s}}a(wL,"getNatsStreamInfo");async function dj(e){let t=new lj;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await KS(),t.time=GS(),t.cpu=await qS(),t.memory=await kS(),t.disk=await $S(),t.network=await YS(),t.harperdb_processes=await VS(),t.table_size=await WS(),t.metrics=await QS(),t.threads=await yL(),t.replication=await wL(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await KS();break;case"time":t.time=GS();break;case"cpu":t.cpu=await qS();break;case"memory":t.memory=await kS();break;case"disk":t.disk=await $S();break;case"network":t.network=await YS();break;case"harperdb_processes":t.harperdb_processes=await VS();break;case"table_size":t.table_size=await WS();break;case"database_metrics":case"metrics":t.metrics=await QS();break;case"threads":t.threads=await yL();break;case"replication":t.replication=await wL();break;default:break}return t}a(dj,"systemInformation")});var Sd=T((Ade,DL)=>{"use strict";DL.exports={version:fj,printVersion:Ej};var pd=eu();function fj(){if(pd)return pd.version}a(fj,"version");function Ej(){pd&&console.log(`HarperDB Version ${pd.version}`)}a(Ej,"printVersion")});var bs=T((yde,PL)=>{"use strict";var hj=en(),JS=J(),mj=require("util"),ao=P(),LL=te();LL.initSync();var pj=LS(),UL=Zr(),{Node:bde,NodeSubscription:Nde}=_a(),Sj=ta(),Tj=pL(),{RemotePayloadObject:gj,RemotePayloadSubscription:Rj}=Su(),{handleHDBError:Aj,hdb_errors:Oj}=re(),{HTTP_STATUS_CODES:bj,HDB_ERROR_MSGS:Nj}=Oj,yj=Jn(),wj=da(),Ij=Sd(),{getDatabases:Cj}=(Re(),ne(Ge)),Dj=mj.promisify(pj.authorize),Lj=UL.searchByHash,Uj=UL.searchByValue;PL.exports={authHeaderToUser:Mj,isEmpty:Pj,getNodeRecord:vj,upsertNodeRecord:Bj,buildNodePayloads:Hj,checkClusteringEnabled:xj,getAllNodeRecords:Fj,getSystemInfo:Gj,reverseSubscription:ML};async function Mj(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Dj(t,null),e}a(Mj,"authHeaderToUser");function Pj(e){return e==null}a(Pj,"isEmpty");async function vj(e){let t=new Sj(ao.SYSTEM_SCHEMA_NAME,ao.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Lj(t)}a(vj,"getNodeRecord");async function Bj(e){let t=new Tj(ao.SYSTEM_SCHEMA_NAME,ao.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return hj.upsert(t)}a(Bj,"upsertNodeRecord");function ML(e){if(JS.isEmpty(e.subscribe)||JS.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(ML,"reverseSubscription");function Hj(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:u,table:_}=c,l=JS.getTableHashAttribute(u,_),{subscribe:d,publish:f}=ML(c),E=Cj()[u]?.[_],h=new Rj(u,_,l,f,d,c.start_time,E.schemaDefined?E.attributes:void 0);s.push(h)}return new gj(r,t,s,n)}a(Hj,"buildNodePayloads");function xj(){if(!LL.get(ao.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Aj(new Error,Nj.CLUSTERING_NOT_ENABLED,bj.BAD_REQUEST,void 0,void 0,!0)}a(xj,"checkClusteringEnabled");async function Fj(){let e=new yj(ao.SYSTEM_SCHEMA_NAME,ao.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Uj(e))}a(Fj,"getAllNodeRecords");async function Gj(){let e=await wj.getSystemInformation();return{hdb_version:Ij.version(),node_version:e.node_version,platform:e.platform}}a(Gj,"getSystemInfo")});var XS=T((Ide,kL)=>{"use strict";var Td=Nt(),vL=J(),BL=nt(),HL=P(),gd=Q(),xL=od(),qj=pp(),{RemotePayloadObject:kj}=Su(),{handleHDBError:FL,hdb_errors:Vj}=re(),{HTTP_STATUS_CODES:GL}=Vj,{NodeSubscription:qL}=_a();kL.exports=$j;async function $j(e,t){let r;try{r=await Td.request(`${t}.${BL.REQUEST_SUFFIX}`,new kj(HL.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),gd.trace("Response from remote describe all request:",r)}catch(o){gd.error(`addNode received error from describe all request to remote node: ${o}`);let c=Td.requestErrorHandler(o,"add_node",t);throw FL(new Error,c,GL.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===BL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw FL(new Error,o,GL.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,u=o.database??o.schema??"data";if(u===HL.SYSTEM_SCHEMA_NAME){await Td.createLocalTableStream(u,c);let h=new qL(u,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let _=vL.doesSchemaExist(u),l=n[u]!==void 0,d=c?vL.doesTableExist(u,c):!0,f=c?n?.[u]?.[c]!==void 0:!0;if(!_&&!l||!d&&!f){s.push(o);continue}if(!_&&l&&(gd.trace(`addNode creating schema: ${u}`),await xL.createSchema({operation:"create_schema",schema:u})),!d&&f){gd.trace(`addNode creating table: ${c} in schema: ${u} with attributes ${JSON.stringify(n[u][c].attributes)}`);let h=new qj(u,c,n[u][c].hash_attribute);n[u][c].attributes&&(h.attributes=n[u][c].attributes),await xL.createTable(h)}await Td.createLocalTableStream(u,c);let E=new qL(u,c,o.publish,o.subscribe);E.start_time=o.start_time,i.push(E)}return{added:i,skipped:s}}a($j,"reviewSubscriptions")});var Od=T((Dde,YL)=>{"use strict";var{handleHDBError:Rd,hdb_errors:Yj}=re(),{HTTP_STATUS_CODES:Ad}=Yj,{addUpdateNodeValidator:Kj}=_d(),Tu=Q(),$L=P(),VL=nt(),Wj=J(),jS=Nt(),gu=bs(),Qj=te(),zj=XS(),{Node:Jj,NodeSubscription:Xj}=_a(),{broadcast:jj}=et(),Zj="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",eZ="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",tZ=Qj.get($L.CONFIG_PARAMS.CLUSTERING_NODENAME);YL.exports=rZ;async function rZ(e,t=!1){Tu.trace("addNode called with:",e),gu.checkClusteringEnabled();let r=Kj(e);if(r)throw Rd(r,r.message,Ad.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await gu.getNodeRecord(n);if(!Wj.isEmptyOrZeroLength(d))throw Rd(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,Ad.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await zj(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=Zj,o;let c=gu.buildNodePayloads(s,tZ,$L.OPERATIONS_ENUM.ADD_NODE,await gu.getSystemInfo());Tu.trace("addNode sending remote payload:",c);let u;try{u=await jS.request(`${n}.${VL.REQUEST_SUFFIX}`,c)}catch(d){Tu.error(`addNode received error from request: ${d}`);let f=jS.requestErrorHandler(d,"add_node",n);throw Rd(new Error,f,Ad.INTERNAL_SERVER_ERROR,"error",f)}if(u.status===VL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${u.message}`;throw Rd(new Error,d,Ad.INTERNAL_SERVER_ERROR,"error",d)}Tu.trace(u);let _=[];for(let d=0,f=s.length;d<f;d++){let E=s[d];Tu.trace("Add node updating work stream for node:",n,"subscriptions:",E),await jS.updateWorkStream(E,n),s[d].start_time===void 0&&delete s[d].start_time,_.push(new Xj(E.schema,E.table,E.publish,E.subscribe))}let l=new Jj(n,_,u.system_info);return await gu.upsertNodeRecord(l),jj({type:"nats_update"}),i.length>0?o.message=eZ:o.message=`Successfully added '${n}' to manifest`,o}a(rZ,"addNode")});var rT=T((Mde,QL)=>{"use strict";var{handleHDBError:ZS,hdb_errors:nZ}=re(),{HTTP_STATUS_CODES:eT}=nZ,{addUpdateNodeValidator:sZ}=_d(),Ru=Q(),WL=P(),KL=nt(),Ude=J(),tT=Nt(),Au=bs(),iZ=te(),{cloneDeep:oZ}=require("lodash"),aZ=XS(),{Node:cZ,NodeSubscription:uZ}=_a(),{broadcast:lZ}=et(),_Z="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",dZ="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",fZ=iZ.get(WL.CONFIG_PARAMS.CLUSTERING_NODENAME);QL.exports=EZ;async function EZ(e){Ru.trace("updateNode called with:",e),Au.checkClusteringEnabled();let t=sZ(e);if(t)throw ZS(t,t.message,eT.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Au.getNodeRecord(r);s.length>0&&(n=oZ(s));let{added:i,skipped:o}=await aZ(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=_Z,c;let u=Au.buildNodePayloads(i,fZ,WL.OPERATIONS_ENUM.UPDATE_NODE,await Au.getSystemInfo());Ru.trace("updateNode sending remote payload:",u);let _;try{_=await tT.request(`${r}.${KL.REQUEST_SUFFIX}`,u)}catch(l){Ru.error(`updateNode received error from request: ${l}`);let d=tT.requestErrorHandler(l,"update_node",r);throw ZS(new Error,d,eT.INTERNAL_SERVER_ERROR,"error",d)}if(_.status===KL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let l=`Error returned from remote node ${r}: ${_.message}`;throw ZS(new Error,l,eT.INTERNAL_SERVER_ERROR,"error",l)}Ru.trace(_);for(let l=0,d=i.length;l<d;l++){let f=i[l];Ru.trace(`updateNode updating work stream for node: ${r} subscription:`,f),await tT.updateWorkStream(f,r),i[l].start_time===void 0&&delete i[l].start_time}return n||(n=[new cZ(r,[],_.system_info)]),await hZ(n[0],i,_.system_info),o.length>0?c.message=dZ:c.message=`Successfully updated '${r}'`,c}a(EZ,"updateNode");async function hZ(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let u=0,_=e.subscriptions.length;u<_;u++){let l=n.subscriptions[u];if(l.schema===o.schema&&l.table===o.table){l.publish=o.publish,l.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new uZ(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Au.upsertNodeRecord(n),lZ({type:"nats_update"})}a(hZ,"updateNodeTable")});var ZL=T((vde,jL)=>{"use strict";var XL=require("joi"),{string:zL}=XL.types(),mZ=rt(),JL=P(),pZ=te(),SZ=nt();jL.exports=TZ;function TZ(e){let t=zL.invalid(pZ.get(JL.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(SZ.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=XL.object({operation:zL.valid(JL.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return mZ.validateBySchema(e,r)}a(TZ,"removeNodeValidator")});var Nd=T((Hde,iU)=>{"use strict";var{handleHDBError:eU,hdb_errors:gZ}=re(),{HTTP_STATUS_CODES:tU}=gZ,RZ=ZL(),Ou=Q(),rU=bs(),AZ=J(),bd=P(),nU=nt(),sU=Nt(),OZ=te(),{RemotePayloadObject:bZ}=Su(),{NodeSubscription:NZ}=_a(),yZ=Yc(),wZ=ki(),{broadcast:IZ}=et(),CZ=OZ.get(bd.CONFIG_PARAMS.CLUSTERING_NODENAME);iU.exports=DZ;async function DZ(e){Ou.trace("removeNode called with:",e),rU.checkClusteringEnabled();let t=RZ(e);if(t)throw eU(t,t.message,tU.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await rU.getNodeRecord(r);if(AZ.isEmptyOrZeroLength(n))throw eU(new Error,`Node '${r}' was not found.`,tU.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new bZ(bd.OPERATIONS_ENUM.REMOVE_NODE,CZ,[]),i,o=!1;try{i=await sU.request(`${r}.${nU.REQUEST_SUFFIX}`,s),Ou.trace("Remove node reply from remote node:",r,i)}catch(u){Ou.error("removeNode received error from request:",u),o=!0}for(let u=0,_=n.subscriptions.length;u<_;u++){let l=n.subscriptions[u];Ou.trace(`Remove node removing subscription: ${l.schema}.${l.table} for node: ${r}`);let d=new NZ(l.schema,l.table,!1,!1);await sU.updateWorkStream(d,r)}let c=new yZ(bd.SYSTEM_SCHEMA_NAME,bd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await wZ.deleteRecord(c),IZ({type:"nats_update"}),i?.status===nU.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(Ou.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(DZ,"removeNode")});var cU=T((Fde,aU)=>{"use strict";var oU=require("joi"),{string:LZ,array:UZ}=oU.types(),MZ=rt(),PZ=_d();aU.exports=vZ;function vZ(e){let t=oU.object({operation:LZ.valid("configure_cluster").required(),connections:UZ.items(PZ.validation_schema).required()});return MZ.validateBySchema(e,t)}a(vZ,"configureClusterValidator")});var nT=T((qde,fU)=>{"use strict";var BZ=P(),yd=Q(),HZ=J(),xZ=Nd(),FZ=Od(),uU=bs(),GZ=cU(),{handleHDBError:lU,hdb_errors:qZ}=re(),{HTTP_STATUS_CODES:_U}=qZ,kZ="Configure cluster complete.",VZ="Failed to configure the cluster. Check the logs for more details.",$Z="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";fU.exports=YZ;async function YZ(e){yd.trace("configure cluster called with:",e),uU.checkClusteringEnabled();let t=GZ(e);if(t)throw lU(t,t.message,_U.BAD_REQUEST,void 0,void 0,!0);let r=await uU.getAllNodeRecords(),n=[];for(let f=0,E=r.length;f<E;f++)n.push(dU(xZ,{operation:BZ.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[f].name},r[f].name));let s=await Promise.allSettled(n);yd.trace("All results from configure_cluster remove node:",s);let i=[],o=e.connections.length;for(let f=0;f<o;f++){let E=e.connections[f];i.push(dU(FZ,E,E.node_name))}let c=await Promise.allSettled(i);yd.trace("All results from configure_cluster add node:",c);let u=[],_=[],l=!1,d=s.concat(c);for(let f=0,E=d.length;f<E;f++){let h=d[f];h.status==="rejected"&&(yd.error(h.reason),u.includes(h.reason.node_name)||u.push(h.reason.node_name)),h.status==="fulfilled"&&(l=!0);let S=h?.value?.result;typeof S=="string"&&S.includes("Successfully removed")||h.status==="rejected"||_.push({node_name:h?.value?.node_name,subscriptions:h?.value?.result})}if(HZ.isEmptyOrZeroLength(u))return{message:kZ,connections:_};if(l)return{message:$Z,failed_nodes:u,connections:_};throw lU(new Error,VZ,_U.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(YZ,"configureCluster");async function dU(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){throw{node_name:r,error:n}}}a(dU,"functionWrapper")});var hU=T((Vde,EU)=>{"use strict";var wd=require("joi"),KZ=rt(),{validateSchemaExists:WZ,validateTableExists:QZ,validateSchemaName:zZ}=Yn(),JZ=wd.object({operation:wd.string().valid("purge_stream"),schema:wd.string().custom(WZ).custom(zZ).required(),table:wd.string().custom(QZ).required()});function XZ(e){return KZ.validateBySchema(e,JZ)}a(XZ,"purgeStreamValidator");EU.exports=XZ});var sT=T((Yde,mU)=>{"use strict";var{handleHDBError:jZ,hdb_errors:ZZ}=re(),{HTTP_STATUS_CODES:e5}=ZZ,t5=hU(),r5=Nt(),n5=bs();mU.exports=s5;async function s5(e){if(e.purge_ingest!==!0){let s=t5(e);if(s)throw jZ(s,s.message,e5.BAD_REQUEST,void 0,void 0,!0)}n5.checkClusteringEnabled();let{schema:t,table:r,purge_ingest:n}=e;return await r5.purgeTableStream(t,r,n),n?"Successfully purged ingest":`Successfully purged table '${t}.${r}'`}a(s5,"purgeStream")});var aT=T((Wde,AU)=>{"use strict";var oT=bs(),i5=Nt(),TU=te(),Id=P(),co=nt(),o5=J(),iT=Q(),{RemotePayloadObject:a5}=Su(),{ErrorCode:pU}=require("nats"),SU=TU.get(Id.CONFIG_PARAMS.CLUSTERING_ENABLED),gU=TU.get(Id.CONFIG_PARAMS.CLUSTERING_NODENAME);AU.exports={clusterStatus:c5,buildNodeStatus:RU};async function c5(){let e={node_name:gU,is_enabled:SU,connections:[]};if(!SU)return e;let t=await oT.getAllNodeRecords();if(o5.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(RU(t[n],e.connections));return await Promise.allSettled(r),e}a(c5,"clusterStatus");async function RU(e,t){let r=e.name,n=new a5(Id.OPERATIONS_ENUM.CLUSTER_STATUS,gU,void 0,await oT.getSystemInfo()),s,i,o=co.CLUSTER_STATUS_STATUSES.OPEN;try{let u=Date.now();s=await i5.request(co.REQUEST_SUBJECT(r),n),i=Date.now()-u,s.status===co.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=co.CLUSTER_STATUS_STATUSES.CLOSED,iT.error(`Error getting node status from ${r} `,s))}catch(u){iT.warn(`Error getting node status from ${r}`,u),u.code===pU.NoResponders?o=co.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:u.code===pU.Timeout?o=co.CLUSTER_STATUS_STATUSES.TIMEOUT:o=co.CLUSTER_STATUS_STATUSES.CLOSED}let c=new u5(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let u={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==Id.PRE_4_0_0_VERSION&&await oT.upsertNodeRecord(u)}catch(u){iT.error("Cluster status encountered an error updating system info for node:",r,u)}t.push(c)}a(RU,"buildNodeStatus");function u5(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(u5,"NodeStatusObject")});var uT=T((zde,OU)=>{"use strict";var{handleHDBError:l5,hdb_errors:_5}=re(),{HTTP_STATUS_CODES:d5}=_5,f5=Nt(),E5=bs(),cT=J(),Cd=require("joi"),h5=rt(),m5=2e3,p5=Cd.object({timeout:Cd.number().min(1),connected_nodes:Cd.boolean(),routes:Cd.boolean()});OU.exports=S5;async function S5(e){E5.checkClusteringEnabled();let t=h5.validateBySchema(e,p5);if(t)throw l5(t,t.message,d5.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||cT.autoCastBoolean(n),o=s===void 0||cT.autoCastBoolean(s),c={nodes:[]},u=await f5.getServerList(r??m5),_={};if(i)for(let l=0,d=u.length;l<d;l++){let f=u[l].statsz;f&&(_[u[l].server.name]=f.routes)}for(let l=0,d=u.length;l<d;l++){if(u[l].statsz)continue;let f=u[l].server,E=u[l].data;if(f.name.endsWith("-hub")){let h={name:f.name.slice(0,-4),response_time:u[l].response_time};i&&(h.connected_nodes=[],_[f.name]&&_[f.name].forEach(S=>{h.connected_nodes.includes(S.name.slice(0,-4))||h.connected_nodes.push(S.name.slice(0,-4))})),o&&(h.routes=E.cluster?.urls?E.cluster?.urls.map(S=>({host:S.split(":")[0],port:cT.autoCast(S.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(S5,"clusterNetwork")});var wU=T((Xde,yU)=>{"use strict";var lT=require("joi"),bU=rt(),{route_constraints:NU}=Cm();yU.exports={setRoutesValidator:T5,deleteRoutesValidator:g5};function T5(e){let t=lT.object({server:lT.valid("hub","leaf").required(),routes:NU.required()});return bU.validateBySchema(e,t)}a(T5,"setRoutesValidator");function g5(e){let t=lT.object({routes:NU.required()});return bU.validateBySchema(e,t)}a(g5,"deleteRoutesValidator")});var dT=T((Zde,LU)=>{"use strict";var uo=Lr(),_T=J(),Dd=P(),IU=wU(),{handleHDBError:CU,hdb_errors:R5}=re(),{HTTP_STATUS_CODES:DU}=R5,A5="cluster routes successfully set",O5="cluster routes successfully deleted";LU.exports={setRoutes:b5,getRoutes:N5,deleteRoutes:y5};function b5(e){let t=IU.setRoutesValidator(e);if(t)throw CU(t,t.message,DU.BAD_REQUEST,void 0,void 0,!0);let r=uo.getClusteringRoutes(),n=e.server==="hub"?r.hub_routes:r.leaf_routes,s=e.server==="hub"?r.leaf_routes:r.hub_routes,i=[],o=[];for(let c=0,u=e.routes.length;c<u;c++){let _=e.routes[c];_.port=_T.autoCast(_.port);let l=n.some(f=>f.host===_.host&&f.port===_.port),d=s.some(f=>f.host===_.host&&f.port===_.port);l||d?i.push(_):(n.push(_),o.push(_))}return e.server==="hub"?uo.updateConfigValue(Dd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n):uo.updateConfigValue(Dd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n),{message:A5,set:o,skipped:i}}a(b5,"setRoutes");function N5(){let e=uo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}a(N5,"getRoutes");function y5(e){let t=IU.deleteRoutesValidator(e);if(t)throw CU(t,t.message,DU.BAD_REQUEST,void 0,void 0,!0);let r=uo.getClusteringRoutes(),n=r.hub_routes,s=r.leaf_routes,i=[],o=[],c=!1,u=!1;for(let _=0,l=e.routes.length;_<l;_++){let d=e.routes[_],f=!1;for(let E=0,h=n.length;E<h;E++){let S=n[E];if(d.host===S.host&&d.port===S.port){n.splice(E,1),f=!0,c=!0,i.push(d);break}}if(!f){let E=!0;for(let h=0,S=s.length;h<S;h++){let p=s[h];if(d.host===p.host&&d.port===p.port){s.splice(h,1),u=!0,E=!1,i.push(d);break}}E&&o.push(d)}}return c&&(n=_T.isEmptyOrZeroLength(n)?null:n,uo.updateConfigValue(Dd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n)),u&&(s=_T.isEmptyOrZeroLength(s)?null:s,uo.updateConfigValue(Dd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,s)),{message:O5,deleted:i,skipped:o}}a(y5,"deleteRoutes")});var MU=T((tfe,UU)=>{"use strict";var bu=require("alasql"),lo=require("recursive-iterator"),Un=Q(),w5=J(),Nu=P(),fT=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,C5(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=>Nu.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=>!Nu.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][Nu.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=I5(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(_=>({attribute_name:_.attribute}));let u=this.affected_attributes.get(i).get(o).filter(_=>!Nu.SEARCH_WILDCARDS.includes(_));c.forEach(({attribute_name:_})=>{let l=new bu.yy.Column({columnid:_});s.tableid&&(l.tableid=s.tableid),this.ast.columns.push(l),u.includes(_)||u.push(_)}),this.affected_attributes.get(i).set(o,u)}}),this.ast}};function I5(e){return e.filter(t=>t[Nu.PERMS_CRUD_ENUM.READ])}a(I5,"filterReadRestrictedAttrs");function C5(e,t,r,n,s){D5(e,t,r,n,s)}a(C5,"interpretAST");function yu(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(yu,"addSchemaTableToMap");function D5(e,t,r,n,s){if(!e){Un.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof bu.yy.Insert?P5(e,t,r):e instanceof bu.yy.Select?L5(e,t,r,n,s):e instanceof bu.yy.Update?U5(e,t,r):e instanceof bu.yy.Delete?M5(e,t,r):Un.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(D5,"getRecordAttributesAST");function L5(e,t,r,n,s){if(!e){Un.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(w5.isEmptyOrZeroLength(i)){Un.error("No schema specified");return}e.from.forEach(c=>{yu(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),yu(c.table,t,r,n,s)});let o=new lo(e.columns);for(let{node:c}of o)if(c&&c.columnid){let u=c.tableid,_=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(_).has(u))if(r.has(u))u=r.get(u);else{Un.info(`table specified as ${u} not found.`);return}t.get(_).get(u).indexOf(c.columnid)<0&&t.get(_).get(u).push(c.columnid)}if(e.where){let c=new lo(e.where),u=e.from[0].tableid;for(let{node:_}of c)if(_&&_.columnid){let l=_.tableid?_.tableid:u;if(!t.get(i).has(l))if(r.has(l))l=r.get(l);else{Un.info(`table specified as ${l} not found.`);continue}t.get(i).get(l).indexOf(_.columnid)<0&&t.get(i).get(l).push(_.columnid)}}if(e.joins&&e.joins.forEach(c=>{let u=new lo(c.on);for(let{node:_}of u)if(_&&_.columnid){let l=_.tableid,d=s.get(l);if(!t.get(d).has(l))if(r.has(l))l=r.get(l);else{Un.info(`table specified as ${l} not found.`);continue}t.get(d).get(l).indexOf(_.columnid)<0&&t.get(d).get(l).push(_.columnid)}}),e.order){let c=new lo(e.order);for(let{node:u}of c)if(u&&u.columnid){let _=u.tableid,l=n.has(_)?n.get(_):i;if(_||(_=e.from[0].tableid),!t.get(l).has(_))if(r.has(_))_=r.get(_);else{Un.info(`table specified as ${_} not found.`);return}t.get(l).get(_).indexOf(u.columnid)<0&&t.get(l).get(_).push(u.columnid)}}}a(L5,"getSelectAttributes");function U5(e,t,r){if(!e){Un.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new lo(e.columns),s=e.table.databaseid;yu(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&ET(e.table.tableid,s,i.columnid,t,r)}a(U5,"getUpdateAttributes");function M5(e,t,r){if(!e){Un.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new lo(e.where),s=e.table.databaseid;yu(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&ET(e.table.tableid,s,i.columnid,t,r)}a(M5,"getDeleteAttributes");function P5(e,t,r){if(!e){Un.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new lo(e.columns),s=e.into.databaseid;yu(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&ET(e.into.tableid,s,i.columnid,t,r)}a(P5,"getInsertAttributes");function ET(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(ET,"pushAttribute");UU.exports=fT});var pT=T((nfe,HU)=>{var Ld=Ki(),PU=require("chalk"),xr=Q(),vU=require("prompt"),{promisify:v5}=require("util"),hT=P(),B5=require("fs-extra"),H5=require("path"),x5=J(),F5=Sd(),BU=te();BU.initSync();var G5=require("moment"),q5=v5(vU.get),k5=H5.join(BU.getHdbBasePath(),hT.LICENSE_KEY_DIR_NAME,hT.LICENSE_FILE_NAME,hT.LICENSE_FILE_NAME);HU.exports={getFingerprint:$5,setLicense:V5,parseLicense:mT,register:Y5,getRegistrationInfo:W5};async function V5(e){if(e&&e.key&&e.company){try{xr.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await mT(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw xr.error(r),xr.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(V5,"setLicense");async function $5(){let e={};try{e=await Ld.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw xr.error(r),xr.error(t),new Error(r)}return e}a($5,"getFingerprint");async function mT(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");xr.info("Validating license input...");let r=Ld.validateLicense(e,t);if(xr.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(xr.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(xr.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{xr.info("writing license to disk"),await B5.writeFile(k5,JSON.stringify({license_key:e,company:t}))}catch(n){throw xr.error("Failed to write License"),n}return"Registration successful."}a(mT,"parseLicense");async function Y5(){let e=await K5();return mT(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(Y5,"register");async function K5(){let e=await Ld.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:PU.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:PU.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{vU.start()}catch(n){xr.error(n)}let r;try{r=await q5(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(K5,"promptForRegistration");async function W5(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await Ld.getLicense()}catch(r){throw xr.error(`There was an error when searching licenses due to: ${r.message}`),r}if(x5.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=F5.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=G5.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(W5,"getRegistrationInfo")});var FU=T((ife,xU)=>{"use strict";var Q5=nt(),ST=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,u,_,l,d,f,E,h){this.port=t,o===null&&(o=void 0),this.server_name=r+Q5.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:u},this.leafnodes={port:_,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:l,port:d,routes:f,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:u}},this.accounts={SYS:{users:E},HDB:{users:h}},this.system_account="SYS"}};xU.exports=ST});var kU=T((afe,qU)=>{"use strict";var GU=nt(),TT=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,u,_,l,d){this.port=t,d===null&&(d=void 0),this.server_name=r+GU.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+GU.SERVER_SUFFIX.LEAF},this.tls={cert_file:_,key_file:l,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:u,jetstream:"enabled"}},this.system_account="SYS"}};qU.exports=TT});var $U=T((ufe,VU)=>{"use strict";var gT=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};VU.exports=gT});var KU=T((_fe,YU)=>{"use strict";var z5=nt(),RT=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+z5.SERVER_SUFFIX.ADMIN,this.password=r}};YU.exports=RT});var bT=T((ffe,zU)=>{"use strict";var fa=require("path"),Pd=require("fs-extra"),J5=FU(),X5=kU(),j5=$U(),Z5=KU(),AT=tn(),ha=J(),hr=Lr(),Md=P(),wu=nt(),{CONFIG_PARAMS:_t}=Md,Iu=Q(),Cu=te(),WU=Ss(),OT=Nt(),Ea="clustering",e8=1e4,QU=5;zU.exports={generateNatsConfig:r8,removeNatsConfig:n8,getHubConfigPath:t8};function t8(){let e=Cu.get(_t.ROOTPATH);return fa.join(e,Ea,wu.NATS_CONFIG_FILES.HUB_SERVER)}a(t8,"getHubConfigPath");async function r8(e=!1,t=void 0){Cu.initSync();let r=Cu.get(_t.ROOTPATH),n=fa.join(r,Ea,wu.PID_FILES.HUB),s=fa.join(r,Ea,wu.PID_FILES.LEAF),i=hr.getConfigFromFile(_t.CLUSTERING_LEAFSERVER_STREAMS_PATH),o=fa.join(r,Ea,wu.NATS_CONFIG_FILES.HUB_SERVER),c=fa.join(r,Ea,wu.NATS_CONFIG_FILES.LEAF_SERVER),u=hr.getConfigFromFile(_t.CLUSTERING_TLS_CERTIFICATE),_=hr.getConfigFromFile(_t.CLUSTERING_TLS_PRIVATEKEY),l=hr.getConfigFromFile(_t.CLUSTERING_TLS_CERT_AUTH),d=hr.getConfigFromFile(_t.CLUSTERING_TLS_INSECURE),f=hr.getConfigFromFile(_t.CLUSTERING_TLS_VERIFY),E=hr.getConfigFromFile(_t.CLUSTERING_NODENAME),h=hr.getConfigFromFile(_t.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await OT.checkNATSServerInstalled()||vd("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await AT.listUsers(),p=hr.getConfigFromFile(_t.CLUSTERING_USER),R=await AT.getClusterUser();(ha.isEmpty(R)||R.active!==!0)&&vd(`Invalid cluster user '${p}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Ud(_t.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Ud(_t.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Ud(_t.CLUSTERING_HUBSERVER_NETWORK_PORT),await Ud(_t.CLUSTERING_LEAFSERVER_NETWORK_PORT));let A=[],g=[];for(let[V,ce]of S.entries())ce.role.role===Md.ROLE_TYPES_ENUM.CLUSTER_USER&&ce.active&&(A.push(new Z5(ce.username,WU.decrypt(ce.hash))),g.push(new j5(ce.username,WU.decrypt(ce.hash))));let v=[],{hub_routes:H}=hr.getClusteringRoutes();if(!ha.isEmptyOrZeroLength(H))for(let V of H)v.push(`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@${V.host}:${V.port}`);let M=new J5(hr.getConfigFromFile(_t.CLUSTERING_HUBSERVER_NETWORK_PORT),E,n,u,_,l,d,f,h,hr.getConfigFromFile(_t.CLUSTERING_HUBSERVER_CLUSTER_NAME),hr.getConfigFromFile(_t.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),v,A,g);l==null&&(delete M.tls.ca_file,delete M.leafnodes.tls.ca_file),t=ha.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===Md.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Pd.writeJson(o,M),Iu.trace(`Hub server config written to ${o}`));let U=`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}`,K=new X5(hr.getConfigFromFile(_t.CLUSTERING_LEAFSERVER_NETWORK_PORT),E,s,i,[U],[Y],A,g,u,_,l,d);l==null&&delete K.tls.ca_file,(t===void 0||t===Md.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Pd.writeJson(c,K),Iu.trace(`Leaf server config written to ${c}`))}a(r8,"generateNatsConfig");async function Ud(e){let t=Cu.get(e);return ha.isEmpty(t)&&vd(`port undefined for '${e}'`),await ha.isPortTaken(t)&&vd(`'${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(Ud,"isPortAvailable");function vd(e){let t=`Error generating clustering config: ${e}`;Iu.error(t),console.error(t),process.exit(1)}a(vd,"generateNatsConfigError");async function n8(e){let{port:t,config_file:r}=OT.getServerConfig(e),{username:n,decrypt_hash:s}=await AT.getClusterUser(),i=0,o=2e3;for(;i<QU;){try{let _=await OT.createConnection(t,n,s,!1);if(_.protocol.connected===!0){_.close();break}}catch(_){Iu.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${_}`)}if(i++,i>=QU)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.`);await ha.async_set_timeout(o*(i*2))}let c="0".repeat(e8),u=fa.join(Cu.get(_t.ROOTPATH),Ea,r);await Pd.writeFile(u,c),await Pd.remove(u),Iu.notify(e,"started.")}a(n8,"removeNatsConfig")});var tM=T((hfe,eM)=>{"use strict";var Fr=te(),s8=Ki(),he=P(),Du=nt(),Ns=require("path"),{PACKAGE_ROOT:Hd}=P(),JU=te(),Bd=J(),ma="/dev/null",i8=Ns.join(Hd,"launchServiceScripts"),XU=Ns.join(Hd,"utility/scripts"),o8=Ns.join(XU,he.HDB_RESTART_SCRIPT),jU=Ns.resolve(Hd,"dependencies",`${process.platform}-${process.arch}`,Du.NATS_BINARY_NAME);function ZU(){let t=s8.licenseSearch().ram_allocation||he.RAM_ALLOCATION_ENUM.DEFAULT,r=he.MEM_SETTING_KEY+t,n={[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Bd.noBootFile()&&(n[he.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Bd.getEnvCliRootPath()),{name:he.PROCESS_DESCRIPTORS.HDB,script:he.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:Hd}}a(ZU,"generateMainServerConfig");var a8=9930;function c8(){Fr.initSync(!0);let e=Fr.get(he.CONFIG_PARAMS.ROOTPATH),t=Ns.join(e,"clustering",Du.NATS_CONFIG_FILES.HUB_SERVER),r=Ns.join(Fr.get(he.HDB_SETTINGS_NAMES.LOG_PATH_KEY),he.LOG_NAMES.HDB),n=JU.get(he.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Du.LOG_LEVEL_FLAGS[Fr.get(he.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:he.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==a8?"-"+n:""),script:jU,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Fr.get(he.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=ma,i.error_file=ma),i}a(c8,"generateNatsHubServerConfig");var u8=9940;function l8(){Fr.initSync(!0);let e=Fr.get(he.CONFIG_PARAMS.ROOTPATH),t=Ns.join(e,"clustering",Du.NATS_CONFIG_FILES.LEAF_SERVER),r=Ns.join(Fr.get(he.HDB_SETTINGS_NAMES.LOG_PATH_KEY),he.LOG_NAMES.HDB),n=JU.get(he.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Du.LOG_LEVEL_FLAGS[Fr.get(he.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:he.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==u8?"-"+n:""),script:jU,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Fr.get(he.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=ma,i.error_file=ma),i}a(l8,"generateNatsLeafServerConfig");function _8(){Fr.initSync();let e=Ns.join(Fr.get(he.CONFIG_PARAMS.LOGGING_ROOT),he.LOG_NAMES.HDB),t={name:he.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:he.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:i8,autorestart:!1};return Fr.get(he.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=ma,t.error_file=ma),t}a(_8,"generateClusteringUpgradeV4ServiceConfig");function d8(){let e={[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.RESTART_HDB};return Bd.noBootFile()&&(e[he.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Bd.getEnvCliRootPath()),{...{name:he.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:XU},script:o8}}a(d8,"generateRestart");function f8(){return{apps:[ZU()]}}a(f8,"generateAllServiceConfigs");eM.exports={generateAllServiceConfigs:f8,generateMainServerConfig:ZU,generateRestart:d8,generateNatsHubServerConfig:c8,generateNatsLeafServerConfig:l8,generateClusteringUpgradeV4ServiceConfig:_8}});var hM=T((Sfe,EM)=>{"use strict";var ve=P(),E8=J(),ys=bT(),Lu=Nt(),es=nt(),_i=tM(),xd=te(),di=Q(),h8=bs(),{startWorker:rM,onMessageFromWorkers:m8}=et(),p8=da(),pfe=require("util"),S8=require("child_process"),T8=require("fs"),{execFile:g8}=S8,we;EM.exports={enterPM2Mode:R8,start:fi,stop:NT,reload:sM,restart:iM,list:yT,describe:aM,connect:ws,kill:y8,startAllServices:w8,startService:wT,getUniqueServicesList:cM,restartAllServices:I8,isServiceRegistered:uM,reloadStopStart:lM,restartHdb:oM,deleteProcess:b8,startClusteringProcesses:dM,startClusteringThreads:fM,isHdbRestartRunning:N8,isClusteringRunning:D8,stopClustering:C8,reloadClustering:L8};var Uu=!1;m8(e=>{e.type==="restart"&&xd.initSync(!0)});function R8(){Uu=!0}a(R8,"enterPM2Mode");function ws(){return we||(we=require("pm2")),new Promise((e,t)=>{we.connect((r,n)=>{di.setupConsoleLogging(),r&&t(r),e(n)})})}a(ws,"connect");var mr,A8=10,nM;function fi(e,t=!1){if(Uu)return O8(e);let r=g8(e.script,e.args.split(" "),e);r.name=e.name,r.on("exit",async i=>{let o=mr.indexOf(r);o>-1&&mr.splice(o,1),!nM&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<A8&&(T8.existsSync(ys.getHubConfigPath())?fi(e):(await ys.generateNatsConfig(!0),fi(e),await new Promise(c=>setTimeout(c,3e3)),await ys.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ys.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=xd.get(ve.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,u,_=0,l;for(;u=c.exec(i);){if(u.index&&es.LOG_LEVEL_HIERARCHY[o]>=es.LOG_LEVEL_HIERARCHY[l||"info"]){let E=l===es.LOG_LEVELS.ERR||l===es.LOG_LEVELS.WRN?di.OUTPUTS.STDERR:di.OUTPUTS.STDOUT;di.logCustomLevel(l||"info",E,n,i.slice(_,u.index).trim())}let[d,f]=u;_=u.index+d.length,l=es.LOG_LEVELS[f]}if(es.LOG_LEVEL_HIERARCHY[o]>=es.LOG_LEVEL_HIERARCHY[l||"info"]){let d=l===es.LOG_LEVELS.ERR||l===es.LOG_LEVELS.WRN?di.OUTPUTS.STDERR:di.OUTPUTS.STDOUT;di.logCustomLevel(l||"info",d,n,i.slice(_).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),mr=[],!mr&&!t){let i=a(()=>{nM=!0,mr&&(mr.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)}mr.push(r)}a(fi,"start");function O8(e){return new Promise(async(t,r)=>{try{await ws()}catch(n){r(n)}we.start(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(O8,"startWithPM2");function NT(e){if(!Uu){for(let t of mr||[])t.name===e&&(mr.splice(mr.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await ws()}catch(n){r(n)}we.stop(e,async(n,s)=>{n&&(we.disconnect(),r(n)),we.delete(e,(i,o)=>{i&&(we.disconnect(),r(n)),we.disconnect(),t(o)})})})}a(NT,"stop");function sM(e){return new Promise(async(t,r)=>{try{await ws()}catch(n){r(n)}we.reload(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(sM,"reload");function iM(e){if(!Uu)for(let t of mr||[])t.name===e&&t.kill();return new Promise(async(t,r)=>{try{await ws()}catch(n){r(n)}we.restart(e,(n,s)=>{we.disconnect(),t(s)})})}a(iM,"restart");function b8(e){return new Promise(async(t,r)=>{try{await ws()}catch(n){r(n)}we.delete(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(b8,"deleteProcess");async function oM(){await fi(_i.generateRestart())}a(oM,"restartHdb");async function N8(){let e=await yT();for(let t in e)if(e[t].name===ve.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(N8,"isHdbRestartRunning");function yT(){return new Promise(async(e,t)=>{try{await ws()}catch(r){t(r)}we.list((r,n)=>{r&&(we.disconnect(),t(r)),we.disconnect(),e(n)})})}a(yT,"list");function aM(e){return new Promise(async(t,r)=>{try{await ws()}catch(n){r(n)}we.describe(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(aM,"describe");function y8(){if(!Uu){for(let e of mr||[])e.kill();mr=[];return}return new Promise(async(e,t)=>{try{await ws()}catch(r){t(r)}we.killDaemon((r,n)=>{r&&(we.disconnect(),t(r)),we.disconnect(),e(n)})})}a(y8,"kill");async function w8(){try{await dM(),await fM(),await fi(_i.generateAllServiceConfigs())}catch(e){throw we?.disconnect(),e}}a(w8,"startAllServices");async function wT(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case ve.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=_i.generateMainServerConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=_i.generateNatsIngestServiceConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=_i.generateNatsReplyServiceConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=_i.generateNatsHubServerConfig(),await fi(r,t),await ys.removeNatsConfig(e);return;case ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=_i.generateNatsLeafServerConfig(),await fi(r,t),await ys.removeNatsConfig(e);return;case ve.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=_i.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await fi(r)}catch(r){throw we?.disconnect(),r}}a(wT,"startService");async function cM(){try{let e=await yT(),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 we?.disconnect(),e}}a(cM,"getUniqueServicesList");async function I8(e=[]){try{let t=!1,r=await cM();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===ve.PROCESS_DESCRIPTORS.HDB?t=!0:await iM(o))}t&&await lM(ve.PROCESS_DESCRIPTORS.HDB)}catch(t){throw we?.disconnect(),t}}a(I8,"restartAllServices");async function uM(e){if(mr?.find(r=>r.name===e))return!0;let t=await p8.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(uM,"isServiceRegistered");async function lM(e){let t=xd.get(ve.CONFIG_PARAMS.THREADS_COUNT)??xd.get(ve.CONFIG_PARAMS.THREADS),r=await aM(e),n=E8.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await NT(e),await wT(e)):e===ve.PROCESS_DESCRIPTORS.HDB?await oM():await sM(e)}a(lM,"reloadStopStart");var _M;async function dM(e=!1){for(let t in ve.CLUSTERING_PROCESSES){let r=ve.CLUSTERING_PROCESSES[t];await wT(r,e)}}a(dM,"startClusteringProcesses");async function fM(){_M=rM(ve.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:ve.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE}),await Lu.createWorkQueueStream(es.WORK_QUEUE_CONSUMER_NAMES),await Lu.updateIngestStreamConsumer(),await Lu.updateLocalStreams();let e=await h8.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===ve.PRE_4_0_0_VERSION){di.info("Starting clustering upgrade 4.0.0 process"),rM(ve.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(fM,"startClusteringThreads");async function C8(){for(let e in ve.CLUSTERING_PROCESSES)if(e!==ve.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===ve.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await _M.terminate();else{let t=ve.CLUSTERING_PROCESSES[e];await NT(t)}}a(C8,"stopClustering");async function D8(){for(let e in ve.CLUSTERING_PROCESSES){let t=ve.CLUSTERING_PROCESSES[e];if(await uM(t)===!1)return!1}return!0}a(D8,"isClusteringRunning");async function L8(){await ys.generateNatsConfig(!0),await Lu.reloadNATSHub(),await Lu.reloadNATSLeaf(),await ys.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await ys.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(L8,"reloadClustering")});var kd=T((gfe,AM)=>{"use strict";var U8=require("minimist"),{isMainThread:DT,parentPort:SM}=require("worker_threads"),st=P(),{PROCESS_DESCRIPTORS_VALIDATE:Mu}=st,ts=Q(),LT=J(),Fd=bT(),pa=Nt(),IT=nt(),TM=Lr(),rs=hM(),mM=da(),M8=rh(),{restartWorkers:Gd,onMessageByType:P8}=et(),{handleHDBError:v8,hdb_errors:B8}=re(),{HTTP_STATUS_CODES:H8}=B8,qd=te();qd.initSync();var Pu=`Restarting HarperDB. This may take up to ${st.RESTART_TIMEOUT_MS/1e3} seconds.`,x8="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",pM="Clustering is not enabled so cannot be restarted",F8="Invalid service",Sa,on;AM.exports={restart:gM,restartService:UT};DT&&P8(st.ITC_EVENT_TYPES.RESTART,e=>{e.workerType?UT({service:e.workerType}):gM({operation:"restart"})});async function gM(e){on=Object.keys(e).length===0,Sa=await rs.isServiceRegistered(st.HDB_PROC_DESCRIPTOR);let t=U8(process.argv);if(t.service){await UT(t);return}if(on&&!Sa){console.error(x8);return}if(on&&console.log(Pu),Sa){rs.enterPM2Mode(),ts.notify(Pu);let r=M8(Object.keys(st.CONFIG_PARAM_MAP),!0);return LT.isEmptyOrZeroLength(Object.keys(r))||TM.updateConfigValue(void 0,void 0,r,!0,!0),q8(),Pu}return DT?(ts.notify(Pu),setTimeout(()=>{Gd()},50)):SM.postMessage({type:st.ITC_EVENT_TYPES.RESTART}),Pu}a(gM,"restart");async function UT(e){let{service:t}=e;if(st.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw v8(new Error,F8,H8.BAD_REQUEST,void 0,void 0,!0);if(Sa=await rs.isServiceRegistered(st.HDB_PROC_DESCRIPTOR),!DT)return SM.postMessage({type:st.ITC_EVENT_TYPES.RESTART,workerType:t}),t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`;let r;switch(t){case Mu.clustering:if(!qd.get(st.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=pM;break}on&&console.log("Restarting clustering"),ts.notify("Restarting clustering"),await RM();break;case Mu.clustering_config:case Mu["clustering config"]:if(!qd.get(st.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=pM;break}on&&console.log("Restarting clustering_config"),ts.notify("Restarting clustering_config"),await rs.reloadClustering();break;case"custom_functions":case"custom functions":case Mu.harperdb:case Mu.http_workers:if(on&&!Sa){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}on&&console.log("Restarting http_workers"),ts.notify("Restarting http_workers"),on?await rs.restart(st.HDB_PROC_DESCRIPTOR):setTimeout(()=>{Gd("http")},200);break;default:r=`Unrecognized service: ${t}`;break}return r?(ts.error(r),on&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(UT,"restartService");async function G8(){await pa.publishToStream(`${IT.SUBJECT_PREFIXES.TXN}.${IT.WORK_QUEUE_CONSUMER_NAMES.stream_name}`,IT.WORK_QUEUE_CONSUMER_NAMES.stream_name,pa.addNatsMsgHeader({operation:"dummy_msg"},void 0),{operation:"dummy_msg"})}a(G8,"postDummyNatsMsg");async function q8(){await RM(),await rs.restart(st.HDB_PROC_DESCRIPTOR),await LT.async_set_timeout(2e3),qd.get(st.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await CT(),on&&(await pa.closeConnection(),process.exit(0))}a(q8,"restartPM2Mode");async function RM(){if(!TM.getConfigFromFile(st.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await mM.getHDBProcessInfo()).clustering.length===0)ts.trace("Clustering not running, restart will start clustering services"),await Fd.generateNatsConfig(!0),await rs.startClusteringProcesses(),await rs.startClusteringThreads(),await CT(),on&&await pa.closeConnection();else{await G8(),await Fd.generateNatsConfig(!0),Sa?(ts.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await rs.restart(st.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await rs.restart(st.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await mM.getHDBProcessInfo()).clustering.forEach(s=>{ts.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await LT.async_set_timeout(3e3),await CT(),await pa.updateLocalStreams(),on&&await pa.closeConnection(),ts.trace("Restart clustering restarting ingest and reply service threads");let t=Gd(st.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=Gd(st.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(RM,"restartClustering");async function CT(){await Fd.removeNatsConfig(st.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Fd.removeNatsConfig(st.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(CT,"removeNatsConfig")});var MM=T((Ofe,UM)=>{"use strict";var Afe=require("lodash"),pr=P(),{handleHDBError:OM,hdb_errors:k8}=re(),{HDB_ERROR_MSGS:V8,HTTP_STATUS_CODES:$8}=k8,MT=Q();UM.exports={getRolePermissions:K8};var _o=Object.create(null),Y8=a(e=>({key:e,perms:{}}),"perms_template_obj"),wM=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),IM=a((e=!1,t=!1,r=!1,n=!1)=>({[pr.PERMS_CRUD_ENUM.READ]:e,[pr.PERMS_CRUD_ENUM.INSERT]:t,[pr.PERMS_CRUD_ENUM.UPDATE]:r,[pr.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),PT=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...IM(t,r,n,s)}),"table_perms_template"),bM=a((e,t=IM())=>({attribute_name:e,describe:LM(t),[vu]:t[vu],[vT]:t[vT],[BT]:t[BT]}),"attr_perms_template"),NM=a((e,t=!1)=>({attribute_name:e,describe:t,[vu]:t}),"timestamp_attr_perms_template"),{READ:vu,INSERT:vT,UPDATE:BT}=pr.PERMS_CRUD_ENUM,CM=Object.values(pr.PERMS_CRUD_ENUM),DM=[vu,vT,BT];function K8(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r=Object.assign({},global.hdb_schema);delete r[pr.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(_o[t]&&_o[t].key===n)return _o[t].perms;let s=W8(e,r);return _o[t]?_o[t].key=n:_o[t]=Y8(n),_o[t].perms=s,s}catch(r){if(!e[pr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[pr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<pr.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 MT.error(n),MT.debug(r),OM(new Error,V8.OUTDATED_PERMS_TRANSLATION_ERROR,$8.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
|
|
11
|
-
${r.stack}`;throw MT.error(n),OM(new Error)}}}a(K8,"getRolePermissions");function W8(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[pr.SYSTEM_SCHEMA_NAME]=n[pr.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]=Q8(t[i]);return}r[i]=wM(),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],u=t[i][o],_=z8(c,u);r[i].describe||CM.forEach(l=>{_[l]&&(r[i].describe=!0)}),r[i].tables[o]=_}else r[i].tables[o]=PT()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=PT()})}),r}a(W8,"translateRolePermissions");function Q8(e){let t=wM(!0);return Object.keys(e).forEach(r=>{t.tables[r]=PT(!0,!0,!0,!0,!0)}),t}a(Q8,"createStructureUserPermissions");function z8(e,t){let{attribute_permissions:r}=e;if(r.length>0){let s=Object.assign({},e);s.attribute_permissions=[];let i=r.reduce((_,l)=>{let{attribute_name:d}=l,f=l;return pr.TIME_STAMP_NAMES.includes(d)&&(f=NM(d,l[vu])),_[d]=f,_},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],u=bM(o);return t.attributes.forEach(({attribute:_})=>{if(i[_]){let l=i[_];l.describe=LM(l),s.attribute_permissions.push(l),c||J8(l,u)}else if(_!==o){let l;pr.TIME_STAMP_NAMES.includes(_)?l=NM(_):l=bM(_),s.attribute_permissions.push(l)}}),c||s.attribute_permissions.push(u),s.describe=yM(s),s}else return e.describe=yM(e),e}a(z8,"getTableAttrPerms");function yM(e){return CM.filter(t=>e[t]).length>0}a(yM,"getSchemaTableDescribePerm");function LM(e){return DM.filter(t=>e[t]).length>0}a(LM,"getAttributeDescribePerm");function J8(e,t){DM.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(J8,"checkForHashPerms")});var PM={};Ye(PM,{Resources:()=>Vd,keyArrayToString:()=>Ta,resetResources:()=>X8,resources:()=>Ei});function X8(){return Ei=new Vd}function Ta(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var Vd,Ei,Bu=ge(()=>{ji();Vd=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,type:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s)throw new Error(`Conflicting paths for ${t}`);super.set(t,i);for(let[c,u]of this){let _=2;for(;(_=c.indexOf("/",_))>-1;){let l=this.get(c.slice(0,_));l&&(l.hasSubPaths=!0),_+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),u=this.get(c);if(u){if(u.relativeURL=t.slice(n),!u.hasSubPaths)return u;s=u}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),s?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Je(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(X8,"resetResources");a(Ta,"keyArrayToString")});var vM={};Ye(vM,{Headers:()=>hi,appendHeader:()=>HT});function HT(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}var hi,Hu=ge(()=>{hi=class extends Map{static{a(this,"Headers")}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(HT,"appendHeader")});var xu={};Ye(xu,{authentication:()=>VM,bypassAuth:()=>s6,login:()=>o6,logout:()=>a6,start:()=>i6});function s6(){kM=!0}async function VM(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let E=e.isOperationsServer?t6?e6:[]:Z8?j8:[];if(E.includes(i)||E.includes("*")){if(e.method==="OPTIONS"){let h=new hi([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return $d&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),$d&&o.push("Access-Control-Allow-Credentials","true")}}let u,_;if($d){let E=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.indexOf(E);if(h>=0){let S=s.indexOf(";",h),p=s.indexOf("=",h);u=s.slice(p+1,S===-1?s.length:S),_=await HM.get(u)}e.session=_||(_={})}e.user=null;let l=a((E,h,S)=>{let p=new Kd.AuthAuditLog(E,h,qt.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);p.auth_strategy=S,u&&(p.session_id=u),r.referer&&(p.referer=r.referer),r.origin&&(p.origin=r.origin),h===qt.AUTH_AUDIT_STATUS.SUCCESS?BM.notify(p):BM.error(p)},"authAuditLog");if(e.mtlsConfig&&e.authorized){let E=e.mtlsConfig.user;E!==null&&((E===void 0||E==="Common Name"||E==="CN")&&(E=e.peerCertificate.subject.CN),e.user=await Ze.getUser(E,null,null))}let d;if(!e.user)if(n){if(d=fo.get(n),!d){let[E,h]=n.split(" "),S,p;try{switch(E){case"Basic":[S,p]=atob(h).split(":"),d=S||p?await Ze.getUser(S,p,e):null;break;case"Bearer":try{d=await(0,Yd.validateOperationToken)(h)}catch(R){if(R.message==="invalid token")try{return await(0,Yd.validateRefreshToken)(h),c({status:-1})}catch{throw R}}break}}catch(R){return n6&&(fo.get(h)||(fo.set(h,h),l(S,qt.AUTH_AUDIT_STATUS.FAILURE,E))),c({status:401,body:mi({error:R.message},e)})}fo.set(n,d),r6&&l(d.username,qt.AUTH_AUDIT_STATUS.SUCCESS,E)}e.user=d}else _?.user?e.user=await Ze.getUser(_.user,null,e):(kM&&(e.ip?.includes("127.0.0.1")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,FM.getSuperUser)());$d&&(e.session.update=function(E){if(!u){u=(0,GM.v4)();let S=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${u}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",S):f?.headers?.set&&f.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")):f?.headers?.set&&(i&&f.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),f.headers.set("X-Hdb-Session","Secure"))),E.id=u,HM.put(E)},e.login=async function(E,h){e.user=await Ze.getUser(E,h,e),e.session.update({user:e.user.username})},(d&&!_||_?.user?.username!==d?.username)&&r["user-agent"]?.startsWith("Mozilla")&&e.session.update({user:e.user.username}));let f=await t(e);return f&&(f.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Ei.loginPath?(f.status=302,f.headers.set("Location",Ei.loginPath(e))):f.headers.set("WWW-Authenticate","Basic")),c(f))}catch(u){throw c(u)}function c(u){let _=o.length;if(_>0){let l=u.headers;l||(u.headers=l=new hi);for(let d=0;d<_;){let f=o[d++];l.set(f,o[d++])}}return o=null,u}a(c,"applyResponseHeaders")}function i6({server:e,port:t}){e.request(VM,{port:t||"all"}),xM||(xM=!0,setInterval(()=>{fo=new Map},an.get(qt.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),qM.user.addListener(()=>{fo=new Map}))}async function o6(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 a6(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var FM,Yd,GM,an,qt,Kd,qM,BM,j8,Z8,e6,t6,HM,$d,kM,r6,n6,fo,xM,Wd=ge(()=>{FM=x(tn());rr();Bu();Yd=x(pu());Re();GM=require("uuid"),an=x(te()),qt=x(P()),Kd=x(Q()),qM=x(Bc());Hu();ga();BM=(0,Kd.loggerWithTag)("auth-event");an.initSync();j8=an.get(qt.CONFIG_PARAMS.HTTP_CORSACCESSLIST),Z8=an.get(qt.CONFIG_PARAMS.HTTP_CORS),e6=an.get(qt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),t6=an.get(qt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),HM=ct({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),$d=an.get(qt.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,kM=an.get(qt.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,r6=an.get(qt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,n6=an.get(qt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,fo=new Map;Ze.onInvalidatedUser(()=>{fo=new Map});a(s6,"bypassAuth");a(VM,"authentication");a(i6,"start");a(o6,"login");a(a6,"logout")});var JM=T((Pfe,zM)=>{"use strict";var Ie=require("joi"),$M=require("fs-extra"),YM=require("path"),Cs=rt(),KM=te(),WM=P(),QM=Q(),{hdb_errors:c6}=re(),{HDB_ERROR_MSGS:Jt}=c6,Is=/^[a-zA-Z0-9-_]+$/;zM.exports={getDropCustomFunctionValidator:l6,setCustomFunctionValidator:_6,addComponentValidator:h6,dropCustomFunctionProjectValidator:m6,packageComponentValidator:p6,deployComponentValidator:S6,setComponentFileValidator:d6,getComponentFileValidator:E6,dropComponentFileValidator:f6};function Qd(e,t,r){try{let n=KM.get(WM.CONFIG_PARAMS.COMPONENTSROOT),s=YM.join(n,t);return $M.existsSync(s)?e?t:r.message(Jt.PROJECT_EXISTS):e?r.message(Jt.NO_PROJECT):t}catch(n){return QM.error(n),r.message(Jt.VALIDATION_ERR)}}a(Qd,"checkProjectExists");function Fu(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(Fu,"checkFilePath");function u6(e,t,r,n){try{let s=KM.get(WM.CONFIG_PARAMS.COMPONENTSROOT),i=YM.join(s,e,t,r+".js");return $M.existsSync(i)?r:n.message(Jt.NO_FILE)}catch(s){return QM.error(s),n.message(Jt.VALIDATION_ERR)}}a(u6,"checkFileExists");function l6(e){let t=Ie.object({project:Ie.string().pattern(Is).custom(Qd.bind(null,!0)).required().messages({"string.pattern.base":Jt.BAD_PROJECT_NAME}),type:Ie.string().valid("helpers","routes").required(),file:Ie.string().pattern(Is).custom(u6.bind(null,e.project,e.type)).custom(Fu).required().messages({"string.pattern.base":Jt.BAD_FILE_NAME})});return Cs.validateBySchema(e,t)}a(l6,"getDropCustomFunctionValidator");function _6(e){let t=Ie.object({project:Ie.string().pattern(Is).custom(Qd.bind(null,!0)).required().messages({"string.pattern.base":Jt.BAD_PROJECT_NAME}),type:Ie.string().valid("helpers","routes").required(),file:Ie.string().custom(Fu).required(),function_content:Ie.string().required()});return Cs.validateBySchema(e,t)}a(_6,"setCustomFunctionValidator");function d6(e){let t=Ie.object({project:Ie.string().pattern(Is).required().messages({"string.pattern.base":Jt.BAD_PROJECT_NAME}),file:Ie.string().custom(Fu).required(),payload:Ie.string().allow("").optional(),encoding:Ie.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Cs.validateBySchema(e,t)}a(d6,"setComponentFileValidator");function f6(e){let t=Ie.object({project:Ie.string().pattern(Is).required().messages({"string.pattern.base":Jt.BAD_PROJECT_NAME}),file:Ie.string().custom(Fu).optional()});return Cs.validateBySchema(e,t)}a(f6,"dropComponentFileValidator");function E6(e){let t=Ie.object({project:Ie.string().required(),file:Ie.string().custom(Fu).required(),encoding:Ie.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Cs.validateBySchema(e,t)}a(E6,"getComponentFileValidator");function h6(e){let t=Ie.object({project:Ie.string().pattern(Is).custom(Qd.bind(null,!1)).required().messages({"string.pattern.base":Jt.BAD_PROJECT_NAME})});return Cs.validateBySchema(e,t)}a(h6,"addComponentValidator");function m6(e){let t=Ie.object({project:Ie.string().pattern(Is).custom(Qd.bind(null,!0)).required().messages({"string.pattern.base":Jt.BAD_PROJECT_NAME})});return Cs.validateBySchema(e,t)}a(m6,"dropCustomFunctionProjectValidator");function p6(e){let t=Ie.object({project:Ie.string().pattern(Is).required().messages({"string.pattern.base":Jt.BAD_PROJECT_NAME}),skip_node_modules:Ie.boolean()});return Cs.validateBySchema(e,t)}a(p6,"packageComponentValidator");function S6(e){let t=Ie.object({project:Ie.string().pattern(Is).required().messages({"string.pattern.base":Jt.BAD_PROJECT_NAME}),payload:Ie.string().optional().messages({"string.pattern.base":Jt.BAD_PACKAGE}),package:Ie.string().optional()});return Cs.validateBySchema(e,t)}a(S6,"deployComponentValidator")});var jd=T((Bfe,nP)=>{"use strict";var zd=require("joi"),Jd=require("path"),XM=require("fs-extra"),{exec:T6}=require("child_process"),g6=require("util"),jM=g6.promisify(T6),Gu=P(),{handleHDBError:Ra,hdb_errors:R6}=re(),{HTTP_STATUS_CODES:Aa}=R6,qu=te(),A6=rt(),Oa=Q();qu.initSync();var xT=qu.get(Gu.CONFIG_PARAMS.COMPONENTSROOT),ZM="npm install --omit=dev --json",O6=`${ZM} --dry-run`;nP.exports={installModules:w6,auditModules:I6,installAllRootModules:b6,uninstallRootModule:N6,linkHarperdb:y6};async function b6(e=!1){await Xd(),await ku(e?"npm install --ignore-scripts":"npm install",qu.get(Gu.CONFIG_PARAMS.ROOTPATH))}a(b6,"installAllRootModules");async function N6(e){await ku(`npm uninstall ${e}`,qu.get(Gu.CONFIG_PARAMS.ROOTPATH))}a(N6,"uninstallRootModule");async function y6(){await Xd(),await ku(`npm link ${Gu.PACKAGE_ROOT}`,qu.get(Gu.CONFIG_PARAMS.ROOTPATH))}a(y6,"linkHarperdb");async function ku(e,t=void 0){let r,n;try{({stdout:r,stderr:n}=await jM(e,{cwd:t}))}catch(s){throw new Error(s.stderr.replace(`
|
|
10
|
+
`,"")}a(CD,"runCommand");async function s3(){try{await v4.access(fS)}catch{return!1}let e=await CD(`${fS} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return B4.eq(t,r3)}a(s3,"checkNATSServerInstalled");async function SS(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await ID.getClusterUser();if(no(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}Un.trace("create nats connection called");let i=await K4({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Mt.get(Ce.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Mt.get(Ce.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Mt.get(Ce.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),Un.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&Un.error("Error with Nats client connection, connection closed",o),DD()}),i}a(SS,"createConnection");function DD(){_r=void 0,eo=void 0,to=void 0,ro=void 0}a(DD,"clearClientCache");async function i3(){_r&&(await _r.drain(),_r=void 0,eo=void 0,to=void 0,ro=void 0)}a(i3,"closeConnection");var _r,ro;async function dd(){return ro||(ro=SS(Mt.get(Ce.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),_r=await ro),_r||ro}a(dd,"getConnection");async function cu(){if(eo)return eo;no(_r)&&await dd();let{domain:e}=uu(Ce.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(no(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return eo=await _r.jetstreamManager({domain:e,timeout:6e4}),eo}a(cu,"getJetStreamManager");async function LD(){if(to)return to;no(_r)&&await dd();let{domain:e}=uu(Ce.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(no(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return to=_r.jetstream({domain:e,timeout:6e4}),to}a(LD,"getJetStream");async function Pn(){let e=_r||await dd(),t=eo||await cu(),r=to||await LD();return{connection:e,jsm:t,js:r}}a(Pn,"getNATSReferences");async function o3(e){let t=Mt.get(Ce.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await ID.getClusterUser(),s=await SS(t,r,n),i=pS(),o=s.subscribe(i),c=[],u,_=(async()=>{for await(let l of o){let d=wD.decode(l.data);d.response_time=Date.now()-u,c.push(d)}})();return u=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 ld.async_set_timeout(e),await o.drain(),await s.close(),await _,c}a(o3,"getServerList");async function TS(e,t){let{jsm:r}=await Pn(),n=Mt.get(Ce.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Mt.get(Ce.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Mt.get(Ce.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:W4.File,retention:Q4.Limits,subjects:t,discard:z4.Old,max_msgs:s,max_bytes:i,max_age:n})}a(TS,"createLocalStream");async function MD(){let{jsm:e}=await Pn(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(MD,"listStreams");async function a3(e){let{jsm:t}=await Pn();await t.streams.delete(e)}a(a3,"deleteLocalStream");async function c3(e){let{connection:t}=await Pn(),r=[],n=pS(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(wD.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(c3,"listRemoteStreams");async function u3(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Pn(),i=OD(),o={durable_name:i,ack_policy:hS.Explicit};t&&(o.deliver_policy=mS.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),u=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let _=[];for await(let l of u){let d=ES(l.data),f={nats_timestamp:l.info.timestampNanos,nats_sequence:l.info.streamSequence,entry:d};if(l.headers&&(f.origin=l.headers.get(qt.MSG_HEADERS.ORIGIN)),_.push(f),l.ack(),l.info.pending===0)break}return await c.delete(),_}a(u3,"viewStream");async function*l3(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Pn(),i=OD(),o={durable_name:i,ack_policy:hS.Explicit};t&&(o.deliver_policy=mS.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),u=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let _ of u){let l=ES(_.data);l[0]||(l=[l]);for(let d of l){let f={nats_timestamp:_.info.timestampNanos,nats_sequence:_.info.streamSequence,entry:d};_.headers&&(f.origin=_.headers.get(qt.MSG_HEADERS.ORIGIN)),yield f}if(_.ack(),_.info.pending===0)break}await c.delete()}a(l3,"viewStreamIterator");async function _3(e,t,r,n){Un.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=UD(n,r);let{js:s}=await Pn(),i=await fd(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:ND.encode(n);try{Un.trace(`publishToStream publishing to subject: ${o}`),e3(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(u){if(u.code&&u.code.toString()==="503")return vD(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(u.code&&u.code.toString()==="503"){Un.trace(`publishToStream creating stream: ${t}`);let l=o.split(".");l[2]="*",await TS(t,[o]),await s.publish(o,c,{headers:r})}else throw u}});throw u}}a(_3,"publishToStream");function UD(e,t){t===void 0&&(t=X4());let r=Mt.get(Ce.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(qt.MSG_HEADERS.ORIGIN)&&r&&t.append(qt.MSG_HEADERS.ORIGIN,r),t}a(UD,"addNatsMsgHeader");function uu(e){e=e.toLowerCase();let t=au.join(Mt.get(Ce.CONFIG_PARAMS.ROOTPATH),t3);if(e===Ce.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return no(dS)&&(dS={port:iu.getConfigFromFile(Ce.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:iu.getConfigFromFile(Ce.CONFIG_PARAMS.CLUSTERING_NODENAME)+qt.SERVER_SUFFIX.HUB,config_file:qt.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:au.join(t,qt.PID_FILES.HUB),hdb_nats_path:t}),dS;if(e===Ce.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return no(_S)&&(_S={port:iu.getConfigFromFile(Ce.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:iu.getConfigFromFile(Ce.CONFIG_PARAMS.CLUSTERING_NODENAME)+qt.SERVER_SUFFIX.LEAF,config_file:qt.NATS_CONFIG_FILES.LEAF_SERVER,domain:iu.getConfigFromFile(Ce.CONFIG_PARAMS.CLUSTERING_NODENAME)+qt.SERVER_SUFFIX.LEAF,pid_file_path:au.join(t,qt.PID_FILES.LEAF),hdb_nats_path:t}),_S;Un.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(uu,"getServerConfig");async function PD(e,t,r,n){try{await e.consumers.add(t,{ack_policy:hS.Explicit,durable_name:r,deliver_policy:mS.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(PD,"createConsumer");async function d3(e,t,r){await e.consumers.delete(t,r)}a(d3,"removeConsumer");function f3(e){return e.split(".")[1]}a(f3,"extractServerName");async function E3(e,t,r=6e4,n=pS()){if(!ld.isObject(t))throw new Error("data param must be an object");let s=ND.encode(t),{connection:i}=await Pn(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return ES(c.data)}a(E3,"request");function gS(e){return new Promise(async(t,r)=>{let n=F4(fS,["--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(gS,"reloadNATS");async function h3(){let{pid_file_path:e}=uu(Ce.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await gS(e)}a(h3,"reloadNATSHub");async function m3(){let{pid_file_path:e}=uu(Ce.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await gS(e)}a(m3,"reloadNATSLeaf");function p3(e,t,r){let n;switch(e.code){case AD.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case AD.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(p3,"requestErrorHandler");async function S3(e,t){let r=t+qt.SERVER_SUFFIX.LEAF,{connection:n}=await Pn(),{jsm:s}=await N3(r),{schema:i,table:o}=e,c=_d.createNatsTableStreamName(i,o),u=e.start_time?e.start_time:new Date(Date.now()).toISOString();await vD(async()=>{if(e.subscribe===!0)await PD(s,c,n.info.server_name,u);else try{await d3(s,c,n.info.server_name)}catch(_){Un.trace(_)}})}a(S3,"updateRemoteConsumer");async function T3(e,t,r,n){let s=_d.createNatsTableStreamName(e,t),i=r+qt.SERVER_SUFFIX.LEAF,o={type:Ce.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!yD&&$4()<Mt.get(Ce.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=lS();await c(o)}await k4(o),n==="stop"&&await ld.async_set_timeout(1e3)}a(T3,"updateConsumerIterator");function vD(e){return q4.writeTransaction(Ce.SYSTEM_SCHEMA_NAME,Ce.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(vD,"exclusiveLock");async function BD(e,t){let r=_d.createNatsTableStreamName(e,t),n=await fd(),s=O3(e,t,n);await TS(r,[s])}a(BD,"createLocalTableStream");async function g3(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await BD(n,s)}}a(g3,"createTableStreams");async function HD(e,t){if(Mt.get(Ce.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let r=_d.createNatsTableStreamName(e,t),{jsm:n}=await Pn();await n.streams.purge(r)}catch(r){if(r.message==="stream not found")Un.warn(r);else throw r}}a(HD,"purgeTableStream");async function R3(e,t){if(Mt.get(Ce.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await HD(e,t[r])}a(R3,"purgeSchemaTableStreams");async function A3(e){return(await cu()).streams.info(e)}a(A3,"getStreamInfo");function O3(e,t,r){return`${qt.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(O3,"createSubjectName");async function fd(){if(ou)return ou;if(ou=(await cu())?.nc?.info?.server_name,ou===void 0)throw new Error("Unable to get jetstream manager server name");return ou}a(fd,"getJsmServerName");async function b3(){let e=await cu(),t=await fd(),r=await MD();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=y3(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let _=i.split(".");_[_.length-1]=t;let l=_.join(".");Un.trace(`Updating stream subject name from: ${i} to: ${l}`),s.subjects[0]=l,await e.streams.update(s.name,s)}}a(b3,"updateLocalStreams");function y3(e){let{config:t}=e,r=!1,n=Mt.get(Ce.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Mt.get(Ce.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Mt.get(Ce.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(y3,"updateStreamLimits");async function N3(e){let t,r;try{t=await _r.jetstream({domain:e,timeout:6e4}),r=await _r.jetstreamManager({domain:e,timeout:6e4})}catch(n){throw Un.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(N3,"connectToRemoteJS")});var pd=g((M_e,kD)=>{"use strict";var sa=l_(),ia=WC(),I3=K(),w3=require("uuid").v4,L_e=require("clone"),hd=Ts(),oa=U(),C3=require("util"),ii=yn(),{handleHDBError:dr,hdb_errors:D3}=ne(),{HDB_ERROR_MSGS:Ed,HTTP_STATUS_CODES:fr}=D3,{SchemaEventMsg:md}=wn(),GD=bt(),{getDatabases:L3}=(Ae(),se(Fe)),{transformReq:aa}=z();kD.exports={createSchema:M3,createSchemaStructure:FD,createTable:U3,createTableStructure:qD,createAttribute:x3,dropSchema:P3,dropTable:v3,dropAttribute:B3,getBackup:G3};async function M3(e){let t=await FD(e);return hd.signalSchemaChange(new md(process.pid,e.operation,e.schema)),t}a(M3,"createSchema");async function FD(e){let t=sa.schema_object(e);if(t)throw dr(t,t.message,fr.BAD_REQUEST,void 0,void 0,!0);if(aa(e),!await ia.checkSchemaExists(e.schema))throw dr(new Error,Ed.SCHEMA_EXISTS_ERR(e.schema),fr.BAD_REQUEST,oa.LOG_LEVELS.ERROR,Ed.SCHEMA_EXISTS_ERR(e.schema),!0);return await ii.createSchema(e),`database '${e.schema}' successfully created`}a(FD,"createSchemaStructure");async function U3(e){return aa(e),e.hash_attribute=e.primary_key??e.hash_attribute,await qD(e)}a(U3,"createTable");async function qD(e){let t=sa.create_table_object(e);if(t)throw dr(t,t.message,fr.BAD_REQUEST,void 0,void 0,!0);if(sa.validateTableResidence(e.residence),!await ia.checkSchemaTableExists(e.schema,e.table))throw dr(new Error,Ed.TABLE_EXISTS_ERR(e.schema,e.table),fr.BAD_REQUEST,oa.LOG_LEVELS.ERROR,Ed.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:w3(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await ii.createTable(n,e);else throw dr(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",fr.BAD_REQUEST);else await ii.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(qD,"createTableStructure");async function P3(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=sa.schema_object(e),n=t??r;if(n)throw dr(n,n.message,fr.BAD_REQUEST,void 0,void 0,!0);aa(e);let s=await ia.checkSchemaExists(e.schema);if(s)throw dr(new Error,s,fr.NOT_FOUND,oa.LOG_LEVELS.ERROR,s,!0);let i=await ia.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);return await ii.dropSchema(e),hd.signalSchemaChange(new md(process.pid,e.operation,e.schema)),await GD.purgeSchemaTableStreams(e.schema,o),`successfully deleted '${e.schema}'`}a(P3,"dropSchema");async function v3(e){let t=sa.table_object(e);if(t)throw dr(t,t.message,fr.BAD_REQUEST,void 0,void 0,!0);aa(e);let r=await ia.checkSchemaTableExists(e.schema,e.table);if(r)throw dr(new Error,r,fr.NOT_FOUND,oa.LOG_LEVELS.ERROR,r,!0);return await ii.dropTable(e),await GD.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(v3,"dropTable");async function B3(e){let t=sa.attribute_object(e);if(t)throw dr(t,t.message,fr.BAD_REQUEST,void 0,void 0,!0);aa(e);let r=await ia.checkSchemaTableExists(e.schema,e.table);if(r)throw dr(new Error,r,fr.NOT_FOUND,oa.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw dr(new Error,"You cannot drop a hash attribute",fr.BAD_REQUEST,void 0,void 0,!0);if(oa.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw dr(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,fr.BAD_REQUEST,void 0,void 0,!0);try{return await ii.dropAttribute(e),H3(e),hd.signalSchemaChange(new md(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw I3.error(`Got an error deleting attribute ${C3.inspect(e)}.`),n}}a(B3,"dropAttribute");function H3(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(H3,"dropAttributeFromGlobal");async function x3(e){aa(e);let t=L3()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw dr(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,fr.BAD_REQUEST,void 0,void 0,!0);return await ii.createAttribute(e),hd.signalSchemaChange(new md(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(x3,"createAttribute");function G3(e){return ii.getBackup(e)}a(G3,"getBackup")});var $D=g((P_e,VD)=>{"use strict";var{OPERATIONS_ENUM:F3}=U(),RS=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=F3.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};VD.exports=RS});var AS=g((H_e,zD)=>{"use strict";var q3=yn(),B_e=$D(),Sd=z(),Td=U(),k3=re(),{handleHDBError:YD,hdb_errors:V3}=ne(),{HDB_ERROR_MSGS:KD,HTTP_STATUS_CODES:WD}=V3,$3=Object.values(Td.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),QD="To use this operation audit log must be enabled in harperdb-config.yaml";zD.exports=Y3;async function Y3(e){if(Sd.isEmpty(e.schema))throw new Error(KD.SCHEMA_REQUIRED_ERR);if(Sd.isEmpty(e.table))throw new Error(KD.TABLE_REQUIRED_ERR);if(!k3.get(Td.CONFIG_PARAMS.LOGGING_AUDITLOG))throw YD(new Error,QD,WD.BAD_REQUEST,Td.LOG_LEVELS.ERROR,QD,!0);let t=Sd.checkSchemaTableExist(e.schema,e.table);if(t)throw YD(new Error,t,WD.NOT_FOUND,Td.LOG_LEVELS.ERROR,t,!0);if(!Sd.isEmpty(e.search_type)&&$3.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await q3.readAuditLog(e)}a(Y3,"readAuditLog")});var XD=g((G_e,JD)=>{"use strict";var{OPERATIONS_ENUM:K3}=U(),OS=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=K3.GET_BACKUP,this.schema=t,this.table=r}};JD.exports=OS});var eL=g((V_e,ZD)=>{"use strict";var W3=yn(),q_e=XD(),bS=z(),Q3=U(),k_e=re(),{handleHDBError:z3,hdb_errors:J3}=ne(),{HDB_ERROR_MSGS:jD,HTTP_STATUS_CODES:X3}=J3;ZD.exports=j3;async function j3(e){if(bS.isEmpty(e.schema))throw new Error(jD.SCHEMA_REQUIRED_ERR);if(bS.isEmpty(e.table))throw new Error(jD.TABLE_REQUIRED_ERR);let t=bS.checkSchemaTableExist(e.schema,e.table);if(t)throw z3(new Error,t,X3.NOT_FOUND,Q3.LOG_LEVELS.ERROR,t,!0);return await W3.getBackup(read_audit_log_object)}a(j3,"getBackup")});var oL=g((Y_e,iL)=>{var oi=require("validate.js"),rL=tt(),ca=U(),{handleHDBError:Z3,hdb_errors:eX}=ne(),{HDB_ERROR_MSGS:ut,HTTP_STATUS_CODES:tX}=eX,yS=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),rX={STRUCTURE_USER:"structure_user"},tL=Object.values(ca.ROLE_TYPES_ENUM),nX="attribute_permissions",sX="attribute_name",{PERMS_CRUD_ENUM:ua}=ca,iX=[nX,...Object.values(ua)],nL=[ua.READ,ua.INSERT,ua.UPDATE],oX=[sX,...nL];function aX(e){let t=yS();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,sL(e,t)}a(aX,"addRoleValidation");function cX(e){let t=yS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,sL(e,t)}a(cX,"alterRoleValidation");function uX(e){let t=yS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,rL.validateObject(e,t)}a(uX,"dropRoleValidation");var lX=["operation","role","id","permission","hdb_user","hdb_auth_header"];function sL(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)lX.includes(n[o])||s.push(n[o]);s.length>0&&Et(ut.INVALID_ROLE_JSON_KEYS(s),r);let i=rL.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{Et(o,r)}),e.permission){let o=_X(e);o&&Et(o,r),tL.forEach(c=>{e.permission[c]&&!oi.isBoolean(e.permission[c])&&Et(ut.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(tL.indexOf(o)<0){if(o===rX.STRUCTURE_USER){let u=e.permission[o];if(typeof u=="boolean")continue;if(Array.isArray(u)){for(let _=0,l=u.length;_<l;_++){let d=u[_];global.hdb_schema[d]||Et(ut.SCHEMA_NOT_FOUND(d),r)}continue}Et(ut.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){Et(ut.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let u in c.tables){let _=c.tables[u];if(!u||!global.hdb_schema[o][u]){Et(ut.TABLE_NOT_FOUND(o,u),r);continue}if(Object.keys(_).forEach(l=>{iX.includes(l)||Et(ut.INVALID_PERM_KEY(l),r,o,u)}),Object.values(ua).forEach(l=>{oi.isDefined(_[l])?oi.isBoolean(_[l])||Et(ut.TABLE_PERM_NOT_BOOLEAN(l),r,o,u):Et(ut.TABLE_PERM_MISSING(l),r,o,u)}),oi.isDefined(_.attribute_permissions)){if(!oi.isArray(_.attribute_permissions)){Et(ut.ATTR_PERMS_NOT_ARRAY,r,o,u);continue}}else{Et(ut.ATTR_PERMS_ARRAY_MISSING,r,o,u);continue}if(_.attribute_permissions){let l=global.hdb_schema[o][u].attributes.map(({attribute:f})=>f),d={read:!1,insert:!1,update:!1};for(let f in _.attribute_permissions){let E=_.attribute_permissions[f];if(Object.keys(E).forEach(p=>{!oX.includes(p)&&p!==ua.DELETE&&Et(ut.INVALID_ATTR_PERM_KEY(p),r,o,u)}),!oi.isDefined(E.attribute_name)){Et(ut.ATTR_PERM_MISSING_NAME,r,o,u);continue}let h=E.attribute_name;if(!l.includes(h)){Et(ut.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,u);continue}nL.forEach(p=>{oi.isDefined(E[p])?oi.isBoolean(E[p])||Et(ut.ATTR_PERM_NOT_BOOLEAN(p,h),r,o,u):Et(ut.ATTR_PERM_MISSING(p,h),r,o,u)}),!d.read&&E.read===!0&&(d.read=!0),!d.insert&&E.insert===!0&&(d.insert=!0),!d.update&&E.update===!0&&(d.update=!0)}if(_.read===!1&&d.read===!0||_.insert===!1&&d.insert===!0||_.update===!1&&d.update===!0){let f=`${o}.${u}`;Et(ut.MISMATCHED_TABLE_ATTR_PERMS(f),r,o,u)}}}}return dX(r)}a(sL,"customValidate");iL.exports={addRoleValidation:aX,alterRoleValidation:cX,dropRoleValidation:uX};function _X(e){let{operation:t,permission:r}=e;if(t===ca.OPERATIONS_ENUM.ADD_ROLE||t===ca.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 ut.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?ca.ROLE_TYPES_ENUM.SUPER_USER:ca.ROLE_TYPES_ENUM.CLUSTER_USER;return ut.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(_X,"validateNoSUPerms");function dX(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:ut.ROLE_PERMS_ERROR,...e};return Z3(new Error,n,tX.BAD_REQUEST)}else return null}a(dX,"generateRolePermResponse");function Et(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(Et,"addPermError")});var LS=g((W_e,lL)=>{"use strict";var aL=rn(),cL=Dr(),fX=qi(),IS=oL(),wS=Ts(),EX=require("uuid").v4,hX=require("util"),gd=U(),mX=z(),CS=cL.searchByValue,pX=cL.searchByHash,SX=hX.promisify(fX.delete),TX=jn(),gX=Zo(),{hdb_errors:RX,handleHDBError:so}=ne(),{HDB_ERROR_MSGS:uL,HTTP_STATUS_CODES:lu}=RX,{UserEventMsg:DS}=wn();lL.exports={addRole:AX,alterRole:OX,dropRole:bX,listRoles:yX};function NS(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(NS,"scrubRoleDetails");async function AX(e){let t=IS.addRoleValidation(e);if(t)throw t;e=NS(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 CS(r)||[])}catch(i){throw so(i)}if(n&&n.length>0)throw so(new Error,uL.ROLE_ALREADY_EXISTS(e.role),lu.CONFLICT,void 0,void 0,!0);e.id||(e.id=EX());let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await aL.insert(s),wS.signalUserChange(new DS(process.pid)),e=NS(e),e}a(AX,"addRole");async function OX(e){let t=IS.alterRoleValidation(e);if(t)throw t;e=NS(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await aL.update(r)}catch(s){throw so(s)}if(n&&n?.message==="updated 0 of 1 records")throw so(new Error,"Invalid role id",lu.BAD_REQUEST,void 0,void 0,!0);return await wS.signalUserChange(new DS(process.pid)),e}a(OX,"alterRole");async function bX(e){let t=IS.dropRoleValidation(e);if(t)throw so(new Error,t,lu.BAD_REQUEST,void 0,void 0,!0);let r=new gX(gd.SYSTEM_SCHEMA_NAME,gd.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await pX(r));if(n.length===0)throw so(new Error,uL.ROLE_NOT_FOUND,lu.NOT_FOUND,void 0,void 0,!0);let s=new TX(gd.SYSTEM_SCHEMA_NAME,gd.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await CS(s)),o=!1;if(mX.isEmptyOrZeroLength(i)===!1){for(let u=0;u<i.length;u++)if(i[u].active===!0){o=!0;break}}if(o===!0)throw so(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,lu.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await SX(c),wS.signalUserChange(new DS(process.pid)),`${n[0].role} successfully deleted`}a(bX,"dropRole");async function yX(){return CS({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(yX,"listRoles")});var EL=g((z_e,fL)=>{"use strict";var NX=re(),ai=require("joi"),IX=tt(),_L=require("moment"),wX=require("fs-extra"),MS=require("path"),CX=require("lodash"),_u=U(),{LOG_LEVELS:io}=U(),DX="YYYY-MM-DD hh:mm:ss",LX=MS.resolve(__dirname,"../logs");fL.exports=function(e){return IX.validateBySchema(e,MX)};var MX=ai.object({from:ai.custom(dL),until:ai.custom(dL),level:ai.valid(io.NOTIFY,io.FATAL,io.ERROR,io.WARN,io.INFO,io.DEBUG,io.TRACE),order:ai.valid("asc","desc"),limit:ai.number().min(1),start:ai.number().min(0),log_name:ai.custom(UX)});function dL(e,t){if(_L(e,_L.ISO_8601).format(DX)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(dL,"validateDatetime");function UX(e,t){if(CX.invert(_u.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=NX.get(_u.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?_u.LOG_NAMES.HDB:e,i=s===_u.LOG_NAMES.INSTALL?MS.join(LX,_u.LOG_NAMES.INSTALL):MS.join(n,s);return wX.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(UX,"validateReadLogPath")});var PS=g((X_e,mL)=>{"use strict";var Rd=U(),PX=K(),vX=re(),BX=EL(),US=require("path"),hL=require("fs-extra"),{once:HX}=require("events"),{handleHDBError:xX,hdb_errors:GX}=ne(),{PACKAGE_ROOT:FX}=U(),qX=US.join(FX,"logs"),kX=1e3,VX=200;mL.exports=$X;async function $X(e){let t=BX(e);if(t)throw xX(t,t.message,GX.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=vX.get(Rd.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?Rd.LOG_NAMES.HDB:e.log_name,s=n===Rd.LOG_NAMES.INSTALL?US.join(qX,Rd.LOG_NAMES.INSTALL):US.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,u=c?new Date(e.from):void 0,_=e.until!==void 0,l=_?new Date(e.until):void 0,d=e.limit===void 0?kX:e.limit,f=e.order===void 0?void 0:e.order,E=e.start===void 0?0:e.start,h=E+d,p=0;f==="desc"&&!u&&!l&&(p=Math.max(hL.statSync(s).size-(h+5)*VX,0));let S=hL.createReadStream(s,{start:p});S.on("error",P=>{PX.error(P)});let T=0,b=[],R="",L;S.on("data",P=>{let k=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;P=R+P;let B=0,J;for(;(J=k.exec(P))&&!S.destroyed;){L&&(L.message=P.slice(B,J.index),H(L));let[Q,X,Te]=J,ce=Te.split("] ["),de=ce[0],Le=ce[1];ce.splice(0,2),L={timestamp:X,thread:de,level:Le,tags:ce,message:""},B=J.index+Q.length}R=P.slice(B)}),S.on("end",P=>{S.destroyed||L&&(L.message=R.trim(),H(L))}),S.resume();function H(P){let k,B,J;switch(!0){case(i&&c&&_):k=new Date(P.timestamp),B=new Date(u),J=new Date(l),P.level===o&&k>=B&&k<=J&&T<E?T++:P.level===o&&k>=B&&k<=J&&(ci(P,f,b),T++,T===h&&S.destroy());break;case(i&&c):k=new Date(P.timestamp),B=new Date(u),P.level===o&&k>=B&&T<E?T++:P.level===o&&k>=B&&(ci(P,f,b),T++,T===h&&S.destroy());break;case(i&&_):k=new Date(P.timestamp),J=new Date(l),P.level===o&&k<=J&&T<E?T++:P.level===o&&k<=J&&(ci(P,f,b),T++,T===h&&S.destroy());break;case(c&&_):k=new Date(P.timestamp),B=new Date(u),J=new Date(l),k>=B&&k<=J&&T<E?T++:k>=B&&k<=J&&(ci(P,f,b),T++,T===h&&S.destroy());break;case i:P.level===o&&T<E?T++:P.level===o&&(ci(P,f,b),T++,T===h&&S.destroy());break;case c:k=new Date(P.timestamp),B=new Date(u),k>=B&&T<E?T++:k>=B&&T>=E&&(ci(P,f,b),T++,T===h&&S.destroy());break;case _:k=new Date(P.timestamp),J=new Date(l),k<=J&&T<E?T++:k<=J&&T>=E&&(ci(P,f,b),T++,T===h&&S.destroy());break;default:T<E?T++:(ci(P,f,b),T++,T===h&&S.destroy())}}return a(H,"onLogMessage"),await HX(S,"close"),b}a($X,"readLog");function ci(e,t,r){t==="desc"?YX(e,r):t==="asc"?KX(e,r):r.push(e)}a(ci,"pushLineToResult");function YX(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(YX,"insertDescending");function KX(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(KX,"insertAscending")});var Ad=g((rde,gL)=>{"use strict";var vS=require("joi"),{string:du,boolean:pL,date:WX}=vS.types(),QX=tt(),{validateSchemaExists:Z_e,validateTableExists:ede,validateSchemaName:tde}=Wn(),zX=U(),JX=rt(),SL=re();SL.initSync();var XX=du.invalid(SL.get(zX.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(JX.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).required(),TL={operation:du.valid("add_node","update_node","set_node_replication"),node_name:XX,subscriptions:vS.array().items({table:du.optional(),schema:du.optional(),database:du.optional(),subscribe:pL.required(),publish:pL.required().custom(ZX),start_time:WX.iso()}).min(1).required()};function jX(e){return QX.validateBySchema(e,vS.object(TL))}a(jX,"addUpdateNodeValidator");function ZX(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(ZX,"checkForFalsy");gL.exports={addUpdateNodeValidator:jX,validation_schema:TL}});var AL=g((sde,RL)=>{var ej=tt(),tj={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};RL.exports=function(e){return ej.validateObject(e,tj)}});var HS=g((ide,OL)=>{"use strict";var rj=U().OPERATIONS_ENUM,BS=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=rj.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};OL.exports=BS});var yL=g((ade,bL)=>{"use strict";var nj={OPERATION:"operation",REFRESH:"refresh"},xS=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},GS=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};bL.exports={JWTTokens:xS,TOKEN_TYPE_ENUM:nj,JWTRSAKeys:GS}});var hu=g((ude,CL)=>{"use strict";var Eu=require("jsonwebtoken"),FS=require("fs-extra"),qS=z(),on=U(),{handleHDBError:Er,hdb_errors:sj}=ne(),{HTTP_STATUS_CODES:hr,AUTHENTICATION_ERROR_MSGS:mr}=sj,fu=K(),NL=N_(),$S=nn(),ij=rn().update,oj=HS(),aj=Ts(),{UserEventMsg:cj}=wn(),ui=re();ui.initSync();var kS=require("path"),{JWTTokens:uj,JWTRSAKeys:lj,TOKEN_TYPE_ENUM:Od}=yL(),_j=ui.get(on.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?ui.get(on.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",dj=ui.get(on.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?ui.get(on.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",bd="RS256",VS;CL.exports={createTokens:fj,validateOperationToken:hj,refreshOperationToken:Ej,validateRefreshToken:wL};async function fj(e){if(qS.isEmpty(e)||typeof e!="object")throw Er(new Error,mr.INVALID_AUTH_OBJECT,hr.BAD_REQUEST,void 0,void 0,!0);if(qS.isEmpty(e.username))throw Er(new Error,mr.USERNAME_REQUIRED,hr.BAD_REQUEST,void 0,void 0,!0);if(qS.isEmpty(e.password))throw Er(new Error,mr.PASSWORD_REQUIRED,hr.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await $S.findAndValidateUser(e.username,e.password),!t)throw Er(new Error,mr.INVALID_CREDENTIALS,hr.UNAUTHORIZED,void 0,void 0,!0)}catch(f){throw fu.error(f),Er(new Error,mr.INVALID_CREDENTIALS,hr.UNAUTHORIZED,void 0,void 0,!0)}let r=await yd(),n=!1,s=!1;t.role&&t.role.permission&&(n=t.role.permission.super_user===!0,s=t.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s},o=await IL(i,r.private_key,r.passphrase),c=await Eu.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:dj,algorithm:bd,subject:Od.REFRESH}),u=NL.hash(c),_=new oj(on.SYSTEM_SCHEMA_NAME,on.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]),l,d;try{l=await ij(_)}catch(f){fu.error(f),d=f}if(d!==void 0||l.skipped_hashes.length>0)throw Er(new Error,mr.REFRESH_TOKEN_SAVE_FAILED,hr.INTERNAL_SERVER_ERROR);return aj.signalUserChange(new cj(process.pid)),new uj(o,c)}a(fj,"createTokens");async function IL(e,t,r){return await Eu.sign(e,{key:t,passphrase:r},{expiresIn:_j,algorithm:bd,subject:Od.OPERATION})}a(IL,"signOperationToken");async function yd(){if(VS===void 0)try{let e=kS.join(ui.getHdbBasePath(),on.LICENSE_KEY_DIR_NAME,on.JWT_ENUM.JWT_PASSPHRASE_NAME),t=kS.join(ui.getHdbBasePath(),on.LICENSE_KEY_DIR_NAME,on.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=kS.join(ui.getHdbBasePath(),on.LICENSE_KEY_DIR_NAME,on.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await FS.readFile(e)).toString(),s=(await FS.readFile(t)).toString(),i=(await FS.readFile(r)).toString();VS=new lj(i,s,n)}catch(e){throw fu.error(e),Er(new Error,mr.NO_ENCRYPTION_KEYS,hr.INTERNAL_SERVER_ERROR)}return VS}a(yd,"getJWTRSAKeys");async function Ej(e){if(!e)throw Er(new Error,mr.INVALID_BODY,hr.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw Er(new Error,mr.REFRESH_TOKEN_REQUIRED,hr.BAD_REQUEST,void 0,void 0,!0);await wL(e.refresh_token);let t=await yd(),r=await Eu.decode(e.refresh_token);return{operation_token:await IL({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(Ej,"refreshOperationToken");async function hj(e){try{let t=await yd(),r=await Eu.verify(e,t.public_key,{algorithms:bd,subject:Od.OPERATION});return await $S.findAndValidateUser(r.username,void 0,!1)}catch(t){throw fu.warn(t),t.name&&t.name==="TokenExpiredError"?Er(new Error,mr.TOKEN_EXPIRED,hr.FORBIDDEN):Er(new Error,mr.INVALID_TOKEN,hr.UNAUTHORIZED)}}a(hj,"validateOperationToken");async function wL(e){let t;try{let r=await yd(),n=await Eu.verify(e,r.public_key,{algorithms:bd,subject:Od.REFRESH});t=await $S.findAndValidateUser(n.username,void 0,!1)}catch(r){throw fu.warn(r),r.name&&r.name==="TokenExpiredError"?Er(new Error,mr.TOKEN_EXPIRED,hr.FORBIDDEN):Er(new Error,mr.INVALID_TOKEN,hr.UNAUTHORIZED)}if(!NL.validate(t.refresh_token,e))throw Er(new Error,mr.INVALID_TOKEN,hr.UNAUTHORIZED);return t}a(wL,"validateRefreshToken")});var YS=g((dde,ML)=>{"use strict";var mj=AL(),la=require("passport"),pj=require("passport-local").Strategy,Sj=require("passport-http").BasicStrategy,Tj=require("util"),gj=nn(),LL=Tj.callbackify(gj.findAndValidateUser),_de=Nr(),Rj=U(),DL=hu();la.use(new pj(function(e,t,r){LL(e,t,r)}));la.use(new Sj(function(e,t,r){LL(e,t,r)}));la.serializeUser(function(e,t){t(null,e)});la.deserializeUser(function(e,t){t(null,e)});function Aj(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":la.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===Rj.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?DL.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):DL.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:la.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(Aj,"authorize");function Oj(e,t){let r=mj(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(Oj,"checkPermissions");ML.exports={authorize:Aj,checkPermissions:Oj}});var _a=g((Ede,UL)=>{"use strict";var KS=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},WS=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};UL.exports={Node:KS,NodeSubscription:WS}});var vL=g((mde,PL)=>{"use strict";var bj=U().OPERATIONS_ENUM,QS=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=bj.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};PL.exports=QS});var mu=g((Sde,BL)=>{"use strict";var zS=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},JS=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)}};BL.exports={RemotePayloadObject:zS,RemotePayloadSubscription:JS}});var xL=g((gde,HL)=>{"use strict";var XS=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}};HL.exports=XS});var qL=g((yde,FL)=>{"use strict";var yj=xL(),Ade=_t(),GL=Ye(),Nj=K(),{getSchemaPath:Ode,getTransactionAuditStorePath:bde}=Qe(),{getDatabases:Ij}=(Ae(),se(Fe));FL.exports=wj;async function wj(e){let t=new yj;try{let r=Ij()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats(),i=await GL.environmentDataSize(schema_path,e.name),o=await GL.environmentDataSize(txn_path,e.name);t.schema=e.schema,t.table=e.name,t.table_size=i,t.record_count=n.entryCount,t.transaction_log_size=o,t.transaction_log_record_count=s.entryCount}catch(r){Nj.warn(`unable to stat table dbi due to ${r}`)}return t}a(wj,"lmdbGetTableSize")});var VL=g((Ide,kL)=>{"use strict";var jS=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}};kL.exports=jS});var da=g((Mde,QL)=>{"use strict";var Cj=require("fs-extra"),Dj=require("path"),Jt=require("systeminformation"),li=K(),$L=bt(),Cde=rt(),Id=U(),Lj=qL(),WL=Bi(),{getThreadInfo:YL}=Ze(),cT=re();cT.initSync();var Mj=VL(),{openEnvironment:Dde}=Ye(),{getSchemaPath:Lde}=Qe(),{database:Uj}=(Ae(),se(Fe)),Nd;QL.exports={getHDBProcessInfo:rT,getNetworkInfo:sT,getDiskInfo:nT,getMemoryInfo:tT,getCPUInfo:eT,getTimeInfo:ZS,getSystemInformation:iT,systemInformation:Pj,getTableSize:oT,getMetrics:aT};function ZS(){return Jt.time()}a(ZS,"getTimeInfo");async function eT(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:u,cache:_,...l}=await Jt.cpu();l.cpu_speed=await Jt.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:f,raw_currentload_irq:E,raw_currentload_nice:h,raw_currentload_system:p,raw_currentload_user:S,cpus:T,...b}=await Jt.currentLoad();return b.cpus=[],T.forEach(R=>{let{raw_load:L,raw_load_idle:H,raw_load_irq:P,raw_load_nice:k,raw_load_system:B,raw_load_user:J,...Q}=R;b.cpus.push(Q)}),l.current_load=b,l}catch(e){return li.error(`error in getCPUInfo: ${e}`),{}}}a(eT,"getCPUInfo");async function tT(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Jt.mem();return Object.assign(s,process.memoryUsage())}catch(e){return li.error(`error in getMemoryInfo: ${e}`),{}}}a(tT,"getMemoryInfo");async function rT(){let e={core:[],clustering:[]};try{let t=await Jt.processes(),r;try{r=Number.parseInt(await Cj.readFile(Dj.join(cT.get(Id.CONFIG_PARAMS.ROOTPATH),Id.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Id.NODE_ERROR_CODES.ENOENT)li.error("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB");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 li.error(`error in getHDBProcessInfo: ${t}`),e}}a(rT,"getHDBProcessInfo");async function nT(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Jt.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:u,..._}=await Jt.fsStats();return e.read_write=_,e.size=await Jt.fsSize(),e}catch(t){return li.error(`error in getDiskInfo: ${t}`),e}}a(nT,"getDiskInfo");async function sT(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await Jt.networkInterfaceDefault(),e.latency=await Jt.inetChecksite("google.com"),(await Jt.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:u,ieee8021xAuth:_,ieee8021xState:l,carrier_changes:d,...f}=n;e.interfaces.push(f)}),(await Jt.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)}),e}catch(t){return li.error(`error in getNetworkInfo: ${t}`),e}}a(sT,"getNetworkInfo");async function iT(){if(Nd!==void 0)return Nd;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Jt.osInfo();e=c;let u=await Jt.versions("node, npm");return e.node_version=u.node,e.npm_version=u.npm,Nd=e,Nd}catch(t){return li.error(`error in getSystemInformation: ${t}`),e}}a(iT,"getSystemInformation");async function oT(){let e=[],t=await WL.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await Lj(n));return e}a(oT,"getTableSize");async function aT(){let e=await WL.describeAll(),t={};for(let r in e){let n=t[r]={};for(let s in e[r])try{let i=Uj({database:r,table:s}),o=i.getStats();o.readers=i.readerList().split(/\n\s+/).slice(1).map(c=>{let[u,_,l]=c.trim().split(" ");return{pid:u,thread:_,txnid:l}}),n[s]=o}catch(i){li.notify(`Error getting stats for table ${s}: ${i}`)}}return t}a(aT,"getMetrics");async function KL(){if(cT.get(Id.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await $L.getNATSReferences(),t=await $L.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(KL,"getNatsStreamInfo");async function Pj(e){let t=new Mj;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await iT(),t.time=ZS(),t.cpu=await eT(),t.memory=await tT(),t.disk=await nT(),t.network=await sT(),t.harperdb_processes=await rT(),t.table_size=await oT(),t.metrics=await aT(),t.threads=await YL(),t.replication=await KL(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await iT();break;case"time":t.time=ZS();break;case"cpu":t.cpu=await eT();break;case"memory":t.memory=await tT();break;case"disk":t.disk=await nT();break;case"network":t.network=await sT();break;case"harperdb_processes":t.harperdb_processes=await rT();break;case"table_size":t.table_size=await oT();break;case"database_metrics":case"metrics":t.metrics=await aT();break;case"threads":t.threads=await YL();break;case"replication":t.replication=await KL();break;default:break}return t}a(Pj,"systemInformation")});var Cd=g((Pde,zL)=>{"use strict";zL.exports={version:vj,printVersion:Bj};var wd=Xc();function vj(){if(wd)return wd.version}a(vj,"version");function Bj(){wd&&console.log(`HarperDB Version ${wd.version}`)}a(Bj,"printVersion")});var bs=g((xde,ZL)=>{"use strict";var Hj=rn(),uT=z(),xj=require("util"),oo=U(),JL=re();JL.initSync();var Gj=YS(),XL=Dr(),{Node:Bde,NodeSubscription:Hde}=_a(),Fj=Zo(),qj=vL(),{RemotePayloadObject:kj,RemotePayloadSubscription:Vj}=mu(),{handleHDBError:$j,hdb_errors:Yj}=ne(),{HTTP_STATUS_CODES:Kj,HDB_ERROR_MSGS:Wj}=Yj,Qj=jn(),zj=da(),Jj=Cd(),{getDatabases:Xj}=(Ae(),se(Fe)),jj=xj.promisify(Gj.authorize),Zj=XL.searchByHash,eZ=XL.searchByValue;ZL.exports={authHeaderToUser:tZ,isEmpty:rZ,getNodeRecord:nZ,upsertNodeRecord:sZ,buildNodePayloads:iZ,checkClusteringEnabled:oZ,getAllNodeRecords:aZ,getSystemInfo:cZ,reverseSubscription:jL};async function tZ(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await jj(t,null),e}a(tZ,"authHeaderToUser");function rZ(e){return e==null}a(rZ,"isEmpty");async function nZ(e){let t=new Fj(oo.SYSTEM_SCHEMA_NAME,oo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Zj(t)}a(nZ,"getNodeRecord");async function sZ(e){let t=new qj(oo.SYSTEM_SCHEMA_NAME,oo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return Hj.upsert(t)}a(sZ,"upsertNodeRecord");function jL(e){if(uT.isEmpty(e.subscribe)||uT.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(jL,"reverseSubscription");function iZ(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:u,table:_}=c,l=uT.getTableHashAttribute(u,_),{subscribe:d,publish:f}=jL(c),E=Xj()[u]?.[_],h=new Vj(u,_,l,f,d,c.start_time,E.schemaDefined?E.attributes:void 0);s.push(h)}return new kj(r,t,s,n)}a(iZ,"buildNodePayloads");function oZ(){if(!JL.get(oo.CONFIG_PARAMS.CLUSTERING_ENABLED))throw $j(new Error,Wj.CLUSTERING_NOT_ENABLED,Kj.BAD_REQUEST,void 0,void 0,!0)}a(oZ,"checkClusteringEnabled");async function aZ(){let e=new Qj(oo.SYSTEM_SCHEMA_NAME,oo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await eZ(e))}a(aZ,"getAllNodeRecords");async function cZ(){let e=await zj.getSystemInformation();return{hdb_version:Jj.version(),node_version:e.node_version,platform:e.platform}}a(cZ,"getSystemInfo")});var lT=g((Fde,aM)=>{"use strict";var Dd=bt(),eM=z(),tM=rt(),rM=U(),Ld=K(),nM=pd(),uZ=bp(),{RemotePayloadObject:lZ}=mu(),{handleHDBError:sM,hdb_errors:_Z}=ne(),{HTTP_STATUS_CODES:iM}=_Z,{NodeSubscription:oM}=_a();aM.exports=dZ;async function dZ(e,t){let r;try{r=await Dd.request(`${t}.${tM.REQUEST_SUFFIX}`,new lZ(rM.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),Ld.trace("Response from remote describe all request:",r)}catch(o){Ld.error(`addNode received error from describe all request to remote node: ${o}`);let c=Dd.requestErrorHandler(o,"add_node",t);throw sM(new Error,c,iM.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===tM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw sM(new Error,o,iM.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,u=o.database??o.schema??"data";if(u===rM.SYSTEM_SCHEMA_NAME){await Dd.createLocalTableStream(u,c);let h=new oM(u,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let _=eM.doesSchemaExist(u),l=n[u]!==void 0,d=c?eM.doesTableExist(u,c):!0,f=c?n?.[u]?.[c]!==void 0:!0;if(!_&&!l||!d&&!f){s.push(o);continue}if(!_&&l&&(Ld.trace(`addNode creating schema: ${u}`),await nM.createSchema({operation:"create_schema",schema:u})),!d&&f){Ld.trace(`addNode creating table: ${c} in schema: ${u} with attributes ${JSON.stringify(n[u][c].attributes)}`);let h=new uZ(u,c,n[u][c].hash_attribute);n[u][c].attributes&&(h.attributes=n[u][c].attributes),await nM.createTable(h)}await Dd.createLocalTableStream(u,c);let E=new oM(u,c,o.publish,o.subscribe);E.start_time=o.start_time,i.push(E)}return{added:i,skipped:s}}a(dZ,"reviewSubscriptions")});var vd=g((kde,lM)=>{"use strict";var{handleHDBError:Md,hdb_errors:fZ}=ne(),{HTTP_STATUS_CODES:Ud}=fZ,{addUpdateNodeValidator:EZ}=Ad(),Pd=K(),uM=U(),cM=rt(),hZ=z(),pu=bt(),Su=bs(),mZ=re(),pZ=lT(),{Node:SZ,NodeSubscription:TZ}=_a(),{broadcast:gZ}=Ze(),RZ="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",AZ="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",OZ=mZ.get(uM.CONFIG_PARAMS.CLUSTERING_NODENAME);lM.exports=bZ;async function bZ(e,t=!1){Pd.trace("addNode called with:",e),Su.checkClusteringEnabled();let r=EZ(e);if(r)throw Md(r,r.message,Ud.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await Su.getNodeRecord(n);if(!hZ.isEmptyOrZeroLength(d))throw Md(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,Ud.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await pZ(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=RZ,o;let c=Su.buildNodePayloads(s,OZ,uM.OPERATIONS_ENUM.ADD_NODE,await Su.getSystemInfo()),u=[];for(let d=0,f=s.length;d<f;d++){let E=s[d];s[d].start_time===void 0&&delete s[d].start_time,u.push(new TZ(E.schema,E.table,E.publish,E.subscribe))}Pd.trace("addNode sending remote payload:",c);let _;try{_=await pu.request(`${n}.${cM.REQUEST_SUFFIX}`,c)}catch(d){Pd.error(`addNode received error from request: ${d}`);for(let E=0,h=s.length;E<h;E++){let p=s[E];p.publish=!1,p.subscribe=!1,await pu.updateRemoteConsumer(p,n)}let f=pu.requestErrorHandler(d,"add_node",n);throw Md(new Error,f,Ud.INTERNAL_SERVER_ERROR,"error",f)}if(_.status===cM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${_.message}`;throw Md(new Error,d,Ud.INTERNAL_SERVER_ERROR,"error",d)}Pd.trace(_);for(let d=0,f=s.length;d<f;d++){let E=s[d];await pu.updateRemoteConsumer(E,n),E.subscribe===!0&&await pu.updateConsumerIterator(E.schema,E.table,n,"start")}let l=new SZ(n,u,_.system_info);return await Su.upsertNodeRecord(l),gZ({type:"nats_update"}),i.length>0?o.message=AZ:o.message=`Successfully added '${n}' to manifest`,o}a(bZ,"addNode")});var fT=g((Yde,fM)=>{"use strict";var{handleHDBError:_T,hdb_errors:yZ}=ne(),{HTTP_STATUS_CODES:dT}=yZ,{addUpdateNodeValidator:NZ}=Ad(),Tu=K(),dM=U(),_M=rt(),$de=z(),gu=bt(),Ru=bs(),IZ=re(),{cloneDeep:wZ}=require("lodash"),CZ=lT(),{Node:DZ,NodeSubscription:LZ}=_a(),{broadcast:MZ}=Ze(),UZ="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",PZ="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",vZ=IZ.get(dM.CONFIG_PARAMS.CLUSTERING_NODENAME);fM.exports=BZ;async function BZ(e){Tu.trace("updateNode called with:",e),Ru.checkClusteringEnabled();let t=NZ(e);if(t)throw _T(t,t.message,dT.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Ru.getNodeRecord(r);s.length>0&&(n=wZ(s));let{added:i,skipped:o}=await CZ(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=UZ,c;let u=Ru.buildNodePayloads(i,vZ,dM.OPERATIONS_ENUM.UPDATE_NODE,await Ru.getSystemInfo());for(let l=0,d=i.length;l<d;l++){let f=i[l];Tu.trace(`updateNode updating work stream for node: ${r} subscription:`,f),i[l].start_time===void 0&&delete i[l].start_time}Tu.trace("updateNode sending remote payload:",u);let _;try{_=await gu.request(`${r}.${_M.REQUEST_SUFFIX}`,u)}catch(l){Tu.error(`updateNode received error from request: ${l}`);let d=gu.requestErrorHandler(l,"update_node",r);throw _T(new Error,d,dT.INTERNAL_SERVER_ERROR,"error",d)}if(_.status===_M.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let l=`Error returned from remote node ${r}: ${_.message}`;throw _T(new Error,l,dT.INTERNAL_SERVER_ERROR,"error",l)}Tu.trace(_);for(let l=0,d=i.length;l<d;l++){let f=i[l];await gu.updateRemoteConsumer(f,r),f.subscribe===!0?await gu.updateConsumerIterator(f.schema,f.table,r,"start"):await gu.updateConsumerIterator(f.schema,f.table,r,"stop")}return n||(n=[new DZ(r,[],_.system_info)]),await HZ(n[0],i,_.system_info),o.length>0?c.message=PZ:c.message=`Successfully updated '${r}'`,c}a(BZ,"updateNode");async function HZ(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let u=0,_=e.subscriptions.length;u<_;u++){let l=n.subscriptions[u];if(l.schema===o.schema&&l.table===o.table){l.publish=o.publish,l.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new LZ(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Ru.upsertNodeRecord(n),MZ({type:"nats_update"})}a(HZ,"updateNodeTable")});var SM=g((Wde,pM)=>{"use strict";var mM=require("joi"),{string:EM}=mM.types(),xZ=tt(),hM=U(),GZ=re(),FZ=rt();pM.exports=qZ;function qZ(e){let t=EM.invalid(GZ.get(hM.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(FZ.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=mM.object({operation:EM.valid(hM.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return xZ.validateBySchema(e,r)}a(qZ,"removeNodeValidator")});var Hd=g((zde,OM)=>{"use strict";var{handleHDBError:TM,hdb_errors:kZ}=ne(),{HTTP_STATUS_CODES:gM}=kZ,VZ=SM(),Au=K(),RM=bs(),$Z=z(),Bd=U(),AM=rt(),ET=bt(),YZ=re(),{RemotePayloadObject:KZ}=mu(),{NodeSubscription:WZ}=_a(),QZ=kc(),zZ=qi(),{broadcast:JZ}=Ze(),XZ=YZ.get(Bd.CONFIG_PARAMS.CLUSTERING_NODENAME);OM.exports=jZ;async function jZ(e){Au.trace("removeNode called with:",e),RM.checkClusteringEnabled();let t=VZ(e);if(t)throw TM(t,t.message,gM.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await RM.getNodeRecord(r);if($Z.isEmptyOrZeroLength(n))throw TM(new Error,`Node '${r}' was not found.`,gM.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new KZ(Bd.OPERATIONS_ENUM.REMOVE_NODE,XZ,[]),i,o=!1;for(let u=0,_=n.subscriptions.length;u<_;u++){let l=n.subscriptions[u];l.subscribe===!0&&await ET.updateConsumerIterator(l.schema,l.table,r,"stop");try{await ET.updateRemoteConsumer(new WZ(l.schema,l.table,!1,!1),r)}catch(d){Au.error(d)}}try{i=await ET.request(`${r}.${AM.REQUEST_SUFFIX}`,s),Au.trace("Remove node reply from remote node:",r,i)}catch(u){Au.error("removeNode received error from request:",u),o=!0}let c=new QZ(Bd.SYSTEM_SCHEMA_NAME,Bd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await zZ.deleteRecord(c),JZ({type:"nats_update"}),i?.status===AM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(Au.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(jZ,"removeNode")});var NM=g((Xde,yM)=>{"use strict";var bM=require("joi"),{string:ZZ,array:e5}=bM.types(),t5=tt(),r5=Ad();yM.exports=n5;function n5(e){let t=bM.object({operation:ZZ.valid("configure_cluster").required(),connections:e5.items(r5.validation_schema).required()});return t5.validateBySchema(e,t)}a(n5,"configureClusterValidator")});var hT=g((Zde,LM)=>{"use strict";var s5=U(),xd=K(),i5=z(),o5=Hd(),a5=vd(),IM=bs(),c5=NM(),{handleHDBError:wM,hdb_errors:u5}=ne(),{HTTP_STATUS_CODES:CM}=u5,l5="Configure cluster complete.",_5="Failed to configure the cluster. Check the logs for more details.",d5="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";LM.exports=f5;async function f5(e){xd.trace("configure cluster called with:",e),IM.checkClusteringEnabled();let t=c5(e);if(t)throw wM(t,t.message,CM.BAD_REQUEST,void 0,void 0,!0);let r=await IM.getAllNodeRecords(),n=[];for(let f=0,E=r.length;f<E;f++)n.push(DM(o5,{operation:s5.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[f].name},r[f].name));let s=await Promise.allSettled(n);xd.trace("All results from configure_cluster remove node:",s);let i=[],o=e.connections.length;for(let f=0;f<o;f++){let E=e.connections[f];i.push(DM(a5,E,E.node_name))}let c=await Promise.allSettled(i);xd.trace("All results from configure_cluster add node:",c);let u=[],_=[],l=!1,d=s.concat(c);for(let f=0,E=d.length;f<E;f++){let h=d[f];h.status==="rejected"&&(xd.error(h.reason),u.includes(h.reason.node_name)||u.push(h.reason.node_name)),h.status==="fulfilled"&&(l=!0);let p=h?.value?.result;typeof p=="string"&&p.includes("Successfully removed")||h.status==="rejected"||_.push({node_name:h?.value?.node_name,subscriptions:h?.value?.result})}if(i5.isEmptyOrZeroLength(u))return{message:l5,connections:_};if(l)return{message:d5,failed_nodes:u,connections:_};throw wM(new Error,_5,CM.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(f5,"configureCluster");async function DM(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){throw{node_name:r,error:n}}}a(DM,"functionWrapper")});var UM=g((tfe,MM)=>{"use strict";var Gd=require("joi"),E5=tt(),{validateSchemaExists:h5,validateTableExists:m5,validateSchemaName:p5}=Wn(),S5=Gd.object({operation:Gd.string().valid("purge_stream"),schema:Gd.string().custom(h5).custom(p5).required(),table:Gd.string().custom(m5).required()});function T5(e){return E5.validateBySchema(e,S5)}a(T5,"purgeStreamValidator");MM.exports=T5});var mT=g((nfe,PM)=>{"use strict";var{handleHDBError:g5,hdb_errors:R5}=ne(),{HTTP_STATUS_CODES:A5}=R5,O5=UM(),b5=bt(),y5=bs();PM.exports=N5;async function N5(e){if(e.purge_ingest!==!0){let s=O5(e);if(s)throw g5(s,s.message,A5.BAD_REQUEST,void 0,void 0,!0)}y5.checkClusteringEnabled();let{schema:t,table:r,purge_ingest:n}=e;return await b5.purgeTableStream(t,r,n),n?"Successfully purged ingest":`Successfully purged table '${t}.${r}'`}a(N5,"purgeStream")});var TT=g((ife,FM)=>{"use strict";var ST=bs(),I5=bt(),HM=re(),Fd=U(),ao=rt(),w5=z(),pT=K(),{RemotePayloadObject:C5}=mu(),{ErrorCode:vM}=require("nats"),BM=HM.get(Fd.CONFIG_PARAMS.CLUSTERING_ENABLED),xM=HM.get(Fd.CONFIG_PARAMS.CLUSTERING_NODENAME);FM.exports={clusterStatus:D5,buildNodeStatus:GM};async function D5(){let e={node_name:xM,is_enabled:BM,connections:[]};if(!BM)return e;let t=await ST.getAllNodeRecords();if(w5.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(GM(t[n],e.connections));return await Promise.allSettled(r),e}a(D5,"clusterStatus");async function GM(e,t){let r=e.name,n=new C5(Fd.OPERATIONS_ENUM.CLUSTER_STATUS,xM,void 0,await ST.getSystemInfo()),s,i,o=ao.CLUSTER_STATUS_STATUSES.OPEN;try{let u=Date.now();s=await I5.request(ao.REQUEST_SUBJECT(r),n),i=Date.now()-u,s.status===ao.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=ao.CLUSTER_STATUS_STATUSES.CLOSED,pT.error(`Error getting node status from ${r} `,s))}catch(u){pT.warn(`Error getting node status from ${r}`,u),u.code===vM.NoResponders?o=ao.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:u.code===vM.Timeout?o=ao.CLUSTER_STATUS_STATUSES.TIMEOUT:o=ao.CLUSTER_STATUS_STATUSES.CLOSED}let c=new L5(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let u={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==Fd.PRE_4_0_0_VERSION&&await ST.upsertNodeRecord(u)}catch(u){pT.error("Cluster status encountered an error updating system info for node:",r,u)}t.push(c)}a(GM,"buildNodeStatus");function L5(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(L5,"NodeStatusObject")});var RT=g((afe,qM)=>{"use strict";var{handleHDBError:M5,hdb_errors:U5}=ne(),{HTTP_STATUS_CODES:P5}=U5,v5=bt(),B5=bs(),gT=z(),qd=require("joi"),H5=tt(),x5=2e3,G5=qd.object({timeout:qd.number().min(1),connected_nodes:qd.boolean(),routes:qd.boolean()});qM.exports=F5;async function F5(e){B5.checkClusteringEnabled();let t=H5.validateBySchema(e,G5);if(t)throw M5(t,t.message,P5.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||gT.autoCastBoolean(n),o=s===void 0||gT.autoCastBoolean(s),c={nodes:[]},u=await v5.getServerList(r??x5),_={};if(i)for(let l=0,d=u.length;l<d;l++){let f=u[l].statsz;f&&(_[u[l].server.name]=f.routes)}for(let l=0,d=u.length;l<d;l++){if(u[l].statsz)continue;let f=u[l].server,E=u[l].data;if(f.name.endsWith("-hub")){let h={name:f.name.slice(0,-4),response_time:u[l].response_time};i&&(h.connected_nodes=[],_[f.name]&&_[f.name].forEach(p=>{h.connected_nodes.includes(p.name.slice(0,-4))||h.connected_nodes.push(p.name.slice(0,-4))})),o&&(h.routes=E.cluster?.urls?E.cluster?.urls.map(p=>({host:p.split(":")[0],port:gT.autoCast(p.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(F5,"clusterNetwork")});var YM=g((ufe,$M)=>{"use strict";var AT=require("joi"),kM=tt(),{route_constraints:VM}=Bm();$M.exports={setRoutesValidator:q5,deleteRoutesValidator:k5};function q5(e){let t=AT.object({server:AT.valid("hub","leaf").required(),routes:VM.required()});return kM.validateBySchema(e,t)}a(q5,"setRoutesValidator");function k5(e){let t=AT.object({routes:VM.required()});return kM.validateBySchema(e,t)}a(k5,"deleteRoutesValidator")});var bT=g((_fe,zM)=>{"use strict";var co=Ur(),OT=z(),kd=U(),KM=YM(),{handleHDBError:WM,hdb_errors:V5}=ne(),{HTTP_STATUS_CODES:QM}=V5,$5="cluster routes successfully set",Y5="cluster routes successfully deleted";zM.exports={setRoutes:K5,getRoutes:W5,deleteRoutes:Q5};function K5(e){let t=KM.setRoutesValidator(e);if(t)throw WM(t,t.message,QM.BAD_REQUEST,void 0,void 0,!0);let r=co.getClusteringRoutes(),n=e.server==="hub"?r.hub_routes:r.leaf_routes,s=e.server==="hub"?r.leaf_routes:r.hub_routes,i=[],o=[];for(let c=0,u=e.routes.length;c<u;c++){let _=e.routes[c];_.port=OT.autoCast(_.port);let l=n.some(f=>f.host===_.host&&f.port===_.port),d=s.some(f=>f.host===_.host&&f.port===_.port);l||d?i.push(_):(n.push(_),o.push(_))}return e.server==="hub"?co.updateConfigValue(kd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n):co.updateConfigValue(kd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n),{message:$5,set:o,skipped:i}}a(K5,"setRoutes");function W5(){let e=co.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}a(W5,"getRoutes");function Q5(e){let t=KM.deleteRoutesValidator(e);if(t)throw WM(t,t.message,QM.BAD_REQUEST,void 0,void 0,!0);let r=co.getClusteringRoutes(),n=r.hub_routes,s=r.leaf_routes,i=[],o=[],c=!1,u=!1;for(let _=0,l=e.routes.length;_<l;_++){let d=e.routes[_],f=!1;for(let E=0,h=n.length;E<h;E++){let p=n[E];if(d.host===p.host&&d.port===p.port){n.splice(E,1),f=!0,c=!0,i.push(d);break}}if(!f){let E=!0;for(let h=0,p=s.length;h<p;h++){let S=s[h];if(d.host===S.host&&d.port===S.port){s.splice(h,1),u=!0,E=!1,i.push(d);break}}E&&o.push(d)}}return c&&(n=OT.isEmptyOrZeroLength(n)?null:n,co.updateConfigValue(kd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n)),u&&(s=OT.isEmptyOrZeroLength(s)?null:s,co.updateConfigValue(kd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,s)),{message:Y5,deleted:i,skipped:o}}a(Q5,"deleteRoutes")});var XM=g((ffe,JM)=>{"use strict";var Ou=require("alasql"),uo=require("recursive-iterator"),vn=K(),z5=z(),bu=U(),yT=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,X5(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=>bu.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=>!bu.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][bu.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=J5(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(_=>({attribute_name:_.attribute}));let u=this.affected_attributes.get(i).get(o).filter(_=>!bu.SEARCH_WILDCARDS.includes(_));c.forEach(({attribute_name:_})=>{let l=new Ou.yy.Column({columnid:_});s.tableid&&(l.tableid=s.tableid),this.ast.columns.push(l),u.includes(_)||u.push(_)}),this.affected_attributes.get(i).set(o,u)}}),this.ast}};function J5(e){return e.filter(t=>t[bu.PERMS_CRUD_ENUM.READ])}a(J5,"filterReadRestrictedAttrs");function X5(e,t,r,n,s){j5(e,t,r,n,s)}a(X5,"interpretAST");function yu(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(yu,"addSchemaTableToMap");function j5(e,t,r,n,s){if(!e){vn.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Ou.yy.Insert?r8(e,t,r):e instanceof Ou.yy.Select?Z5(e,t,r,n,s):e instanceof Ou.yy.Update?e8(e,t,r):e instanceof Ou.yy.Delete?t8(e,t,r):vn.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(j5,"getRecordAttributesAST");function Z5(e,t,r,n,s){if(!e){vn.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(z5.isEmptyOrZeroLength(i)){vn.error("No schema specified");return}e.from.forEach(c=>{yu(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),yu(c.table,t,r,n,s)});let o=new uo(e.columns);for(let{node:c}of o)if(c&&c.columnid){let u=c.tableid,_=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(_).has(u))if(r.has(u))u=r.get(u);else{vn.info(`table specified as ${u} not found.`);return}t.get(_).get(u).indexOf(c.columnid)<0&&t.get(_).get(u).push(c.columnid)}if(e.where){let c=new uo(e.where),u=e.from[0].tableid;for(let{node:_}of c)if(_&&_.columnid){let l=_.tableid?_.tableid:u;if(!t.get(i).has(l))if(r.has(l))l=r.get(l);else{vn.info(`table specified as ${l} not found.`);continue}t.get(i).get(l).indexOf(_.columnid)<0&&t.get(i).get(l).push(_.columnid)}}if(e.joins&&e.joins.forEach(c=>{let u=new uo(c.on);for(let{node:_}of u)if(_&&_.columnid){let l=_.tableid,d=s.get(l);if(!t.get(d).has(l))if(r.has(l))l=r.get(l);else{vn.info(`table specified as ${l} not found.`);continue}t.get(d).get(l).indexOf(_.columnid)<0&&t.get(d).get(l).push(_.columnid)}}),e.order){let c=new uo(e.order);for(let{node:u}of c)if(u&&u.columnid){let _=u.tableid,l=n.has(_)?n.get(_):i;if(_||(_=e.from[0].tableid),!t.get(l).has(_))if(r.has(_))_=r.get(_);else{vn.info(`table specified as ${_} not found.`);return}t.get(l).get(_).indexOf(u.columnid)<0&&t.get(l).get(_).push(u.columnid)}}}a(Z5,"getSelectAttributes");function e8(e,t,r){if(!e){vn.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new uo(e.columns),s=e.table.databaseid;yu(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&NT(e.table.tableid,s,i.columnid,t,r)}a(e8,"getUpdateAttributes");function t8(e,t,r){if(!e){vn.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new uo(e.where),s=e.table.databaseid;yu(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&NT(e.table.tableid,s,i.columnid,t,r)}a(t8,"getDeleteAttributes");function r8(e,t,r){if(!e){vn.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new uo(e.columns),s=e.into.databaseid;yu(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&NT(e.into.tableid,s,i.columnid,t,r)}a(r8,"getInsertAttributes");function NT(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(NT,"pushAttribute");JM.exports=yT});var CT=g((hfe,tU)=>{var Vd=Yi(),jM=require("chalk"),Gr=K(),ZM=require("prompt"),{promisify:n8}=require("util"),IT=U(),s8=require("fs-extra"),i8=require("path"),o8=z(),a8=Cd(),eU=re();eU.initSync();var c8=require("moment"),u8=n8(ZM.get),l8=i8.join(eU.getHdbBasePath(),IT.LICENSE_KEY_DIR_NAME,IT.LICENSE_FILE_NAME,IT.LICENSE_FILE_NAME);tU.exports={getFingerprint:d8,setLicense:_8,parseLicense:wT,register:f8,getRegistrationInfo:h8};async function _8(e){if(e&&e.key&&e.company){try{Gr.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await wT(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Gr.error(r),Gr.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(_8,"setLicense");async function d8(){let e={};try{e=await Vd.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Gr.error(r),Gr.error(t),new Error(r)}return e}a(d8,"getFingerprint");async function wT(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Gr.info("Validating license input...");let r=Vd.validateLicense(e,t);if(Gr.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Gr.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Gr.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Gr.info("writing license to disk"),await s8.writeFile(l8,JSON.stringify({license_key:e,company:t}))}catch(n){throw Gr.error("Failed to write License"),n}return"Registration successful."}a(wT,"parseLicense");async function f8(){let e=await E8();return wT(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(f8,"register");async function E8(){let e=await Vd.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:jM.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:jM.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{ZM.start()}catch(n){Gr.error(n)}let r;try{r=await u8(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(E8,"promptForRegistration");async function h8(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await Vd.getLicense()}catch(r){throw Gr.error(`There was an error when searching licenses due to: ${r.message}`),r}if(o8.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=a8.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=c8.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(h8,"getRegistrationInfo")});var nU=g((pfe,rU)=>{"use strict";var m8=rt(),DT=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,u,_,l,d,f,E,h){this.port=t,o===null&&(o=void 0),this.server_name=r+m8.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:u},this.leafnodes={port:_,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:l,port:d,routes:f,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:u}},this.accounts={SYS:{users:E},HDB:{users:h}},this.system_account="SYS"}};rU.exports=DT});var oU=g((Tfe,iU)=>{"use strict";var sU=rt(),LT=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,u,_,l,d){this.port=t,d===null&&(d=void 0),this.server_name=r+sU.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+sU.SERVER_SUFFIX.LEAF},this.tls={cert_file:_,key_file:l,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:u,jetstream:"enabled"}},this.system_account="SYS"}};iU.exports=LT});var cU=g((Rfe,aU)=>{"use strict";var MT=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};aU.exports=MT});var lU=g((Ofe,uU)=>{"use strict";var p8=rt(),UT=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+p8.SERVER_SUFFIX.ADMIN,this.password=r}};uU.exports=UT});var BT=g((yfe,fU)=>{"use strict";var fa=require("path"),Kd=require("fs-extra"),S8=nU(),T8=oU(),g8=cU(),R8=lU(),PT=nn(),ha=z(),pr=Ur(),Yd=U(),Nu=rt(),{CONFIG_PARAMS:lt}=Yd,Iu=K(),wu=re(),_U=Ss(),vT=bt(),Ea="clustering",A8=1e4,dU=5;fU.exports={generateNatsConfig:b8,removeNatsConfig:y8,getHubConfigPath:O8};function O8(){let e=wu.get(lt.ROOTPATH);return fa.join(e,Ea,Nu.NATS_CONFIG_FILES.HUB_SERVER)}a(O8,"getHubConfigPath");async function b8(e=!1,t=void 0){wu.initSync();let r=wu.get(lt.ROOTPATH),n=fa.join(r,Ea,Nu.PID_FILES.HUB),s=fa.join(r,Ea,Nu.PID_FILES.LEAF),i=pr.getConfigFromFile(lt.CLUSTERING_LEAFSERVER_STREAMS_PATH),o=fa.join(r,Ea,Nu.NATS_CONFIG_FILES.HUB_SERVER),c=fa.join(r,Ea,Nu.NATS_CONFIG_FILES.LEAF_SERVER),u=pr.getConfigFromFile(lt.CLUSTERING_TLS_CERTIFICATE),_=pr.getConfigFromFile(lt.CLUSTERING_TLS_PRIVATEKEY),l=pr.getConfigFromFile(lt.CLUSTERING_TLS_CERT_AUTH),d=pr.getConfigFromFile(lt.CLUSTERING_TLS_INSECURE),f=pr.getConfigFromFile(lt.CLUSTERING_TLS_VERIFY),E=pr.getConfigFromFile(lt.CLUSTERING_NODENAME),h=pr.getConfigFromFile(lt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await vT.checkNATSServerInstalled()||Wd("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let p=await PT.listUsers(),S=pr.getConfigFromFile(lt.CLUSTERING_USER),T=await PT.getClusterUser();(ha.isEmpty(T)||T.active!==!0)&&Wd(`Invalid cluster user '${S}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await $d(lt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await $d(lt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await $d(lt.CLUSTERING_HUBSERVER_NETWORK_PORT),await $d(lt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let b=[],R=[];for(let[Q,X]of p.entries())X.role.role===Yd.ROLE_TYPES_ENUM.CLUSTER_USER&&X.active&&(b.push(new R8(X.username,_U.decrypt(X.hash))),R.push(new g8(X.username,_U.decrypt(X.hash))));let L=[],{hub_routes:H}=pr.getClusteringRoutes();if(!ha.isEmptyOrZeroLength(H))for(let Q of H)L.push(`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@${Q.host}:${Q.port}`);let P=new S8(pr.getConfigFromFile(lt.CLUSTERING_HUBSERVER_NETWORK_PORT),E,n,u,_,l,d,f,h,pr.getConfigFromFile(lt.CLUSTERING_HUBSERVER_CLUSTER_NAME),pr.getConfigFromFile(lt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),L,b,R);l==null&&(delete P.tls.ca_file,delete P.leafnodes.tls.ca_file),t=ha.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===Yd.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Kd.writeJson(o,P),Iu.trace(`Hub server config written to ${o}`));let k=`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,B=`tls://${T.uri_encoded_name}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,J=new T8(pr.getConfigFromFile(lt.CLUSTERING_LEAFSERVER_NETWORK_PORT),E,s,i,[k],[B],b,R,u,_,l,d);l==null&&delete J.tls.ca_file,(t===void 0||t===Yd.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Kd.writeJson(c,J),Iu.trace(`Leaf server config written to ${c}`))}a(b8,"generateNatsConfig");async function $d(e){let t=wu.get(e);return ha.isEmpty(t)&&Wd(`port undefined for '${e}'`),await ha.isPortTaken(t)&&Wd(`'${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($d,"isPortAvailable");function Wd(e){let t=`Error generating clustering config: ${e}`;Iu.error(t),console.error(t),process.exit(1)}a(Wd,"generateNatsConfigError");async function y8(e){let{port:t,config_file:r}=vT.getServerConfig(e),{username:n,decrypt_hash:s}=await PT.getClusterUser(),i=0,o=2e3;for(;i<dU;){try{let _=await vT.createConnection(t,n,s,!1);if(_.protocol.connected===!0){_.close();break}}catch(_){Iu.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${_}`)}if(i++,i>=dU)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.`);await ha.async_set_timeout(o*(i*2))}let c="0".repeat(A8),u=fa.join(wu.get(lt.ROOTPATH),Ea,r);await Kd.writeFile(u,c),await Kd.remove(u),Iu.notify(e,"started.")}a(y8,"removeNatsConfig")});var TU=g((Ife,SU)=>{"use strict";var Fr=re(),N8=Yi(),he=U(),Cu=rt(),ys=require("path"),{PACKAGE_ROOT:zd}=U(),EU=re(),Qd=z(),ma="/dev/null",I8=ys.join(zd,"launchServiceScripts"),hU=ys.join(zd,"utility/scripts"),w8=ys.join(hU,he.HDB_RESTART_SCRIPT),mU=ys.resolve(zd,"dependencies",`${process.platform}-${process.arch}`,Cu.NATS_BINARY_NAME);function pU(){let t=N8.licenseSearch().ram_allocation||he.RAM_ALLOCATION_ENUM.DEFAULT,r=he.MEM_SETTING_KEY+t,n={[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Qd.noBootFile()&&(n[he.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Qd.getEnvCliRootPath()),{name:he.PROCESS_DESCRIPTORS.HDB,script:he.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:zd}}a(pU,"generateMainServerConfig");var C8=9930;function D8(){Fr.initSync(!0);let e=Fr.get(he.CONFIG_PARAMS.ROOTPATH),t=ys.join(e,"clustering",Cu.NATS_CONFIG_FILES.HUB_SERVER),r=ys.join(Fr.get(he.HDB_SETTINGS_NAMES.LOG_PATH_KEY),he.LOG_NAMES.HDB),n=EU.get(he.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Cu.LOG_LEVEL_FLAGS[Fr.get(he.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:he.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==C8?"-"+n:""),script:mU,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Fr.get(he.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=ma,i.error_file=ma),i}a(D8,"generateNatsHubServerConfig");var L8=9940;function M8(){Fr.initSync(!0);let e=Fr.get(he.CONFIG_PARAMS.ROOTPATH),t=ys.join(e,"clustering",Cu.NATS_CONFIG_FILES.LEAF_SERVER),r=ys.join(Fr.get(he.HDB_SETTINGS_NAMES.LOG_PATH_KEY),he.LOG_NAMES.HDB),n=EU.get(he.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Cu.LOG_LEVEL_FLAGS[Fr.get(he.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:he.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==L8?"-"+n:""),script:mU,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Fr.get(he.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=ma,i.error_file=ma),i}a(M8,"generateNatsLeafServerConfig");function U8(){Fr.initSync();let e=ys.join(Fr.get(he.CONFIG_PARAMS.LOGGING_ROOT),he.LOG_NAMES.HDB),t={name:he.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:he.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:I8,autorestart:!1};return Fr.get(he.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=ma,t.error_file=ma),t}a(U8,"generateClusteringUpgradeV4ServiceConfig");function P8(){let e={[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.RESTART_HDB};return Qd.noBootFile()&&(e[he.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Qd.getEnvCliRootPath()),{...{name:he.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:hU},script:w8}}a(P8,"generateRestart");function v8(){return{apps:[pU()]}}a(v8,"generateAllServiceConfigs");SU.exports={generateAllServiceConfigs:v8,generateMainServerConfig:pU,generateRestart:P8,generateNatsHubServerConfig:D8,generateNatsLeafServerConfig:M8,generateClusteringUpgradeV4ServiceConfig:U8}});var UU=g((Dfe,MU)=>{"use strict";var ve=U(),B8=z(),Is=BT(),Jd=bt(),Ns=rt(),_i=TU(),Xd=re(),di=K(),H8=bs(),{startWorker:gU,onMessageFromWorkers:x8}=Ze(),G8=da(),Cfe=require("util"),F8=require("child_process"),q8=require("fs"),{execFile:k8}=F8,Ne;MU.exports={enterPM2Mode:V8,start:fi,stop:HT,reload:AU,restart:OU,list:xT,describe:yU,connect:ws,kill:Q8,startAllServices:z8,startService:GT,getUniqueServicesList:NU,restartAllServices:J8,isServiceRegistered:IU,reloadStopStart:wU,restartHdb:bU,deleteProcess:K8,startClusteringProcesses:DU,startClusteringThreads:LU,isHdbRestartRunning:W8,isClusteringRunning:j8,stopClustering:X8,reloadClustering:Z8};var Du=!1;x8(e=>{e.type==="restart"&&Xd.initSync(!0)});function V8(){Du=!0}a(V8,"enterPM2Mode");function ws(){return Ne||(Ne=require("pm2")),new Promise((e,t)=>{Ne.connect((r,n)=>{di.setupConsoleLogging(),r&&t(r),e(n)})})}a(ws,"connect");var Sr,$8=10,RU;function fi(e,t=!1){if(Du)return Y8(e);let r=k8(e.script,e.args.split(" "),e);r.name=e.name,r.on("exit",async i=>{let o=Sr.indexOf(r);o>-1&&Sr.splice(o,1),!RU&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<$8&&(q8.existsSync(Is.getHubConfigPath())?fi(e):(await Is.generateNatsConfig(!0),fi(e),await new Promise(c=>setTimeout(c,3e3)),await Is.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Is.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Xd.get(ve.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,u,_=0,l;for(;u=c.exec(i);){if(u.index&&Ns.LOG_LEVEL_HIERARCHY[o]>=Ns.LOG_LEVEL_HIERARCHY[l||"info"]){let E=l===Ns.LOG_LEVELS.ERR||l===Ns.LOG_LEVELS.WRN?di.OUTPUTS.STDERR:di.OUTPUTS.STDOUT;di.logCustomLevel(l||"info",E,n,i.slice(_,u.index).trim())}let[d,f]=u;_=u.index+d.length,l=Ns.LOG_LEVELS[f]}if(Ns.LOG_LEVEL_HIERARCHY[o]>=Ns.LOG_LEVEL_HIERARCHY[l||"info"]){let d=l===Ns.LOG_LEVELS.ERR||l===Ns.LOG_LEVELS.WRN?di.OUTPUTS.STDERR:di.OUTPUTS.STDOUT;di.logCustomLevel(l||"info",d,n,i.slice(_).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),Sr=[],!Sr&&!t){let i=a(()=>{RU=!0,Sr&&(Sr.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)}Sr.push(r)}a(fi,"start");function Y8(e){return new Promise(async(t,r)=>{try{await ws()}catch(n){r(n)}Ne.start(e,(n,s)=>{n&&(Ne.disconnect(),r(n)),Ne.disconnect(),t(s)})})}a(Y8,"startWithPM2");function HT(e){if(!Du){for(let t of Sr||[])t.name===e&&(Sr.splice(Sr.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await ws()}catch(n){r(n)}Ne.stop(e,async(n,s)=>{n&&(Ne.disconnect(),r(n)),Ne.delete(e,(i,o)=>{i&&(Ne.disconnect(),r(n)),Ne.disconnect(),t(o)})})})}a(HT,"stop");function AU(e){return new Promise(async(t,r)=>{try{await ws()}catch(n){r(n)}Ne.reload(e,(n,s)=>{n&&(Ne.disconnect(),r(n)),Ne.disconnect(),t(s)})})}a(AU,"reload");function OU(e){if(!Du)for(let t of Sr||[])t.name===e&&t.kill();return new Promise(async(t,r)=>{try{await ws()}catch(n){r(n)}Ne.restart(e,(n,s)=>{Ne.disconnect(),t(s)})})}a(OU,"restart");function K8(e){return new Promise(async(t,r)=>{try{await ws()}catch(n){r(n)}Ne.delete(e,(n,s)=>{n&&(Ne.disconnect(),r(n)),Ne.disconnect(),t(s)})})}a(K8,"deleteProcess");async function bU(){await fi(_i.generateRestart())}a(bU,"restartHdb");async function W8(){let e=await xT();for(let t in e)if(e[t].name===ve.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(W8,"isHdbRestartRunning");function xT(){return new Promise(async(e,t)=>{try{await ws()}catch(r){t(r)}Ne.list((r,n)=>{r&&(Ne.disconnect(),t(r)),Ne.disconnect(),e(n)})})}a(xT,"list");function yU(e){return new Promise(async(t,r)=>{try{await ws()}catch(n){r(n)}Ne.describe(e,(n,s)=>{n&&(Ne.disconnect(),r(n)),Ne.disconnect(),t(s)})})}a(yU,"describe");function Q8(){if(!Du){for(let e of Sr||[])e.kill();Sr=[];return}return new Promise(async(e,t)=>{try{await ws()}catch(r){t(r)}Ne.killDaemon((r,n)=>{r&&(Ne.disconnect(),t(r)),Ne.disconnect(),e(n)})})}a(Q8,"kill");async function z8(){try{await DU(),await LU(),await fi(_i.generateAllServiceConfigs())}catch(e){throw Ne?.disconnect(),e}}a(z8,"startAllServices");async function GT(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case ve.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=_i.generateMainServerConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=_i.generateNatsIngestServiceConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=_i.generateNatsReplyServiceConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=_i.generateNatsHubServerConfig(),await fi(r,t),await Is.removeNatsConfig(e);return;case ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=_i.generateNatsLeafServerConfig(),await fi(r,t),await Is.removeNatsConfig(e);return;case ve.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=_i.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await fi(r)}catch(r){throw Ne?.disconnect(),r}}a(GT,"startService");async function NU(){try{let e=await xT(),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 Ne?.disconnect(),e}}a(NU,"getUniqueServicesList");async function J8(e=[]){try{let t=!1,r=await NU();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===ve.PROCESS_DESCRIPTORS.HDB?t=!0:await OU(o))}t&&await wU(ve.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ne?.disconnect(),t}}a(J8,"restartAllServices");async function IU(e){if(Sr?.find(r=>r.name===e))return!0;let t=await G8.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(IU,"isServiceRegistered");async function wU(e){let t=Xd.get(ve.CONFIG_PARAMS.THREADS_COUNT)??Xd.get(ve.CONFIG_PARAMS.THREADS),r=await yU(e),n=B8.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await HT(e),await GT(e)):e===ve.PROCESS_DESCRIPTORS.HDB?await bU():await AU(e)}a(wU,"reloadStopStart");var CU;async function DU(e=!1){for(let t in ve.CLUSTERING_PROCESSES){let r=ve.CLUSTERING_PROCESSES[t];await GT(r,e)}}a(DU,"startClusteringProcesses");async function LU(){CU=gU(ve.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:ve.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await Jd.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await Jd.updateLocalStreams();let e=await H8.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===ve.PRE_4_0_0_VERSION){di.info("Starting clustering upgrade 4.0.0 process"),gU(ve.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(LU,"startClusteringThreads");async function X8(){for(let e in ve.CLUSTERING_PROCESSES)if(e!==ve.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===ve.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await CU.terminate();else{let t=ve.CLUSTERING_PROCESSES[e];await HT(t)}}a(X8,"stopClustering");async function j8(){for(let e in ve.CLUSTERING_PROCESSES){let t=ve.CLUSTERING_PROCESSES[e];if(await IU(t)===!1)return!1}return!0}a(j8,"isClusteringRunning");async function Z8(){await Is.generateNatsConfig(!0),await Jd.reloadNATSHub(),await Jd.reloadNATSLeaf(),await Is.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await Is.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Z8,"reloadClustering")});var rf=g((Ufe,FU)=>{"use strict";var e6=require("minimist"),{isMainThread:qT,parentPort:BU}=require("worker_threads"),nt=U(),{PROCESS_DESCRIPTORS_VALIDATE:Lu}=nt,rs=K(),kT=z(),Zd=BT(),jd=bt(),Mfe=rt(),HU=Ur(),ns=UU(),PU=da(),t6=_h(),{restartWorkers:ef,onMessageByType:r6}=Ze(),{handleHDBError:n6,hdb_errors:s6}=ne(),{HTTP_STATUS_CODES:i6}=s6,tf=re();tf.initSync();var Mu=`Restarting HarperDB. This may take up to ${nt.RESTART_TIMEOUT_MS/1e3} seconds.`,o6="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",vU="Clustering is not enabled so cannot be restarted",a6="Invalid service",pa,an;FU.exports={restart:xU,restartService:VT};qT&&r6(nt.ITC_EVENT_TYPES.RESTART,e=>{e.workerType?VT({service:e.workerType}):xU({operation:"restart"})});async function xU(e){an=Object.keys(e).length===0,pa=await ns.isServiceRegistered(nt.HDB_PROC_DESCRIPTOR);let t=e6(process.argv);if(t.service){await VT(t);return}if(an&&!pa){console.error(o6);return}if(an&&console.log(Mu),pa){ns.enterPM2Mode(),rs.notify(Mu);let r=t6(Object.keys(nt.CONFIG_PARAM_MAP),!0);return kT.isEmptyOrZeroLength(Object.keys(r))||HU.updateConfigValue(void 0,void 0,r,!0,!0),c6(),Mu}return qT?(rs.notify(Mu),setTimeout(()=>{ef()},50)):BU.postMessage({type:nt.ITC_EVENT_TYPES.RESTART}),Mu}a(xU,"restart");async function VT(e){let{service:t}=e;if(nt.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw n6(new Error,a6,i6.BAD_REQUEST,void 0,void 0,!0);if(pa=await ns.isServiceRegistered(nt.HDB_PROC_DESCRIPTOR),!qT)return BU.postMessage({type:nt.ITC_EVENT_TYPES.RESTART,workerType:t}),t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`;let r;switch(t){case Lu.clustering:if(!tf.get(nt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=vU;break}an&&console.log("Restarting clustering"),rs.notify("Restarting clustering"),await GU();break;case Lu.clustering_config:case Lu["clustering config"]:if(!tf.get(nt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=vU;break}an&&console.log("Restarting clustering_config"),rs.notify("Restarting clustering_config"),await ns.reloadClustering();break;case"custom_functions":case"custom functions":case Lu.harperdb:case Lu.http_workers:if(an&&!pa){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}an&&console.log("Restarting http_workers"),rs.notify("Restarting http_workers"),an?await ns.restart(nt.HDB_PROC_DESCRIPTOR):setTimeout(()=>{ef("http")},200);break;default:r=`Unrecognized service: ${t}`;break}return r?(rs.error(r),an&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(VT,"restartService");async function c6(){await GU(),await ns.restart(nt.HDB_PROC_DESCRIPTOR),await kT.async_set_timeout(2e3),tf.get(nt.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await FT(),an&&(await jd.closeConnection(),process.exit(0))}a(c6,"restartPM2Mode");async function GU(){if(!HU.getConfigFromFile(nt.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await PU.getHDBProcessInfo()).clustering.length===0)rs.trace("Clustering not running, restart will start clustering services"),await Zd.generateNatsConfig(!0),await ns.startClusteringProcesses(),await ns.startClusteringThreads(),await FT(),an&&await jd.closeConnection();else{await Zd.generateNatsConfig(!0),pa?(rs.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await ns.restart(nt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ns.restart(nt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await PU.getHDBProcessInfo()).clustering.forEach(s=>{rs.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await kT.async_set_timeout(3e3),await FT(),await jd.updateLocalStreams(),an&&await jd.closeConnection(),rs.trace("Restart clustering restarting ingest and reply service threads");let t=ef(nt.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=ef(nt.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(GU,"restartClustering");async function FT(){await Zd.removeNatsConfig(nt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Zd.removeNatsConfig(nt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(FT,"removeNatsConfig")});var XU=g((Bfe,JU)=>{"use strict";var vfe=require("lodash"),Tr=U(),{handleHDBError:qU,hdb_errors:u6}=ne(),{HDB_ERROR_MSGS:l6,HTTP_STATUS_CODES:_6}=u6,$T=K();JU.exports={getRolePermissions:f6};var lo=Object.create(null),d6=a(e=>({key:e,perms:{}}),"perms_template_obj"),YU=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),KU=a((e=!1,t=!1,r=!1,n=!1)=>({[Tr.PERMS_CRUD_ENUM.READ]:e,[Tr.PERMS_CRUD_ENUM.INSERT]:t,[Tr.PERMS_CRUD_ENUM.UPDATE]:r,[Tr.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),YT=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...KU(t,r,n,s)}),"table_perms_template"),kU=a((e,t=KU())=>({attribute_name:e,describe:zU(t),[Uu]:t[Uu],[KT]:t[KT],[WT]:t[WT]}),"attr_perms_template"),VU=a((e,t=!1)=>({attribute_name:e,describe:t,[Uu]:t}),"timestamp_attr_perms_template"),{READ:Uu,INSERT:KT,UPDATE:WT}=Tr.PERMS_CRUD_ENUM,WU=Object.values(Tr.PERMS_CRUD_ENUM),QU=[Uu,KT,WT];function f6(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r=Object.assign({},global.hdb_schema);delete r[Tr.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(lo[t]&&lo[t].key===n)return lo[t].perms;let s=E6(e,r);return lo[t]?lo[t].key=n:lo[t]=d6(n),lo[t].perms=s,s}catch(r){if(!e[Tr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Tr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Tr.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 $T.error(n),$T.debug(r),qU(new Error,l6.OUTDATED_PERMS_TRANSLATION_ERROR,_6.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
|
|
11
|
+
${r.stack}`;throw $T.error(n),qU(new Error)}}}a(f6,"getRolePermissions");function E6(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[Tr.SYSTEM_SCHEMA_NAME]=n[Tr.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]=h6(t[i]);return}r[i]=YU(),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],u=t[i][o],_=m6(c,u);r[i].describe||WU.forEach(l=>{_[l]&&(r[i].describe=!0)}),r[i].tables[o]=_}else r[i].tables[o]=YT()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=YT()})}),r}a(E6,"translateRolePermissions");function h6(e){let t=YU(!0);return Object.keys(e).forEach(r=>{t.tables[r]=YT(!0,!0,!0,!0,!0)}),t}a(h6,"createStructureUserPermissions");function m6(e,t){let{attribute_permissions:r}=e;if(r.length>0){let s=Object.assign({},e);s.attribute_permissions=[];let i=r.reduce((_,l)=>{let{attribute_name:d}=l,f=l;return Tr.TIME_STAMP_NAMES.includes(d)&&(f=VU(d,l[Uu])),_[d]=f,_},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],u=kU(o);return t.attributes.forEach(({attribute:_})=>{if(i[_]){let l=i[_];l.describe=zU(l),s.attribute_permissions.push(l),c||p6(l,u)}else if(_!==o){let l;Tr.TIME_STAMP_NAMES.includes(_)?l=VU(_):l=kU(_),s.attribute_permissions.push(l)}}),c||s.attribute_permissions.push(u),s.describe=$U(s),s}else return e.describe=$U(e),e}a(m6,"getTableAttrPerms");function $U(e){return WU.filter(t=>e[t]).length>0}a($U,"getSchemaTableDescribePerm");function zU(e){return QU.filter(t=>e[t]).length>0}a(zU,"getAttributeDescribePerm");function p6(e,t){QU.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(p6,"checkForHashPerms")});var jU={};$e(jU,{Resources:()=>nf,keyArrayToString:()=>Sa,resetResources:()=>S6,resources:()=>Ei});function S6(){return Ei=new nf}function Sa(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var nf,Ei,Pu=Re(()=>{Xi();nf=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,type:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s)throw new Error(`Conflicting paths for ${t}`);super.set(t,i);for(let[c,u]of this){let _=2;for(;(_=c.indexOf("/",_))>-1;){let l=this.get(c.slice(0,_));l&&(l.hasSubPaths=!0),_+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),u=this.get(c);if(u){if(u.relativeURL=t.slice(n),!u.hasSubPaths)return u;s=u}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),s?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return ze(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(S6,"resetResources");a(Sa,"keyArrayToString")});var ZU={};$e(ZU,{Headers:()=>hi,appendHeader:()=>QT});function QT(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}var hi,vu=Re(()=>{hi=class extends Map{static{a(this,"Headers")}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(QT,"appendHeader")});var Bu={};$e(Bu,{authentication:()=>aP,bypassAuth:()=>y6,login:()=>I6,logout:()=>w6,start:()=>N6});function y6(){oP=!0}async function aP(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let E=e.isOperationsServer?A6?R6:[]:g6?T6:[];if(E.includes(i)||E.includes("*")){if(e.method==="OPTIONS"){let h=new hi([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return sf&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),sf&&o.push("Access-Control-Allow-Credentials","true")}}let u,_;if(sf){let E=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.indexOf(E);if(h>=0){let p=s.indexOf(";",h),S=s.indexOf("=",h);u=s.slice(S+1,p===-1?s.length:p),_=await tP.get(u)}e.session=_||(_={})}e.user=null;let l=a((E,h,p)=>{let S=new Ta.AuthAuditLog(E,h,Ut.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);S.auth_strategy=p,u&&(S.session_id=u),r.referer&&(S.referer=r.referer),r.origin&&(S.origin=r.origin),h===Ut.AUTH_AUDIT_STATUS.SUCCESS?eP.notify(S):eP.error(S)},"authAuditLog");if(e.mtlsConfig&&e.authorized){let E=e.mtlsConfig.user;E!==null?((E===void 0||E==="Common Name"||E==="CN")&&(E=e.peerCertificate.subject.CN),e.user=await je.getUser(E,null,null),l(E,Ut.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,Ta.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=_o.get(n),!d){let[E,h]=n.split(" "),p,S;try{switch(E){case"Basic":[p,S]=atob(h).split(":"),d=p||S?await je.getUser(p,S,e):null;break;case"Bearer":try{d=await(0,of.validateOperationToken)(h)}catch(T){if(T.message==="invalid token")try{return await(0,of.validateRefreshToken)(h),c({status:-1})}catch{throw T}}break}}catch(T){return b6&&(_o.get(h)||(_o.set(h,h),l(p,Ut.AUTH_AUDIT_STATUS.FAILURE,E))),c({status:401,body:mi({error:T.message},e)})}_o.set(n,d),O6&&l(d.username,Ut.AUTH_AUDIT_STATUS.SUCCESS,E)}e.user=d}else _?.user?e.user=await je.getUser(_.user,null,e):(oP&&(e.ip?.includes("127.0.0.1")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,nP.getSuperUser)());sf&&(e.session.update=function(E){if(!u){u=(0,sP.v4)();let p=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${u}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",p):f?.headers?.set&&f.headers.set("Set-Cookie",p)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):f?.headers?.set&&(i&&f.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),f.headers.set("X-Hdb-Session","Secure"))),E.id=u,tP.put(E)},e.login=async function(E,h){e.user=await je.getUser(E,h,e),e.session.update({user:e.user.username})},(d&&!_||_?.user?.username!==d?.username)&&r["user-agent"]?.startsWith("Mozilla")&&e.session.update({user:e.user.username}));let f=await t(e);return f&&(f.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Ei.loginPath?(f.status=302,f.headers.set("Location",Ei.loginPath(e))):f.headers.set("WWW-Authenticate","Basic")),c(f))}catch(u){throw c(u)}function c(u){let _=o.length;if(_>0){let l=u.headers;l||(u.headers=l=new hi);for(let d=0;d<_;){let f=o[d++];l.set(f,o[d++])}}return o=null,u}a(c,"applyResponseHeaders")}function N6({server:e,port:t}){e.request(aP,{port:t||"all"}),rP||(rP=!0,setInterval(()=>{_o=new Map},cn.get(Ut.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),iP.user.addListener(()=>{_o=new Map}))}async function I6(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 w6(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var nP,of,sP,cn,Ut,Ta,iP,eP,T6,g6,R6,A6,tP,sf,oP,O6,b6,_o,rP,af=Re(()=>{nP=x(nn());sr();Pu();of=x(hu());Ae();sP=require("uuid"),cn=x(re()),Ut=x(U()),Ta=x(K()),iP=x(Uc());vu();ga();eP=(0,Ta.loggerWithTag)("auth-event");cn.initSync();T6=cn.get(Ut.CONFIG_PARAMS.HTTP_CORSACCESSLIST),g6=cn.get(Ut.CONFIG_PARAMS.HTTP_CORS),R6=cn.get(Ut.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),A6=cn.get(Ut.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),tP=at({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),sf=cn.get(Ut.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,oP=cn.get(Ut.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,O6=cn.get(Ut.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,b6=cn.get(Ut.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,_o=new Map;je.onInvalidatedUser(()=>{_o=new Map});a(y6,"bypassAuth");a(aP,"authentication");a(N6,"start");a(I6,"login");a(w6,"logout")});var EP=g((Wfe,fP)=>{"use strict";var Ie=require("joi"),cP=require("fs-extra"),uP=require("path"),Ds=tt(),lP=re(),_P=U(),dP=K(),{hdb_errors:C6}=ne(),{HDB_ERROR_MSGS:Xt}=C6,Cs=/^[a-zA-Z0-9-_]+$/;fP.exports={getDropCustomFunctionValidator:L6,setCustomFunctionValidator:M6,addComponentValidator:B6,dropCustomFunctionProjectValidator:H6,packageComponentValidator:x6,deployComponentValidator:G6,setComponentFileValidator:U6,getComponentFileValidator:v6,dropComponentFileValidator:P6};function cf(e,t,r){try{let n=lP.get(_P.CONFIG_PARAMS.COMPONENTSROOT),s=uP.join(n,t);return cP.existsSync(s)?e?t:r.message(Xt.PROJECT_EXISTS):e?r.message(Xt.NO_PROJECT):t}catch(n){return dP.error(n),r.message(Xt.VALIDATION_ERR)}}a(cf,"checkProjectExists");function Hu(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(Hu,"checkFilePath");function D6(e,t,r,n){try{let s=lP.get(_P.CONFIG_PARAMS.COMPONENTSROOT),i=uP.join(s,e,t,r+".js");return cP.existsSync(i)?r:n.message(Xt.NO_FILE)}catch(s){return dP.error(s),n.message(Xt.VALIDATION_ERR)}}a(D6,"checkFileExists");function L6(e){let t=Ie.object({project:Ie.string().pattern(Cs).custom(cf.bind(null,!0)).required().messages({"string.pattern.base":Xt.BAD_PROJECT_NAME}),type:Ie.string().valid("helpers","routes").required(),file:Ie.string().pattern(Cs).custom(D6.bind(null,e.project,e.type)).custom(Hu).required().messages({"string.pattern.base":Xt.BAD_FILE_NAME})});return Ds.validateBySchema(e,t)}a(L6,"getDropCustomFunctionValidator");function M6(e){let t=Ie.object({project:Ie.string().pattern(Cs).custom(cf.bind(null,!0)).required().messages({"string.pattern.base":Xt.BAD_PROJECT_NAME}),type:Ie.string().valid("helpers","routes").required(),file:Ie.string().custom(Hu).required(),function_content:Ie.string().required()});return Ds.validateBySchema(e,t)}a(M6,"setCustomFunctionValidator");function U6(e){let t=Ie.object({project:Ie.string().pattern(Cs).required().messages({"string.pattern.base":Xt.BAD_PROJECT_NAME}),file:Ie.string().custom(Hu).required(),payload:Ie.string().allow("").optional(),encoding:Ie.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Ds.validateBySchema(e,t)}a(U6,"setComponentFileValidator");function P6(e){let t=Ie.object({project:Ie.string().pattern(Cs).required().messages({"string.pattern.base":Xt.BAD_PROJECT_NAME}),file:Ie.string().custom(Hu).optional()});return Ds.validateBySchema(e,t)}a(P6,"dropComponentFileValidator");function v6(e){let t=Ie.object({project:Ie.string().required(),file:Ie.string().custom(Hu).required(),encoding:Ie.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Ds.validateBySchema(e,t)}a(v6,"getComponentFileValidator");function B6(e){let t=Ie.object({project:Ie.string().pattern(Cs).custom(cf.bind(null,!1)).required().messages({"string.pattern.base":Xt.BAD_PROJECT_NAME})});return Ds.validateBySchema(e,t)}a(B6,"addComponentValidator");function H6(e){let t=Ie.object({project:Ie.string().pattern(Cs).custom(cf.bind(null,!0)).required().messages({"string.pattern.base":Xt.BAD_PROJECT_NAME})});return Ds.validateBySchema(e,t)}a(H6,"dropCustomFunctionProjectValidator");function x6(e){let t=Ie.object({project:Ie.string().pattern(Cs).required().messages({"string.pattern.base":Xt.BAD_PROJECT_NAME}),skip_node_modules:Ie.boolean()});return Ds.validateBySchema(e,t)}a(x6,"packageComponentValidator");function G6(e){let t=Ie.object({project:Ie.string().pattern(Cs).required().messages({"string.pattern.base":Xt.BAD_PROJECT_NAME}),payload:Ie.string().optional().messages({"string.pattern.base":Xt.BAD_PACKAGE}),package:Ie.string().optional()});return Ds.validateBySchema(e,t)}a(G6,"deployComponentValidator")});var df=g((zfe,RP)=>{"use strict";var uf=require("joi"),lf=require("path"),hP=require("fs-extra"),{exec:F6}=require("child_process"),q6=require("util"),mP=q6.promisify(F6),xu=U(),{handleHDBError:Ra,hdb_errors:k6}=ne(),{HTTP_STATUS_CODES:Aa}=k6,Gu=re(),V6=tt(),Oa=K();Gu.initSync();var zT=Gu.get(xu.CONFIG_PARAMS.COMPONENTSROOT),pP="npm install --omit=dev --json",$6=`${pP} --dry-run`;RP.exports={installModules:Q6,auditModules:z6,installAllRootModules:Y6,uninstallRootModule:K6,linkHarperdb:W6};async function Y6(e=!1){await _f(),await Fu(e?"npm install --ignore-scripts":"npm install",Gu.get(xu.CONFIG_PARAMS.ROOTPATH))}a(Y6,"installAllRootModules");async function K6(e){await Fu(`npm uninstall ${e}`,Gu.get(xu.CONFIG_PARAMS.ROOTPATH))}a(K6,"uninstallRootModule");async function W6(){await _f(),await Fu(`npm link ${xu.PACKAGE_ROOT}`,Gu.get(xu.CONFIG_PARAMS.ROOTPATH))}a(W6,"linkHarperdb");async function Fu(e,t=void 0){let r,n;try{({stdout:r,stderr:n}=await mP(e,{cwd:t}))}catch(s){throw new Error(s.stderr.replace(`
|
|
12
12
|
`,""))}return n&&!n.includes("Debugger listening")&&Oa.error("Error running NPM command:",e,n),Oa.trace(r,n),r?.replace(`
|
|
13
|
-
`,"")}a(
|
|
13
|
+
`,"")}a(Fu,"runCommand");async function Q6(e){Oa.info(`starting installModules for request: ${e}`);let t=gP(e);if(t)throw Ra(t,t.message,Aa.BAD_REQUEST);let{projects:r,dry_run:n}=e,s=n===!0?$6:pP;await _f(),await TP(r);let i={};for(let o=0,c=r.length;o<c;o++){let u=r[o];i[u]={npm_output:null,npm_error:null};let _=lf.join(zT,u),l,d=null;try{let{stdout:f,stderr:E}=await mP(s,{cwd:_});l=f?f.replace(`
|
|
14
14
|
`,""):null,d=E?E.replace(`
|
|
15
|
-
`,""):null}catch(f){f.stderr?i[u].npm_error=
|
|
16
|
-
`);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(eP,"parseNPMStdErr");async function I6(e){Oa.info(`starting auditModules for request: ${e}`);let t=rP(e);if(t)throw Ra(t,t.message,Aa.BAD_REQUEST);let{projects:r}=e;await Xd(),await tP(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=Jd.join(xT,o);n[o]={npm_output:null,npm_error:null};try{let u=await ku("npm audit --json",c);n[o].npm_output=JSON.parse(u)}catch(u){n[o].npm_error=eP(u.stderr)}}return Oa.info(`finished auditModules with response ${n}`),n}a(I6,"auditModules");async function Xd(){try{return await ku("npm -v"),!0}catch{throw Ra(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",Aa.BAD_REQUEST,void 0,void 0,!0)}}a(Xd,"checkNPMInstalled");async function tP(e){if(!Array.isArray(e)||e.length===0)throw Ra(new Error,"projects argument must be an array with at least 1 element",Aa.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=Jd.join(xT,i.toString());if(!await XM.pathExists(o)){t.push(i);continue}let u=Jd.join(o,"package.json");await XM.pathExists(u)||r.push(i)}if(t.length>0)throw Ra(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Aa.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw Ra(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Aa.BAD_REQUEST,void 0,void 0,!0)}a(tP,"checkProjectPaths");function rP(e){let t=zd.object({projects:zd.array().min(1).items(zd.string()).required(),dry_run:zd.boolean().default(!1)});return A6.validateBySchema(e,t)}a(rP,"modulesValidator")});var GT=T((xfe,cP)=>{"use strict";var ba=require("fs-extra"),FT=require("path"),Zd=Q(),sP=J(),ef=P(),aP=te(),C6=Lr();cP.exports=D6;async function D6(){let e=L6(),t=aP.get(ef.CONFIG_PARAMS.ROOTPATH),r=FT.join(t,"package.json"),n={dependencies:{harperdb:"file:"+ef.PACKAGE_ROOT}},s=FT.join(t,"node_modules");await ba.ensureDir(s);let i,o=!0,c=!1;try{i=await ba.readJson(r)}catch(u){if(sP.isEmptyOrZeroLength(e))return;if(u.code!==ef.NODE_ERROR_CODES.ENOENT)throw u;o=!1}if(!sP.isEmptyOrZeroLength(e)){for(let{name:u,package:_}of e){let l=await iP(_);n.dependencies[u]=l+_}if(!o){Zd.notify("Installing components"),await oP(r,n,null);return}for(let{name:u,package:_}of e){let l=i.dependencies[u],d=await iP(_);if(l===void 0||l!==d+_){c=!0;break}}}for(let u in i.dependencies)n.dependencies[u]===void 0&&(Zd.notify("Removing component",u),c=!0);c&&(Zd.notify("Updating components."),await oP(r,n,i))}a(D6,"installComponents");function L6(){let e=C6.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(L6,"getComponentsConfig");async function iP(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":FT.extname(e)||await ba.pathExists(e)?"file:":"github:"}a(iP,"getPkgPrefix");async function oP(e,t,r){Zd.trace("npm installing components package.json",t),await ba.writeFile(e,JSON.stringify(t,null," "));try{await jd().installAllRootModules(aP.get(ef.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?await ba.writeFile(e,JSON.stringify(r,null," ")):await ba.unlink(e),n}}a(oP,"installPackages")});var VT=T((qfe,dP)=>{"use strict";var qe=require("fs-extra"),qT=require("fast-glob"),pe=require("path"),lP=require("tar-fs"),Gfe=require("uuid").v4,kT=require("normalize-path"),ns=JM(),yt=Q(),We=P(),mt=te(),Vu=Lr(),U6=J(),{PACKAGE_ROOT:M6}=P(),{handleHDBError:Mt,hdb_errors:P6}=re(),{basename:v6}=require("path"),B6=GT(),_P=te(),H6=P(),{Readable:x6}=require("stream"),{isMainThread:F6}=require("worker_threads"),{HDB_ERROR_MSGS:Eo,HTTP_STATUS_CODES:Pt}=P6,G6=pe.join(M6,"application-template"),uP=pe.join(mt.get(We.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp");function q6(){yt.trace("getting custom api status");let e={};try{e={port:mt.get(We.CONFIG_PARAMS.HTTP_PORT),directory:mt.get(We.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Mt(new Error,Eo.FUNCTION_STATUS,Pt.INTERNAL_SERVER_ERROR,yt.ERR,t)}return e}a(q6,"customFunctionsStatus");function k6(){yt.trace("getting custom api endpoints");let e={},t=mt.get(We.CONFIG_PARAMS.COMPONENTSROOT);try{qT.sync(kT(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:qT.sync(kT(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:qT.sync(kT(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Mt(new Error,Eo.GET_FUNCTIONS,Pt.INTERNAL_SERVER_ERROR,yt.ERR,r)}return e}a(k6,"getCustomFunctions");function V6(e){e.project&&(e.project=pe.parse(e.project).name),e.file&&(e.file=pe.parse(e.file).name);let t=ns.getDropCustomFunctionValidator(e);if(t)throw Mt(t,t.message,Pt.BAD_REQUEST);yt.trace("getting custom api endpoint file content");let r=mt.get(We.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=pe.join(r,n,s,i+".js");try{return qe.readFileSync(o,{encoding:"utf8"})}catch(c){throw Mt(new Error,Eo.GET_FUNCTION,Pt.INTERNAL_SERVER_ERROR,yt.ERR,c)}}a(V6,"getCustomFunction");function $6(e){e.project&&(e.project=pe.parse(e.project).name),e.file&&(e.file=pe.parse(e.file).name);let t=ns.setCustomFunctionValidator(e);if(t)throw Mt(t,t.message,Pt.BAD_REQUEST);yt.trace("setting custom function file content");let r=mt.get(We.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{return qe.outputFileSync(pe.join(r,n,s,i+".js"),o),`Successfully updated custom function: ${i}.js`}catch(c){throw Mt(new Error,Eo.SET_FUNCTION,Pt.INTERNAL_SERVER_ERROR,yt.ERR,c)}}a($6,"setCustomFunction");function Y6(e){e.project&&(e.project=pe.parse(e.project).name),e.file&&(e.file=pe.parse(e.file).name);let t=ns.getDropCustomFunctionValidator(e);if(t)throw Mt(t,t.message,Pt.BAD_REQUEST);yt.trace("dropping custom function file");let r=mt.get(We.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{return qe.unlinkSync(pe.join(r,n,s,i+".js")),`Successfully deleted custom function: ${i}.js`}catch(o){throw Mt(new Error,Eo.DROP_FUNCTION,Pt.INTERNAL_SERVER_ERROR,yt.ERR,o)}}a(Y6,"dropCustomFunction");function K6(e){e.project&&(e.project=pe.parse(e.project).name);let t=ns.addComponentValidator(e);if(t)throw Mt(t,t.message,Pt.BAD_REQUEST);yt.trace("adding component");let r=mt.get(We.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=pe.join(r,n);return qe.mkdirSync(s,{recursive:!0}),qe.copySync(G6,s),`Successfully added project: ${n}`}catch(s){throw Mt(new Error,Eo.ADD_FUNCTION,Pt.INTERNAL_SERVER_ERROR,yt.ERR,s)}}a(K6,"addComponent");function W6(e){e.project&&(e.project=pe.parse(e.project).name);let t=ns.dropCustomFunctionProjectValidator(e);if(t)throw Mt(t,t.message,Pt.BAD_REQUEST);yt.trace("dropping custom function project");let r=mt.get(We.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=mt.get(We.CONFIG_PARAMS.APPS);if(!U6.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 Vu.updateConfigValue(We.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=pe.join(r,n);return qe.rmSync(i,{recursive:!0}),`Successfully deleted project: ${n}`}catch(i){throw Mt(new Error,Eo.DROP_FUNCTION_PROJECT,Pt.INTERNAL_SERVER_ERROR,yt.ERR,i)}}a(W6,"dropCustomFunctionProject");async function Q6(e){e.project&&(e.project=pe.parse(e.project).name);let t=ns.packageComponentValidator(e);if(t)throw Mt(t,t.message,Pt.BAD_REQUEST);let r=mt.get(We.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;yt.trace("packaging component",n);let s;try{s=await qe.realpath(pe.join(r,n))}catch(u){if(u.code!==We.NODE_ERROR_CODES.ENOENT)throw u;try{s=await qe.realpath(pe.join(mt.get(We.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(_){if(_.code===We.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}await qe.ensureDir(uP);let i=pe.join(uP,`${n}.tar`),o={};(e.skip_node_modules===!0||e.skip_node_modules==="true")&&(o={ignore:u=>u.includes(pe.join(s,"node_modules"))}),lP.pack(s,o).pipe(qe.createWriteStream(i,{overwrite:!0})),await new Promise(u=>setTimeout(u,2e3));let c=qe.readFileSync(i,{encoding:"base64"});return await qe.remove(i),{project:n,payload:c}}a(Q6,"packageComponent");async function z6(e){e.project&&(e.project=pe.parse(e.project).name);let t=ns.deployComponentValidator(e);if(t)throw Mt(t,t.message,Pt.BAD_REQUEST);let r=mt.get(We.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i}=e;if(yt.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let o;if(s){o=pe.join(r,n),i="file:"+o,await qe.ensureDir(o);let f=x6.from(Buffer.from(s,"base64"));await new Promise((h,S)=>{f.pipe(lP.extract(o,{finish:h})).on("error",S)});let E=await qe.readdir(o);E.length===1&&E[0]==="package"&&(await qe.copy(pe.join(o,"package"),o),await qe.remove(pe.join(o,"package")))}if(await Vu.addConfig(n,{package:i}),!s){await B6();let f=_P.get(H6.CONFIG_PARAMS.ROOTPATH);o=pe.join(f,"node_modules",n)}if(F6)return;let c=new Map;c.isWorker=!0;let u=(rf(),ne(tf)),_;u.setErrorReporter(f=>_=f);let l=v6(o),d=u.component_errors.get(l);try{await u.loadComponent(o,c)}finally{u.component_errors.set(l,d)}if(_)throw _;return yt.info("Installed component"),`Successfully deployed: ${n}`}a(z6,"deployComponent");async function J6(){let e=Vu.getConfiguration(),t=[];for(let o in e)if(e[o]?.package){if(e[o].package.startsWith("file:"))continue;t.push(Object.assign({},e[o],{name:o}))}let r=a(async(o,c)=>{try{let u=await qe.readdir(o,{withFileTypes:!0});for(let _ of u){let l=_.name;if(l.startsWith(".")||l==="node_modules")continue;let d=pe.join(o,l);if(_.isDirectory()||_.isSymbolicLink()){let f={name:l,entries:[]};c.entries.push(f),await r(d,f)}else{let f=await qe.stat(d),E={name:pe.basename(l),mtime:f.mtime,size:f.size};c.entries.push(E)}}return c}catch(u){return yt.warn("Error loading package",u),{error:u.toString(),entries:[]}}},"walk_dir"),n=await r(mt.get(We.CONFIG_PARAMS.COMPONENTSROOT),{name:mt.get(We.CONFIG_PARAMS.COMPONENTSROOT).split(pe.sep).slice(-1).pop(),entries:t});for(let o of n.entries)if(o.package){let c=await r(pe.join(mt.get(We.CONFIG_PARAMS.ROOTPATH),"node_modules",o.name),{name:o.name,entries:[]});Object.assign(o,c)}let i=(rf(),ne(tf)).component_errors;for(let o of t){let c=i.get(o.name);c?o.error=i.get(o.name):c===void 0&&(o.error="The component has not been loaded yet (may need a restart)")}return n}a(J6,"getComponents");async function X6(e){let t=ns.getComponentFileValidator(e);if(t)throw Mt(t,t.message,Pt.BAD_REQUEST);let n=Vu.getConfigObj()[e.project]||e.project==="harperdb"?pe.join(_P.get(We.CONFIG_PARAMS.ROOTPATH),"node_modules"):mt.get(We.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await qe.stat(pe.join(n,e.project,e.file));return{message:await qe.readFile(pe.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===We.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${pe.join(e.project,e.file)}'`):i}}a(X6,"getComponentFile");async function j6(e){let t=ns.setComponentFileValidator(e);if(t)throw Mt(t,t.message,Pt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=pe.join(mt.get(We.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);return e.payload!==void 0?(await qe.ensureFile(n),await qe.outputFile(n,e.payload,r)):await qe.ensureDir(n),"Successfully set component: "+e.file}a(j6,"setComponentFile");async function Z6(e){let t=ns.dropComponentFileValidator(e);if(t)throw Mt(t,t.message,Pt.BAD_REQUEST);let r=e.file?pe.join(e.project,e.file):e.project,n=pe.join(mt.get(We.CONFIG_PARAMS.COMPONENTSROOT),r);return await qe.pathExists(n)&&await qe.remove(n),Vu.deleteConfigFromFile([e.project]),"Successfully dropped: "+r}a(Z6,"dropComponent");dP.exports={customFunctionsStatus:q6,getCustomFunctions:k6,getCustomFunction:V6,setCustomFunction:$6,dropCustomFunction:Y6,addComponent:K6,dropCustomFunctionProject:W6,packageComponent:Q6,deployComponent:z6,getComponents:J6,getComponentFile:X6,setComponentFile:j6,dropComponent:Z6}});var $T=T((Vfe,EP)=>{"use strict";var ss=require("joi"),fP=rt();EP.exports={readTransactionLogValidator:e9,deleteTransactionLogsBeforeValidator:t9};function e9(e){let t=ss.object({schema:ss.string().required(),table:ss.string().required(),from:ss.date().timestamp(),to:ss.date().timestamp(),limit:ss.number().min(1)});return fP.validateBySchema(e,t)}a(e9,"readTransactionLogValidator");function t9(e){let t=ss.object({schema:ss.string().required(),table:ss.string().required(),timestamp:ss.date().timestamp().required()});return fP.validateBySchema(e,t)}a(t9,"deleteTransactionLogsBeforeValidator")});var sf=T((Yfe,TP)=>{"use strict";var YT=P(),nf=Nt(),hP=J(),mP=te(),pP=Ss(),{handleHDBError:Na,hdb_errors:r9}=re(),{HTTP_STATUS_CODES:ya}=r9,{readTransactionLogValidator:n9,deleteTransactionLogsBeforeValidator:s9}=$T(),SP="This operation relies on clustering and cannot run with it disable.",i9="Logs successfully deleted from transaction log.",o9="All logs successfully deleted from transaction log.";TP.exports={readTransactionLog:a9,deleteTransactionLogsBefore:c9};async function*a9(e){let t=n9(e);if(t)throw Na(t,t.message,ya.BAD_REQUEST,void 0,void 0,!0);if(!mP.get(YT.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Na(new Error,SP,ya.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:n}=e,s=hP.checkSchemaTableExist(r,n);if(s)throw Na(new Error,s,ya.NOT_FOUND,void 0,void 0,!0);let i=pP.createNatsTableStreamName(r,n),o=await nf.viewStreamIterator(i,parseInt(e.from),e.limit);for await(let c of o){let u=Math.floor(c?.nats_timestamp/1e6);if(e.to&&u>e.to)break;let _={operation:c?.entry?.operation,user:c?.entry?.__origin?.user,timestamp:u,records:c?.entry?.records,attributes:c?.entry?.attributes};c?.entry?.operation===YT.OPERATIONS_ENUM.DELETE&&(_.hash_values=c?.entry?.hash_values),yield _}}a(a9,"readTransactionLog");async function c9(e){let t=s9(e);if(t)throw Na(t,t.message,ya.BAD_REQUEST,void 0,void 0,!0);if(!mP.get(YT.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Na(new Error,SP,ya.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:n,timestamp:s}=e,i=hP.checkSchemaTableExist(r,n);if(i)throw Na(new Error,i,ya.NOT_FOUND,void 0,void 0,!0);let o=pP.createNatsTableStreamName(r,n),{jsm:c}=await nf.getNATSReferences(),u=await nf.getStreamInfo(o),_=new Date(u.state.first_ts).getTime();if(s<=_)return`No transactions exist before: ${s}`;let l=i9,d,f=new Date(u.state.last_ts).getTime();return s>f?(d=u.state.last_seq+1,l=o9):d=(await nf.viewStream(o,parseInt(s),1))[0].nats_sequence,await c.streams.purge(o,{seq:d}),l}a(c9,"deleteTransactionLogsBefore")});var RP=T((Wfe,gP)=>{"use strict";var KT=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}};gP.exports=KT});var OP=T((zfe,AP)=>{"use strict";var WT=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};AP.exports=WT});var zT=T((Xfe,NP)=>{"use strict";var bP=RP(),u9=OP(),{HDB_ERROR_MSGS:l9}=Nr(),QT=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=l9.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 bP(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let u=new u9(c,s[c]);i.push(u)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new bP(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}};NP.exports=QT});var uf=T((Zfe,qP)=>{"use strict";var JT=en(),of=Zr(),un=od(),Ku=Hi(),XT=ki(),_9=cS(),d9=BD(),Wu=tn(),af=pS(),wt=Q(),f9=gS(),E9=Od(),h9=rT(),m9=Nd(),p9=nT(),S9=sT(),T9=aT(),g9=uT(),jT=dT(),Ds=J(),R9=MU(),ZT=pT(),IP=kd(),cn=P(),CP=MM(),A9=da(),DP=pu(),LP=(Wd(),ne(xu)),UP=Lr(),Gr=VT(),O9=require("alasql"),MP=sf(),PP=jd(),vP=zT(),{handleHDBError:Sr,hdb_errors:BP}=re(),{HDB_ERROR_MSGS:kt,HTTP_STATUS_CODES:$u}=BP,k=new Map,HP="delete",pi="insert",Ls="read",ho="update",Yu="describe",yP=Ku.describeSchema.name,wP=Ku.describeTable.name,xP={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},b9="catchup",N9="handleGetJob",y9="handleGetJobsByStartDate",cf={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},w9=[un.createTable.name,un.createAttribute.name,un.dropTable.name,un.dropAttribute.name],FP={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},z=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};k.set(JT.insert.name,new z(!1,[pi]));k.set(JT.update.name,new z(!1,[ho]));k.set(JT.upsert.name,new z(!1,[pi,ho]));k.set(of.searchByConditions.name,new z(!1,[Ls]));k.set(of.searchByHash.name,new z(!1,[Ls]));k.set(of.searchByValue.name,new z(!1,[Ls]));k.set(of.search.name,new z(!1,[Ls]));k.set(un.createSchema.name,new z(!0,[]));k.set(un.createTable.name,new z(!0,[]));k.set(un.createAttribute.name,new z(!1,[pi]));k.set(un.dropSchema.name,new z(!0,[]));k.set(un.dropTable.name,new z(!0,[]));k.set(un.dropAttribute.name,new z(!0,[]));k.set(Ku.describeSchema.name,new z(!1,[Ls]));k.set(Ku.describeTable.name,new z(!1,[Ls]));k.set(XT.deleteRecord.name,new z(!1,[HP]));k.set(Wu.addUser.name,new z(!0,[]));k.set(Wu.alterUser.name,new z(!0,[]));k.set(Wu.dropUser.name,new z(!0,[]));k.set(Wu.listUsersExternal.name,new z(!0,[]));k.set(af.listRoles.name,new z(!0,[]));k.set(af.addRole.name,new z(!0,[]));k.set(af.alterRole.name,new z(!0,[]));k.set(af.dropRole.name,new z(!0,[]));k.set(f9.name,new z(!0,[]));k.set(E9.name,new z(!0,[]));k.set(h9.name,new z(!0,[]));k.set(m9.name,new z(!0,[]));k.set(p9.name,new z(!0,[]));k.set(S9.name,new z(!0,[]));k.set(jT.setRoutes.name,new z(!0,[]));k.set(jT.getRoutes.name,new z(!0,[]));k.set(jT.deleteRoutes.name,new z(!0,[]));k.set(UP.setConfiguration.name,new z(!0,[]));k.set(T9.clusterStatus.name,new z(!0,[]));k.set(g9.name,new z(!0,[]));k.set(ZT.getFingerprint.name,new z(!0,[]));k.set(ZT.setLicense.name,new z(!0,[]));k.set(XT.deleteFilesBefore.name,new z(!0,[]));k.set(XT.deleteAuditLogsBefore.name,new z(!0,[]));k.set(IP.restart.name,new z(!0,[]));k.set(IP.restartService.name,new z(!0,[]));k.set(_9.name,new z(!0,[]));k.set(d9.name,new z(!0,[Ls]));k.set(A9.systemInformation.name,new z(!0,[]));k.set(UP.getConfiguration.name,new z(!0,[]));k.set(MP.readTransactionLog.name,new z(!0,[]));k.set(MP.deleteTransactionLogsBefore.name,new z(!0,[]));k.set(PP.installModules.name,new z(!0,[]));k.set(PP.auditModules.name,new z(!0,[]));k.set(DP.createTokens.name,new z(!1,[]));k.set(DP.refreshOperationToken.name,new z(!1,[]));k.set(LP.login.name,new z(!1,[]));k.set(LP.logout.name,new z(!1,[]));k.set(Gr.customFunctionsStatus.name,new z(!0,[]));k.set(Gr.getCustomFunctions.name,new z(!0,[]));k.set(Gr.getComponents.name,new z(!0,[]));k.set(Gr.getComponentFile.name,new z(!0,[]));k.set(Gr.setComponentFile.name,new z(!0,[]));k.set(Gr.dropComponent.name,new z(!0,[]));k.set(Gr.getCustomFunction.name,new z(!0,[]));k.set(Gr.setCustomFunction.name,new z(!0,[]));k.set(Gr.dropCustomFunction.name,new z(!0,[]));k.set(Gr.addComponent.name,new z(!0,[]));k.set(Gr.dropCustomFunctionProject.name,new z(!0,[]));k.set(Gr.packageComponent.name,new z(!0,[]));k.set(Gr.deployComponent.name,new z(!0,[]));k.set(ZT.getRegistrationInfo.name,new z(!1,[]));k.set(Wu.userInfo.name,new z(!1,[]));k.set(Ku.describeAll.name,new z(!1,[]));k.set(N9,new z(!1,[]));k.set(y9,new z(!0,[]));k.set(b9,new z(!0,[]));k.set(cf.CSV_DATA_LOAD,new z(!1,[pi,ho]));k.set(cf.CSV_URL_LOAD,new z(!1,[pi,ho]));k.set(cf.CSV_FILE_LOAD,new z(!1,[pi,ho]));k.set(cf.IMPORT_FROM_S3,new z(!1,[pi,ho]));k.set(FP.EXPORT_TO_S3,new z(!0,[]));k.set(FP.EXPORT_LOCAL,new z(!0,[]));k.set(cn.VALID_SQL_OPS_ENUM.DELETE,new z(!1,[HP]));k.set(cn.VALID_SQL_OPS_ENUM.SELECT,new z(!1,[Ls]));k.set(cn.VALID_SQL_OPS_ENUM.INSERT,new z(!1,[pi]));k.set(cn.VALID_SQL_OPS_ENUM.UPDATE,new z(!1,[ho]));qP.exports={verifyPerms:C9,verifyPermsAst:I9,verifyBulkLoadAttributePerms:L9};function I9(e,t,r){if(Ds.isEmptyOrZeroLength(e))throw wt.info("verify_perms_ast has an empty user parameter"),Sr(new Error);if(Ds.isEmptyOrZeroLength(t))throw wt.info("verify_perms_ast has an empty user parameter"),Sr(new Error);if(Ds.isEmptyOrZeroLength(r))throw wt.info("verify_perms_ast has a null operation parameter"),Sr(new Error);try{let n=new vP,s=new R9(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw wt.info("No schemas defined in verifyPermsAst(), will not continue."),Sr(new Error);let c=!!t.role.permission.super_user,u=i.includes("system");if(u&&xP[r])throw Sr(new Error,kt.DROP_SYSTEM,$u.FORBIDDEN);if(c&&!u)return null;let _=CP.getRolePermissions(t.role);t.role.permission=_,!c&&e instanceof O9.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(_));for(let d=0;d<i.length;d++){let f=s.getTablesBySchemaName(i[d]);f&&o.set(i[d],f)}let l=GP(t,r,o,n);return l||(o.forEach((d,f)=>{for(let E=0;E<d.length;E++){let h=s.getAttributesBySchemaTableName(f,d[E]),S=tg(t.role.permission,f,d[E]);eg(h,S,r,d[E],f,n)}}),n.getPermsResponse())}catch(n){throw Sr(n)}}a(I9,"verifyPermsAst");function C9(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw wt.info("null required parameter in verifyPerms"),Sr(new Error,kt.DEFAULT_INVALID_REQUEST,$u.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 vP;if(Ds.isEmptyOrZeroLength(e.hdb_user.role)||Ds.isEmptyOrZeroLength(e.hdb_user.role.permission))return wt.info(`User ${e.hdb_user.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(kt.USER_HAS_NO_PERMS(e.hdb_user.username));let u=!!e.hdb_user.role.permission.super_user,_=e.hdb_user.role.permission.structure_user,l=o.has(cn.SYSTEM_SCHEMA_NAME)||s===cn.SYSTEM_SCHEMA_NAME;if(l&&xP[r])throw Sr(new Error,kt.DROP_SYSTEM,$u.FORBIDDEN);if(u&&!l||_===!0&&(r===un.createSchema.name||r===un.dropSchema.name))return null;if(w9.indexOf(r)>=0&&(_===!0||Array.isArray(_)))return _===!0||_.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let d=CP.getRolePermissions(e.hdb_user.role);if(e.hdb_user.role.permission=d,r===yP||r===wP){if(s===cn.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(kt.SCHEMA_PERM_ERROR(s));if(!d.super_user){if(r===yP&&(!d[s]||!d[s][Yu]))return c.handleInvalidItem(kt.SCHEMA_NOT_FOUND(s));if(r===wP&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][Yu]))return c.handleInvalidItem(kt.TABLE_NOT_FOUND(s,i))}}let f=GP(e.hdb_user,r,o,c,n);if(f)return f;if(k.get(r)&&k.get(r).perms.length===0)return null;if(!u&&e.get_attributes&&cn.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let S=[],p=d[s].tables[i];p[cn.PERMS_CRUD_ENUM.READ]&&(p.attribute_permissions.length>0?p.attribute_permissions.filter(A=>A[cn.PERMS_CRUD_ENUM.READ]).forEach(A=>{S.push(A.attribute_name)}):S=global.hdb_schema[s][i].attributes.map(R=>R.attribute),e.get_attributes=S)}let E=D9(e),h=tg(e.hdb_user.role.permission,s,i);return eg(E,h,r,i,s,c,n),c.getPermsResponse()}a(C9,"verifyPerms");function GP(e,t,r,n,s){if(Ds.arrayHasEmptyValues([e,t,r]))throw wt.info("hasPermissions has an invalid parameter"),Sr(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||k.get(t).requires_su))return null;if(!k.get(t))throw wt.info(`operation ${t} not found.`),Sr(new Error,kt.OP_NOT_FOUND(t),$u.BAD_REQUEST);if(k.get(t)&&k.get(t).requires_su)return wt.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(kt.OP_IS_SU_ONLY(t));let c=r.keys();for(let u of c){try{if(u&&!o[u]||o[u][Yu]===!1){n.addInvalidItem(kt.SCHEMA_NOT_FOUND(u));continue}}catch{n.addInvalidItem(kt.SCHEMA_NOT_FOUND(u));continue}let _=r.get(u);for(let l of _){let d=o[u].tables[l];if(!d||d[Yu]===!1)n.addInvalidItem(kt.TABLE_NOT_FOUND(u,l));else try{let f=[],E=k.get(t).perms;!Ds.isEmpty(s)&&E.includes(s)&&(E=[s]);for(let h=0;h<E.length;h++){let S=E[h],p=d[S];(p==null||p===!1)&&(wt.info(`Required ${S} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),f.push(S))}f.length>0&&n.addUnauthorizedTable(u,l,f)}catch(f){let E=kt.UNKNOWN_OP_AUTH_ERROR(t,u,l);throw wt.error(E),wt.error(f),Sr(BP.CHECK_LOGS_WRAPPER(E))}}}return r.size<2?n.getPermsResponse():null}a(GP,"hasPermissions");function eg(e,t,r,n,s,i,o){if(!e||!t)throw wt.info("no attributes specified in checkAttributePerms."),Sr(new Error);let c=k.get(r).perms;if(!c||c==="")throw wt.info(`no permissions found for ${r} in checkAttributePerms().`),Sr(new Error);if(Ds.isEmptyOrZeroLength(t))return wt.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let u={};for(let l of e){let d=t.get(l);if(d){if(d[Yu]===!1){i.addInvalidItem(kt.ATTR_NOT_FOUND(s,n,l),s,n);continue}if(c)for(let f of c){if(cn.TIME_STAMP_NAMES.includes(d.attribute_name)&&f!==Ls)throw Sr(new Error,kt.SYSTEM_TIMESTAMP_PERMS_ERR,$u.FORBIDDEN);d[f]===!1&&(u[d.attribute_name]?u[d.attribute_name].push(f):u[d.attribute_name]=[f])}}else i.addInvalidItem(kt.ATTR_NOT_FOUND(s,n,l),s,n)}let _=Object.keys(u);_.length>0&&i.addUnauthorizedAttributes(_,s,n,u)}a(eg,"checkAttributePerms");function D9(e){let t=new Set;try{if(e.action)return t;if(e.operation===cn.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){wt.info(r)}return t}a(D9,"getRecordAttributes");function tg(e,t,r){let n=new Map;if(Ds.isEmpty(e))return wt.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{wt.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(tg,"getAttributePermissions");function L9(e,t,r,n,s,i,o){let c=new Set(i),u=tg(e,n,s);eg(c,u,t,s,n,o,r)}a(L9,"verifyBulkLoadAttributePerms")});var _f=T((tEe,KP)=>{"use strict";KP.exports={evaluateSQL:$9,processAST:YP,convertSQLToAST:$P,checkASTPermissions:VP};var U9=en(),kP=require("util"),M9=kP.callbackify(U9.insert),P9=Zr().search,v9=CC().update,B9=kP.callbackify(v9),H9=LC().convertDelete,Si=require("alasql"),x9=uf(),lf=Q(),F9=W_(),G9=J(),Qu=P(),{hdb_errors:q9,handleHDBError:rg}=re(),{HTTP_STATUS_CODES:ng}=q9;F9(Si);var k9=403,V9="There was a problem performing this insert. Please check the logs and try again.",sg=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function $9(e,t){let r=e.parsed_sql_object;if(!r){r=$P(e.sql);let n,s=r.ast.statements[0];if(s instanceof Si.yy.Insert?n=s.into.databaseid:s instanceof Si.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Si.yy.Update||s instanceof Si.yy.Delete?n=s.table.databaseid:lf.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Si.yy.Select)&&G9.isEmptyOrZeroLength(n))return t("No schema specified",null)}YP(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a($9,"evaluateSQL");function VP(e,t){let r;try{r=x9.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(VP,"checkASTPermissions");function $P(e){let t=new sg;if(!e)throw rg(new Error,"The 'sql' parameter is missing from the request body",ng.BAD_REQUEST);try{let r=e.trim(),n=Si.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
|
|
17
|
-
`);throw n[1]?rg(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,ng.BAD_REQUEST):rg(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",ng.BAD_REQUEST)}return t}a($P,"convertSQLToAST");function YP(e,t,r){try{let n=Y9;if(!e.bypass_auth&&!t.permissions_checked){let i=VP(e,t);if(i&&i.length>0)return r(k9,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case Qu.VALID_SQL_OPS_ENUM.SELECT:n=P9,s=t.ast.statements[0];break;case Qu.VALID_SQL_OPS_ENUM.INSERT:n=K9;break;case Qu.VALID_SQL_OPS_ENUM.UPDATE:n=B9;break;case Qu.VALID_SQL_OPS_ENUM.DELETE:n=H9;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(YP,"processAST");function Y9(e,t){lf.info(e),t("unknown sql statement")}a(Y9,"nullFunction");function K9({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=W9(i,e.values)}catch(o){return r(o)}M9(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(u){lf.error(`Error delete new_attributes from insert response: ${u}`)}r(null,c)})}a(K9,"convertInsert");function W9(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]]=Si.compile(`SELECT ${s.toString()} AS [${Qu.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw lf.error(r),new Error(V9)}}a(W9,"createDataObjects")});var ig=T((nEe,QP)=>{"use strict";var{S3:Q9,GetObjectCommand:z9}=require("@aws-sdk/client-s3");QP.exports={getFileStreamFromS3:J9,getS3AuthObj:WP};async function J9(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await WP(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new z9(r))).Body}a(J9,"getFileStreamFromS3");function WP(e,t,r){return new Q9({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(WP,"getS3AuthObj")});var df=T((iEe,nv)=>{"use strict";var ag=Zr(),X9=_f(),j9=ig(),{AsyncParser:Z9,Transform:e7}=require("json2csv"),Ju=require("stream"),qr=J(),og=require("fs-extra"),t7=require("path"),ln=Q(),{promisify:XP}=require("util"),zu=J(),{handleHDBError:pt,hdb_errors:r7}=re(),{HDB_ERROR_MSGS:Tr,HTTP_STATUS_CODES:St}=r7,{streamAsJSON:n7}=(Oh(),ne(KO)),{Upload:s7}=require("@aws-sdk/lib-storage"),zP=["search_by_value","search_by_hash","sql","search_by_conditions"],JP=["json","csv"],jP="json",ZP="csv",i7="Successfully exported JSON locally.",o7="Successfully exported CSV locally.",a7=1e3,c7=ag.searchByHash,u7=ag.searchByValue,l7=XP(X9.evaluateSQL),_7=XP(Ju.finished);nv.exports={export_to_s3:h7,export_local:d7,toCsvStream:ev};async function d7(e){ln.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=tv(e);if(!qr.isEmpty(t))throw ln.error(t),pt(new Error,t,St.BAD_REQUEST,void 0,void 0,!0);if(qr.isEmpty(e.path))throw ln.error(Tr.MISSING_VALUE("path")),pt(new Error,Tr.MISSING_VALUE("path"),St.BAD_REQUEST,void 0,void 0,!0);let r=(qr.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(t7.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=qr.buildFolderPath(e.path,r);await f7(e.path);let s=await rv(e);return await E7(n,e.format,s)}a(d7,"export_local");async function f7(e){if(ln.trace("in confirmPath"),qr.isEmptyOrZeroLength(e))throw pt(new Error,`Invalid path: ${e}`,St.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await og.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,ln.error(n),pt(new Error,n,St.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 ln.error(r),pt(new Error,r,St.BAD_REQUEST,void 0,void 0,!0)}return!0}a(f7,"confirmPath");async function E7(e,t,r){if(ln.trace("in saveToLocal"),zu.isEmptyOrZeroLength(e))throw pt(new Error,Tr.INVALID_VALUE("file_path"),St.BAD_REQUEST,void 0,void 0,!0);if(zu.isEmptyOrZeroLength(t))throw pt(new Error,Tr.INVALID_VALUE("Source format"),St.BAD_REQUEST,void 0,void 0,!0);if(zu.isEmpty(r))throw pt(new Error,Tr.NOT_FOUND("Data"),St.BAD_REQUEST,void 0,void 0,!0);if(t===jP){let n=og.createWriteStream(e);return n7(r).pipe(n),await _7(n),{message:i7,path:e}}else if(t===ZP){let n=og.createWriteStream(e),s=Ju.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(l=>({label:l,value:l})));let c={objectMode:!0};return await new Z9(i,c).fromInput(s).toOutput(n).promise(!1),{message:o7,path:e}}throw pt(new Error,Tr.INVALID_VALUE("format"),St.BAD_REQUEST)}a(E7,"saveToLocal");async function h7(e){if(!e.s3||Object.keys(e.s3).length===0)throw pt(new Error,Tr.MISSING_VALUE("S3 object"),St.BAD_REQUEST);if(qr.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw pt(new Error,Tr.MISSING_VALUE("aws_access_key_id"),St.BAD_REQUEST);if(qr.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw pt(new Error,Tr.MISSING_VALUE("aws_secret_access_key"),St.BAD_REQUEST);if(qr.isEmptyOrZeroLength(e.s3.bucket))throw pt(new Error,Tr.MISSING_VALUE("bucket"),St.BAD_REQUEST);if(qr.isEmptyOrZeroLength(e.s3.key))throw pt(new Error,Tr.MISSING_VALUE("key"),St.BAD_REQUEST);if(qr.isEmptyOrZeroLength(e.s3.region))throw pt(new Error,Tr.MISSING_VALUE("region"),St.BAD_REQUEST);let t=tv(e);if(!qr.isEmpty(t))throw pt(new Error,t,St.BAD_REQUEST);ln.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await rv(e)}catch(u){throw ln.error(u),u}let n,s=await j9.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new Ju.PassThrough;if(e.format===ZP){i=e.s3.key+".csv";let u=ev(r,r.getColumns?.());u.on("error",_=>{throw _}),u.pipe(o)}else if(e.format===jP){i=e.s3.key+".json";let u=new Ju.Readable;u.pipe(o),u.on("error",d=>{throw d}),u.push("[");let _=r.length,l="";for(let[d,f]of r.entries()){let E=d===_-1?JSON.stringify(f):JSON.stringify(f)+",";l+=E,d!==0&&d%a7===0&&(u.push(l),l="")}l.length!==0&&u.push(l),u.push("]"),u.push(null)}else throw pt(new Error,Tr.INVALID_VALUE("format"),St.BAD_REQUEST);return new s7({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(h7,"export_to_s3");function ev(e,t){let r=Ju.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 e7(n,s);return r.pipe(i)}a(ev,"toCsvStream");function tv(e){if(ln.trace("in exportCoreValidation"),qr.isEmpty(e.format))return"format missing";if(JP.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${JP.join(", ")}`;let t=e.search_operation.operation;if(qr.isEmpty(t))return"search_operation.operation missing";if(zP.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${zP.join(", ")}`}a(tv,"exportCoreValidation");async function rv(e){ln.trace("in getRecords");let t,r;if(zu.isEmpty(e.search_operation)||zu.isEmptyOrZeroLength(e.search_operation.operation))throw pt(new Error,Tr.INVALID_VALUE("Search operation"),St.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=u7;break;case"search_by_hash":t=c7;break;case"search_by_conditions":t=ag.searchByConditions;break;case"sql":t=l7;break;default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,ln.error(r),pt(new Error,r,St.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(rv,"getRecords")});var _v={};Ye(_v,{contentTypes:()=>dg,findBestSerializer:()=>Ef,getDeserializer:()=>po,registerContentHandlers:()=>fg,serialize:()=>hf,serializeMessage:()=>mi});function m7(e){try{return e?.[0]===123?_g(e):e}catch{return e}}function fg(e){e.register(S7,{serializers:[{regex:/^application\/json$/,serializer:hc},{regex:/^application\/cbor$/,serializer:function(t){return new mo.EncoderStream(ju).end(t)}},{regex:/^application\/(x-)?msgpack$/,serializer:function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?ff.Readable.from((0,is.encodeIter)(t,ju)):(0,is.pack)(t)}},{regex:/^text\/csv$/,serializer:function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,cg.toCsvStream)(t)}}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,is.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,mo.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function Ef(e){let r=(e.headers.asObject||e.headers).accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let u of c){let[_,...l]=u.split(/\s*;\s*/),d=1,f={q:1};for(let h of l){let S=h.indexOf("=");f[h.substring(0,S)]=h.substring(S+1)}d=+f.q;let E=vt.get(_);if(E){let h=(E.q||1)*d;h>s&&(n=E,i=E.type||_,s=h,o=f)}}if(!n){if(r)return{serializer(){this.code(406).send("No supported content types found in Accept header, supported types include: "+Array.from(vt.keys()).join(", "))}};n=vt.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function hf(e,t,r){let n=iv&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=Ef(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[Symbol.iterator]||e[Symbol.asyncIterator])&&i.serializer.serializeStream){let o=i.serializer.serializeStream(e,r);return n&&(r.headers.set("Content-Encoding","br"),o=o.pipe((0,Us.createBrotliCompress)({params:{[Us.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?Us.constants.BROTLI_MODE_TEXT:Us.constants.BROTLI_MODE_GENERIC,[Us.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>iv?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,Us.brotliCompress)(s,(c,u)=>{c?o(c):i(u)}))):s}function mi(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return Xu(e);let r=t.serialize;if(r)return r(e);let n=Ef(t);return r=t.serialize=n.serializer.serialize,r(e)}function T7(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 po(e,t){e||(e="");let r=e.indexOf(";"),n;r>-1&&(n=e.slice(r+1),e=e.slice(0,r));let s=vt.get(e);if(t){if(s?.deserializeStream)return s.deserializeStream;let i=vt.get(e)?.deserialize||ov(e,n);return o=>T7(o).then(i)}return e&&vt.get(e)?.deserialize||ov(e,n)}function ov(e,t){if(e.startsWith("text/")){let r=t?.match(/charset=(.+)/)?.[1]||"utf-8";return n=>({contentType:e,data:n.toString(r)})}else return e==="application/octet-stream"?r=>r:r=>{if(!e)try{if(r?.[0]===123)return _g(r)}catch{}return{contentType:e||"application/octet-stream",data:r}}}function g7(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}var cg,is,mo,Us,ff,av,ug,lg,cv,uv,Xu,_g,ju,vt,dg,sv,lv,p7,S7,iv,ga=ge(()=>{Oh();cg=x(df()),is=require("msgpackr"),mo=require("cbor-x"),Us=require("zlib"),ff=require("stream");rr();av=require("../../index"),ug=x(te()),lg=x(P()),cv=x(require("yaml")),uv=ug.default.get(lg.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,Xu=uv?Li:JSON.stringify,_g=uv?Ah:JSON.parse,ju={useRecords:!1,useToJSON:!0},vt=new Map,dg=vt;Ze.contentTypes=dg;(0,av._assignPackageExport)("contentTypes",dg);vt.set("application/json",{serializeStream:hc,serialize:Xu,deserialize:_g,q:.8});sv=new mo.Encoder(ju);vt.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new mo.EncoderStream(ju).end(e)},serialize:sv.encode,deserialize:sv.decode,q:1});vt.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?ff.Readable.from((0,is.encodeIter)(e,ju)):(0,is.pack)(e)},serialize:is.pack,deserialize:is.unpack,q:.9});vt.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,cg.toCsvStream)(e,e?.getColumns?.())},q:.1});vt.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.01});vt.set("text/yaml",{serialize(e){return cv.stringify(e,{aliasDuplicateObjects:!1})},q:.7});vt.set("text/event-stream",{serializeStream:function(e){return ff.Readable.from(g7(e,this.serialize))},serialize: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+`
|
|
18
|
-
`),e.data){let r=e.data;typeof r=="object"&&(r=
|
|
15
|
+
`,""):null}catch(f){f.stderr?i[u].npm_error=SP(f.stderr):i[u].npm_error=f.message;continue}try{i[u].npm_output=JSON.parse(l)}catch{i[u].npm_output=l}try{i[u].npm_error=JSON.parse(d)}catch{i[u].npm_error=d}}return Oa.info(`finished installModules with response ${i}`),i}a(Q6,"installModules");function SP(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
|
|
16
|
+
`);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(SP,"parseNPMStdErr");async function z6(e){Oa.info(`starting auditModules for request: ${e}`);let t=gP(e);if(t)throw Ra(t,t.message,Aa.BAD_REQUEST);let{projects:r}=e;await _f(),await TP(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=lf.join(zT,o);n[o]={npm_output:null,npm_error:null};try{let u=await Fu("npm audit --json",c);n[o].npm_output=JSON.parse(u)}catch(u){n[o].npm_error=SP(u.stderr)}}return Oa.info(`finished auditModules with response ${n}`),n}a(z6,"auditModules");async function _f(){try{return await Fu("npm -v"),!0}catch{throw Ra(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",Aa.BAD_REQUEST,void 0,void 0,!0)}}a(_f,"checkNPMInstalled");async function TP(e){if(!Array.isArray(e)||e.length===0)throw Ra(new Error,"projects argument must be an array with at least 1 element",Aa.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=lf.join(zT,i.toString());if(!await hP.pathExists(o)){t.push(i);continue}let u=lf.join(o,"package.json");await hP.pathExists(u)||r.push(i)}if(t.length>0)throw Ra(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Aa.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw Ra(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Aa.BAD_REQUEST,void 0,void 0,!0)}a(TP,"checkProjectPaths");function gP(e){let t=uf.object({projects:uf.array().min(1).items(uf.string()).required(),dry_run:uf.boolean().default(!1)});return V6.validateBySchema(e,t)}a(gP,"modulesValidator")});var XT=g((Xfe,NP)=>{"use strict";var ba=require("fs-extra"),JT=require("path"),ff=K(),AP=z(),Ef=U(),yP=re(),J6=Ur();NP.exports=X6;async function X6(){let e=j6(),t=yP.get(Ef.CONFIG_PARAMS.ROOTPATH),r=JT.join(t,"package.json"),n={dependencies:{harperdb:"file:"+Ef.PACKAGE_ROOT}},s=JT.join(t,"node_modules");await ba.ensureDir(s);let i,o=!0,c=!1;try{i=await ba.readJson(r)}catch(u){if(AP.isEmptyOrZeroLength(e))return;if(u.code!==Ef.NODE_ERROR_CODES.ENOENT)throw u;o=!1}if(!AP.isEmptyOrZeroLength(e)){for(let{name:u,package:_}of e){let l=await OP(_);n.dependencies[u]=l+_}if(!o){ff.notify("Installing components"),await bP(r,n,null);return}for(let{name:u,package:_}of e){let l=i.dependencies[u],d=await OP(_);if(l===void 0||l!==d+_){c=!0;break}}}for(let u in i.dependencies)n.dependencies[u]===void 0&&(ff.notify("Removing component",u),c=!0);c&&(ff.notify("Updating components."),await bP(r,n,i))}a(X6,"installComponents");function j6(){let e=J6.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(j6,"getComponentsConfig");async function OP(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":JT.extname(e)||await ba.pathExists(e)?"file:":"github:"}a(OP,"getPkgPrefix");async function bP(e,t,r){ff.trace("npm installing components package.json",t),await ba.writeFile(e,JSON.stringify(t,null," "));try{await df().installAllRootModules(yP.get(Ef.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?await ba.writeFile(e,JSON.stringify(r,null," ")):await ba.unlink(e),n}}a(bP,"installPackages")});var eg=g((eEe,DP)=>{"use strict";var qe=require("fs-extra"),jT=require("fast-glob"),pe=require("path"),wP=require("tar-fs"),Zfe=require("uuid").v4,ZT=require("normalize-path"),ss=EP(),yt=K(),Ke=U(),ht=re(),qu=Ur(),Z6=z(),{PACKAGE_ROOT:e9}=U(),{handleHDBError:Pt,hdb_errors:t9}=ne(),{basename:r9}=require("path"),n9=XT(),CP=re(),s9=U(),{Readable:i9}=require("stream"),{isMainThread:o9}=require("worker_threads"),{HDB_ERROR_MSGS:fo,HTTP_STATUS_CODES:vt}=t9,a9=pe.join(e9,"application-template"),IP=pe.join(ht.get(Ke.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp");function c9(){yt.trace("getting custom api status");let e={};try{e={port:ht.get(Ke.CONFIG_PARAMS.HTTP_PORT),directory:ht.get(Ke.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Pt(new Error,fo.FUNCTION_STATUS,vt.INTERNAL_SERVER_ERROR,yt.ERR,t)}return e}a(c9,"customFunctionsStatus");function u9(){yt.trace("getting custom api endpoints");let e={},t=ht.get(Ke.CONFIG_PARAMS.COMPONENTSROOT);try{jT.sync(ZT(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:jT.sync(ZT(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:jT.sync(ZT(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Pt(new Error,fo.GET_FUNCTIONS,vt.INTERNAL_SERVER_ERROR,yt.ERR,r)}return e}a(u9,"getCustomFunctions");function l9(e){e.project&&(e.project=pe.parse(e.project).name),e.file&&(e.file=pe.parse(e.file).name);let t=ss.getDropCustomFunctionValidator(e);if(t)throw Pt(t,t.message,vt.BAD_REQUEST);yt.trace("getting custom api endpoint file content");let r=ht.get(Ke.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=pe.join(r,n,s,i+".js");try{return qe.readFileSync(o,{encoding:"utf8"})}catch(c){throw Pt(new Error,fo.GET_FUNCTION,vt.INTERNAL_SERVER_ERROR,yt.ERR,c)}}a(l9,"getCustomFunction");function _9(e){e.project&&(e.project=pe.parse(e.project).name),e.file&&(e.file=pe.parse(e.file).name);let t=ss.setCustomFunctionValidator(e);if(t)throw Pt(t,t.message,vt.BAD_REQUEST);yt.trace("setting custom function file content");let r=ht.get(Ke.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{return qe.outputFileSync(pe.join(r,n,s,i+".js"),o),`Successfully updated custom function: ${i}.js`}catch(c){throw Pt(new Error,fo.SET_FUNCTION,vt.INTERNAL_SERVER_ERROR,yt.ERR,c)}}a(_9,"setCustomFunction");function d9(e){e.project&&(e.project=pe.parse(e.project).name),e.file&&(e.file=pe.parse(e.file).name);let t=ss.getDropCustomFunctionValidator(e);if(t)throw Pt(t,t.message,vt.BAD_REQUEST);yt.trace("dropping custom function file");let r=ht.get(Ke.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{return qe.unlinkSync(pe.join(r,n,s,i+".js")),`Successfully deleted custom function: ${i}.js`}catch(o){throw Pt(new Error,fo.DROP_FUNCTION,vt.INTERNAL_SERVER_ERROR,yt.ERR,o)}}a(d9,"dropCustomFunction");function f9(e){e.project&&(e.project=pe.parse(e.project).name);let t=ss.addComponentValidator(e);if(t)throw Pt(t,t.message,vt.BAD_REQUEST);yt.trace("adding component");let r=ht.get(Ke.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=pe.join(r,n);return qe.mkdirSync(s,{recursive:!0}),qe.copySync(a9,s),`Successfully added project: ${n}`}catch(s){throw Pt(new Error,fo.ADD_FUNCTION,vt.INTERNAL_SERVER_ERROR,yt.ERR,s)}}a(f9,"addComponent");function E9(e){e.project&&(e.project=pe.parse(e.project).name);let t=ss.dropCustomFunctionProjectValidator(e);if(t)throw Pt(t,t.message,vt.BAD_REQUEST);yt.trace("dropping custom function project");let r=ht.get(Ke.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=ht.get(Ke.CONFIG_PARAMS.APPS);if(!Z6.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 qu.updateConfigValue(Ke.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=pe.join(r,n);return qe.rmSync(i,{recursive:!0}),`Successfully deleted project: ${n}`}catch(i){throw Pt(new Error,fo.DROP_FUNCTION_PROJECT,vt.INTERNAL_SERVER_ERROR,yt.ERR,i)}}a(E9,"dropCustomFunctionProject");async function h9(e){e.project&&(e.project=pe.parse(e.project).name);let t=ss.packageComponentValidator(e);if(t)throw Pt(t,t.message,vt.BAD_REQUEST);let r=ht.get(Ke.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;yt.trace("packaging component",n);let s;try{s=await qe.realpath(pe.join(r,n))}catch(u){if(u.code!==Ke.NODE_ERROR_CODES.ENOENT)throw u;try{s=await qe.realpath(pe.join(ht.get(Ke.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(_){if(_.code===Ke.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}await qe.ensureDir(IP);let i=pe.join(IP,`${n}.tar`),o={};(e.skip_node_modules===!0||e.skip_node_modules==="true")&&(o={ignore:u=>u.includes(pe.join(s,"node_modules"))}),wP.pack(s,o).pipe(qe.createWriteStream(i,{overwrite:!0})),await new Promise(u=>setTimeout(u,2e3));let c=qe.readFileSync(i,{encoding:"base64"});return await qe.remove(i),{project:n,payload:c}}a(h9,"packageComponent");async function m9(e){e.project&&(e.project=pe.parse(e.project).name);let t=ss.deployComponentValidator(e);if(t)throw Pt(t,t.message,vt.BAD_REQUEST);let r=ht.get(Ke.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i}=e;if(yt.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let o;if(s){o=pe.join(r,n),i="file:"+o,await qe.ensureDir(o);let f=i9.from(Buffer.from(s,"base64"));await new Promise((h,p)=>{f.pipe(wP.extract(o,{finish:h})).on("error",p)});let E=await qe.readdir(o);E.length===1&&E[0]==="package"&&(await qe.copy(pe.join(o,"package"),o),await qe.remove(pe.join(o,"package")))}if(await qu.addConfig(n,{package:i}),!s){await n9();let f=CP.get(s9.CONFIG_PARAMS.ROOTPATH);o=pe.join(f,"node_modules",n)}if(o9)return;let c=new Map;c.isWorker=!0;let u=(mf(),se(hf)),_;u.setErrorReporter(f=>_=f);let l=r9(o),d=u.component_errors.get(l);try{await u.loadComponent(o,c)}finally{u.component_errors.set(l,d)}if(_)throw _;return yt.info("Installed component"),`Successfully deployed: ${n}`}a(m9,"deployComponent");async function p9(){let e=qu.getConfiguration(),t=[];for(let o in e)if(e[o]?.package){if(e[o].package.startsWith("file:"))continue;t.push(Object.assign({},e[o],{name:o}))}let r=a(async(o,c)=>{try{let u=await qe.readdir(o,{withFileTypes:!0});for(let _ of u){let l=_.name;if(l.startsWith(".")||l==="node_modules")continue;let d=pe.join(o,l);if(_.isDirectory()||_.isSymbolicLink()){let f={name:l,entries:[]};c.entries.push(f),await r(d,f)}else{let f=await qe.stat(d),E={name:pe.basename(l),mtime:f.mtime,size:f.size};c.entries.push(E)}}return c}catch(u){return yt.warn("Error loading package",u),{error:u.toString(),entries:[]}}},"walk_dir"),n=await r(ht.get(Ke.CONFIG_PARAMS.COMPONENTSROOT),{name:ht.get(Ke.CONFIG_PARAMS.COMPONENTSROOT).split(pe.sep).slice(-1).pop(),entries:t});for(let o of n.entries)if(o.package){let c=await r(pe.join(ht.get(Ke.CONFIG_PARAMS.ROOTPATH),"node_modules",o.name),{name:o.name,entries:[]});Object.assign(o,c)}let i=(mf(),se(hf)).component_errors;for(let o of t){let c=i.get(o.name);c?o.error=i.get(o.name):c===void 0&&(o.error="The component has not been loaded yet (may need a restart)")}return n}a(p9,"getComponents");async function S9(e){let t=ss.getComponentFileValidator(e);if(t)throw Pt(t,t.message,vt.BAD_REQUEST);let n=qu.getConfigObj()[e.project]||e.project==="harperdb"?pe.join(CP.get(Ke.CONFIG_PARAMS.ROOTPATH),"node_modules"):ht.get(Ke.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await qe.stat(pe.join(n,e.project,e.file));return{message:await qe.readFile(pe.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===Ke.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${pe.join(e.project,e.file)}'`):i}}a(S9,"getComponentFile");async function T9(e){let t=ss.setComponentFileValidator(e);if(t)throw Pt(t,t.message,vt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=pe.join(ht.get(Ke.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);return e.payload!==void 0?(await qe.ensureFile(n),await qe.outputFile(n,e.payload,r)):await qe.ensureDir(n),"Successfully set component: "+e.file}a(T9,"setComponentFile");async function g9(e){let t=ss.dropComponentFileValidator(e);if(t)throw Pt(t,t.message,vt.BAD_REQUEST);let r=e.file?pe.join(e.project,e.file):e.project,n=pe.join(ht.get(Ke.CONFIG_PARAMS.COMPONENTSROOT),r);return await qe.pathExists(n)&&await qe.remove(n),qu.deleteConfigFromFile([e.project]),"Successfully dropped: "+r}a(g9,"dropComponent");DP.exports={customFunctionsStatus:c9,getCustomFunctions:u9,getCustomFunction:l9,setCustomFunction:_9,dropCustomFunction:d9,addComponent:f9,dropCustomFunctionProject:E9,packageComponent:h9,deployComponent:m9,getComponents:p9,getComponentFile:S9,setComponentFile:T9,dropComponent:g9}});var tg=g((rEe,MP)=>{"use strict";var is=require("joi"),LP=tt();MP.exports={readTransactionLogValidator:R9,deleteTransactionLogsBeforeValidator:A9};function R9(e){let t=is.object({schema:is.string().required(),table:is.string().required(),from:is.date().timestamp(),to:is.date().timestamp(),limit:is.number().min(1)});return LP.validateBySchema(e,t)}a(R9,"readTransactionLogValidator");function A9(e){let t=is.object({schema:is.string().required(),table:is.string().required(),timestamp:is.date().timestamp().required()});return LP.validateBySchema(e,t)}a(A9,"deleteTransactionLogsBeforeValidator")});var Sf=g((sEe,HP)=>{"use strict";var rg=U(),pf=bt(),UP=z(),PP=re(),vP=Ss(),{handleHDBError:ya,hdb_errors:O9}=ne(),{HTTP_STATUS_CODES:Na}=O9,{readTransactionLogValidator:b9,deleteTransactionLogsBeforeValidator:y9}=tg(),BP="This operation relies on clustering and cannot run with it disable.",N9="Logs successfully deleted from transaction log.",I9="All logs successfully deleted from transaction log.";HP.exports={readTransactionLog:w9,deleteTransactionLogsBefore:C9};async function*w9(e){let t=b9(e);if(t)throw ya(t,t.message,Na.BAD_REQUEST,void 0,void 0,!0);if(!PP.get(rg.CONFIG_PARAMS.CLUSTERING_ENABLED))throw ya(new Error,BP,Na.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:n}=e,s=UP.checkSchemaTableExist(r,n);if(s)throw ya(new Error,s,Na.NOT_FOUND,void 0,void 0,!0);let i=vP.createNatsTableStreamName(r,n),o=await pf.viewStreamIterator(i,parseInt(e.from),e.limit);for await(let c of o){let u=Math.floor(c?.nats_timestamp/1e6);if(e.to&&u>e.to)break;let _={operation:c?.entry?.operation,user:c?.entry?.__origin?.user,timestamp:u,records:c?.entry?.records,attributes:c?.entry?.attributes};c?.entry?.operation===rg.OPERATIONS_ENUM.DELETE&&(_.hash_values=c?.entry?.hash_values),yield _}}a(w9,"readTransactionLog");async function C9(e){let t=y9(e);if(t)throw ya(t,t.message,Na.BAD_REQUEST,void 0,void 0,!0);if(!PP.get(rg.CONFIG_PARAMS.CLUSTERING_ENABLED))throw ya(new Error,BP,Na.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:n,timestamp:s}=e,i=UP.checkSchemaTableExist(r,n);if(i)throw ya(new Error,i,Na.NOT_FOUND,void 0,void 0,!0);let o=vP.createNatsTableStreamName(r,n),{jsm:c}=await pf.getNATSReferences(),u=await pf.getStreamInfo(o),_=new Date(u.state.first_ts).getTime();if(s<=_)return`No transactions exist before: ${s}`;let l=N9,d,f=new Date(u.state.last_ts).getTime();return s>f?(d=u.state.last_seq+1,l=I9):d=(await pf.viewStream(o,parseInt(s),1))[0].nats_sequence,await c.streams.purge(o,{seq:d}),l}a(C9,"deleteTransactionLogsBefore")});var GP=g((oEe,xP)=>{"use strict";var ng=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}};xP.exports=ng});var qP=g((cEe,FP)=>{"use strict";var sg=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};FP.exports=sg});var og=g((lEe,VP)=>{"use strict";var kP=GP(),D9=qP(),{HDB_ERROR_MSGS:L9}=Nr(),ig=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=L9.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 kP(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let u=new D9(c,s[c]);i.push(u)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new kP(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}};VP.exports=ig});var Af=g((dEe,iv)=>{"use strict";var ag=rn(),Tf=Dr(),ln=pd(),$u=Bi(),cg=qi(),M9=AS(),U9=eL(),Yu=nn(),gf=LS(),Nt=K(),P9=PS(),v9=vd(),B9=fT(),H9=Hd(),x9=hT(),G9=mT(),F9=TT(),q9=RT(),ug=bT(),Ls=z(),k9=XM(),lg=CT(),KP=rf(),un=U(),WP=XU(),V9=da(),QP=hu(),zP=(af(),se(Bu)),JP=Ur(),qr=eg(),$9=require("alasql"),XP=Sf(),jP=df(),ZP=og(),{handleHDBError:gr,hdb_errors:ev}=ne(),{HDB_ERROR_MSGS:kt,HTTP_STATUS_CODES:ku}=ev,V=new Map,tv="delete",pi="insert",Ms="read",Eo="update",Vu="describe",$P=$u.describeSchema.name,YP=$u.describeTable.name,rv={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},Y9="catchup",K9="handleGetJob",W9="handleGetJobsByStartDate",Rf={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},Q9=[ln.createTable.name,ln.createAttribute.name,ln.dropTable.name,ln.dropAttribute.name],nv={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},W=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};V.set(ag.insert.name,new W(!1,[pi]));V.set(ag.update.name,new W(!1,[Eo]));V.set(ag.upsert.name,new W(!1,[pi,Eo]));V.set(Tf.searchByConditions.name,new W(!1,[Ms]));V.set(Tf.searchByHash.name,new W(!1,[Ms]));V.set(Tf.searchByValue.name,new W(!1,[Ms]));V.set(Tf.search.name,new W(!1,[Ms]));V.set(ln.createSchema.name,new W(!0,[]));V.set(ln.createTable.name,new W(!0,[]));V.set(ln.createAttribute.name,new W(!1,[pi]));V.set(ln.dropSchema.name,new W(!0,[]));V.set(ln.dropTable.name,new W(!0,[]));V.set(ln.dropAttribute.name,new W(!0,[]));V.set($u.describeSchema.name,new W(!1,[Ms]));V.set($u.describeTable.name,new W(!1,[Ms]));V.set(cg.deleteRecord.name,new W(!1,[tv]));V.set(Yu.addUser.name,new W(!0,[]));V.set(Yu.alterUser.name,new W(!0,[]));V.set(Yu.dropUser.name,new W(!0,[]));V.set(Yu.listUsersExternal.name,new W(!0,[]));V.set(gf.listRoles.name,new W(!0,[]));V.set(gf.addRole.name,new W(!0,[]));V.set(gf.alterRole.name,new W(!0,[]));V.set(gf.dropRole.name,new W(!0,[]));V.set(P9.name,new W(!0,[]));V.set(v9.name,new W(!0,[]));V.set(B9.name,new W(!0,[]));V.set(H9.name,new W(!0,[]));V.set(x9.name,new W(!0,[]));V.set(G9.name,new W(!0,[]));V.set(ug.setRoutes.name,new W(!0,[]));V.set(ug.getRoutes.name,new W(!0,[]));V.set(ug.deleteRoutes.name,new W(!0,[]));V.set(JP.setConfiguration.name,new W(!0,[]));V.set(F9.clusterStatus.name,new W(!0,[]));V.set(q9.name,new W(!0,[]));V.set(lg.getFingerprint.name,new W(!0,[]));V.set(lg.setLicense.name,new W(!0,[]));V.set(cg.deleteFilesBefore.name,new W(!0,[]));V.set(cg.deleteAuditLogsBefore.name,new W(!0,[]));V.set(KP.restart.name,new W(!0,[]));V.set(KP.restartService.name,new W(!0,[]));V.set(M9.name,new W(!0,[]));V.set(U9.name,new W(!0,[Ms]));V.set(V9.systemInformation.name,new W(!0,[]));V.set(JP.getConfiguration.name,new W(!0,[]));V.set(XP.readTransactionLog.name,new W(!0,[]));V.set(XP.deleteTransactionLogsBefore.name,new W(!0,[]));V.set(jP.installModules.name,new W(!0,[]));V.set(jP.auditModules.name,new W(!0,[]));V.set(QP.createTokens.name,new W(!1,[]));V.set(QP.refreshOperationToken.name,new W(!1,[]));V.set(zP.login.name,new W(!1,[]));V.set(zP.logout.name,new W(!1,[]));V.set(qr.customFunctionsStatus.name,new W(!0,[]));V.set(qr.getCustomFunctions.name,new W(!0,[]));V.set(qr.getComponents.name,new W(!0,[]));V.set(qr.getComponentFile.name,new W(!0,[]));V.set(qr.setComponentFile.name,new W(!0,[]));V.set(qr.dropComponent.name,new W(!0,[]));V.set(qr.getCustomFunction.name,new W(!0,[]));V.set(qr.setCustomFunction.name,new W(!0,[]));V.set(qr.dropCustomFunction.name,new W(!0,[]));V.set(qr.addComponent.name,new W(!0,[]));V.set(qr.dropCustomFunctionProject.name,new W(!0,[]));V.set(qr.packageComponent.name,new W(!0,[]));V.set(qr.deployComponent.name,new W(!0,[]));V.set(lg.getRegistrationInfo.name,new W(!1,[]));V.set(Yu.userInfo.name,new W(!1,[]));V.set($u.describeAll.name,new W(!1,[]));V.set(K9,new W(!1,[]));V.set(W9,new W(!0,[]));V.set(Y9,new W(!0,[]));V.set(Rf.CSV_DATA_LOAD,new W(!1,[pi,Eo]));V.set(Rf.CSV_URL_LOAD,new W(!1,[pi,Eo]));V.set(Rf.CSV_FILE_LOAD,new W(!1,[pi,Eo]));V.set(Rf.IMPORT_FROM_S3,new W(!1,[pi,Eo]));V.set(nv.EXPORT_TO_S3,new W(!0,[]));V.set(nv.EXPORT_LOCAL,new W(!0,[]));V.set(un.VALID_SQL_OPS_ENUM.DELETE,new W(!1,[tv]));V.set(un.VALID_SQL_OPS_ENUM.SELECT,new W(!1,[Ms]));V.set(un.VALID_SQL_OPS_ENUM.INSERT,new W(!1,[pi]));V.set(un.VALID_SQL_OPS_ENUM.UPDATE,new W(!1,[Eo]));iv.exports={verifyPerms:J9,verifyPermsAst:z9,verifyBulkLoadAttributePerms:j9};function z9(e,t,r){if(Ls.isEmptyOrZeroLength(e))throw Nt.info("verify_perms_ast has an empty user parameter"),gr(new Error);if(Ls.isEmptyOrZeroLength(t))throw Nt.info("verify_perms_ast has an empty user parameter"),gr(new Error);if(Ls.isEmptyOrZeroLength(r))throw Nt.info("verify_perms_ast has a null operation parameter"),gr(new Error);try{let n=new ZP,s=new k9(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw Nt.info("No schemas defined in verifyPermsAst(), will not continue."),gr(new Error);let c=!!t.role.permission.super_user,u=i.includes("system");if(u&&rv[r])throw gr(new Error,kt.DROP_SYSTEM,ku.FORBIDDEN);if(c&&!u)return null;let _=WP.getRolePermissions(t.role);t.role.permission=_,!c&&e instanceof $9.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(_));for(let d=0;d<i.length;d++){let f=s.getTablesBySchemaName(i[d]);f&&o.set(i[d],f)}let l=sv(t,r,o,n);return l||(o.forEach((d,f)=>{for(let E=0;E<d.length;E++){let h=s.getAttributesBySchemaTableName(f,d[E]),p=dg(t.role.permission,f,d[E]);_g(h,p,r,d[E],f,n)}}),n.getPermsResponse())}catch(n){throw gr(n)}}a(z9,"verifyPermsAst");function J9(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw Nt.info("null required parameter in verifyPerms"),gr(new Error,kt.DEFAULT_INVALID_REQUEST,ku.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 ZP;if(Ls.isEmptyOrZeroLength(e.hdb_user.role)||Ls.isEmptyOrZeroLength(e.hdb_user.role.permission))return Nt.info(`User ${e.hdb_user.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(kt.USER_HAS_NO_PERMS(e.hdb_user.username));let u=!!e.hdb_user.role.permission.super_user,_=e.hdb_user.role.permission.structure_user,l=o.has(un.SYSTEM_SCHEMA_NAME)||s===un.SYSTEM_SCHEMA_NAME;if(l&&rv[r])throw gr(new Error,kt.DROP_SYSTEM,ku.FORBIDDEN);if(u&&!l||_===!0&&(r===ln.createSchema.name||r===ln.dropSchema.name))return null;if(Q9.indexOf(r)>=0&&(_===!0||Array.isArray(_)))return _===!0||_.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let d=WP.getRolePermissions(e.hdb_user.role);if(e.hdb_user.role.permission=d,r===$P||r===YP){if(s===un.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(kt.SCHEMA_PERM_ERROR(s));if(!d.super_user){if(r===$P&&(!d[s]||!d[s][Vu]))return c.handleInvalidItem(kt.SCHEMA_NOT_FOUND(s));if(r===YP&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][Vu]))return c.handleInvalidItem(kt.TABLE_NOT_FOUND(s,i))}}let f=sv(e.hdb_user,r,o,c,n);if(f)return f;if(V.get(r)&&V.get(r).perms.length===0)return null;if(!u&&e.get_attributes&&un.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let p=[],S=d[s].tables[i];S[un.PERMS_CRUD_ENUM.READ]&&(S.attribute_permissions.length>0?S.attribute_permissions.filter(b=>b[un.PERMS_CRUD_ENUM.READ]).forEach(b=>{p.push(b.attribute_name)}):p=global.hdb_schema[s][i].attributes.map(T=>T.attribute),e.get_attributes=p)}let E=X9(e),h=dg(e.hdb_user.role.permission,s,i);return _g(E,h,r,i,s,c,n),c.getPermsResponse()}a(J9,"verifyPerms");function sv(e,t,r,n,s){if(Ls.arrayHasEmptyValues([e,t,r]))throw Nt.info("hasPermissions has an invalid parameter"),gr(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||V.get(t).requires_su))return null;if(!V.get(t))throw Nt.info(`operation ${t} not found.`),gr(new Error,kt.OP_NOT_FOUND(t),ku.BAD_REQUEST);if(V.get(t)&&V.get(t).requires_su)return Nt.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(kt.OP_IS_SU_ONLY(t));let c=r.keys();for(let u of c){try{if(u&&!o[u]||o[u][Vu]===!1){n.addInvalidItem(kt.SCHEMA_NOT_FOUND(u));continue}}catch{n.addInvalidItem(kt.SCHEMA_NOT_FOUND(u));continue}let _=r.get(u);for(let l of _){let d=o[u].tables[l];if(!d||d[Vu]===!1)n.addInvalidItem(kt.TABLE_NOT_FOUND(u,l));else try{let f=[],E=V.get(t).perms;!Ls.isEmpty(s)&&E.includes(s)&&(E=[s]);for(let h=0;h<E.length;h++){let p=E[h],S=d[p];(S==null||S===!1)&&(Nt.info(`Required ${p} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),f.push(p))}f.length>0&&n.addUnauthorizedTable(u,l,f)}catch(f){let E=kt.UNKNOWN_OP_AUTH_ERROR(t,u,l);throw Nt.error(E),Nt.error(f),gr(ev.CHECK_LOGS_WRAPPER(E))}}}return r.size<2?n.getPermsResponse():null}a(sv,"hasPermissions");function _g(e,t,r,n,s,i,o){if(!e||!t)throw Nt.info("no attributes specified in checkAttributePerms."),gr(new Error);let c=V.get(r).perms;if(!c||c==="")throw Nt.info(`no permissions found for ${r} in checkAttributePerms().`),gr(new Error);if(Ls.isEmptyOrZeroLength(t))return Nt.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let u={};for(let l of e){let d=t.get(l);if(d){if(d[Vu]===!1){i.addInvalidItem(kt.ATTR_NOT_FOUND(s,n,l),s,n);continue}if(c)for(let f of c){if(un.TIME_STAMP_NAMES.includes(d.attribute_name)&&f!==Ms)throw gr(new Error,kt.SYSTEM_TIMESTAMP_PERMS_ERR,ku.FORBIDDEN);d[f]===!1&&(u[d.attribute_name]?u[d.attribute_name].push(f):u[d.attribute_name]=[f])}}else i.addInvalidItem(kt.ATTR_NOT_FOUND(s,n,l),s,n)}let _=Object.keys(u);_.length>0&&i.addUnauthorizedAttributes(_,s,n,u)}a(_g,"checkAttributePerms");function X9(e){let t=new Set;try{if(e.action)return t;if(e.operation===un.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){Nt.info(r)}return t}a(X9,"getRecordAttributes");function dg(e,t,r){let n=new Map;if(Ls.isEmpty(e))return Nt.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{Nt.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(dg,"getAttributePermissions");function j9(e,t,r,n,s,i,o){let c=new Set(i),u=dg(e,n,s);_g(c,u,t,s,n,o,r)}a(j9,"verifyBulkLoadAttributePerms")});var bf=g((EEe,lv)=>{"use strict";lv.exports={evaluateSQL:_7,processAST:uv,convertSQLToAST:cv,checkASTPermissions:av};var Z9=rn(),ov=require("util"),e7=ov.callbackify(Z9.insert),t7=Dr().search,r7=FC().update,n7=ov.callbackify(r7),s7=kC().convertDelete,Si=require("alasql"),i7=Af(),Of=K(),o7=Z_(),a7=z(),Ku=U(),{hdb_errors:c7,handleHDBError:fg}=ne(),{HTTP_STATUS_CODES:Eg}=c7;o7(Si);var u7=403,l7="There was a problem performing this insert. Please check the logs and try again.",hg=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function _7(e,t){let r=e.parsed_sql_object;if(!r){r=cv(e.sql);let n,s=r.ast.statements[0];if(s instanceof Si.yy.Insert?n=s.into.databaseid:s instanceof Si.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Si.yy.Update||s instanceof Si.yy.Delete?n=s.table.databaseid:Of.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Si.yy.Select)&&a7.isEmptyOrZeroLength(n))return t("No schema specified",null)}uv(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(_7,"evaluateSQL");function av(e,t){let r;try{r=i7.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(av,"checkASTPermissions");function cv(e){let t=new hg;if(!e)throw fg(new Error,"The 'sql' parameter is missing from the request body",Eg.BAD_REQUEST);try{let r=e.trim(),n=Si.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
|
|
17
|
+
`);throw n[1]?fg(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,Eg.BAD_REQUEST):fg(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",Eg.BAD_REQUEST)}return t}a(cv,"convertSQLToAST");function uv(e,t,r){try{let n=d7;if(!e.bypass_auth&&!t.permissions_checked){let i=av(e,t);if(i&&i.length>0)return r(u7,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case Ku.VALID_SQL_OPS_ENUM.SELECT:n=t7,s=t.ast.statements[0];break;case Ku.VALID_SQL_OPS_ENUM.INSERT:n=f7;break;case Ku.VALID_SQL_OPS_ENUM.UPDATE:n=n7;break;case Ku.VALID_SQL_OPS_ENUM.DELETE:n=s7;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(uv,"processAST");function d7(e,t){Of.info(e),t("unknown sql statement")}a(d7,"nullFunction");function f7({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=E7(i,e.values)}catch(o){return r(o)}e7(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(u){Of.error(`Error delete new_attributes from insert response: ${u}`)}r(null,c)})}a(f7,"convertInsert");function E7(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]]=Si.compile(`SELECT ${s.toString()} AS [${Ku.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw Of.error(r),new Error(l7)}}a(E7,"createDataObjects")});var mg=g((mEe,dv)=>{"use strict";var{S3:h7,GetObjectCommand:m7}=require("@aws-sdk/client-s3");dv.exports={getFileStreamFromS3:p7,getS3AuthObj:_v};async function p7(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await _v(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new m7(r))).Body}a(p7,"getFileStreamFromS3");function _v(e,t,r){return new h7({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(_v,"getS3AuthObj")});var yf=g((SEe,Rv)=>{"use strict";var Sg=Dr(),S7=bf(),T7=mg(),{AsyncParser:g7,Transform:R7}=require("json2csv"),Qu=require("stream"),kr=z(),pg=require("fs-extra"),A7=require("path"),_n=K(),{promisify:hv}=require("util"),Wu=z(),{handleHDBError:mt,hdb_errors:O7}=ne(),{HDB_ERROR_MSGS:Rr,HTTP_STATUS_CODES:pt}=O7,{streamAsJSON:b7}=(Mh(),se(rb)),{Upload:y7}=require("@aws-sdk/lib-storage"),fv=["search_by_value","search_by_hash","sql","search_by_conditions"],Ev=["json","csv"],mv="json",pv="csv",N7="Successfully exported JSON locally.",I7="Successfully exported CSV locally.",w7=1e3,C7=Sg.searchByHash,D7=Sg.searchByValue,L7=hv(S7.evaluateSQL),M7=hv(Qu.finished);Rv.exports={export_to_s3:B7,export_local:U7,toCsvStream:Sv};async function U7(e){_n.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=Tv(e);if(!kr.isEmpty(t))throw _n.error(t),mt(new Error,t,pt.BAD_REQUEST,void 0,void 0,!0);if(kr.isEmpty(e.path))throw _n.error(Rr.MISSING_VALUE("path")),mt(new Error,Rr.MISSING_VALUE("path"),pt.BAD_REQUEST,void 0,void 0,!0);let r=(kr.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(A7.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=kr.buildFolderPath(e.path,r);await P7(e.path);let s=await gv(e);return await v7(n,e.format,s)}a(U7,"export_local");async function P7(e){if(_n.trace("in confirmPath"),kr.isEmptyOrZeroLength(e))throw mt(new Error,`Invalid path: ${e}`,pt.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await pg.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,_n.error(n),mt(new Error,n,pt.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 _n.error(r),mt(new Error,r,pt.BAD_REQUEST,void 0,void 0,!0)}return!0}a(P7,"confirmPath");async function v7(e,t,r){if(_n.trace("in saveToLocal"),Wu.isEmptyOrZeroLength(e))throw mt(new Error,Rr.INVALID_VALUE("file_path"),pt.BAD_REQUEST,void 0,void 0,!0);if(Wu.isEmptyOrZeroLength(t))throw mt(new Error,Rr.INVALID_VALUE("Source format"),pt.BAD_REQUEST,void 0,void 0,!0);if(Wu.isEmpty(r))throw mt(new Error,Rr.NOT_FOUND("Data"),pt.BAD_REQUEST,void 0,void 0,!0);if(t===mv){let n=pg.createWriteStream(e);return b7(r).pipe(n),await M7(n),{message:N7,path:e}}else if(t===pv){let n=pg.createWriteStream(e),s=Qu.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(l=>({label:l,value:l})));let c={objectMode:!0};return await new g7(i,c).fromInput(s).toOutput(n).promise(!1),{message:I7,path:e}}throw mt(new Error,Rr.INVALID_VALUE("format"),pt.BAD_REQUEST)}a(v7,"saveToLocal");async function B7(e){if(!e.s3||Object.keys(e.s3).length===0)throw mt(new Error,Rr.MISSING_VALUE("S3 object"),pt.BAD_REQUEST);if(kr.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw mt(new Error,Rr.MISSING_VALUE("aws_access_key_id"),pt.BAD_REQUEST);if(kr.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw mt(new Error,Rr.MISSING_VALUE("aws_secret_access_key"),pt.BAD_REQUEST);if(kr.isEmptyOrZeroLength(e.s3.bucket))throw mt(new Error,Rr.MISSING_VALUE("bucket"),pt.BAD_REQUEST);if(kr.isEmptyOrZeroLength(e.s3.key))throw mt(new Error,Rr.MISSING_VALUE("key"),pt.BAD_REQUEST);if(kr.isEmptyOrZeroLength(e.s3.region))throw mt(new Error,Rr.MISSING_VALUE("region"),pt.BAD_REQUEST);let t=Tv(e);if(!kr.isEmpty(t))throw mt(new Error,t,pt.BAD_REQUEST);_n.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await gv(e)}catch(u){throw _n.error(u),u}let n,s=await T7.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new Qu.PassThrough;if(e.format===pv){i=e.s3.key+".csv";let u=Sv(r,r.getColumns?.());u.on("error",_=>{throw _}),u.pipe(o)}else if(e.format===mv){i=e.s3.key+".json";let u=new Qu.Readable;u.pipe(o),u.on("error",d=>{throw d}),u.push("[");let _=r.length,l="";for(let[d,f]of r.entries()){let E=d===_-1?JSON.stringify(f):JSON.stringify(f)+",";l+=E,d!==0&&d%w7===0&&(u.push(l),l="")}l.length!==0&&u.push(l),u.push("]"),u.push(null)}else throw mt(new Error,Rr.INVALID_VALUE("format"),pt.BAD_REQUEST);return new y7({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(B7,"export_to_s3");function Sv(e,t){let r=Qu.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 R7(n,s);return r.pipe(i)}a(Sv,"toCsvStream");function Tv(e){if(_n.trace("in exportCoreValidation"),kr.isEmpty(e.format))return"format missing";if(Ev.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${Ev.join(", ")}`;let t=e.search_operation.operation;if(kr.isEmpty(t))return"search_operation.operation missing";if(fv.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${fv.join(", ")}`}a(Tv,"exportCoreValidation");async function gv(e){_n.trace("in getRecords");let t,r;if(Wu.isEmpty(e.search_operation)||Wu.isEmptyOrZeroLength(e.search_operation.operation))throw mt(new Error,Rr.INVALID_VALUE("Search operation"),pt.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=D7;break;case"search_by_hash":t=C7;break;case"search_by_conditions":t=Sg.searchByConditions;break;case"sql":t=L7;break;default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,_n.error(r),mt(new Error,r,pt.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(gv,"getRecords")});var Cv={};$e(Cv,{contentTypes:()=>Og,findBestSerializer:()=>If,getDeserializer:()=>mo,registerContentHandlers:()=>bg,serialize:()=>wf,serializeMessage:()=>mi});function H7(e){try{return e?.[0]===123?Ag(e):e}catch{return e}}function bg(e){e.register(G7,{serializers:[{regex:/^application\/json$/,serializer:hc},{regex:/^application\/cbor$/,serializer:function(t){return new ho.EncoderStream(Ju).end(t)}},{regex:/^application\/(x-)?msgpack$/,serializer:function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?Nf.Readable.from((0,os.encodeIter)(t,Ju)):(0,os.pack)(t)}},{regex:/^text\/csv$/,serializer:function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,Tg.toCsvStream)(t)}}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,os.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,ho.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function If(e){let r=(e.headers.asObject||e.headers).accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let u of c){let[_,...l]=u.split(/\s*;\s*/),d=1,f={q:1};for(let h of l){let p=h.indexOf("=");f[h.substring(0,p)]=h.substring(p+1)}d=+f.q;let E=Bt.get(_);if(E){let h=(E.q||1)*d;h>s&&(n=E,i=E.type||_,s=h,o=f)}}if(!n){if(r)return{serializer(){this.code(406).send("No supported content types found in Accept header, supported types include: "+Array.from(Bt.keys()).join(", "))}};n=Bt.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function wf(e,t,r){let n=Ov&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=If(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[Symbol.iterator]||e[Symbol.asyncIterator])&&i.serializer.serializeStream){let o=i.serializer.serializeStream(e,r);return n&&(r.headers.set("Content-Encoding","br"),o=o.pipe((0,Us.createBrotliCompress)({params:{[Us.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?Us.constants.BROTLI_MODE_TEXT:Us.constants.BROTLI_MODE_GENERIC,[Us.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>Ov?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,Us.brotliCompress)(s,(c,u)=>{c?o(c):i(u)}))):s}function mi(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return zu(e);let r=t.serialize;if(r)return r(e);let n=If(t);return r=t.serialize=n.serializer.serialize,r(e)}function F7(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 mo(e,t){e||(e="");let r=e.indexOf(";"),n;r>-1&&(n=e.slice(r+1),e=e.slice(0,r));let s=Bt.get(e);if(t){if(s?.deserializeStream)return s.deserializeStream;let i=Bt.get(e)?.deserialize||bv(e,n);return o=>F7(o).then(i)}return e&&Bt.get(e)?.deserialize||bv(e,n)}function bv(e,t){if(e.startsWith("text/")){let r=t?.match(/charset=(.+)/)?.[1]||"utf-8";return n=>({contentType:e,data:n.toString(r)})}else return e==="application/octet-stream"?r=>r:r=>{if(!e)try{if(r?.[0]===123)return Ag(r)}catch{}return{contentType:e||"application/octet-stream",data:r}}}function q7(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}var Tg,os,ho,Us,Nf,yv,gg,Rg,Nv,Iv,zu,Ag,Ju,Bt,Og,Av,wv,x7,G7,Ov,ga=Re(()=>{Mh();Tg=x(yf()),os=require("msgpackr"),ho=require("cbor-x"),Us=require("zlib"),Nf=require("stream");sr();yv=require("../../index"),gg=x(re()),Rg=x(U()),Nv=x(require("yaml")),Iv=gg.default.get(Rg.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,zu=Iv?Di:JSON.stringify,Ag=Iv?Lh:JSON.parse,Ju={useRecords:!1,useToJSON:!0},Bt=new Map,Og=Bt;je.contentTypes=Og;(0,yv._assignPackageExport)("contentTypes",Og);Bt.set("application/json",{serializeStream:hc,serialize:zu,deserialize:Ag,q:.8});Av=new ho.Encoder(Ju);Bt.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new ho.EncoderStream(Ju).end(e)},serialize:Av.encode,deserialize:Av.decode,q:1});Bt.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?Nf.Readable.from((0,os.encodeIter)(e,Ju)):(0,os.pack)(e)},serialize:os.pack,deserialize:os.unpack,q:.9});Bt.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,Tg.toCsvStream)(e,e?.getColumns?.())},q:.1});Bt.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.01});Bt.set("text/yaml",{serialize(e){return Nv.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Bt.set("text/event-stream",{serializeStream:function(e){return Nf.Readable.from(q7(e,this.serialize))},serialize: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+`
|
|
18
|
+
`),e.data){let r=e.data;typeof r=="object"&&(r=zu(r)),t+="data: "+r+`
|
|
19
19
|
`}return e.id&&(t+="id: "+e.id+`
|
|
20
20
|
`),e.retry&&(t+="retry: "+e.retry+`
|
|
21
21
|
`),t+`
|
|
22
|
-
`}else return typeof e=="object"?`data: ${
|
|
22
|
+
`}else return typeof e=="object"?`data: ${zu(e)}
|
|
23
23
|
|
|
24
24
|
`:`data: ${e}
|
|
25
25
|
|
|
26
|
-
`},compressible:!1,q:.8});vt.set("application/x-www-form-urlencoded",{deserialize(e){let t={};for(let[r,n]of new URLSearchParams(e))if(t.hasOwnProperty(r)){let s=t[r];Array.isArray(s)?s.push(n):t.key=[s,n]}else t[r]=n},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});lv={type:"application/json",serializeStream:hc,serialize:Xu,deserialize:m7,q:.8};vt.set("*/*",lv);vt.set("",lv);a(m7,"tryJSONParse");a(fg,"registerContentHandlers");p7=require("fastify-plugin"),S7=p7(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=Ef(n.raw);s.type(c),s.serializer(function(u){return(o.serializeStream||o.serialize)(u,{headers:{set:(_,l)=>{s.header(_,l)}}})})}),r()},{name:"content-type-negotiation"});a(Ef,"findBestSerializer");iv=ug.default.get(lg.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(hf,"serialize");a(mi,"serializeMessage");a(T7,"streamToBuffer");a(po,"getDeserializer");a(ov,"deserializerUnknownType");a(g7,"transformIterable")});function mg(e,t,r,n,s,i,o,c){let u=e[0];if(t==="or"){let d=_(u);for(let E=1;E<e.length;E++){let h=e[E],S=_(h);d=d.concat(S)}let f=new Set;return d.filter(E=>{let h=E.key??E;return f.has(h)?!1:(f.add(h),!0)})}else{let d=_(u),f=l(e.slice(1),!0,u.estimated_count);return f.length>0?o(d,f):d}function _(d){return d.conditions?mg(d.conditions,d.operator,r,n,s,i,o,c):Ca(d,n,d.descending||s.reverse===!0,r,s.allowFullScan,c)}a(_,"executeCondition");function l(d,f,E){return d.map((h,S)=>{if(h.conditions){let A=h.operator==="or",g=l(h.conditions,!A,E);return A?(v,H)=>g.some(M=>M(v,H)):(v,H)=>g.every(M=>M(v,H))}let p=(h.attribute||h[0])===r.primaryKey,R=Sg(h,r,i,c,p,E);return f&&S<d.length-1&&E&&(E=C7(r.primaryStore,h.estimated_count,E)),R}).filter(Boolean)}a(l,"mapConditionsToFilters")}function Ca(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,u=e.comparator;if(Array.isArray(o)){let A=o[0],g=Ps(n.attributes,A);if(g.relationship){if(o.length<2)throw new kr.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let v=g.definition?.tableClass||g.elements?.definition?.tableClass,H=new Map,M=Ca({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:u},t,r,v,s,H);if(g.relationship.to){i[o[0]]=H;let U=!!Ps(v.attributes,g.relationship.to)?.elements;M=N7(M,g,v.primaryStore,U,H)}if(g.relationship.from){let U=a(Y=>Ca({attribute:g.relationship.from,value:Y},t,r,n,s,H),"searchEntry");g.elements?(i[o[0]]=H,M=y7(M,g,v.primaryStore,H,U)):M=M.flatMap(U)}return M}else if(o.length===1)o=o[0];else throw new kr.ClientError("Unable to query by attribute "+JSON.stringify(o))}let _,l,d,f;c instanceof Date&&(c=c.getTime());let E;switch(pg[u]||u){case"lt":_=!0,l=c;break;case"le":_=!0,l=c,d=!0;break;case"gt":_=c,f=!0;break;case"ge":_=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],_=c,l=c.slice(0),l[l.length-1]=os.MAXIMUM_KEY;break;case"starts_with":_=c.toString(),l=c+"\uFFFF";break;case"between":_=c[0],_ instanceof Date&&(_=_.getTime()),l=c[1],l instanceof Date&&(l=l.getTime()),d=!0;break;case"equals":case void 0:_=c,l=c,d=!0;break;case"ne":if(c===null){_=c,f=!0;break}case"sort":case"contains":case"ends_with":_=!0,E=!0;break;default:throw new kr.ClientError(`Unknown query comparator "${u}"`)}if(r){let A=_;_=l,l=A,A=!f,f=!d,d=A}let h=o===n.primaryKey||o==null,S=h?n.primaryStore:n.indices[o],p;if(!S||S.isIndexing||E||c===null&&!S.indexNulls){if(s===!1&&!S)throw new kr.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&E)throw new kr.ClientError(`Can not use ${u||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(S?.isIndexing)throw new kr.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&!S.indexNulls)throw new kr.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(p=Sg(e),!p)throw new kr.ClientError(`Unknown search operator ${e.comparator}`)}let R={start:_,end:l,inclusiveEnd:d,exclusiveStart:f,values:!0,versions:h,transaction:t,reverse:r};if(h){let A=S.getRange(R).map(p?function({key:g,value:v}){return this.isSync?v&&p(v)?g:Ti.SKIP:new Promise((H,M)=>setImmediate(()=>{try{H(v&&p(v)?g:Ti.SKIP)}catch(U){M(U)}}))}:g=>g.value==null?Ti.SKIP:g);return A.hasEntries=!0,A}else return S?S.getRange(R).map(p?function({key:A,value:g}){return this.isSync?p({[o]:A})?g:Ti.SKIP:new Promise((v,H)=>setImmediate(()=>{try{v(p({[o]:A})?g:Ti.SKIP)}catch(M){H(M)}}))}:({value:A})=>A):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:A,value:g}){return this.isSync?g&&p(g)?A:Ti.SKIP:new Promise((v,H)=>setImmediate(()=>{try{v(g&&p(g)?A:Ti.SKIP)}catch(M){H(M)}}))})}function Ps(e,t){if(Array.isArray(t))if(t.length>1){let r=Ps(e,t[0]),n=(r?.definition?.tableClass||r?.elements.definition?.tableClass)?.attributes;return n?Ps(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 N7(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;s.hasMappings=!0;let o;return{next(){if(!i){let u=t.relationship.to,_=a((l,d)=>{let f=l;Array.isArray(l)&&(f=Mn(l),o=!0);let E=s.get(f);E?E.push(d):s.set(f,E=[d]),l!==f&&(E.key=l)},"add_entry");for(let l of e){let d=l.value??r.get(l.key??l),f=d?.[u];if(f!=null&&!s.filters?.some(E=>!E(d)))if(n)for(let E=0;E<f.length;E++)_(f[E],l);else _(f,l)}return i=(o?s:s.keys())[Symbol.iterator](),this.next()}let c=i.next();return c.done?c:{value:o?c.value[1].key||c.value[0]:c.value}}}}})}function y7(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let u;if(o)for(;u=o.next(),!u.done;){let _=Mn(u.value);if(!c.has(_))return c.add(_),u}if(!i){let _=new Map;n.fromRecord=l=>l[t.relationship.from]?.filter?.(d=>_.has(Mn(d)));for(let l of e){if(n.filters){let d=r.get(l);if(n.filters.some(f=>!f(d)))continue}_.set(Mn(l),l)}return i=_.values()[Symbol.iterator](),this.next()}do{let _=i.next();return _.done?_:(o=s(_.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function Sg(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,u=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 l=c[0],d=Ps(t.attributes,l),f=d.definition?.tableClass||d.elements.definition?.tableClass,E=n?.[l],h=Sg({attribute:c.length>2?c.slice(1):c[1],value:u,comparator:o},f,r,E?.[l]?.joined,c[1]===f.primaryKey,i);if(!h)return;if(E){E.filters||(E.filters=[]),E.filters.push(h);return}let S=t.propertyResolvers?.[l],p,R=a((A,g)=>{let v,H;if(S){if(S.from&&h.idFilter){if(!p)if(h.idFilter.idSet?.size===1){for(let U of h.idFilter.idSet)e={attribute:S.from,value:U};p=_(S.from,h.idFilter,!0,!0)}else p=_(S.from,h.idFilter,!1,!0);let M=p(A);return p.idFilter&&(R.idFilter=p.idFilter),M}H=S(A,r,g),v=H?.value}else v=A[l];return v?Array.isArray(v)?v.some(h):h(v,H):!1},"recordFilter");return R}}switch(u instanceof Date&&(u=u.getTime()),pg[o]||o){case Eg.SEARCH_TYPES.EQUALS:case void 0:return _(c,l=>l===u,!0);case"contains":return _(c,l=>l?.toString().includes(u));case"ends_with":return _(c,l=>l?.toString().endsWith(u));case"starts_with":return _(c,l=>typeof l=="string"&&l.startsWith(u),!0);case"prefix":return Array.isArray(u)?u[u.length-1]==null&&(u=u.slice(0,-1)):u=[u],_(c,l=>{if(!Array.isArray(l))return!1;for(let d=0,f=u.length;d<f;d++)if(l[d]!==u[d])return!1;return!0},!0);case"between":return u[0]instanceof Date&&(u[0]=u[0].getTime()),u[1]instanceof Date&&(u[1]=u[1].getTime()),_(c,l=>(0,os.compareKeys)(l,u[0])>=0&&(0,os.compareKeys)(l,u[1])<=0,!0);case"gt":return _(c,l=>(0,os.compareKeys)(l,u)>0);case"ge":return _(c,l=>(0,os.compareKeys)(l,u)>=0);case"lt":return _(c,l=>(0,os.compareKeys)(l,u)<0);case"le":return _(c,l=>(0,os.compareKeys)(l,u)<=0);case"ne":return _(c,l=>(0,os.compareKeys)(l,u)!==0);case"sort":return()=>!0;default:throw new kr.ClientError(`Unknown query comparator "${o}"`)}function _(l,d,f,E){let h;f=f&&!s&&t?.indices[l]&&i>3,f&&(e.estimated_count==null&&pf(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(f=!1));let S=0,p=3;function R(A){let g=A[l],v;if(typeof g!="object"||!g||E?v=d(g):Array.isArray(g)?v=g.some(d):g instanceof Date&&(v=d(g.getTime())),f&&(p++,!v&&!R.idFilter&&++S/p*(i-p)>h)){let H=Ca(e,r.transaction.getReadTxn(),!1,t).map(Mn),M=new Set(H);R.idFilter=U=>M.has(Mn(U)),R.idFilter.idSet=M}return v}return a(R,"recordFilter"),s&&(R.idFilter=d),R}a(_,"attributeComparator")}function pf(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/Ms(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=pg[n]||n,n===Eg.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=Ps(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=pf(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),u=e.indices[i.relationship.from];r.estimated_count=c+(u?c*Ms(e.indices[i.relationship.from])/(Ms(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=Ms(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=O7*Ms(e.primaryStore)+1:n==="between"?r.estimated_count=A7*Ms(e.primaryStore)+1:n==="sort"?r.estimated_count=Ms(e.primaryStore)+1:r.estimated_count=R7*Ms(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function Sf(e){if(e)if(gi=e,wa.lastIndex=0,w7.test(e))try{let t=Zu(new Ia,"");if(gr!==gi.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 ${gr} in '${gi}'`,t}else{let t=new URLSearchParams(e);return t.conditions=t,t}}function Zu(e,t){let r=wa,n,s,i,o,c,u=decodeURIComponent,_;for(;n=r.exec(gi);){gr=r.lastIndex;let[,l,d]=n;if(o){if(l)throw new SyntaxError(`expected operator, but encountered '${l}'`);o=!1,c=!1}else c=!0;let f;switch(d){case"=":if(s){if(l.length<=2)i=l;else throw new SyntaxError(`invalid FIQL operator ${l}`);u=dv}else{if(u=decodeURIComponent,i="equals",!l)throw new SyntaxError("attribute must be specified before equality comparator");s=el(l)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=b7[d],u=hg[i]?dv:decodeURIComponent,!l)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=el(l);break;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,value:u(l)};i==="eq"&&fv(h,l),mf(e,_),e.conditions.push(h)}d==="&"&&(_="and"),d==="|"&&(_="or"),s=void 0;break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(el(l)),s=void 0;break;case"(":wa.lastIndex=gr;let E=Zu(l?[]:new Ia,")");switch(l){case"":mf(e,_),e.conditions.push(E);break;case"limit":switch(E.length){case 1:e.limit=+E[0];break;case 2:e.offset=+E[0],e.limit=E[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(E[0])&&E.length===1&&!E[0].name?(e.select=E[0],e.select.asArray=!0):E.length===1?e.select=E[0]:E.length===2&&E[1]===""?e.select=E.slice(0,1):e.select=E;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=Ev(E);break;default:throw new SyntaxError(`unknown query function call ${l}`)}gi[gr]===","?r.lastIndex=++gr:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!l)throw new SyntaxError("property sets must have a defined parent property name");wa.lastIndex=gr,f=Zu([],"}"),f.name=l,e.push(f),gi[gr]===","?r.lastIndex=++gr:o=!0;break;case"[":wa.lastIndex=gr,l?(f=Zu(new Ia,"]"),f.name=l):f=Zu(e.conditions?new Ia:[],"]"),e.conditions?(mf(e,_),e.conditions.push(f),s=null):e.push(f),gi[gr]===","?r.lastIndex=++gr:o=!0;break;case")":case"]":case"}":if(t===d[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:u(l)};i==="eq"&&fv(h,l),mf(e,_),e.conditions.push(h)}else if(l)throw new SyntaxError("no attribute or comparison specified")}else(l||e.length>0&&c)&&e.push(el(l));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?I7:wa,r.lastIndex=gr),gr===gi.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function mf(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 el(e){return e.indexOf(".")>-1?e.split(".").map(el):decodeURIComponent(e)}function dv(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(decodeURIComponent(r));if(t==="string")return decodeURIComponent(r);throw new kr.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function fv(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new kr.ClientError("wildcard can only be used at the end of a string")}function Ev(e){let t=hv(e[0]);return e.length>1&&(t.next=Ev(e.slice(1))),t}function hv(e){if(Array.isArray(e)){let t=hv(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 Mn(e){return Array.isArray(e)?e.join("\0"):e}function Ms(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function C7(e,t,r){return t*r/Ms(e)}var kr,Eg,os,Ti,R7,A7,O7,b7,hg,pg,w7,wa,I7,gr,gi,Ia,Tf=ge(()=>{kr=x(re()),Eg=x(dt()),os=require("ordered-binary"),Ti=require("lmdb"),R7=.3,A7=.1,O7=.05,b7={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},hg={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(mg,"executeConditions");a(Ca,"searchByIndex");a(Ps,"findAttribute");a(N7,"joinTo");a(y7,"joinFrom");pg={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(Sg,"filterByType");a(pf,"estimateCondition");w7=/[()[\]|!<>.]|(=\w*=)/,wa=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,I7=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(Sf,"parseQuery");a(Zu,"parseBlock");a(mf,"assignOperator");a(el,"decodeProperty");a(dv,"typedDecoding");a(fv,"wildcardDecoding");a(Ev,"toSortObject");a(hv,"toSortEntry");Ia=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(Mn,"flattenKey");a(Ms,"estimatedEntryCount");a(C7,"intersectionEstimate")});function gv(e){let t={openapi:D7,info:{title:"HarperDB HTTP REST interface",version:(0,Tv.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)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:u}=n.Resource;if(c=c??"id",!c)continue;let _={},l=[];if(o)for(let{type:g,name:v,elements:H,relationship:M,definition:U}of o){if(M)g==="array"?_[v]={type:"array",items:{$ref:Ri+H.type}}:_[v]={$ref:Ri+g};else{let Y=U??H?.definition;if(Y){if(!t.components.schemas[Y.type]){let K={};Y.properties.forEach(V=>{K[V.name]=new Ag(Tg[V.type],V.type)}),t.components.schemas[Y.type]=new Sv(K)}g==="array"?_[v]={type:"array",items:{$ref:Ri+Y.type}}:_[v]={$ref:Ri+Y.type}}else g==="array"?H.type==="Any"||H.type=="ID"?_[v]={type:"array",items:{format:H.type}}:_[v]={type:"array",items:new Ag(Tg[H.type],H.type)}:g==="Any"||g=="ID"?_[v]={format:g}:_[v]=new Ag(Tg[g],g)}l.push(new Og(v,"query",_[v]))}let d=Object.keys(_),f=new Og(c,"path",{format:"ID"});f.required=!0,f.description="primary key of record";let E=new Og("property","path",{enum:d});E.required=!0,t.components.schemas[i]=new Sv(_);let h=u.post!==Resource.prototype.post||u.update,S=typeof u.put=="function",p=typeof u.get=="function",R=typeof u.delete=="function",A="/"+s+"/";h&&(t.paths[A]={},t.paths[A].post=new L7(i,r,"create a new record auto-assigning a primary key")),p&&(t.paths[A]||(t.paths[A]={}),t.paths[A].get=new gg(l,r,{200:new Rg({$ref:Ri+i})},"search for records by the specified property name and value pairs")),R&&(t.paths[A]||(t.paths[A]={}),t.paths[A].delete=new pv(l,r,"delete all the records that match the provided query",{204:new mv})),A="/"+s+"/{"+c+"}",p&&(t.paths[A]={},t.paths[A].get=new gg([f],r,{200:new Rg({$ref:Ri+i})},"retrieve a record by its primary key")),S&&(t.paths[A]||(t.paths[A]={}),t.paths[A].put=new U7([f],r,i,"create or update the record with the URL path that maps to the record's primary key")),R&&(t.paths[A]||(t.paths[A]={}),t.paths[A].delete=new pv([f],r,"delete a record with the given primary key",{204:new mv})),p&&E.schema.enum.length>0&&(A="/"+s+"/{"+c+"}.{property}",t.paths[A]={},t.paths[A].get=new gg([f,E],r,{200:new Rg({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function L7(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Ri+e}}}},this.security=t,this.responses={200:{description:bg,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function gg(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function Rg(e){this.description=bg,this.content={"application/json":{schema:e}}}function mv(){this.description="successfully processed request, no content returned to client"}function U7(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Ri+r}}}},this.responses={200:{description:bg}}}function pv(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function Sv(e){this.type="object",this.properties=e}function Ag(e,t){this.type=e,this.format=t}function Og(e,t,r){this.name=e,this.in=t,this.schema=r}var Tv,D7,Tg,Ri,bg,Rv=ge(()=>{Tv=x(Sd()),D7="3.0.3",Tg={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Ri="#/components/schemas/",bg="successful operation";a(gv,"generateJsonApi");a(L7,"Post");a(gg,"Get");a(Rg,"Response200");a(mv,"Response204");a(U7,"Put");a(pv,"Delete");a(Sv,"ResourceSchema");a(Ag,"Type");a(Og,"Parameter")});var Rf={};Ye(Rf,{start:()=>v7});async function P7(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream"?"CONNECT":e.method;e.search&&Sf(e);let s=new hi;try{e.responseHeaders=s;let i=e.url.slice(1),o,c;if(i!==Av){let h=gf.getMatch(i);if(!h)return t(e);e.handlerPath=h.path,o={url:h.relativeURL,async:!0},c=h.Resource}let u=r["cache-control"];if(u){u=u.toLowerCase();let h=u.match(/max-age=(\d+)/)?.[1];h&&(e.expiresAt=h*1e3+Date.now()),u.includes("only-if-cached")&&(e.onlyIfCached=!0),u.includes("no-cache")&&(e.noCache=!0),u.includes("no-store")&&(e.noCacheStore=!0),u.includes("stale-if-error")&&(e.staleIfError=!0),u.includes("must-revalidate")&&(e.mustRevalidate=!0)}let _=await Je(e,()=>{if(n==="POST"||n==="PUT"||n==="PATCH"||n==="QUERY")try{e.data=po(r["content-type"],!0)(e.body)}catch(h){throw new Da.ClientError(h,400)}if(e.authorize=!0,i===Av&&n==="GET"){if(e?.user?.role?.permission?.super_user)return gv(gf);throw new Da.ServerError("Forbidden",403)}switch(n){case"GET":case"HEAD":return c.get(o,e);case"POST":return c.post(o,e.data,e);case"PUT":return c.put(o,e.data,e);case"DELETE":return c.delete(o,e);case"PATCH":return c.patch(o,e.data,e);case"OPTIONS":s.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return c.connect(o,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return c.query(o,e.data,e);case"COPY":return c.copy(o,r.destination,e);case"MOVE":return c.move(o,r.destination,e);case"BREW":throw new Da.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Da.ServerError(`Method ${n} is not recognized`,501)}}),l=200,d;if(_==null)l=n==="GET"||n==="HEAD"?404:204,Ng.lastModified&&e.lastModified&&s.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d=e.lastModified){M7[0]=d;let h=String.fromCharCode(34,(Vt[0]&63)+62,(Vt[0]>>6)+(Vt[1]<<2&63)+62,(Vt[1]>>4)+(Vt[2]<<4&63)+62,(Vt[2]>>2)+62,(Vt[3]&63)+62,(Vt[3]>>6)+(Vt[4]<<2&63)+62,(Vt[4]>>4)+(Vt[5]<<4&63)+62,(Vt[5]>>2)+62,(Vt[6]&63)+62,(Vt[6]>>6)+(Vt[7]<<2&63)+62,34),S=r["if-none-match"];S&&h==S?(_?.onDone&&_.onDone(),l=304,_=void 0):s.setIfNone("ETag",h),Ng.lastModified&&s.setIfNone("Last-Modified",new Date(d).toUTCString())}e.createdResource&&(l=201),e.newLocation&&s.setIfNone("Location",e.newLocation);let f={status:l,headers:s,body:void 0},E=_?.wasLoadedFromSource?.();return E!==void 0&&(f.wasCacheMiss=E,!E&&d&&s.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||d))/1e3))),_!==void 0&&(f.body=hf(_,e,f),n==="HEAD"&&(f.body=void 0)),f}catch(i){i.statusCode?i.statusCode===500?So.warn(i):So.info(i):So.error(i),i.statusCode===405&&(i.method&&(i.message+=` to handle HTTP method ${i.method.toUpperCase()||""}`),i.allow&&(i.allow.push("trace","head","options"),s.setIfNone("Allow",i.allow.map(c=>c.toUpperCase()).join(", "))));let o={status:i.statusCode||500,headers:s,body:void 0};return o.body=hf(i.contentType?i:i.toString(),e,o),o}}function v7(e){Ng=e,!Ov&&(Ov=!0,gf=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return P7(t,r)}),e.server.ws(async(t,r,n)=>{tl++;let s=new gn;bv||(bv=!0,su(l=>{tl>0&&l.push({metric:"ws-connections",connections:tl,byThread:!0})}));let i;t.on("error",l=>{i=!0,So.warn(l)});let o;t.on("message",a(function(d){o||(o=po(r.headers.asObject["content-type"]));let f=o(d);s.push(f)},"message"));let c;t.on("close",()=>{tl--,rn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()}),await n;let u=r.url.slice(1),_=gf.getMatch(u);if(rn(!!_,"connection","ws","connect"),!_)t.send(mi(`No resource was found to handle ${r.pathname}`,r));else{r.handlerPath=_.path,Br(h=>({count:h.count,total:tl}),"connections",r.handlerPath,"connect","ws");let l={url:_.relativeURL,async:!0},d=_.Resource;c=(await Je(r,()=>d.connect(l,s,r)))[Symbol.asyncIterator]();let E;for(;!(E=await c.next()).done;){let h=mi(E.value,r);t.send(h),Br(h.length,"bytes-sent",r.handlerPath,"message","ws")}}t.close()}))}var So,Da,Vt,M7,Ng,Av,Ov,gf,bv,tl,Nv=ge(()=>{ga();Os();So=x(Q()),Da=x(re());Tf();fc();ji();Hu();Rv();Vt=new Uint8Array(8),M7=new Float64Array(Vt.buffer,0,1),Ng={},Av="openapi";a(P7,"http");tl=0;a(v7,"start")});var yg=T((OEe,yv)=>{var{recordAction:Af,recordActionBinary:B7}=(Os(),ne(iu)),H7=require("fastify-plugin"),x7=200;yv.exports=H7(function(e,t,r){e.addHook("onResponse",async(n,s)=>{s.getResponseTime()}),e.addHook("onSend",async(n,s,i)=>{let o=s.getResponseTime(),c=performance.now(),u=s.request.routeOptions,_,l,d;u.config?.isOperation?(_=n.body?.operation,l="operation"):(_=u.url,l="fastify-route",d=u.method),Af(o,"duration",_,d,l),B7(s.raw.statusCode<400,"success",_,d,l);let f=x7;i?.pipe?(i.on("data",h=>{f+=h.length}),i.on("end",()=>{Af(performance.now()-c,"transfer",_,d,l),Af(f,"bytes-sent",_,d,l)})):(f+=i?.length||0,Af(f,"bytes-sent",_,d,l));let E=o.toFixed(3);s.header("Server-Timing",`db;dur=${E}`)}),r()},{name:"hdb-request-time"})});var Ug=T((yEe,Dv)=>{var yf=require("clone"),wf=rt(),F7=J(),bf=P(),bEe=Q(),wg=require("fs"),Cg=require("joi"),{string:Nf}=Cg.types(),{hdb_errors:G7,handleHDBError:Of}=re(),{HDB_ERROR_MSGS:NEe,HTTP_STATUS_CODES:Ig}=G7,{common_validators:La}=Yn(),wv=" is required",q7=["insert","update","upsert"],Dg={database:{presence:!1,format:La.schema_format,length:La.schema_length},schema:{presence:!1,format:La.schema_format,length:La.schema_length},table:{presence:!0,format:La.schema_format,length:La.schema_length},action:{inclusion:{within:q7,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},k7={schema:Nf.required(),table:Nf.required(),action:Nf.valid("insert","update","upsert")},{AWS_ACCESS_KEY:V7,AWS_SECRET:$7,AWS_BUCKET:Y7,AWS_FILE_KEY:K7,REGION:W7}=bf.S3_BUCKET_AUTH_KEYS,Q7={s3:{presence:!0},[`s3.${V7}`]:{presence:!0,type:"String"},[`s3.${$7}`]:{presence:!0,type:"String"},[`s3.${Y7}`]:{presence:!0,type:"String"},[`s3.${K7}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${W7}`]:{presence:!0,type:"String"}},Iv=yf(Dg);Iv.data.presence={message:wv};var Cv=yf(Dg);Cv.file_path.presence={message:wv};var z7=Object.assign(yf(Dg),Q7),Lg=yf(k7);Lg.csv_url=Nf.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();Lg.passthrough_headers=Cg.object();function J7(e){let t=wf.validateObject(e,Iv);return If(e,t)}a(J7,"dataObject");function X7(e){let t=wf.validateBySchema(e,Cg.object(Lg));return If(e,t)}a(X7,"urlObject");function j7(e){let t=wf.validateObject(e,Cv);return If(e,t)}a(j7,"fileObject");function Z7(e){let t=wf.validateObject(e,z7);return If(e,t)}a(Z7,"s3FileObject");function If(e,t){if(!t){let r=F7.checkGlobalSchemaTable(e.schema,e.table);if(r)return Of(new Error,r,Ig.BAD_REQUEST);if(e.operation===bf.OPERATIONS_ENUM.CSV_FILE_LOAD)try{wg.accessSync(e.file_path,wg.constants.R_OK|wg.constants.F_OK)}catch(n){return n.code===bf.NODE_ERROR_CODES.ENOENT?Of(n,`No such file or directory ${n.path}`,Ig.BAD_REQUEST):n.code===bf.NODE_ERROR_CODES.EACCES?Of(n,`Permission denied ${n.path}`,Ig.BAD_REQUEST):Of(n)}}return t}a(If,"postValidateChecks");Dv.exports={dataObject:J7,urlObject:X7,fileObject:j7,s3FileObject:Z7}});var Mg=T((IEe,Lv)=>{"use strict";var rl=Q(),Cf=P();async function eee(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===Cf.OPERATIONS_ENUM.INSERT||t.operation===Cf.OPERATIONS_ENUM.UPDATE||t.operation===Cf.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===Cf.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(rl.info(i.message),i):i.http_resp_msg?(rl.error(`Error calling operation: ${e.name}`),rl.error(i.http_resp_msg),i):(rl.error(`Error calling operation: ${e.name}`),rl.error(i),i)}}a(eee,"callOperationFunctionAsAwait");Lv.exports={callOperationFunctionAsAwait:eee}});var Mv=T((DEe,Uv)=>{"use strict";var Pg=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}},vg=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};Uv.exports={BulkLoadFileObject:Pg,BulkLoadDataObject:vg}});var vv=T((UEe,Pv)=>{"use strict";var Bg=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};Pv.exports=Bg});var kg=T((xEe,jv)=>{"use strict";var Df=en(),Uf=Ug(),tee=require("needle"),Pn=P(),PEe=nt(),Ua=J(),{handleHDBError:it,hdb_errors:$v}=re(),{HTTP_STATUS_CODES:$t,HDB_ERROR_MSGS:It,CHECK_LOGS_WRAPPER:go}=$v,Ma=Q(),Hg=require("papaparse");Ua.promisifyPapaParse();var vn=require("fs-extra"),ree=require("path"),{chain:Bv}=require("stream-chain"),Hv=require("stream-json/streamers/StreamArray"),xv=require("stream-json/utils/Batch"),Fv=require("stream-chain/utils/comp"),{finished:Gv}=require("stream"),nee=te(),Yv=Mg(),see=ig(),{BulkLoadFileObject:Fg,BulkLoadDataObject:iee}=Mv(),Gg=zT(),{verifyBulkLoadAttributePerms:Kv}=uf(),vEe=vv(),BEe=Nt(),HEe=Ss(),{databases:oee}=(Re(),ne(Ge)),{coerceType:aee}=(Mf(),ne(Vg)),qv="No records parsed from csv file.",To=`${nee.get("HDB_ROOT")}/tmp`,{schema_regex:cee}=Yn(),kv=1024*1024*2,Vv=5e3,uee={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};jv.exports={csvDataLoad:lee,csvURLLoad:_ee,csvFileLoad:dee,importFromS3:fee};async function lee(e,t){let r=Uf.dataObject(e);if(r)throw it(r,r.message,$t.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=zv(e.schema,e.table),i=Hg.parse(e.data,{header:!0,skipEmptyLines:!0,transform:xg.bind(null,s),dynamicTyping:!1}),o=new Gg;e.hdb_user&&e.hdb_user.role&&e.hdb_user.role.permission&&e.hdb_user.role.permission.super_user!==!0&&Kv(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 it(new Error,c,$t.BAD_REQUEST,void 0,void 0,!0);let u=new iee(e.action,e.schema,e.table,i.data);return n=await Yv.callOperationFunctionAsAwait(Jv,u,null),n.message===qv?qv:Xv(n.records,n.number_written)}catch(s){throw Ro(s)}}a(lee,"csvDataLoad");async function _ee(e){let t=Uf.urlObject(e);if(t)throw it(t,t.message,$t.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${To}/${r}`;try{await Eee(e,r)}catch(s){throw Ma.error(It.DOWNLOAD_FILE_ERR(r)+" - "+s),it(s,go(It.DOWNLOAD_FILE_ERR(r)))}try{let s=new Fg(this.job_operation_function.name,e.action,e.schema,e.table,n,Pn.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission),i=await qg(s);return await Lf(n),i}catch(s){throw await Lf(n),Ro(s)}}a(_ee,"csvURLLoad");async function dee(e){let t=Uf.fileObject(e);if(t)throw it(t,t.message,$t.BAD_REQUEST,void 0,void 0,!0);let r=new Fg(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,Pn.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission);try{return await qg(r)}catch(n){throw Ro(n)}}a(dee,"csvFileLoad");async function fee(e){let t=Uf.s3FileObject(e);if(t)throw it(t,t.message,$t.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=ree.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${To}/${s}`;let i=new Fg(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user.role.permission);await hee(s,e);let o=await qg(i);return await Lf(r),o}catch(n){throw await Lf(r),Ro(n)}}a(fee,"importFromS3");async function Eee(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await tee("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 it(n,s,n.statusCode,Pn.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}pee(r,e.csv_url),await mee(t,r.raw)}a(Eee,"downloadCSVFile");async function hee(e,t){try{let r=`${To}/${e}`;await vn.mkdirp(To),await vn.writeFile(`${To}/${e}`,"",{flag:"a+"});let n=await vn.createWriteStream(r),s=await see.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(){Ma.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Ma.error(It.S3_DOWNLOAD_ERR+" - "+r),it(r,go(It.S3_DOWNLOAD_ERR))}}a(hee,"downloadFileFromS3");async function mee(e,t){try{await vn.mkdirp(To),await vn.writeFile(`${To}/${e}`,t)}catch(r){throw Ma.error(It.WRITE_TEMP_FILE_ERR),it(r,go(It.DEFAULT_BULK_LOAD_ERR))}}a(mee,"writeFileToTempFolder");async function Lf(e){if(e)try{await vn.access(e),await vn.unlink(e)}catch{Ma.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(Lf,"deleteTempFile");function pee(e,t){if(e.statusCode!==$v.HTTP_STATUS_CODES.OK)throw it(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,$t.BAD_REQUEST);if(!uee[e.headers["content-type"]])throw it(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,$t.BAD_REQUEST);if(!e.raw)throw it(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,$t.BAD_REQUEST)}a(pee,"validateURLResponse");async function qg(e){try{let t;switch(e.file_type){case Pn.VALID_S3_FILE_TYPES.CSV:t=await See(e);break;case Pn.VALID_S3_FILE_TYPES.JSON:t=await Tee(e);break;default:throw it(new Error,It.DEFAULT_BULK_LOAD_ERR,$t.BAD_REQUEST,Pn.LOG_LEVELS.ERROR,It.INVALID_FILE_EXT_ERR(e))}return Xv(t.records,t.number_written)}catch(t){throw Ro(t)}}a(qg,"fileLoad");async function Wv(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 Df.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&Kv(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let u=it(c);r(u)}}a(Wv,"validateChunk");async function Qv(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Ua.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Ua.isEmpty(c)&&!Ua.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(u=>{Object.keys(u).forEach(_=>c.add(_))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},u=await Yv.callOperationFunctionAsAwait(Jv,c,null);t.records+=u.records,t.number_written+=u.number_written,s&&s.resume()}catch(c){let u=it(c,go(It.INSERT_CSV_ERR),$t.INTERNAL_SERVER_ERROR,Pn.LOG_LEVELS.ERROR,It.INSERT_CSV_ERR+" - "+c);r(u)}}a(Qv,"insertChunk");async function See(e){let t={records:0,number_written:0},r=zv(e.schema,e.table);try{let n=new Gg,s=vn.createReadStream(e.file_path,{highWaterMark:kv});s.setEncoding("utf8"),await Hg.parsePromise(s,Wv.bind(null,e,n),xg.bind(null,r));let i=n.getPermsResponse();if(i)throw it(new Error,i,$t.BAD_REQUEST);return s=vn.createReadStream(e.file_path,{highWaterMark:kv}),s.setEncoding("utf8"),await Hg.parsePromise(s,Qv.bind(null,e,t),xg.bind(null,r)),s.destroy(),t}catch(n){throw it(n,go(It.PAPA_PARSE_ERR),$t.INTERNAL_SERVER_ERROR,Pn.LOG_LEVELS.ERROR,It.PAPA_PARSE_ERR+n)}}a(See,"callPapaParse");function zv(e,t){let r=oee[e][t].attributes,n=new Map;for(let s of r)s.type&&n.set(s.name,i=>aee(i,s));return n}a(zv,"createTransformMap");function xg(e,t,r){let n=e.get(r);return n?n(t):Ua.autoCast(t)}a(xg,"typeFunction");async function Tee(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new Gg,s=Bv([vn.createReadStream(e.file_path,{encoding:"utf-8"}),Hv.withParser(),c=>c.value,new xv({batchSize:Vv}),Fv(async c=>{await Wv(e,n,r,c)})]);await new Promise((c,u)=>{Gv(s,_=>{_?u(_):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw it(new Error,i,$t.BAD_REQUEST);let o=Bv([vn.createReadStream(e.file_path,{encoding:"utf-8"}),Hv.withParser(),c=>c.value,new xv({batchSize:Vv}),Fv(async c=>{await Qv(e,t,r,c)})]);return await new Promise((c,u)=>{Gv(o,_=>{_?u(_):c()}),o.resume()}),t}catch(n){throw it(n,go(It.INSERT_JSON_ERR),$t.INTERNAL_SERVER_ERROR,Pn.LOG_LEVELS.ERROR,It.INSERT_JSON_ERR+n)}}a(Tee,"insertJson");async function Jv(e){let t={};try{e.data&&e.data.length>0&&gee(e.data[0])?t=await Ree(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Ma.info(t.message))}catch(r){throw Ro(r)}return t}a(Jv,"callBulkFileLoad");function gee(e){let t=Object.keys(e);for(let r of t)if(!cee.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(gee,"validateColumnNames");async function Ree(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=Df.insert;break;case"update":i=Df.update;break;case"upsert":i=Df.upsert;break;default:throw it(new Error,It.INVALID_ACTION_PARAM_ERR(n),$t.BAD_REQUEST,Pn.LOG_LEVELS.ERROR,It.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 l=global.hdb_schema[t][r].hash_attribute,d=e.length;for(;d--;)o.skipped_hashes.indexOf(e[d][l])>=0&&e.splice(d,1)}let u=Ua.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:u,new_attributes:o.new_attributes}}catch(o){throw Ro(o)}}a(Ree,"bulkFileLoad");function Xv(e,t){return`successfully loaded ${t} of ${e} records`}a(Xv,"buildResponseMsg");function Ro(e){return it(e,go(It.DEFAULT_BULK_LOAD_ERR),$t.INTERNAL_SERVER_ERROR,Pn.LOG_LEVELS.ERROR,It.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(Ro,"buildTopLevelErrMsg")});var e0=T((GEe,Zv)=>{"use strict";var $g=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};Zv.exports=$g});var n0=T((kEe,r0)=>{"use strict";var Aee=P(),t0=require("moment"),Oee=require("uuid").v4,Yg=class{static{a(this,"JobObject")}constructor(){this.id=Oee(),this.type=void 0,this.start_datetime=t0().valueOf(),this.created_datetime=t0().valueOf(),this.end_datetime=void 0,this.status=Aee.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};r0.exports=Yg});var Kg=T(($Ee,u0)=>{"use strict";var bee=require("uuid").v4,o0=en(),a0=Zr(),Nee=Jn(),yee=ta(),wee=e0(),ot=P(),Iee=n0(),Cee=OS(),_n=Q(),Dee=wc(),Pa=J(),{promisify:Lee}=require("util"),Ao=require("moment"),Uee=_f(),Pf=Ug(),s0=Sm(),{deleteTransactionLogsBeforeValidator:Mee}=$T(),{handleHDBError:Pee,hdb_errors:vee}=re(),{HTTP_STATUS_CODES:Bee}=vee,i0=a0.searchByValue,Hee=a0.searchByHash,xee=o0.insert,Fee=Lee(Uee.evaluateSQL),Gee=o0.update;u0.exports={addJob:Vee,updateJob:Yee,handleGetJob:qee,handleGetJobsByStartDate:kee,getJobById:c0};async function qee(e){try{let t=await c0(e.id);return Pa.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}catch(t){let r=`There was an error getting job: ${t}`;throw _n.error("There was an error getting job",t),new Error(r)}}a(qee,"handleGetJob");async function kee(e){try{let t=await $ee(e);if(_n.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=Ao(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Ao(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 _n.error(r),new Error(r)}}a(kee,"handleGetJobsByStartDate");async function Vee(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||Pa.isEmptyOrZeroLength(e.operation)){let l="job parameter is invalid";return _n.info(l),t.error=l,t}if(!ot.JOB_TYPE_ENUM[e.operation])return _n.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case ot.OPERATIONS_ENUM.CSV_FILE_LOAD:n=Pf.fileObject(e);break;case ot.OPERATIONS_ENUM.CSV_URL_LOAD:n=Pf.urlObject(e);break;case ot.OPERATIONS_ENUM.CSV_DATA_LOAD:n=Pf.dataObject(e);break;case ot.OPERATIONS_ENUM.IMPORT_FROM_S3:n=Pf.s3FileObject(e);break;case ot.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case ot.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=s0(e,"date");break;case ot.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=s0(e,"timestamp");break;case ot.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=Mee(e);break;default:break}if(n)throw Pee(n,n.message,Bee.BAD_REQUEST,void 0,void 0,!0);let s=new Iee;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 Nee(ot.SYSTEM_SCHEMA_NAME,ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await i0(i))}catch(l){let d=`There was an error inserting a new job: ${l}`;return _n.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=bee();try{o=await i0(i)}catch(l){let d=`There was an error inserting a new job: ${l}`;return _n.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return _n.error("Error creating a job, could not find a unique job id."),t}s.request=e;let u=new Dee(ot.SYSTEM_SCHEMA_NAME,ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),_;try{_=await xee(u)}catch(l){return _n.error(`There was an error inserting a job for job type: ${e.operation} -- ${l}`),t.success=!1,t}if(_.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let l=`Created a job with type ${s.type} and id ${s.id}`;t.message=l,t.createdJob=s,t.success=!0,_n.trace(l)}return t}a(Vee,"addJob");async function $ee(e){let t=Ao(e.from_date,Ao.ISO_8601),r=Ao(e.to_date,Ao.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 wee(n,e.hdb_user);try{return await Fee(s)}catch(i){throw _n.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($ee,"getJobsInDateRange");async function c0(e){if(Pa.isEmptyOrZeroLength(e))return Pa.errorizeMessage("Invalid job ID specified.");let t=new yee(ot.SYSTEM_SCHEMA_NAME,ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await Hee(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return _n.error(n),Pa.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(c0,"getJobById");async function Yee(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(Pa.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=Ao().valueOf());let t=new Cee(ot.SYSTEM_SCHEMA_NAME,ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await Gee(t),r}a(Yee,"updateJob")});var h0=T((KEe,E0)=>{"use strict";var l0=J(),Rr=P(),Kee=require("moment"),vf=kg(),Bf=Q(),_0=Kg(),d0=df(),f0=ki(),Wee=et(),Qee=sf(),Wg=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function zee(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(l0.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(l0.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Rr.JOB_TYPE_ENUM.csv_file_load:await vs(e,vf.csvFileLoad);break;case Rr.JOB_TYPE_ENUM.csv_url_load:await vs(e,vf.csvURLLoad);break;case Rr.JOB_TYPE_ENUM.csv_data_load:await vs(e,vf.csvDataLoad);break;case Rr.JOB_TYPE_ENUM.import_from_s3:await vs(e,vf.importFromS3);break;case Rr.JOB_TYPE_ENUM.empty_trash:break;case Rr.JOB_TYPE_ENUM.export_local:await vs(e,d0.export_local);break;case Rr.JOB_TYPE_ENUM.export_to_s3:await vs(e,d0.export_to_s3);break;case Rr.JOB_TYPE_ENUM.delete_files_before:case Rr.JOB_TYPE_ENUM.delete_records_before:await vs(e,f0.deleteFilesBefore);break;case Rr.JOB_TYPE_ENUM.delete_audit_logs_before:await vs(e,f0.deleteAuditLogsBefore);break;case Rr.JOB_TYPE_ENUM.delete_transaction_logs_before:await vs(e,Qee.deleteTransactionLogsBefore);break;default:return`Invalid operation ${e.json.operation} specified`}}a(zee,"parseMessage");async function vs(e,t){try{e.job.status=Rr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=Kee().valueOf(),await _0.updateJob(e.job),await Jee(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):Bf.error(`There was an error running ${t.name} job with id ${e.job.id}`),Bf.error(n),e.job.message=n,e.job.status=Rr.JOB_STATUS_ENUM.ERROR;try{await _0.updateJob(e.job)}catch(s){throw Bf.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(vs,"runJob");async function Jee(e){Bf.trace("launching job thread:",e),Wee.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:Object.assign({},process.env,{[Rr.PROCESS_NAME_ENV_PROP]:`JOB-${e}`})})}a(Jee,"launchJobThread");E0.exports={parseMessage:zee,RunnerMessage:Wg}});var p0=T((QEe,m0)=>{"use strict";var Qg=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};m0.exports=Qg});var P0=T((JEe,eR)=>{"use strict";var Gf=Zr(),Xg=_f(),Hf=kg(),Bs=od(),xf=Hi(),sl=ki(),Xee=cS(),nl=tn(),Ff=pS(),Yt=VT(),Ct=Q(),jee=gS(),Zee=Od(),S0=rT(),ete=Nd(),tte=nT(),rte=sT(),nte=aT(),ste=uT(),zg=dT(),T0=df(),ite=uf(),jg=Kg(),F=P(),{hdb_errors:ol,handleHDBError:il}=re(),{HTTP_STATUS_CODES:g0}=ol,Jg=pT(),R0=kd(),D0=require("util"),va=en(),ote=Xs(),ate=da(),A0=h0(),O0=pu(),b0=(Wd(),ne(xu)),N0=Lr(),y0=sf(),w0=jd(),{setServerUtilities:cte}=(Mf(),ne(Vg)),{CONTEXT:ute}=(Rn(),ne(fp)),{_assignPackageExport:lte}=require("../../index"),{transformReq:_te}=J(),{server:dte}=(rr(),ne(Di)),fte=Mg(),I0=Gf.searchByHash,Ete=Gf.searchByValue,hte=D0.promisify(Gf.search),mte=D0.promisify(Xg.evaluateSQL),pte={[F.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[F.OPERATIONS_ENUM.CREATE_TABLE]:!0,[F.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[F.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[F.OPERATIONS_ENUM.DROP_TABLE]:!0,[F.OPERATIONS_ENUM.DROP_SCHEMA]:!0},$=p0();async function L0(e,t){try{if(e.body.operation!=="read_log"&&(Ct.log_level===F.LOG_LEVELS.INFO||Ct.log_level===F.LOG_LEVELS.DEBUG||Ct.log_level===F.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,...o}=e.body;Ct.info(o)}}catch(n){Ct.error(n)}let r=await fte.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return pte[e.body.operation]&&ote.setSchemaDataToGlobal(n=>{n&&Ct.error(n)}),r}a(L0,"processLocalTransaction");var C0=Tte();eR.exports={chooseOperation:U0,getOperationFunction:M0,operation:Zg,processLocalTransaction:L0};cte(eR.exports);dte.operation=Zg;function U0(e){let t;try{t=M0(e)}catch(s){throw Ct.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=Xg.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=Xg.checkASTPermissions(e,i);if(o)throw Ct.error(`${g0.FORBIDDEN} from operation ${e.operation}`),Ct.warn(`User '${e.hdb_user.username}' is not permitted to ${e.operation}`),il(new Error,o,ol.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==F.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==F.OPERATIONS_ENUM.LOGIN&&e.operation!==F.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=ite.verifyPerms(i,s);if(o)throw Ct.error(`${g0.FORBIDDEN} from operation ${e.operation}`),Ct.warn(`User '${i.hdb_user.username}' is not permitted to ${i.operation}`),il(new Error,o,ol.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw il(s,"There was an error when trying to choose an operation path")}return r}a(U0,"chooseOperation");function M0(e){if(Ct.trace(`getOperationFunction with operation: ${e.operation}`),C0.has(e.operation))return C0.get(e.operation);throw il(new Error,ol.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),ol.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(M0,"getOperationFunction");lte("operation",Zg);function Zg(e,t){e.hdb_user=this[ute]?.user,e.bypass_auth=!t;let r=U0(e);return L0({body:e},r)}a(Zg,"operation");async function Ste(e){Ct.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[F.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case F.OPERATIONS_ENUM.INSERT:o=await va.insert(i);break;case F.OPERATIONS_ENUM.UPDATE:o=await va.update(i);break;case F.OPERATIONS_ENUM.UPSERT:o=await va.upsert(i);break;case F.OPERATIONS_ENUM.DELETE:o=await sl.deleteRecord(i);break;default:Ct.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){Ct.info("Invalid operation in transaction"),Ct.error(o)}}a(Ste,"catchup");async function as(e){_te(e);let t,r;try{r=await jg.addJob(e),t=r.createdJob,Ct.info("addJob result",r);let n=new A0.RunnerMessage(t,e);return await A0.parseMessage(n),{message:`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 Ct.error(s),il(n,s)}}a(as,"executeJob");function Tte(){let e=new Map;return e.set(F.OPERATIONS_ENUM.INSERT,new $(va.insert)),e.set(F.OPERATIONS_ENUM.UPDATE,new $(va.update)),e.set(F.OPERATIONS_ENUM.UPSERT,new $(va.upsert)),e.set(F.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new $(Gf.searchByConditions)),e.set(F.OPERATIONS_ENUM.SEARCH_BY_HASH,new $(I0)),e.set(F.OPERATIONS_ENUM.SEARCH_BY_ID,new $(I0)),e.set(F.OPERATIONS_ENUM.SEARCH_BY_VALUE,new $(Ete)),e.set(F.OPERATIONS_ENUM.SEARCH,new $(hte)),e.set(F.OPERATIONS_ENUM.SQL,new $(mte)),e.set(F.OPERATIONS_ENUM.CSV_DATA_LOAD,new $(as,Hf.csvDataLoad)),e.set(F.OPERATIONS_ENUM.CSV_FILE_LOAD,new $(as,Hf.csvFileLoad)),e.set(F.OPERATIONS_ENUM.CSV_URL_LOAD,new $(as,Hf.csvURLLoad)),e.set(F.OPERATIONS_ENUM.IMPORT_FROM_S3,new $(as,Hf.importFromS3)),e.set(F.OPERATIONS_ENUM.CREATE_SCHEMA,new $(Bs.createSchema)),e.set(F.OPERATIONS_ENUM.CREATE_DATABASE,new $(Bs.createSchema)),e.set(F.OPERATIONS_ENUM.CREATE_TABLE,new $(Bs.createTable)),e.set(F.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new $(Bs.createAttribute)),e.set(F.OPERATIONS_ENUM.DROP_SCHEMA,new $(Bs.dropSchema)),e.set(F.OPERATIONS_ENUM.DROP_DATABASE,new $(Bs.dropSchema)),e.set(F.OPERATIONS_ENUM.DROP_TABLE,new $(Bs.dropTable)),e.set(F.OPERATIONS_ENUM.DROP_ATTRIBUTE,new $(Bs.dropAttribute)),e.set(F.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new $(xf.describeSchema)),e.set(F.OPERATIONS_ENUM.DESCRIBE_DATABASE,new $(xf.describeSchema)),e.set(F.OPERATIONS_ENUM.DESCRIBE_TABLE,new $(xf.describeTable)),e.set(F.OPERATIONS_ENUM.DESCRIBE_ALL,new $(xf.describeAll)),e.set(F.OPERATIONS_ENUM.DELETE,new $(sl.deleteRecord)),e.set(F.OPERATIONS_ENUM.ADD_USER,new $(nl.addUser)),e.set(F.OPERATIONS_ENUM.ALTER_USER,new $(nl.alterUser)),e.set(F.OPERATIONS_ENUM.DROP_USER,new $(nl.dropUser)),e.set(F.OPERATIONS_ENUM.LIST_USERS,new $(nl.listUsersExternal)),e.set(F.OPERATIONS_ENUM.LIST_ROLES,new $(Ff.listRoles)),e.set(F.OPERATIONS_ENUM.ADD_ROLE,new $(Ff.addRole)),e.set(F.OPERATIONS_ENUM.ALTER_ROLE,new $(Ff.alterRole)),e.set(F.OPERATIONS_ENUM.DROP_ROLE,new $(Ff.dropRole)),e.set(F.OPERATIONS_ENUM.USER_INFO,new $(nl.userInfo)),e.set(F.OPERATIONS_ENUM.READ_LOG,new $(jee)),e.set(F.OPERATIONS_ENUM.ADD_NODE,new $(Zee)),e.set(F.OPERATIONS_ENUM.UPDATE_NODE,new $(S0)),e.set(F.OPERATIONS_ENUM.SET_NODE_REPLICATION,new $(S0)),e.set(F.OPERATIONS_ENUM.REMOVE_NODE,new $(ete)),e.set(F.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new $(tte)),e.set(F.OPERATIONS_ENUM.PURGE_STREAM,new $(rte)),e.set(F.OPERATIONS_ENUM.SET_CONFIGURATION,new $(N0.setConfiguration)),e.set(F.OPERATIONS_ENUM.CLUSTER_STATUS,new $(nte.clusterStatus)),e.set(F.OPERATIONS_ENUM.CLUSTER_NETWORK,new $(ste)),e.set(F.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new $(zg.setRoutes)),e.set(F.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new $(zg.getRoutes)),e.set(F.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new $(zg.deleteRoutes)),e.set(F.OPERATIONS_ENUM.EXPORT_TO_S3,new $(as,T0.export_to_s3)),e.set(F.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new $(as,sl.deleteFilesBefore)),e.set(F.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new $(as,sl.deleteFilesBefore)),e.set(F.OPERATIONS_ENUM.EXPORT_LOCAL,new $(as,T0.export_local)),e.set(F.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new $(jg.handleGetJobsByStartDate)),e.set(F.OPERATIONS_ENUM.GET_JOB,new $(jg.handleGetJob)),e.set(F.OPERATIONS_ENUM.GET_FINGERPRINT,new $(Jg.getFingerprint)),e.set(F.OPERATIONS_ENUM.SET_LICENSE,new $(Jg.setLicense)),e.set(F.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new $(Jg.getRegistrationInfo)),e.set(F.OPERATIONS_ENUM.RESTART,new $(R0.restart)),e.set(F.OPERATIONS_ENUM.RESTART_SERVICE,new $(R0.restartService)),e.set(F.OPERATIONS_ENUM.CATCHUP,new $(Ste)),e.set(F.OPERATIONS_ENUM.SYSTEM_INFORMATION,new $(ate.systemInformation)),e.set(F.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new $(as,sl.deleteAuditLogsBefore)),e.set(F.OPERATIONS_ENUM.READ_AUDIT_LOG,new $(Xee)),e.set(F.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new $(O0.createTokens)),e.set(F.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new $(O0.refreshOperationToken)),e.set(F.OPERATIONS_ENUM.LOGIN,new $(b0.login)),e.set(F.OPERATIONS_ENUM.LOGOUT,new $(b0.logout)),e.set(F.OPERATIONS_ENUM.GET_CONFIGURATION,new $(N0.getConfiguration)),e.set(F.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new $(Yt.customFunctionsStatus)),e.set(F.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new $(Yt.getCustomFunctions)),e.set(F.OPERATIONS_ENUM.GET_COMPONENT_FILE,new $(Yt.getComponentFile)),e.set(F.OPERATIONS_ENUM.GET_COMPONENTS,new $(Yt.getComponents)),e.set(F.OPERATIONS_ENUM.SET_COMPONENT_FILE,new $(Yt.setComponentFile)),e.set(F.OPERATIONS_ENUM.DROP_COMPONENT,new $(Yt.dropComponent)),e.set(F.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new $(Yt.getCustomFunction)),e.set(F.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new $(Yt.setCustomFunction)),e.set(F.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new $(Yt.dropCustomFunction)),e.set(F.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new $(Yt.addComponent)),e.set(F.OPERATIONS_ENUM.ADD_COMPONENT,new $(Yt.addComponent)),e.set(F.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new $(Yt.dropCustomFunctionProject)),e.set(F.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new $(Yt.packageComponent)),e.set(F.OPERATIONS_ENUM.PACKAGE_COMPONENT,new $(Yt.packageComponent)),e.set(F.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new $(Yt.deployComponent)),e.set(F.OPERATIONS_ENUM.DEPLOY_COMPONENT,new $(Yt.deployComponent)),e.set(F.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new $(y0.readTransactionLog)),e.set(F.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new $(as,y0.deleteTransactionLogsBefore)),e.set(F.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new $(w0.installModules)),e.set(F.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new $(w0.auditModules)),e.set(F.OPERATIONS_ENUM.GET_BACKUP,new $(Bs.getBackup)),e}a(Tte,"initializeOperationFunctionMap")});var kf=T((jEe,H0)=>{"use strict";var tR=P(),gte=J(),al=Q(),{handleHDBError:rR,hdb_errors:qf}=re(),{isMainThread:Rte}=require("worker_threads"),{Readable:Ate}=require("stream"),v0=require("os"),Ote=require("util"),bte=LS(),Nte=Ote.promisify(bte.authorize),B0=P0(),{createGzip:yte,constants:wte}=require("zlib");function Ite(e){let t=`Found an uncaught exception with message: ${e.message}. ${v0.EOL}Stack: ${e.stack} ${v0.EOL}Terminating ${Rte?"HDB":"thread"}.`;console.error(t),al.fatal(t),process.exit(1)}a(Ite,"handleServerUncaughtException");function Cte(e,t,r){if(al[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:qf.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(Cte,"serverErrorHandler");function Dte(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=rR(new Error,"Invalid JSON.",qf.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(gte.isEmpty(e.body.operation)){let n=rR(new Error,"Request body must include an 'operation' property.",qf.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Dte,"reqBodyValidationHandler");function Lte(e,t,r){let n;e.body.operation!==tR.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==tR.OPERATIONS_ENUM.LOGIN&&e.body.operation!==tR.OPERATIONS_ENUM.LOGOUT?Nte(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{al.warn(s),al.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r(rR(s,i,qf.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(Lte,"authHandler");async function Ute(e,t,r=!1){let n;try{r&&(e.body.operation!=="configure_cluster"||e.body.operation!=="set_configuration")&&(e.body.bypass_auth=r),n=B0.chooseOperation(e.body);let s=await B0.processLocalTransaction(e,n);if(s instanceof Ate&&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(yte({level:wte.Z_BEST_SPEED})))}return s}catch(s){throw al.error(s),s}}a(Ute,"handlePostRequest");H0.exports={authHandler:Lte,handlePostRequest:Ute,handleServerUncaughtException:Ite,serverErrorHandler:Cte,reqBodyValidationHandler:Dte}});var q0=T((ehe,G0)=>{"use strict";var Mte=require("fastify-plugin"),{handlePostRequest:x0,authHandler:Pte,reqBodyValidationHandler:vte}=kf();async function Bte(e){e.decorate("hdbCore",{preValidation:[vte,Pte],request:t=>F0(x0(t,response)),requestWithoutAuthentication:(t,r)=>F0(x0(t,r,!0))})}a(Bte,"hdbCore");async function F0(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(F0,"convertAsyncIterators");G0.exports=Mte(Bte)});var $0=T((nhe,V0)=>{"use strict";var rhe=require("fs"),nR=te();nR.initSync();var{CONFIG_PARAMS:k0}=P(),Hte=1024*1024*1024;function xte(e){let t=nR.get(k0.HTTP_TIMEOUT),r=nR.get(k0.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:Hte,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,https:e}}a(xte,"getServerOptions");V0.exports=xte});var W0=T((ihe,K0)=>{"use strict";var sR=te();sR.initSync();var{CONFIG_PARAMS:Y0}=P();function Fte(){let e=sR.get(Y0.HTTP_CORSACCESSLIST),t=sR.get(Y0.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(Fte,"getCORSOptions");K0.exports=Fte});var J0=T((ahe,z0)=>{"use strict";var Q0=te();Q0.initSync();var Gte=P();function qte(){return Q0.get(Gte.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(qte,"getHeaderTimeoutConfig");z0.exports=qte});var oR={};Ye(oR,{customFunctionsServer:()=>$te,ready:()=>_B,start:()=>Vte});function Vte(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){Hs||(Hs=lB(t),Ze.http((await Hs).server));let o=await Hs,c=(0,iR.dirname)(s),u=(0,iR.dirname)(n);if(u.startsWith("/")&&(u=u.slice(1)),!X0.has(c)){X0.add(c);try{o.register(Kte(c,u))}catch(_){if(_.message==="Root plugin has already booted")ke.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw _}}},ready:_B}}async function $te(){try{ke.info("In Custom Functions Fastify server"+process.cwd()),ke.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),ke.debug(`Custom Functions server process ${process.pid} starting up.`),await Yte();let e=nB.get(sB.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=Hs=await lB(e)}catch(r){throw ke.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw ke.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){ke.error(`Custom Functions ${process.pid} Error: ${e}`),ke.error(e),process.exit(1)}}async function Yte(){try{ke.info("Custom Functions starting configuration."),await iB.setUsersToGlobal(),ke.info("Custom Functions completed configuration.")}catch(e){ke.error(e)}}function Kte(e,t){return async function(r){try{ke.info("Custom Functions starting buildRoutes"),ke.trace("Loading fastify routes folder "+e),(0,j0.existsSync)(e)&&r.register(rB.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:ke.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?ke.error(s.message):s&&ke.error(s),o()})}catch(n){ke.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function lB(e){ke.info("Custom Functions starting buildServer.");let t=(0,oB.default)(e),r=(0,Z0.default)(t);r.server.headersTimeout=(0,cB.default)(),r.setErrorHandler(uB.serverErrorHandler);let n=(0,aB.default)();return n&&r.register(eB.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,u){r.server.emit("unhandled",c.raw,u.raw)}),o()}),r.register(tB.default),await r.register(kte),await r.after(),fg(r),ke.info("Custom Functions completed buildServer."),r}function _B(){if(Hs)return Hs.then?Hs.then(e=>e.ready()):Hs.ready()}var iR,j0,Z0,eB,tB,rB,nB,sB,ke,kte,iB,oB,aB,cB,uB,Hs,X0,dB=ge(()=>{iR=require("path"),j0=require("fs"),Z0=x(require("fastify")),eB=x(require("@fastify/cors")),tB=x(yg()),rB=x(require("@fastify/autoload")),nB=x(te()),sB=x(P()),ke=x(Q()),kte=x(q0()),iB=x(tn()),oB=x($0()),aB=x(W0()),cB=x(J0()),uB=x(kf());ga();rr();X0=new Set;a(Vte,"start");a($te,"customFunctionsServer");a(Yte,"setUp");a(Kte,"buildRouteFolder");a(lB,"buildServer");a(_B,"ready")});var aR={};Ye(aR,{start:()=>Wte});function Wte(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,pB.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){EB||(EB=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=fB.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,hB.default)(s,(0,mB.realpathSync)(o))}}return i(s)},{runFirst:!0})),fB.set(r,n)}}}var hB,mB,pB,fB,EB,SB=ge(()=>{hB=x(require("send")),mB=require("fs"),pB=x(require("serve-static")),fB=new Map;a(Wte,"start")});function Jte(e,t=1,r){if(cR++,(0,Oo.startWorker)("server/threads/threadServer.js",{name:Yf.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function u(_){_.type===Yf.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",u),o(n))}a(u,"onMessage"),n.on("message",u),n.on("error",c)});zte.push(s),await s,Ba.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=$f.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Ba.indexOf(n);o>-1&&Ba.splice(o,1)}if(a(i,"removeWorker"),Ha){let o=Ha;Ha=[];for(let c of o)AB[c.localPort](null,c)}}}),r){let n=setInterval(()=>{uR?uR=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Oo.shutdownWorkers)(),cR=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function OB(e=0,t){if(typeof e=="string")try{(0,Kf.existsSync)(e)&&(0,Kf.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=Xte:r=jte(t):r=_R;let n=(0,xa.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=AB[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),uR=!0,r(o,(c,u)=>{if(!c){if(TB){let l=o._socket||new xa.Socket({handle:o,writable:!0,readable:!0});TB.deliverSocket(l,e,u),l.resume()}else cR>0?(Ha.length===0&&setTimeout(()=>{Ha.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),o.localPort=e,Ha.push(o)):(console.log("start up a dynamic thread to handle request"),Jte(0));Br(!1,"socket-routed");return}c.requests++;let _=o.fd;if(_>=0)c.postMessage({port:e,fd:_,data:u});else{let l=o._socket||new xa.Socket({handle:o,writable:!0,readable:!0});rre(l,c,e)}Br(!0,"socket-routed")})};let s=eu();lR.info(`HarperDB ${s.version} Server running on port ${e}`)}return n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function _R(e,t){let r,n=0;for(let s of Ba){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=Vf)return Vf=i,t(r);n=i}Vf=0,t(r)}function Xte(e,t){let r={};e.getpeername(r);let n=r.address,s=Fa.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);_R(e,o=>{Fa.set(n,{worker:o,lastUsed:i}),t(o)})}function jte(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new xa.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let u=o.toString("latin1").match(t)?.[1],_=Fa.get(u),l=Date.now();if(_&&_.worker.threadId!==-1)return _.lastUsed=l,s(_.worker);_R(n,d=>{Fa.set(u,{worker:d,lastUsed:l}),s(d,o)})})}a(r,"findByHeaderAffinity")}function ere(){Vf=0;for(let e of Ba)e.expectedIdle=e.recentELU.idle+Zte,e.requests=1;Ba.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function rre(e,t,r){let n=tre++;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(),$f.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")),$f.delete(n)),s.event=="destroy"&&(e.destroy(),$f.delete(n))})}var Oo,xa,Yf,lR,Kf,RB,Qte,Ba,Ha,AB,TB,cR,zte,uR,Vf,gB,Fa,Zte,$f,tre,bB=ge(()=>{Oo=x(et()),xa=require("net"),Yf=x(P()),lR=x(Q()),Kf=require("fs");Os();RB=require("worker_threads"),Qte=x(Ki()),Ba=[],Ha=[],AB=[],cR=0,zte=[];RB.isMainThread&&process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)});a(Jte,"startHTTPWorker");a(OB,"startSocketServer");Vf=0;a(_R,"findMostIdleWorker");gB=36e5,Fa=new Map;a(Xte,"findByRemoteAddressAffinity");a(jte,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of Fa)r.lastUsed+gB<e&&Fa.delete(t)},gB).unref();Zte=1e3;a(ere,"updateWorkerIdleness");(0,Oo.setMonitorListener)(ere);$f=new Map,tre=1;a(rre,"proxySocket")});var hR={};Ye(hR,{Request:()=>dR,createReuseportFd:()=>Wf});var NB,dR,fR,ER,Wf,Qf=ge(()=>{NB=require("os"),dR=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 ER(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 fR(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},fR=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}},ER=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)}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,NB.platform)()!="win32"&&(Wf=require("node-unix-socket").createReuseportFd)});var CB=T((Ahe,IB)=>{"use strict";var nre=require("cluster"),bo=te();bo.initSync();var wB=P(),phe=require("util"),xs=Q(),She=require("fs"),sre=require("fastify"),The=eu(),ire=require("@fastify/cors"),ore=require("@fastify/compress"),are=require("@fastify/static"),cre=yg(),ure=require("path"),{PACKAGE_ROOT:lre}=P(),_re=Xs(),dre=J(),fre=tn(),Ere=Ki(),{server:hre}=(rr(),ne(Di)),{node_request_key:ghe}=(Qf(),ne(hR)),{authHandler:mre,handlePostRequest:pre,serverErrorHandler:Sre,reqBodyValidationHandler:Tre}=kf(),Rhe=require("net"),{registerContentHandlers:gre}=(ga(),ne(_v)),Rre=6e4,Are=1024*1024*1024,Ore="TRUE",{CONFIG_PARAMS:cl}=wB,Ga;IB.exports={hdbServer:yB,start:yB};async function yB(e){try{xs.info("In Fastify server"+process.cwd()),xs.info(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),xs.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=nre.isMaster,await bre();let t=e.securePort>0;Ga=Nre(t),await Ga.ready(),e||(e={}),e.isOperationsServer=!0;try{hre.http(Ga.server,e),Ga.server.closeIdleConnections||await Ga.listen({port:0,host:"::"})}catch(r){throw Ga.close(),xs.error(r),xs.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),xs.fatal(t),process.exit(1)}}a(yB,"operationsServer");async function bre(){xs.trace("Configuring HarperDB process."),_re.setSchemaDataToGlobal(),await fre.setUsersToGlobal(),await Ere.getLicense()}a(bre,"setUp");function Nre(e){xs.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=yre(e),r=sre(t);r.server.headersTimeout=Ire(),r.setErrorHandler(Sre);let n=wre();n&&r.register(ire,n),r.register(function(i,o,c){i.setNotFoundHandler(function(u,_){r.server.emit("unhandled",u.raw,_.raw)}),c()}),r.register(cre),r.register(ore),r.register(are,{root:ure.join(lre,"studio/build-local")}),gre(r);let s=bo.get(wB.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!dre.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[Tre,mre],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),pre(i,o)}),r.get("/health",()=>"HarperDB is running."),xs.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(Nre,"buildServer");function yre(e){let t=bo.get(cl.OPERATIONSAPI_NETWORK_TIMEOUT),r=bo.get(cl.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:Are,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(yre,"getServerOptions");function wre(){let e=bo.get(cl.OPERATIONSAPI_NETWORK_CORS),t=bo.get(cl.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===Ore)&&(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(wre,"getCORSOpts");function Ire(){return bo.get(cl.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??Rre}a(Ire,"getHeaderTimeoutConfig")});var FB=T((whe,xB)=>{"use strict";var{decode:Cre}=require("msgpackr"),{isMainThread:bhe,parentPort:Dre,threadId:Nhe}=require("worker_threads"),pR=Nt(),Fs=nt(),Lre=P(),Ai=Q(),DB=te(),UB=P();et();var Ure=Ss(),{recordAction:Mre,recordActionBinary:Pre}=(Os(),ne(iu)),{publishToStream:vre}=pR,{ConsumerEvents:Bre}=require("nats"),yhe={durable:Fs.WORK_QUEUE_CONSUMER_NAMES.durable_name,queue:Fs.WORK_QUEUE_CONSUMER_NAMES.deliver_group},Hre,xre,Fre,MB,PB;xB.exports={initialize:SR,workQueueListener:HB,setSubscription:Gre,setIgnoreOrigin:kre,getDatabaseSubscriptions:qre};async function SR(){PB=!0,Ai.notify("Starting clustering ingest service.");let{connection:e,jsm:t,js:r}=await pR.getNATSReferences();Hre=e,xre=e.info.server_name,Fre=t,MB=r}a(SR,"initialize");var Jf=new Map;function Gre(e,t,r){let n=Jf.get(e);n||Jf.set(e,n=new Map),n.set(t,r),PB||SR().then(HB)}a(Gre,"setSubscription");function qre(){return Jf}a(qre,"getDatabaseSubscriptions");var vB;function kre(e){vB=e}a(kre,"setIgnoreOrigin");var BB=100,LB=new Array(BB),zf=0;async function HB(){let e=await MB.consumers.get(Fs.WORK_QUEUE_CONSUMER_NAMES.stream_name,Fs.WORK_QUEUE_CONSUMER_NAMES.durable_name),t=!1,r;for(Dre?.on("message",async n=>{let{type:s}=n;s===UB.ITC_EVENT_TYPES.SHUTDOWN&&(t=!0,r&&r.close?.()&&r.close())});!t;){r=await e.consume(),(async()=>{for await(let n of await r.status())if(n.type===Bre.HeartbeatsMissed){let s=n.data;Ai.trace(`${s} clustering ingest consumer heartbeats missed`),s===2&&(Ai.warn("Restarting clustering ingest consumer due to missed heartbeat threshold being met"),r.stop())}})();try{for await(let n of r)await LB[zf],LB[zf]=Vre(n).catch(s=>{Ai.error(s)}),++zf>=BB&&(zf=0)}catch(n){Ai.error("Error consuming clustering ingest, restarting consumer",n)}pR.clearClientCache(),await SR()}}a(HB,"workQueueListener");async function Vre(e){let t=Cre(e.data);Mre(e.data.length,"bytes-received",e.subject,t.operation,"ingest");let r=e.headers,n=!1,s=DB.get(Lre.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Fs.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Fs.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Fs.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!vB),Pre(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Fs.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:u,table:_,records:l,hash_values:d,__origin:f,expiresAt:E}=t;Ai.trace("processing message:",o,c,_,(l?"records: "+l.map(g=>g?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),Ai.trace(`messageProcessor nats msg id: ${e.headers.get(Fs.MSG_HEADERS.NATS_MSG_ID)}`);let h;l||(l=d);let{timestamp:S,user:p,node_name:R}=f||{},A=Jf.get(c)?.get(_);if(!A)throw new Error("Missing table for replication message",_);if(o==="define_schema")t.type=o,A.send(t);else if(l.length===1&&!u)A.send({type:mR(o),value:l[0],id:d?.[0],expiresAt:E,timestamp:S,table:_,onCommit:h,user:p,nodeName:R});else{let g=l.map((v,H)=>({type:mR(o),value:v,expiresAt:E,id:d?.[H],table:_}));for(;u;)g.push({type:mR(u.operation),value:u.record,expiresAt:u.expiresAt,id:u.id,table:u.table}),u=u.next;A.send({type:"transaction",writes:g,table:_,timestamp:S,onCommit:h,user:p,nodeName:R})}DB.get(UB.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&vre(e.subject.split(".").slice(0,-1).join("."),Ure.createNatsTableStreamName(c,_),e.headers,e.data)}catch(o){Ai.error(o)}e.ack()}a(Vre,"messageProcessor");function mR(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(mR,"convertOperation")});var bR={};Ye(bR,{disableNATS:()=>Yre,publishToStream:()=>tE,setNATSReplicator:()=>TR,setPublishToStream:()=>Kre,setSubscription:()=>OR,start:()=>$re});function $re(){jf.default.get(Zf.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&Qre()}function Yre(e=!0){$B=e}function Kre(e,t){tE=e,OR=t}function Qre(){if($B||process.env._DISABLE_NATS)return;let e=Cn(),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];TR(s,r,i)}}NR((r,n)=>{TR(r.tableName,r.databaseName,r),n&&KB(r)}),!GB&&(GB=!0)}function TR(e,t,r){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 xt{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this[Le],record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this[Le]})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this[Le],record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this[Le],record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this[Le]})}static defineSchema(i){KB(i)}static subscribe(){let i=new gn;return OR(t,e,i),i}static subscribeOnThisThread(i){return i<Wre}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 Xf(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=YB;return i}a(n,"getNATSTransaction")}function KB(e){let t=jf.default.get(Zf.default.CONFIG_PARAMS.CLUSTERING_NODENAME);tE(`${RR.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,AR.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 qB,RR,AR,kB,VB,jf,Zf,eE,$B,tE,OR,Wre,YB,GB,Xf,gR,WB=ge(()=>{Re();Rn();qB=x(Nt()),RR=x(nt()),AR=x(Ss());fc();kB=x(FB()),VB=x(yr()),jf=x(te()),Zf=x(P()),eE=x(Q());a($re,"start");a(Yre,"disableNATS");tE=qB.publishToStream,OR=kB.setSubscription;a(Kre,"setPublishToStream");Wre=2;a(Qre,"assignReplicationSource");a(TR,"setNATSReplicator");a(KB,"publishSchema");Xf=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=jf.default.get(Zf.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],u,_;for(let l of i){let d=l.table,f=l.operation=="put"?"upsert":l.operation;u||(eE.trace(`Sending transaction event ${f}`),_=u={operation:f,schema:s,table:d,__origin:{user:this.user?.username,timestamp:t,node_name:r}},u.hash_values=c,f!=="delete"&&f!=="invalidate"&&(u.records=o)),u.table===d&&u.operation===f?(o.push(l.record),c.push(l.id)):_=_.next={operation:f,table:d,id:l.id,record:l.record},l.expiresAt&&(_.expiresAt=l.expiresAt)}u&&n.push(tE(`${RR.SUBJECT_PREFIXES.TXN}.${s}.${u.table}`,(0,AR.createNatsTableStreamName)(s,u.table),void 0,u)?.catch(l=>{throw eE.error("An error has occurred trying to replicate transaction",u,l),l.statusCode=504,l}))}return Promise.all(n)}},gR=class extends Xf{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,VB.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};YB=new gR});async function XB({clientId:e,user:t,clean:r,will:n}){let s;if(e&&!r){let i=await yR.get(e,{returnNonexistent:!0});s=new CR(e,t,i),i&&(s.sessionWasPresent=!0)}else{if(e){let i=await yR.get(e);i&&i.delete()}s=new nE(e,t)}return n&&(n.id=e,n.user={username:t?.username},ul.put(n)),s}function wR(){return rE++,rE>65500&&(rE=1),rE}function IR(e,t,r=e){let{topic:n,retain:s}=e;e.data=t,e.async=!0,e.authorize=!0;let i=Ei.getMatch(n);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 Je(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var QB,Oi,zB,JB,yR,ul,rE,nE,CR,jB=ge(()=>{Re();Bu();QB=x(yr()),Oi=x(Q());ji();zB=x(et()),JB=x(ZB());rr();yR=ct({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"}]}}]}),ul=ct({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,zB.getWorkerIndex)()===0&&(async()=>{await JB.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of ul.search({})){let t=e.data,r=Object.assign({},e);r.user?.username&&(r.user=await Ze.getUser(r.user.username)),Je(r,()=>{try{IR(r,t)}catch{(0,Oi.warn)("Failed to publish will",t)}ul.delete(e.id,r)})}})();a(XB,"getSession");rE=1;a(wR,"getNextMessageId");nE=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;subscriptions=[];awaitingAcks;sessionWasPresent;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("?"),u,_;if(c>-1?(u=s.slice(c),_=s.slice(0,c)):_=s,!_)throw new Error("No topic provided");if(_.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let l=this.subscriptions.find(R=>R.topic===s),d;l?(d=i>0,l.end(),this.subscriptions.splice(this.subscriptions.indexOf(l),1)):d=i===2;let f={search:u,async:!0,authorize:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,Oi.trace)("Resuming subscription from",s,"from",o);let E=Ei.getMatch(_);if(!E){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(f.url=E.relativeURL,f.url.indexOf("+")>-1||f.url.indexOf("#")>-1){let R=f.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(f.isCollection=!0,R.indexOf("+")===R.length-1)f.onlyChildren=!0,f.url="/"+R.slice(0,R.length-1);else{let A=R.split("/"),g;for(let M=0;M<A.length;M++)if(A[M].indexOf("+")>-1)if(A[M]==="+")g=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&g)throw new Error("Filters can not be combined");let v=!0;A[A.length-1]==="#"&&(A.length--,v=!1),g&&(n=a(M=>{let U=M.id;if(!Array.isArray(U)||v&&U.length!==A.length)return!1;for(let Y=0;Y<A.length;Y++)if(A[Y]!=="+"&&A[Y]!==U[Y])return!1;return!0},"filter"));let H=A.indexOf("+");f.url="/"+(H>-1?A.slice(0,H):A).concat("").join("/")}}let h=E.path,S=E.Resource,p=await Je(f,async()=>{let R=await S.subscribe(f);if(!R)throw new Error(`No subscription was returned from subscribe for topic ${s}`);if(!R[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);return(async()=>{for await(let A of R)try{let g;if(A.type&&A.type!=="put"&&A.type!=="delete"&&A.type!=="message"&&A.type!=="patch"||n&&!n(A))continue;r?(A.topic=s,g=this.needsAcknowledge(A)):(A.acknowledge?.(),g=wR());let v=A.id;Array.isArray(v)&&(v=Ta(v)),v==null&&(v=""),this.listener(h+"/"+v,A.value,g,t)}catch(g){(0,Oi.warn)(g)}})(),R});return p.topic=s,p.qos=t.qos,this.subscriptions.push(p),p}resume(){}needsAcknowledge(t){let r=wR();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,t.acknowledge)),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),!0}async publish(t,r){return t.user=this.user,IR(t,r)}setListener(t){this.listener=t}disconnect(t){let r={};Je(r,async()=>{if(!t){let n=await ul.get(this.sessionId,r);n?.doesExist()&&await IR(n,n.data,r)}await ul.delete(this.sessionId,r)}).catch(n=>{(0,Oi.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}};a(IR,"publish");CR=class extends nE{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.timestamp):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=wR(),n={topic:t.topic,timestamp:t.timestamp};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks.get(t);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,Oi.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.sessionRecord.subscriptions=this.subscriptions.map(i=>{let o=i.startTime;return o||(o=i.startTime=(0,QB.getNextMonotonicTime)()),(0,Oi.trace)("Added durable subscription",i.topic,o),{qos:i.qos,topic:i.topic,startTime:o}}),yR.put(this.sessionRecord)),t.qos}}});var DR={};Ye(DR,{bypassAuth:()=>zre,start:()=>Jre});function zre(){sH=!0}function Jre({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){let o=e.mqtt={requireAuthentication:i,sessions:new Set},c,u=r?.mtls;return n&&(c=e.ws((_,l,d)=>{if(_.protocol==="mqtt"){let{onMessage:f,onClose:E}=rH(_,(h,S)=>{if(_.send(h),S&&_._socket.writableNeedDrain)return new Promise(p=>this._socket.once("drain",p))},l,Promise.resolve(d).then(()=>l?.user),o);_.on("message",f),_.on("close",E),_.on("error",h=>{(0,Ar.info)("WebSocket error",h)})}},Object.assign({subProtocol:"mqtt"},n))),(t||s)&&(c=e.socket(async _=>{let l;if(u){if(_.authorized)try{let E=u.user;E!==null&&((E===void 0||E==="Common Name"||E==="CN")&&(E=_.getPeerCertificate().subject.CN),l=await e.getUser(E,null,null))}catch(E){(0,Ar.error)(E)}else if(u.required)return(0,Ar.info)(`Unauthorized connection attempt, no authorized client certificate provided, error: ${_.authorizationError}`),_.end()}!l&&sH&&_.remoteAddress.includes("127.0.0.1")&&(l=await(0,nH.getSuperUser)());let{onMessage:d,onClose:f}=rH(_,E=>_.write(E),null,l,o);_.on("data",d),_.on("close",f),_.on("error",E=>{(0,Ar.info)("Socket error",E)})},{port:t,securePort:s,mtls:u})),c}function rH(e,t,r,n,s){tH||(tH=!0,su(d=>{sE>0&&d.push({metric:"mqtt-connections",connections:sE,byThread:!0})}));let i;sE++;let o,c={protocolVersion:4},u=(0,oE.parser)({protocolVersion:5});function _(d){u.parse(d)}a(_,"onMessage");function l(){sE--,i||(i=!0,o?.disconnect(),s.sessions.delete(o),rn(!1,"connection","mqtt","disconnect"))}return a(l,"onClose"),u.on("packet",async d=>{n?.then&&(n=await n),o?.then&&await o;try{switch(d.cmd){case"connect":if(c.protocolVersion=d.protocolVersion,d.username)try{n=await Ze.getUser(d.username,d.password.toString(),r),(0,iE.get)(cs.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&eH.notify({username:n.username,status:cs.AUTH_AUDIT_STATUS.SUCCESS,type:cs.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch{return(0,iE.get)(cs.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&eH.error({username:n.username,status:cs.AUTH_AUDIT_STATUS.FAILURE,type:cs.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),f({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return rn(!1,"connection","mqtt","connect"),f({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let g=e.deserialize||(e.deserialize=po(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?g(d.will.payload):void 0,delete d.will.payload}o=XB({user:n,...d}),o=await o,s.sessions.add(o)}catch(g){return(0,Ar.error)(g),rn(!1,"connection","mqtt","connect"),f({cmd:"connack",reasonCode:g.code||5,returnCode:g.code||128})}rn(!0,"connection","mqtt","connect"),f({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((g,v,H,M)=>{try{let U=g.indexOf("/",1),Y=U>0?g.slice(0,U):g;f({cmd:"publish",topic:g,payload:E(v),messageId:H||Math.floor(Math.random()*1e8),qos:M.qos},Y)}catch(U){(0,Ar.error)(U),o?.disconnect(),s.sessions.delete(o)}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let h=[];for(let g of d.subscriptions){let v;try{v=(await o.addSubscription(g,g.qos>=1)).qos||0}catch(H){(0,Ar.error)(H),v=c.protocolVersion<5?128:H.statusCode===403?135:H.statusCode===404?143:128}h.push(v)}await o.committed,f({cmd:"suback",granted:h,messageId:d.messageId});break;case"unsubscribe":{let g=[];for(let v of d.unsubscriptions)g.push(o.removeSubscription(v)?0:17);f({cmd:"unsuback",granted:g,messageId:d.messageId});break}case"pubrel":f({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let S=d.qos===2?"pubrec":"puback",p=e.deserialize||(e.deserialize=po(r?.headers.get?.("content-type"))),R=d.payload?.length>0?p(d.payload):void 0,A;try{A=await o.publish(d,R)}catch(g){(0,Ar.warn)(g),d.qos>0&&f({cmd:S,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&f({cmd:S,messageId:d.messageId,reasonCode:A===!1?144:0},d.topic);break;case"pubrec":f({cmd:"pubrel",messageId:d.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(d.messageId);break;case"pingreq":f({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.sessions.delete(o),rn(!0,"connection","mqtt","disconnect"),e.close?e.close():e.end();break}}catch(h){(0,Ar.error)(h),f({cmd:"disconnect"})}function f(h,S){let p=(0,oE.generate)(h,c);t(p),Br(p.length,"bytes-sent",S,h.cmd,"mqtt")}a(f,"sendPacket");function E(h){return mi(h,r)}a(E,"serialize")}),{onMessage:_,onClose:l}}var oE,nH,iE,cs,Ar,eH,sH,tH,sE,iH=ge(()=>{oE=require("mqtt-packet");jB();nH=x(tn());ga();Os();rr();iE=x(te()),cs=x(P()),Ar=x(Q()),eH=(0,Ar.loggerWithTag)("auth-event"),sH=(0,iE.get)(cs.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(zre,"bypassAuth");a(Jre,"start");sE=0;a(rH,"onSocket")});var tf={};Ye(tf,{component_errors:()=>ka,loadComponent:()=>aE,loadComponentDirectories:()=>EH,setErrorReporter:()=>ene});function EH(e,t){t&&(UR=t),e&&(MR=e);let r=[];if((0,Bn.existsSync)(LR)){let s=(0,Bn.readdirSync)(LR,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,Tt.join)(LR,o);r.push(aE(c,UR,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(aE(n,UR,n,!1,null,process.env.DEV_MODE)),Promise.all(r).then(()=>{fH=!0})}function ene(e){_l=e}async function aE(e,t,r,n,s,i){if(!aH.has(e)){aH.set(e,!0),s&&(MR=s);try{let o;n&&(ka=new Map);let c=(0,Tt.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,Bn.existsSync)(c)?o=n?(0,dH.getConfigObj)():(0,cH.parseDocument)((0,Bn.readFileSync)(c,"utf8"),{simpleKeys:!0}).toJSON():o=PR;let u=[],_=n;for(let l in o){let d=o[l];if(ka.set(n?l:(0,Tt.basename)(e),!1),!d)continue;let f,E=d.package;try{if(E){let A=e,g;for(;!(0,Bn.existsSync)(g=(0,Tt.join)(A,"node_modules",l));)if(A=(0,Tt.dirname)(A),A.length<(0,_H.getHdbBasePath)().length){g=null;break}if(g)f=await aE(g,t,r,!1),_=!0;else throw new Error(`Unable to find package ${l}:${E}`)}else f=Zre[l];if(!f)continue;u.push(f);let h=a(A=>(A.origin=r,ct(A)),"ensureTable"),S=d.network||(d.port||d.securePort)&&d,p=S?.securePort||S?.https&&S.port,R=!S?.https&&S?.port;if(qa.isMainThread&&(f=await f.startOnMainThread?.({server:Ze,ensureTable:h,port:R,securePort:p,resources:t,...d})||f,n&&S))for(let A of[R,p])try{if(+A&&!oH.includes(A)){let g=vR.get(BR.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);g&&ll.default.warn("Session affinity is not recommended and may cause memory leaks"),(g||!Wf)&&(oH.push(A),OB(A,g))}}catch(g){console.error("Error listening on socket",A,g,l)}if(t.isWorker&&(f=await f.start?.({server:Ze,ensureTable:h,port:R,securePort:p,resources:t,...d})||f),MR.set(f,!0),(f.handleFile||f.handleDirectory)&&d.files){if(d.files.includes(".."))throw(0,lH.handleHDBError)("Can not reference parent directories");let A=(0,Tt.join)(e,d.files).replace(/\\/g,"/"),g=A.indexOf("/*");if(g>-1&&d.files!==PR[l]?.files&&!(0,Bn.existsSync)(A.slice(0,g)))throw new Error(`The path '${A.slice(0,g)}' does not exist and cannot be used as the base of the resolved 'files' path value '${d.files}'`);let v=(0,Tt.basename)(e),H=d.path||"/";H=H.startsWith("/")?H:H.startsWith("./")?"/"+v+H.slice(2):H==="."?"/"+v:"/"+v+"/"+H;let M,U,Y;if(d.root){let V=d.root;V.startsWith("/")&&(V=V.slice(1)),V.endsWith("/")&&(V=V.slice(0,-1)),V+="/",U=(0,Tt.join)(e,V)}else(Y=A.indexOf("/*"))>-1&&(U=A.slice(0,Y+1),M=(0,Tt.relative)(e,U));let K=!1;if(qa.isMainThread&&f.setupDirectory&&(K=await f.setupDirectory?.(H,U,t)),t.isWorker&&f.handleDirectory&&(K=await f.handleDirectory?.(H,U,t)),K)continue;for(let V of await(0,uH.default)(A,{onlyFiles:!1,objectMode:!0})){let{path:ce,dirent:de}=V;_=!0;let xe=(0,Tt.relative)(e,ce).replace(/\\/g,"/");if(M)if(xe.startsWith(M))xe=xe.slice(M.length+1);else throw new Error(`The root path '${d.root}' does not reference a valid part of the file path '${xe}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let ae=H+(H.endsWith("/")?"":"/")+xe;try{if(de.isFile()){let Oe=await jre(ce);qa.isMainThread&&await f.setupFile?.(Oe,ae,ce,t),t.isWorker&&await f.handleFile?.(Oe,ae,ce,t)}else qa.isMainThread&&await f.setupDirectory?.(ae,ce,t),t.isWorker&&await f.handleDirectory?.(ae,ce,t)}catch(Oe){Oe.message=`Could not load ${de.isFile()?"file":"directory"} '${ce}'${d.module?" using '"+d.module+"'":""} for application '${e}' due to: ${Oe.message}`,_l?.(Oe),((0,Va.getWorkerIndex)()===0?console:ll.default).error(Oe),t.set(d.path||"/",new dl(Oe)),ka.set(n?l:(0,Tt.basename)(e),Oe.message)}}}}catch(h){h.message=`Could not load component '${l}' for application '${(0,Tt.basename)(e)}' due to: ${h.message}`,_l?.(h),((0,Va.getWorkerIndex)()===0?console:ll.default).error(h),t.set(d.path||"/",new dl(h),null,!0),ka.set(n?l:(0,Tt.basename)(e),h.message)}}if(qa.isMainThread&&!fH&&i&&(0,Va.watchDir)(e,async()=>EH()),o.extensionModule)return await $l((0,Tt.join)(e,o.extensionModule));if(!_&&t.isWorker){let l=`${e} did not load any modules, resources, or files, is this a valid component?`;_l?.(new Error(l)),((0,Va.getWorkerIndex)()===0?console:ll.default).error(l),ka.set((0,Tt.basename)(e),l)}}catch(o){console.error(`Could not load application directory ${e}`,o),o.message=`Could not load application due to ${o.message}`,_l?.(o),t.set("",new dl(o))}}}var Bn,Tt,qa,cH,vR,BR,uH,Va,ll,lH,_H,Xre,dH,jre,LR,MR,fH,UR,ka,Zre,PR,oH,aH,_l,dl,rf=ge(()=>{Bn=require("fs"),Tt=require("path"),qa=require("worker_threads"),cH=require("yaml"),vR=x(te()),BR=x(P());PO();xO();FO();Nv();dB();SB();uH=x(require("fast-glob")),Va=x(et()),ll=x(Q());mh();rr();lH=x(re());Rn();Re();bB();_H=x(te()),Xre=x(CB());Wd();WB();iH();dH=x(Lr());Qf();({readFile:jre}=Bn.promises),LR=vR.get(BR.CONFIG_PARAMS.COMPONENTSROOT),MR=new Map,ka=new Map;a(EH,"loadComponentDirectories");Zre={REST:Rf,rest:Rf,graphqlSchema:hh,jsResource:Sh,fastifyRoutes:oR,login:gh,static:aR,operationsApi:Xre,customFunctions:{},http:{},clustering:bR,authentication:xu,mqtt:DR},PR={rest:!0,graphqlSchema:{files:"*.graphql"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(PR,"static",{value:{files:"web/**"}});oH=[],aH=new Map;a(ene,"setErrorReporter");a(aE,"loadComponent");dl=class extends xt{constructor(r){super();this.error=r}static{a(this,"ErrorResource")}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 xR=T((nme,mH)=>{var{isMainThread:hH}=require("worker_threads"),{getTables:tne}=(Re(),ne(Ge)),{loadComponentDirectories:rne,loadComponent:nne}=(rf(),ne(tf)),{resetResources:sne}=(Bu(),ne(PM)),ine=GT(),one=Lr(),{dirname:ane}=require("path"),{getConnection:cne}=Nt(),une=te(),lne=P(),HR=new Map;async function _ne(e=!1){!hH&&une.get(lne.CONFIG_PARAMS.CLUSTERING_ENABLED)&&cne();try{hH&&await ine()}catch(n){console.error(n)}let t=sne();tne(),t.isWorker=e,await nne(ane(one.getConfigFilePath()),t,"hdb",!0,HR),await rne(HR,t);let r=[];for(let[n]of HR)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(_ne,"loadRootComponents");mH.exports.loadRootComponents=_ne});var et=T((ime,Ni)=>{"use strict";var{Worker:dne,MessageChannel:fne,parentPort:us,isMainThread:VR,threadId:Ene,workerData:Gs}=require("worker_threads"),{PACKAGE_ROOT:hne}=P(),{join:gH,isAbsolute:mne,extname:pne}=require("path"),{server:RH}=(rr(),ne(Di)),{watch:Sne,readdir:Tne}=require("fs/promises"),{totalmem:pH}=require("os"),fl=P(),AH=te(),qs=Q(),{randomBytes:gne}=require("crypto"),{_assignPackageExport:Rne}=require("../../index"),Ane=P(),SH=1024*1024,bi=[],dn=[],One=50,$R=1e4,bne="restart",OH="request_thread_info",bH="resource_report",NH="thread_info",yH="added-port",Nne="ack",FR;Rne("threads",dn);Ni.exports={startWorker:GR,restartWorkers:KR,shutdownWorkers:Dne,workers:bi,setMonitorListener:xne,onMessageFromWorkers:Lne,onMessageByType:MH,broadcast:Mne,broadcastWithAcknowledgement:vne,setChildListenerByType:Cne,getWorkerIndex:wH,getWorkerCount:IH,getTicketKeys:DH,setMainIsWorker:wne,setTerminateTimeout:yne,restartNumber:Gs?.restartNumber||1};dn.onMessageByType=MH;dn.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=dn.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};var YR;function yne(e){$R=e}a(yne,"setTerminateTimeout");function wH(){return Gs?Gs.workerIndex:YR?0:void 0}a(wH,"getWorkerIndex");function IH(){return Gs?Gs.workerCount:YR?1:void 0}a(IH,"getWorkerCount");function wne(e){YR=e}a(wne,"setMainIsWorker");var CH=1,cE;function DH(){return cE||(cE=VR?gne(48):Gs.ticketKeys,cE)}a(DH,"getTicketKeys");Object.defineProperty(RH,"workerIndex",{get(){return wH()}});Object.defineProperty(RH,"workerCount",{get(){return IH()}});var LH={[OH](e,t){Bne(t)},[bH](e,t){Hne(t,e)}};function GR(e,t={}){let r=process.constrainedMemory?.()||pH();r=Math.min(r,pH(),2e4*SH);let n=AH.get(fl.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/SH/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let u of dn){let _=new fne;_.existingPort=u,i.push(_),o.push(_.port2)}pne(e)||(e+=".js");let c=new dne(mne(e)?e:gH(hne,e),Object.assign({resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(u=>u.existingPort.threadId),workerIndex:t.workerIndex,workerCount:CH=t.threadCount,name:t.name,restartNumber:Ni.exports.restartNumber,ticketKeys:DH()},transferList:o},t));for(let{port1:u,existingPort:_}of i)_.postMessage({type:yH,port:u,threadId:c.threadId},[u]);return lE(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>GR(e,t),c.on("error",u=>{console.error("Worker error:",u),qs.error("Worker error:",u)}),c.on("exit",u=>{bi.splice(bi.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<One?(t.unexpectedRestarts=c.unexpectedRestarts+1,GR(e,t)):qs.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",u=>{LH[u.type]?.(u,c)}),bi.push(c),Gne(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(GR,"startWorker");var Ine=[fl.THREAD_TYPES.HTTP];async function KR(e=null,t=Math.max(CH>3,1),r=!0){if(VR){if(r){let{loadRootComponents:o}=xR();await o()}Ni.exports.restartNumber++,t<1&&(t=t*bi.length);let n=[],s=[];for(let o of bi.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;qs.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Ni.exports.restartNumber,type:fl.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=Ine.indexOf(o.name)>-1,u=new Promise(_=>{let l=setTimeout(()=>o.terminate(),$R*2).unref();o.on("exit",()=>{clearTimeout(l),n.splice(n.indexOf(u)),!c&&r&&o.startCopy(),_()})});if(n.push(u),c&&r){let _=o.startCopy(),l=new Promise(d=>{let f=a(E=>{E.type===Ane.ITC_EVENT_TYPES.CHILD_STARTED&&(qs.trace("Worker has started",_.threadId),d(),s.splice(s.indexOf(l)),_.off("message",f))},"startListener");qs.trace("Waiting for worker to start",_.threadId),_.on("message",f)});s.push(l),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}=kd();r&&(e==="http"||!e)&&AH.get(fl.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else us.postMessage({type:bne,workerType:e})}a(KR,"restartWorkers");function Cne(e,t){LH[e]=t}a(Cne,"setChildListenerByType");function Dne(e){return KR(e,1/0,!1)}a(Dne,"shutdownWorkers");var UH=[];function Lne(e){UH.push(e)}a(Lne,"onMessageFromWorkers");var qR=new Map;function MH(e,t){let r=qR.get(e);r||qR.set(e,r=[]),r.push(t)}a(MH,"onMessageByType");var Une=10;async function Mne(e){let t=0;for(let r of dn)try{r.postMessage(e),t++>Une&&(t=0,await new Promise(setImmediate))}catch(n){qs.error("Unable to send message to worker",n)}}a(Mne,"broadcast");var uE=new Map,Pne=1;function vne(e){return new Promise(t=>{let r=0;for(let n of dn)try{let s=Pne++,i=a(()=>{uE.delete(s),--r===0&&t(),n!==us&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,uE.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of uE)o.port===n&&o()})),n.postMessage(e),r++}catch(s){qs.error("Unable to send message to worker",s)}r===0&&t()})}a(vne,"broadcastWithAcknowledgement");function Bne(e){e.postMessage({type:NH,workers:PH()})}a(Bne,"sendThreadInfo");function PH(){let e=Date.now();return bi.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(PH,"getChildWorkerInfo");function Hne(e,t){e.resources=t,e.resources.updated=Date.now()}a(Hne,"recordResourceReport");var kR;function xne(e){kR=e}a(xne,"setMonitorListener");var Fne=1e3,TH=!1;function Gne(){TH||(TH=!0,setInterval(()=>{for(let e of bi){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}kR&&kR()},Fne).unref())}a(Gne,"startMonitoring");var qne=1e3;if(us){lE(us);for(let e=0,t=Gs.addPorts.length;e<t;e++){let r=Gs.addPorts[e];r.threadId=Gs.addThreadIds[e],lE(r)}setInterval(()=>{let e=process.memoryUsage();us.postMessage({type:bH,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},qne).unref(),FR=a(()=>new Promise((e,t)=>{us.on("message",r),us.postMessage({type:OH});function r(n){n.type===NH&&(us.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else FR=PH;Ni.exports.getThreadInfo=FR;function lE(e,t){dn.push(e),e.on("message",r=>{if(r.type===yH)r.port.threadId=r.threadId,lE(r.port);else if(r.type===Nne){let n=uE.get(r.id);n&&n()}else{for(let s of UH)s(r,e);let n=qR.get(r.type);if(n)for(let s of n)try{s(r,e)}catch(i){qs.error(i)}}}).on("close",()=>{dn.splice(dn.indexOf(e),1)}).on("exit",()=>{dn.splice(dn.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(lE,"addPort");if(VR){let e,t,r=a(async(n,s)=>{s&&(e=s);for(let i of await Tne(n,{withFileTypes:!0}))i.isDirectory()&&i.name!=="node_modules"&&r(gH(n,i.name));try{for await(let{filename:i}of Sne(n,{persistent:!1}))t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await KR(),console.log("Reloaded HarperDB components")},100)}catch(i){console.warn("Error trying to watch component directory",n,i)}},"watch_dir");Ni.exports.watchDir=r,process.env.WATCH_DIR&&r(process.env.WATCH_DIR)}else us.on("message",async e=>{let{type:t}=e;t===fl.ITC_EVENT_TYPES.SHUTDOWN&&(Ni.exports.restartNumber=e.restartNumber,us.unref(),setTimeout(()=>{qs.warn("Thread did not voluntarily terminate",Ene),process.exit(0)},$R).unref())})});var $I={};Ye($I,{AUDIT_STORE_OPTIONS:()=>$H,createAuditEntry:()=>zl,openAuditStore:()=>EE,readAuditEntry:()=>Lt,setAuditRetention:()=>Vne,transactionKeyEncoder:()=>VH});function EE(e){let t=e.auditStore=e.openDB(GH.AUDIT_STORE_NAME,$H);t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,{remove(){delete r[i]}}};let n=null;function s(i=_E){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed")return;let o=0,c;try{for(let{key:u,value:_}of t.getRange({start:0,snapshot:!1,end:Date.now()-WR})){if((_[0]&15)===JR){let l=Lt(_),d=l.tableId;r[d]?.(l.recordId)}if(c=t.remove(u),await new Promise(setImmediate),++o>=kne){i=10;break}}await c}finally{o===0&&(i=Math.min(i<<1,WR/10)),s(i)}},i).unref()}return a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,fE.getWorkerIndex)()===(0,fE.getWorkerCount)()-1&&s(_E),t}function Vne(e,t=_E){WR=e,_E=t}function zl(e,t,r,n,s,i,o){let c=YH[i];if(!c)throw new Error(`Invalid audit entry type ${i}`);let u=1;n&&(n>1?$a.setFloat64(0,n):fn.set(Hh),u=9),f(0),f(t),d(r),$a.setFloat64(u,e),u+=8,s?d(s):fn[u++]=0,fn[n?8:0]=c;let l=fn.subarray(0,u);if(o)return Buffer.concat([l,o]);return l;function d(E){let h=u;u+=1,u=(0,Ya.writeKey)(E,fn,u);let S=u-h-1;S>127?S>16383?(jR.error("Key or username was too large for audit entry",E),u=h+1,fn[h]=0):(fn.copyWithin(h+2,h+1,u),$a.setUint16(h,S|32768),u++):fn[h]=S}function f(E){E<128?fn[u++]=E:E<16384?($a.setUint16(u,E|32768),u+=2):E<1056964608?($a.setUint32(u,E|3221225472),u+=4):(fn[u]=255,$a.setUint32(u+1,E),u+=5)}}function Lt(e){try{let t=e.dataView||(e.dataView=new XR(e.buffer,e.byteOffset,e.byteLength)),r;e[0]==66&&(r=t.readFloat64());let n=t.readInt(),s=t.readInt(),i=t.readInt(),o=t.readInt(),c=t.position,u=t.position+=o,_=t.readFloat64();o=t.readInt();let l=t.position,d=t.position+=o;return{type:YH[n&7],tableId:i,get recordId(){return FH(e,c,u)},version:_,previousLocalTime:r,get user(){return d>l?FH(e,l,d):void 0},getValue(f,E,h){if(n&QR||n&zR&&!E)return f.decoder.decode(e.subarray(t.position));if(n&zR&&h)return ZR(f.getEntry(this.recordId),h,f)}}}catch{return jR.error("Reading audit entry error",e),{}}}function FH(e,t,r){let n=e.subarray(t,r);return(0,Ya.readKey)(n,0,r-t)}var Ya,dE,GH,qH,fE,kH,jR,fn,$a,VH,$H,WR,kne,_E,QR,zR,vH,JR,BH,HH,xH,YH,XR,Mi=ge(()=>{Ya=require("ordered-binary"),dE=x(te()),GH=x(dt()),qH=x(P()),fE=x(et()),kH=x(J());Fo();jR=x(Q());hE();(0,dE.initSync)();fn=Buffer.alloc(1024),$a=new DataView(fn.buffer,fn.byteOffset,1024),VH={writeKey(e,t,r){return e===Tc?(t.set(Tc,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Ya.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,Ya.readKey)(e,t,r)}},$H={encoding:"binary",keyEncoder:VH},WR=(0,kH.convertToMS)((0,dE.get)(qH.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,kne=1e3,_E=1e4;a(EE,"openAuditStore");a(Vne,"setAuditRetention");QR=16,zR=32,vH=1,JR=2,BH=3,HH=4,xH=5,YH={put:vH|QR,[vH]:"put",delete:JR,[JR]:"delete",message:BH|QR,[BH]:"message",invalidate:HH,[HH]:"invalidate",patch:xH|zR,[xH]:"patch"};a(zl,"createAuditEntry");a(Lt,"readAuditEntry");XR=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t=this.getUint8(this.position++);return 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{debugger}}};a(FH,"readKeySafely")});var eA={};Ye(eA,{add:()=>mE,applyReverse:()=>KH,getRecordAtTime:()=>ZR,rebuildUpdateBefore:()=>pE});function mE(e,t,r){isNaN(e[t])?e[t]=r.value:e[t]+=r.value}function pE(e,t){let r=null;for(let n in e)if(n in t){let s=t[n];if(s?.__op__){let i=e[n];if(i?.__op__)if(i.__op__===s.__op__)r||(r={}),r[n]=i;else throw new Error("Can not merge updates with different operations");else r||(r={}),r[n]=i,mE(r,n,s)}}else r||(r={}),r[n]=e[n];return r}function KH(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=$ne[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=WH}}function ZR(e,t,r){let n=r.rootStore.auditStore,s=Object.assign({},e.value),i=e.localTime;for(;i>t;){let u=n.get(i),_=Lt(u);switch(_.type){case"put":s=_.getValue(r);break;case"patch":KH(s,_.getValue(r));break;case"delete":s=null}i=_.previousLocalTime}let o={},c=0;for(let u in s)s[u]===WH&&(o[u]=!0,c++);for(;c>0&&i>0;){let u=n.get(i),_=Lt(u),l;switch(_.type){case"put":l=_.getValue(r);break;case"patch":l=_.getValue(r);break}for(let d in l)o[d]&&(s[d]=l[d],o[d]=!1,c--);i=_.previousLocalTime}if(c>0)for(let u in o)s[u]=null;return s}var $ne,WH,hE=ge(()=>{Mi();a(mE,"add");mE.reverse=function(e,t,r){isNaN(e[t])||(e[t]-=r.value)};$ne={add:mE};a(pE,"rebuildUpdateBefore");a(KH,"applyReverse");WH={};a(ZR,"getRecordAtTime")});function Vr(e){return e[Dt]||(e[Dt]=Object.create(null))}function AE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,u,_;if(o.resolve)_={get(){return o.resolve(this,this[Ae])},set(l){return o.set(this,l)},configurable:!0};else{switch(o.type){case"String":u=a(function(l){if(!(typeof l=="string"||l==null&&o.nullable!==!1))throw new En.ClientError(`${c} must be a string, attempt to assign ${l}`);Vr(this)[c]=l},"set");break;case"ID":u=a(function(l){if(!(typeof l=="string"||l?.length>0&&l.every?.(d=>typeof d=="string")||l==null&&o.nullable!==!1))throw new En.ClientError(`${c} must be a string, attempt to assign ${l}`);Vr(this)[c]=l},"set");break;case"Float":case"Number":u=a(function(l){if(!(typeof l=="number"||l==null&&o.nullable!==!1))throw new En.ClientError(`${c} must be a number, attempt to assign ${l}`);Vr(this)[c]=l},"set");break;case"Int":u=a(function(l){if(!(l>>0===l||l==null&&o.nullable!==!1))if(typeof l=="number"&&Math.abs((l>>0)-l)<=1)l=Math.round(l);else throw new En.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${l}`);Vr(this)[c]=l},"set");break;case"Long":u=a(function(l){if(!(Math.round(l)===l&&Math.abs(l)<=9007199254740992||l==null&&o.nullable!==!1))if(typeof l=="number"&&Math.abs(l)<=9007199254740992)l=Math.round(l);else throw new En.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${l}`);Vr(this)[c]=l},"set");break;case"BigInt":u=a(function(l){if(!(typeof l=="bigint"||l==null&&o.nullable!==!1))if(typeof l=="string"||typeof l=="number")l=BigInt(l);else throw new En.ClientError(`${c} must be a number, attempt to assign ${l}`);Vr(this)[c]=l},"set");break;case"Boolean":u=a(function(l){if(!(typeof l=="boolean"||l==null&&o.nullable!==!1))throw new En.ClientError(`${c} must be a boolean, attempt to assign ${l}`);Vr(this)[c]=l},"set");break;case"Date":u=a(function(l){if(!(l instanceof Date||l==null&&o.nullable!==!1))if(typeof l=="string"||typeof l=="number")l=new Date(l);else throw new En.ClientError(`${c} must be a Date, attempt to assign ${l}`);Vr(this)[c]=l},"set");break;case"Bytes":u=a(function(l){if(!(l instanceof Uint8Array||l==null&&o.nullable!==!1))throw new En.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${l}`);Vr(this)[c]=l},"set");break;case"Any":case void 0:u=a(function(l){Vr(this)[c]=l},"set");break;default:u=a(function(l){if(!(typeof l=="object"||l==null&&o.nullable!==!1))throw new En.ClientError(`${c} must be an object, attempt to assign ${l}`);Vr(this)[c]=l},"set")}_={get(){let l=this[Dt];if(l&&c in l){let f=l[c];if(f?.__op__){let E=this[_e]?.[c];return f.update(E)}return f}let d=this[_e]?.[c];if(d&&typeof d=="object"){let f=zH(d,o);if(f)return l||(l=this[Dt]=Object.create(null)),l[c]=f}return d},set:u,enumerable:!0,configurable:!0}}_.get.isAttribute=!0,n[c]=_,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,_)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let u=this[Dt];return u?.[o]!==void 0?u[o]:this[_e]?.[o]}),i("set",function(o,c){let u=n[o];if(u)return u.set.call(this,c);if(t.sealed)throw new En.ClientError("Can not add a property to a sealed table schema");Vr(this)[o]=c}),i("deleteProperty",function(o){Vr(this)[o]=void 0}),i("toJSON",function(){let o=this[Dt],c;for(let _ in o){c||(c=Object.assign({},this[_e]));let l=o[_];if(l?.__op__){let d=c[_];l=l.update(d)}c[_]=l}return Object.keys(this).length>0&&(c||(c=Object.assign({},this[_e])),Object.assign(c,this)),c||this[_e]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function zH(e,t){let r;switch(e.constructor){case Object:return t?((r=t.TrackedObject)||(t.TrackedObject=r=class{static{a(this,"TrackedObject")}constructor(s){if(s?.[_e])throw new Error("Can not track an already tracked object, check for circular references");this[_e]=s}},AE(r,t)),new r(e)):new SE(e);case Array:let n=new gE(e.length);n[_e]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=zH(o,t?.elements)),n[s]=o}return n;default:return e}}function $_(e){let t=e[Dt],r;for(let s in t){r||(r=Object.assign({},e[_e]));let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=$_(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=Object.assign({},e[_e])),Object.assign(r,e)),r||e[_e]}function yo(e,t=e[Dt]){let r;if(QH.call(e,_e)&&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=yo(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=Object.assign({},e[_e]));let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=eA[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=yo(s);r[n]=s}return r?Object.freeze(r):QH.call(e,_e)?e[_e]:e}function TE(e){let t=e[_e];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[No]||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?.[_e]===s){if(TE(i))return!0}else return!0}}else{let r=e[Dt];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[_e]===i){if(TE(s))return!0}else return!0}else return!0}}return!1}var En,Dt,SE,QH,No,gE,RE,Y_=ge(()=>{Rn();En=x(re());hE();Dt=Symbol("own-data");a(Vr,"getChanges");a(AE,"assignTrackedAccessors");a(zH,"trackObject");SE=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[_e])throw new Error("Can not track an already tracked object, check for circular references");this[_e]=t}};AE(SE,{});a($_,"collapseData");QH=Object.prototype.hasOwnProperty;a(yo,"deepFreeze");a(TE,"hasChanges");No=Symbol.for("has-array-changes"),gE=class extends Array{static{a(this,"TrackedArray")}[No];constructor(t){super(t)}splice(...t){return this[No]=!0,super.splice(...t)}push(...t){return this[No]=!0,super.push(...t)}pop(){return this[No]=!0,super.pop()}unshift(...t){return this[No]=!0,super.unshift(...t)}shift(){return this[No]=!0,super.shift()}};gE.prototype.constructor=Array;RE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var fp={};Ye(fp,{CONTEXT:()=>Ae,ID_PROPERTY:()=>Le,IS_COLLECTION:()=>hn,RECORD_PROPERTY:()=>_e,Resource:()=>xt,snake_case:()=>Kne,transformForSelect:()=>bE});function Kne(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function JH(e,t){if(El=!1,e==="")return null;if(e=e.slice(1),e.indexOf("/")===-1)return e===""?(El=!0,null):(e.startsWith("$")&&(e=parseInt(e,36)),t.coerceId(decodeURIComponent(e)));let r=e.split("/"),n=new rA;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){El=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}function $r(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,u,_,l;if(r?(o?(l=i,o=o[Ae]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(l=s,c=l[this.primaryKey]??null,o=i[Ae]||i):l=i:(l=s,c=l[Le]??l[this.primaryKey]??null),c==null&&(_=!0)):i?o=i[Ae]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="string")c=s;else if(typeof s=="object"&&s)if(u=s,s[Symbol.iterator]){c=[],_=!0;for(let E of s){if(typeof E=="object"&&E)break;c.push(E)}c.length===0?c=null:(c.length===1&&(c=c[0]),u.slice&&(u=u.slice(c.length,u.length),u.length===0&&(u=null,_=!1)))}else{if(typeof(c=s.url)=="string"){let E=c.indexOf("?");if(E>-1){let S=this.parseQuery(c.slice(E+1));u?u=Object.assign(S,u):u=S,c=c.slice(0,E)}let h=this.parsePath(c,o,u);h?.id!==void 0?(h.query&&(u?u=Object.assign(h.query,u):u=h.query),_=h.isCollection,c=h.id):c=h}c===void 0&&(c=s.id??null,c==null&&(_=!0))}else c=s??null,c==null&&(_=!0);o||(o={});let d;if(u?.ensureLoaded!=null||u?.async||_?(d=Object.assign({},t),u?.ensureLoaded!=null&&(d.ensureLoaded=u.ensureLoaded),u?.async&&(d.async=u.async),_&&(d.isCollection=!0)):d=t,o.transaction){let E=this.getResource(c,o,d);return E.then?E.then(f):f(E)}else return Je(o,()=>{let E=this.getResource(c,o,d);return E.then?E.then(f):f(E)},d);function f(E){if(o.authorize){o.authorize=!1;let h=t.type==="read"?E.allowRead(o.user,u,o):t.type==="update"?E.doesExist?.()===!1?E.allowCreate(o.user,l,o):E.allowUpdate(o.user,l,o):t.type==="create"?E.allowCreate(o.user,l,o):E.allowDelete(o.user,u,o);if(h?.then)return h.then(S=>{if(!S)throw new OE(o.user);return typeof l?.then=="function"?l.then(p=>e(E,u,o,p)):e(E,u,o,l)});if(!h)throw new OE(o.user)}return typeof l?.then=="function"?l.then(h=>e(E,u,o,h)):e(E,u,o,l)}a(f,"authorizeActionOnResource")}}function Yr(e,t){let r=new ZH.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 tA(e,t,r){let n=e[_e];if(n){let s=e[Dt];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 bE(e,t){let r=t?.propertyResolvers,n=t[Ae],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):tA(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(u){if(u.then)return u.then(c);if(Array.isArray(u))return u.map(c);let _=[],l=i(tA(u,r,n));for(let d of e)_.push(l(d));return _},"transform");let o=e.forceNulls;return a(function c(u){if(u.then)return u.then(c);if(Array.isArray(u))return u.map(f=>f&&typeof f=="object"?c(f):f);let _={},l=i(tA(u,r,n)),d;for(let f of e){let E=l(f);E===void 0&&o&&(E=null),E?.then?(d||(d=[]),d.push(E.then(h=>_[f.name||f]=h))):_[f.name||f]=E}return d?Promise.all(d).then(()=>_):_},"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 u=s[c.name];if(!u){let l=r[c.name]?.definition?.tableClass;u=s[c.name]=bE(c.select||c,l)}let _=o(c.name);return u(_)}else return o(c);else return c}}a(i,"handleProperty")}var XH,jH,ZH,Ae,Le,hn,_e,Yne,xt,OE,El,rA,Rn=ge(()=>{XH=require("crypto");fc();jH=require("../../index"),ZH=x(re());Y_();ji();Tf();Ae=Symbol.for("context"),Le=Symbol.for("primary-key"),hn=Symbol("is-collection"),_e=Symbol("stored-record"),Yne={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},xt=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[Le]=t;let n=r?.[Ae];this[Ae]=n!==void 0?n:r||null}static get=$r(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let u;if((u=r?.select)&&c!=null&&!c.selectApplied){let _=bE(u,t.constructor);return typeof c?.map=="function"?c.map(_):_(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=$r(function(t,r,n,s){if(Array.isArray(s)&&t[hn]){let i=[],o=n.authorize;for(let c of s){let u=t.constructor,_=u.getResource(c[u.primaryKey],n,{async:!0});_.then?i.push(_.then(l=>l.put(c,n))):i.push(_.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):Yr(t,"put")},{hasContent:!0,type:"update"});static patch=$r(function(t,r,n,s){return t.patch?t.patch(s,r):Yr(t,"patch")},{hasContent:!0,type:"update"});static delete=$r(function(t,r,n,s){return t.delete?t.delete(r):Yr(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,XH.randomUUID)()}static create(t,r,n){let s;return t==null?s=this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=[...t,this.getNewId()]:typeof t!="object"?s=[t,this.getNewId()]:(s=this.getNewId(),n=r,r=t),Je(n,()=>{let i=new this(s,n),o=i.update?i.update(r):Yr(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>s):s})}static invalidate=$r(function(t,r,n,s){return t.invalidate?t.invalidate(r):Yr(t,"delete")},{hasContent:!1,type:"update"});static post=$r(function(t,r,n,s){return t[Le]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=$r(function(t,r,n,s){return t.connect?t.connect(s,r):Yr(t,"connect")},{hasContent:!0,type:"read"});static subscribe=$r(function(t,r,n,s){return t.subscribe?t.subscribe(r):Yr(t,"subscribe")},{type:"read"});static publish=$r(function(t,r,n,s){return t[Le]!=null&&t.update?.(),t.publish?t.publish(s,r):Yr(t,"publish")},{hasContent:!0,type:"create"});static search=$r(function(t,r,n,s){let i=t.search?t.search(r):Yr(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=bE(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=$r(function(t,r,n,s){return t.search?t.search(s,r):Yr(t,"search")},{hasContent:!0,type:"read"});static copy=$r(function(t,r,n,s){return t.copy?t.copy(s,r):Yr(t,"copy")},{type:"create"});static move=$r(function(t,r,n,s){return t.move?t.move(s,r):Yr(t,"move")},{type:"delete"});post(t){if(this[hn])return this.constructor.create(this[Le],t,this[Ae]);Yr(this,"post")}static isCollection(t){return t?.[hn]}static coerceId(t){return t}static parseQuery(t){return Sf(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1);t=t.slice(0,s);let c=r?.headers&&Yne[o];if(c)r.headers.set("accept",c);else if(n)n.property=o;else return{query:{property:o},id:JH(t,this),isCollection:El}}let i=JH(t,this);return El?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[Ae],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 u;if(i.resourceCache?u=i.resourceCache:u=i.resourceCache=[],u.asMap){let _=u.asMap.get(t);if(s=_?.find(l=>l.constructor===c),s)return s;_||u.asMap.set(t,_=[]),_.push(s=new c(t,i))}else{if(s=u.find(_=>_[Le]===t&&_.constructor===c),s)return s;if(u.push(s=new c(t,i)),u.length>10){let _=new Map;for(let l of u){let d=l[Le],f=_.get(d);f?f.push(l):_.set(d,[l])}i.resourceCache.length=0,i.resourceCache.asMap=_}}}else s=new c(t,i);return o&&(s[hn]=!0),s}subscribe(t){return new gn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new gn}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[Le]}getContext(){return this[Ae]}};xt.prototype[Ae]=null;(0,jH._assignPackageExport)("Resource",xt);a(Kne,"snake_case");OE=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(JH,"pathToId");rA=class extends Array{static{a(this,"MulitPartId")}toString(){return this.join("/")}};a($r,"transactional");a(Yr,"missingMethod");a(tA,"selectFromObject");a(bE,"transformForSelect")});function tx(e,t,r,n){let s=e.primaryStore.env.path,i=e.primaryStore.tableId;Ka||((0,NE.onMessageByType)(ex,l=>{rx(l.path)}),Ka=Object.create(null));let o=Ka[s]||(Ka[s]=[]);o.auditStore=e.auditStore,o.lastTxnTime==null&&(o.lastTxnTime=Date.now());let c=o[i];c||(c=o[i]=new Map,c.envs=o,c.tableId=i,c.store=e.primaryStore),t=Ta(t);let u=new sA(r);u.startTime=n;let _=c.get(t);return _?_.push(u):(c.set(t,_=[u]),_.tables=c,_.key=t),u.subscriptions=_,u}function rx(e,t){if(!Ka)return;let r=Ka[e];if(!r)return;try{r.auditStore.resetReadTxn()}catch(s){throw s.message+=" in "+e,s}let n;for(let{key:s,value:i}of r.auditStore.getRange({start:r.lastTxnTime,exclusiveStart:!0})){r.lastTxnTime=s;let o=Lt(i),c=r[o.tableId];if(!c)continue;let u=o.recordId,_,l=Ta(o.recordId),d=0;do{let f=c.get(l);if(f){for(let h of f)if(!(d>0&&!(h.includeDescendants&&!(h.onlyChildren&&d>1)))){if(h.startTime>=s){(0,nA.info)("omitting",u,h.startTime,s);continue}try{if(h.crossThreads===!1&&!t)continue;let S;h.supportsTransactions&&h.txnInProgress!==o.version&&(S=!0,h.txnInProgress||(n?n.push(h):n=[h]),h.txnInProgress=o.version),h.listener(u,o,s,S)}catch(S){console.error(S),(0,nA.info)(S)}}}if(l==null)break;let E=l.lastIndexOf?.("/",l.length-2);E>-1?l=l.slice(0,E):l=null,d++}while(!0)}if(n)for(let s of n)s.txnInProgress=null,s.listener(null,{type:"end_txn"},r.lastTxnTime,!0)}function nx(e,t){let r=t||e,n=r.env;if(t&&!t.cache&&(t.cache=new Map),!n.hasBroadcastListener){n.hasBroadcastListener=!0;let s=n.path;r.on("aftercommit",()=>{(0,NE.broadcast)({type:ex,path:s}),rx(s,!0)})}}var nA,NE,ex,Ka,wme,sA,sx=ge(()=>{nA=x(Q()),NE=x(et());fc();Bu();Mi();ex="transaction",wme=Buffer.alloc(4096);a(tx,"addSubscription");sA=class extends gn{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,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(rx,"notifyFromTransactionData");a(nx,"listenToCommits")});var Vg={};Ye(Vg,{coerceType:()=>yE,makeTable:()=>CE,setServerUtilities:()=>tse,updateResource:()=>wE});function CE(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:u,schemaDefined:_,dbisDB:l}=e,{expirationMS:d,evictionMS:f,audit:E,trackDeletes:h}=e,{attributes:S}=e;S||(S=[]),nx(i,u);let p=Gh(i,n,u),R=0,A,g,v={},H=Promise.resolve(),M,U,Y;for(let W of S)(W.assignCreatedTime||W.name==="__createdtime__")&&(M=W),(W.assignUpdatedTime||W.name==="__updatedtime__")&&(U=W),W.expiresAt&&(Y=W),W.isPrimaryKey&&(v=W);let K,V=[],ce=[],de=1,xe=2,ae={},Oe={},Ve=864e5,Fn,Mo,Vs,AA=!1,KE,Jx=i.getRange({start:!1,end:!1}).constructor,Xx=10,jx=6;E&&NA();class Qe extends xt{static name=s;static primaryStore=i;static auditStore=u;static primaryKey=t;static tableName=s;static indices=r;static audit=E;static databasePath=o;static databaseName=c;static attributes=S;static expirationTimer;static createdTimeProperty=M;static updatedTimeProperty=U;static propertyResolvers;static sources=[];static get expirationMS(){return d}static dbisDB=l;static schemaDefined=_;static sourcedFrom(m,O){O&&(this.sourceOptions=O,(O.expiration||O.eviction||O.scanInterval)&&this.setTTLExpiration(O)),O?.intermediateSource?(m.intermediateSource=!0,this.sources.unshift(m)):this.sources.push(m),g=m.get&&(!m.get.reliesOnPrototype||m.prototype.get);let w=a(D=>{let y=this.sources.slice(0,-1);if(y=y.filter(L=>L[D]&&(!L[D].reliesOnPrototype||L.prototype[D])),y.length>0)if(y.length===1){let L=y[0];return(q,C,B)=>{if(q?.source!==L)return L[D](C,B,q)}}else return(L,q,C)=>{let B=[];for(let G of y){if(L?.source===G)break;B.push(G[D](q,C,L))}return Promise.all(B)}},"getApplyToIntermediateSource"),N=this.sources[this.sources.length-1],b=a(D=>{if(N[D]&&(!N[D].reliesOnPrototype||N.prototype[D]))return(y,L,q)=>{if(!y?.source)return N[D](L,q,y)}},"getApplyToCanonicalSource");return ae={put:b("put"),patch:b("patch"),delete:b("delete"),publish:b("publish")},Oe={put:w("put"),patch:w("patch"),delete:w("delete"),publish:w("publish"),invalidate:w("invalidate")},(async()=>{let D=!1,y=a(async(L,q)=>{let C=L.value,B=L.table?tt[c][L.table]:Qe;if(c===xn.SYSTEM_SCHEMA_NAME&&(L.table===xn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||L.table===xn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(D=!0),L.id===void 0&&(L.id=C[B.primaryKey],L.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(L));L.source=m;let G=await B.getResource(L.id,q,Wa);switch(L.type){case"put":return G._writeUpdate(C,!0,Wa);case"patch":return G._writeUpdate(C,!1,Wa);case"delete":return G._writeDelete(Wa);case"publish":return G._writePublish(C,Wa);case"invalidate":return G.invalidate(Wa);default:Xe.error("Unknown operation",L.type,L.id)}},"writeUpdate");try{let L=m.subscribe;L&&h==null&&(h=!0);let q=m.subscribeOnThisThread?m.subscribeOnThisThread((0,Io.getWorkerIndex)()):(0,Io.getWorkerIndex)()===0,C=L&&q&&await m.subscribe?.({crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0});if(C){let B;for await(let G of C)try{if(!(G.type==="transaction"?G.writes[0]:G)){Xe.error("Bad subscription event",G);continue}if(G.source=m,B)if(G.beginTxn)B.resolve();else{y(G,B);continue}if(G.type==="end_txn")continue;let be=Je(G,()=>{if(G.type==="transaction"){let Z=[];for(let Me of G.writes)try{Z.push(y(Me,G))}catch(oe){throw oe.message+=" writing "+JSON.stringify(Me)+" of event "+JSON.stringify(G),oe}return Promise.all(Z)}else if(G.type==="define_schema"){let Z=this.attributes.slice(0),Me;for(let oe of G.attributes)Z.find(Fe=>Fe.name===oe.name)||(Z.push(oe),Me=!0);Me&&(ct({table:s,database:c,attributes:Z,origin:"cluster"}),Rl.signalSchemaChange(new Al.SchemaEventMsg(process.pid,xn.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return G.beginTxn?(B=G,y(G,G),new Promise(Z=>{B.resolve=Z})):y(G,G)});D&&(await be,Rl.signalUserChange(new Al.UserEventMsg(process.pid))),G.onCommit&&(be?.then?be.then(G.onCommit):G.onCommit())}catch(ie){Xe.error("error in subscription handler",ie)}}}catch(L){Xe.error(L)}})(),this}static getResource(m,O,w){let N=super.getResource(m,O,w);if(m!=null){ja(m);try{if(N.hasOwnProperty(_e))return N;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let b=!w?.async||i.cache?.get(m),D=Sn(O),y=D.getReadTxn();if(y?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return WE(m,O,{transaction:y},b,L=>{if(L?wE(N,L):N[_e]=null,O.onlyIfCached&&O.noCacheStore){if(!N.doesExist())throw new mn.ServerError("Entry is not cached",504)}else if(w?.ensureLoaded){let q=QE(m,L,O,N);if(q)return D?.disregardReadTxn(),N[iA]=!0,aA(q,C=>(wE(N,C),N))}return N})}catch(b){throw b.message.includes("Unable to serialize object")&&(b.message+=": "+JSON.stringify(m)),b}}return N}ensureLoaded(){let m=QE(this[Le],this[Kr],this[Ae]);if(m)return this[iA]=!0,aA(m,O=>{this[Kr]=O,this[_e]=O.value,this[Tl]=O.version})}static setTTLExpiration(m){if(typeof m=="number")d=m*1e3,f||(f=0);else if(m&&typeof m=="object")d=m.expiration*1e3,f=(m.eviction||0)*1e3,Ve=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(d<0)throw new Error("Expiration can not be negative");Ve=Ve||(d+f)/4,JE()}static enableAuditing(m=!0){E=m,m&&NA(),Qe.audit=m}static coerceId(m){return m===""?null:yE(m,v)}static async dropTable(){if(delete tt[c][s],c===o){for(let m of S)l.remove(Qe.tableName+"/"+m.name),r[m.name]?.drop();l.remove(Qe.tableName+"/"),i.drop(),await l.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));Rl.signalSchemaChange(new Al.SchemaEventMsg(process.pid,xn.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this[hn])return this.search(m);if(this[Le]===null){if(m?.conditions)return this.search(m);let O=Qe.getRecordCount();return{recordCount:O.recordCount,estimatedRecordRange:O.estimatedRange,records:"./",name:s,database:c,attributes:S}}if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this[Ae]?.returnNonexistent)return this}allowRead(m,O){let w=Ll(m);if(w?.read){if(w.isSuperUser)return!0;let N=w.attribute_permissions,b=O?.select;if(N?.length>0||AA&&b){if(O||(O={}),b){let D=N?.length>0&&oA(N,"read");O.select=b.map(y=>{let L=y.name||y;if(!D||D[L]){let q=Vs[L]?.definition?.tableClass;if(q){if(y.name||(y={name:y}),!q.prototype.allowRead.call(null,m,y))return!1;if(!y.select)return y.name}return y}}).filter(Boolean)}else O.select=N.filter(D=>D.read&&!Vs[D.attribute_name]).map(D=>D.attribute_name);return O}else return!0}}allowUpdate(m,O){let w=Ll(m);if(w?.update){let N=w.attribute_permissions;if(N?.length>0){let b=oA(N,"update");for(let D in O)if(!b[D])return!1;for(let D of N){let y=D.attribute_name;!D.update&&!(y in O)&&(O[y]=this.getProperty(y))}}return!0}}allowCreate(m,O){if(this[hn]){let w=Ll(m);if(w?.insert){let N=w.attribute_permissions;if(N?.length>0){let b=oA(N,"insert");for(let D in O)if(!b[D])return!1}else return!0}}else return this.allowUpdate(m,{})}allowDelete(m){return Ll(m)?.delete}update(m,O){if(!Sn(this[Ae]))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let N;return typeof m=="object"&&m&&(O?(Object.isFrozen(m)&&(m=Object.assign({},m)),this[_e]={},this[Dt]=m):(N=this[Dt],N&&(m=Object.assign(N,m)),this[Dt]=N=m)),this._writeUpdate(this[Dt],O),this}addTo(m,O){if(typeof O=="number")this[hl]===ox?this.set(m,(+this.getProperty(m)||0)+O):(this[hl]||this.update(),this.set(m,new RE(O)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,O){if(typeof O=="number")return this.addTo(m,-O);throw new Error("Can not subtract a non-numeric value")}invalidate(m){let O=this[Ae],w=this[Le];ja(w),Sn(this[Ae]).addWrite({key:w,store:i,invalidated:!0,entry:this[Kr],nodeName:this[Ae]?.nodeName,before:ae.invalidate?.bind(this,O,w),beforeIntermediate:Oe.invalidate?.bind(this,O,w),commit:(b,D)=>{if(D?.version>b)return;let y=null;for(let L in r)y||(y={}),y[L]=this.getProperty(L);p(w,y,this[Kr],b,ml,E,this[Ae],0,"invalidate")}})}static evict(m,O,w){let N=this.Source,b;if(!((g||E)&&(!O||(b=i.getEntry(m),!b||!O)||b.version!==w))){if(g){if(i.hasLock(m,b.version))return;let D;for(let y in r)D||(D={}),D[y]=O[y];if(D)return p(m,D,b,w,pl,null,null,0,null,!0)}return i.ifVersion(w,()=>{Dl(m,O,null)}),E?p(m,null,b,w,pl,null,null,0,null,!0):i.remove(m,w)}}lock(){throw new Error("Not yet implemented")}static operation(m,O){return m.table||=s,m.schema||=c,dx.operation(m,O)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,O,w){let N=this[Ae],b=Sn(N),D=this[Le];ja(D);let y=this[Kr];this[hl]=O?ox:jne;let L={key:D,store:i,entry:y,nodeName:N?.nodeName,validate:q=>{m||(m=this[Dt]),O||m&&TE(m)?(this.validate(m,!O),N?.source||(U&&(m[U.name]=U.type==="Date"?new Date(q):U.type==="String"?new Date(q).toISOString():q),O&&(t&&m[t]!==D&&(m[t]=D),M&&(y?.value?m[M.name]=y?.value[M.name]:m[M.name]=M.type==="Date"?new Date(q):M.type==="String"?new Date(q).toISOString():q),m=yo(m)))):b.removeWrite(L)},before:O?ae.put?()=>ae.put(N,D,m):null:ae.patch?()=>ae.patch(N,D,m):ae.put?()=>ae.put(N,D,yo(this)):null,beforeIntermediate:O?Oe.put?()=>Oe.put(N,D,m):null:Oe.patch?()=>Oe.patch(N,D,m):Oe.put?()=>Oe.put(N,D,yo(this)):null,commit:(q,C,B)=>{if(B){if(N&&C?.version>(N.lastModified||0)&&(N.lastModified=C.version),this[Kr]=C,C?.value?.[_e])throw new Error("Can not assign a record to a record, check for circular references");O||(this[_e]=C?.value??null)}this[Dt]=m,this[Tl]=q;let G=C?.value,ie=m;if(this[hl]=0,C?.version>=q)if(E){let oe=C.localTime,Fe=C.version;for(;ie&&(oe>q||Fe>=q&&oe>0);){let ee=u.get(oe),X=Lt(ee);if(Fe=X.version,Fe>q){if(X.type==="patch"){let Te=X.getValue(i);ie=pE(ie,Te)}else if(X.type==="put"||X.type==="delete")return}else if(Fe===q)return;oe=X.previousLocalTime}}else{if(O)return;ie=pE(ie,G)}let be;if(O?be=ie:(this[_e]=G,be=O?ie:yo(this,ie)),this[_e]=be,be?.[_e])throw new Error("Can not assign a record to a record, check for circular references");let Z;O||(Z=m),Dl(D,G,be);let Me=O?"put":"patch";p(D,be,C,q,0,E,N,N.expiresAt||(d?d+Date.now():0),Me,!1,Z)}};b.addWrite(L)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this[hn]){for await(let O of this.search(m))(await Qe.getResource(O[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this[_e]?this._writeDelete(m):!1}_writeDelete(m){let O=Sn(this[Ae]),w=this[Le];ja(w);let N=this[Ae];return O.addWrite({key:w,store:i,resource:this,nodeName:N?.nodeName,before:ae.delete?.bind(this,N,w),beforeIntermediate:Oe.delete?.bind(this,N,w),commit:(b,D,y)=>{let L=D?.value;y&&(N&&D?.version>(N.lastModified||0)&&(N.lastModified=D.version),wE(this,D)),!(D?.version>b)&&(Dl(this[Le],L),Xe.trace("Write delete entry",w,b),E||h?(p(w,null,this[Kr],b,0,E,this[Ae],0,"delete"),E||JE()):i.remove(this[Le]))}}),!0}search(m){let O=this[Ae],w=Sn(O);if(!m)throw new Error("No query provided");let N=m.conditions;N?N.length===void 0&&(N=N[Symbol.iterator]?Array.from(N):[N]):N=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this[Le]&&(N=[{attribute:null,comparator:"prefix",value:this[Le]}].concat(N));let b,D={};function y(X,Te){let Be;switch(Te){case"and":case void 0:if(X.length<1)throw new Error('An "and" operator requires at least one condition');Be=!0;break;case"or":if(X.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+Te)}let Gn=Be&&{},$s;for(let $e of X){if($e.conditions){$e.conditions=y($e.conditions,$e.operator);continue}let Bt=$e[0]??$e.attribute,Jr=Bt==null?v:Ps(S,Bt);if(Jr){if(Be){let qn=Mn(Bt),Ht=Gn[qn];Ht?(Ht.push($e),$s=!0):Gn[qn]=[$e]}(Jr.type||hg[$e.comparator])&&($e[1]===void 0?$e.value=q($e.value,Jr):$e[1]=q($e[1],Jr))}else if(Bt!=null)throw(0,mn.handleHDBError)(new Error,`${Bt} is not a defined attribute`,404)}if(m.enforceExecutionOrder)return X;if($s)for(let $e in Gn){let Bt=Gn[$e],Jr=Bt.length;if(Jr>1)for(let qn=0;qn<Jr;qn++){let Ht=Bt[qn];if(Ht.comparator==="ge"||Ht.comparator==="greater_than_equal")for(let Ys=0;Ys<Jr;Ys++){let Po=Bt[Ys];(Po.comparator==="le"||Po.comparator==="less_than_equal")&&(Ht.comparator="between",Ht.value=[Ht.value,Po.value],X.splice(X.indexOf(Po),1))}if(Ht.comparator==="equals"||!Ht.comparator){for(let Ys=0;Ys<Jr;Ys++)if(Ys!==qn){let Po=Bt[Ys];X.splice(X.indexOf(Po),1)}break}}}return X}a(y,"prepareConditions");function L(X,Te){if(m.enforceExecutionOrder)return X;for(let Be of X)Be.conditions&&(Be.conditions=L(Be.conditions,Be.operator));return X.length>1&&Te!=="or"?(0,_x.sortBy)(X,pf(Qe)):X}a(L,"orderConditions");function q(X,Te){return Array.isArray(X)?X.map(Be=>yE(Be,Te)):yE(X,Te)}a(q,"coerceTypedValues");let C=m.operator;(N.length>0||C)&&(N=y(N,C));let B=typeof m.sort=="object"&&m.sort,G;if(B&&C!=="or"){let X=B.attribute;if(b=N.find(Te=>Mn(Te.attribute)===Mn(X)),!b){if(!Ps(S,X))throw(0,mn.handleHDBError)(new Error,`${Array.isArray(X)?X.join("."):X} is not a defined attribute`,404);b={attribute:X,comparator:"sort"},N.push(b)}b.descending=!!B.descending}N=L(N,C),B&&(N[0]===b?B.next&&(G={dbOrderedAttribute:B.attribute,attribute:B.next.attribute,descending:B.next.descending,next:B.next.next}):(b&&N.splice(N.indexOf(b),1),G=B));let ie=m.select;if(N.length===0&&(N=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:N,operator:C,postOrdering:G,selectApplied:!!ie};let be=w.useReadTxn(),Z=mg(N,C,Qe,be,m,O,(X,Te)=>OA(X,ie,O,be,Te),D),Me=m.ensureLoaded!==!1;G||(Z=ee(Z));let oe=Qe.transformEntryForSelect(ie,O,be,D,Me,!0),Fe=Qe.transformToOrderedSelect(Z,ie,G,be,O,oe);function ee(X){return m.offset||m.limit!==void 0?X.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):X}return a(ee,"applyOffset"),G&&(Fe=ee(Fe)),Fe.onDone=()=>{Fe.onDone=null,w.doneReadTxn()},Fe.selectApplied=!0,Fe.getColumns=()=>{if(ie){let X=[];for(let Te of ie)Te==="*"?X.push(...S.map(Be=>Be.name)):X.push(Te.name||Te);return X}return S.map(X=>X.name)},Fe}static transformToOrderedSelect(m,O,w,N,b,D){let y=new Jx;if(w){m=OA(m,O,N,b,null);let L;y.iterate=function(){let C,B=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),G,ie=w.dbOrderedAttribute,be,Z,Me=!0;function oe(ee){let X=ee.next&&oe(ee.next),Te=ee.descending;return(Be,Gn)=>{let $s=zE(Be,ee.attribute,N),$e=zE(Gn,ee.attribute,N),Bt=Te?(0,Co.compareKeys)($e,$s):(0,Co.compareKeys)($s,$e);return Bt===0?X?.(Be,Gn)||0:Bt}}a(oe,"createComparator");let Fe=oe(w);return{async next(){let ee;if(C)if(ee=C.next(),ee.done){if(G)return y.onDone&&y.onDone(),ee}else return{value:await D.call(this,ee.value)};L=[],be&&L.push(be);do if(ee=await B.next(),ee.done){if(G=!0,L.length)break;return y.onDone&&y.onDone(),ee}else{let X=ee.value;if(X?.then&&(X=await X),ie){let Te=zE(X,ie,N);if(Me)Me=!1,Z=Te;else if(Te!==Z){Z=Te,be=X;break}}L.push(X)}while(!0);return w.isGrouped,L.sort(Fe),C=L[Symbol.iterator](),ee=C.next(),ee.done?(y.onDone&&y.onDone(),ee):{value:await D.call(this,ee.value)}},return(){y.onDone&&y.onDone(),B.return()},throw(){y.onDone&&y.onDone(),B.throw()}}};let q=a(C=>{if(typeof O=="object"&&Array.isArray(C.attribute))for(let B=0;B<O.length;B++){let G=O[B],ie;if(G.name===C.attribute[0]){for(ie=G.sort||(G.sort={});ie.next;)ie=ie.next;ie.attribute=C.attribute.slice(1),ie.descending=C.descending}else G===C.attribute[0]&&(O[B]=ie={name:G,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&q(C.next)},"applySortingOnSelect");q(w)}else y.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),y=y.map(D);return y}static transformEntryForSelect(m,O,w,N,b,D){if(m&&(m===t||m?.length===1&&m[0]===t)){let C=a(B=>B?.key??B,"transform");return m===t?C:m.asArray?B=>[C(B)]:B=>({[t]:C(B)})}let y;b&&g&&!m?.every(C=>{let B;return typeof C=="object"?B=C.name:B=C,r[B]||B===t})&&(y=!0);let L,q=a(function(C){let B;if(C!=null){if(KE=C,B=C.value||C.deref?.(),!B&&(C.key===void 0||C.deref)){if(C=WE(C.key??C,O,{transaction:w,lazy:m?.length<4},this.isSync,G=>G),C?.then)return C.then(q.bind(this));B=C?.value}if(y&&(C.metadataFlags&(ml|pl)||C.expiresAt&&C.expiresAt<Date.now())){let G=QE(C.key??C,C,O);if(G?.then)return G.then(q)}}if(B==null)return D?wo.SKIP:B;if(m&&!(m[0]==="*"&&m.length===1)){let G,ie=a((Z,Me)=>{let oe;typeof Z=="object"?oe=Z.name:oe=Z;let Fe=Vs?.[oe],ee;if(Fe){let X=N?.[oe];if(X)if(X.hasMappings){let Be=Fe.from?B[Fe.from]:Mn(C.key);ee=X.get(Be),ee||(ee=[])}else ee=X.fromRecord?.(B);else ee=Fe(B,O,C);let Te=a(Be=>{if(Be&&typeof Be=="object"){let Gn=Fe.definition?.tableClass||Qe;L||(L={});let $s=L[oe]||(L[oe]=Gn.transformEntryForSelect(oe===Z?null:Z.select||(Array.isArray(Z)?Z:null),O,w,X,b));if(Array.isArray(Be)){let $e=[],Bt=Gn.transformToOrderedSelect(Be,Z.select,typeof Z.sort=="object"&&Z.sort,O,w,$s)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Jr=a(Ht=>{for(;!Ht.done;){if(Ht?.then)return Ht.then(Jr);$e.push(Ht.value),Ht=Bt.next()}Me($e,oe)},"nextValue"),qn=Jr(Bt.next());qn&&(G||(G=[]),G.push(qn));return}else if(Be=$s.call(this,Be),Be?.then){G||(G=[]),G.push(Be.then($e=>Me($e,oe)));return}}Me(Be,oe)},"handleResolvedValue");ee?.then?(G||(G=[]),G.push(ee.then(Te))):Te(ee);return}else ee=B[oe],ee&&typeof ee=="object"&&oe!==Z&&(ee=Qe.transformEntryForSelect(Z.select||Z,O,w,null)({value:ee}));Me(ee,oe)},"selectAttribute"),be;if(typeof m=="string")ie(m,Z=>{be=Z});else if(Array.isArray(m))if(m.asArray)be=[],m.forEach((Z,Me)=>{Z==="*"?m[Me]=B:ie(Z,oe=>be[Me]=oe)});else{be={};let Z=m.forceNulls;for(let Me of m)if(Me==="*")for(let oe in B)be[oe]=B[oe];else ie(Me,(oe,Fe)=>{oe===void 0&&Z&&(oe=null),be[Fe]=oe})}else throw new mn.ClientError("Invalid select"+m);return G?Promise.all(G).then(()=>be):be}return B},"transform");return q}async subscribe(m){if(!u)throw new Error("Can not subscribe to a table without an audit log");E||ct({table:s,database:c,schemaDefined:_,attributes:S,audit:!0}),m||(m={});let O=!m.rawEvents,w=tx(Qe,this[Le]??null,function(y,L,q,C){try{let B=L.getValue?.(i,O);if(!B&&L.type==="patch"&&O){let G=i.getEntry(y);G?.version===L.version?B=G.value:B=L.getValue?.(i,!0,q),L.type="put"}this.send({id:y,timestamp:q,value:B,version:L.version,type:L.type,beginTxn:C})}catch(B){Xe.error(B)}},m.startTime||0,this[hn]);this[hn]&&(w.includeDescendants=!0,m.onlyChildren&&(w.onlyChildren=!0)),m.crossThreads===!1&&(w.crossThreads=!1),m.supportsTransactions&&(w.supportsTransactions=!0);let N=this[Le],b=m.previousCount;b>1e3&&(b=1e3);let D=m.startTime;if(this[hn]){if(D){if(b)throw new mn.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:y,value:L}of u.getRange({start:D,exclusiveStart:!0})){let q=Lt(L);if(q.tableId!==n)continue;let C=q.recordId;if(N==null||ux(N,C)){let B=q.getValue(i,O,y);w.send({id:C,timestamp:y,value:B,version:q.version,type:q.type})}w.startTime=y}}else if(b){let y=[];for(let{key:L,value:q}of u.getRange({start:"z",end:!1,reverse:!0}))try{let C=Lt(q);if(C.tableId!==n)continue;let B=C.recordId;if(N==null||ux(N,B)){let G=C.getValue(i,O,L);if(y.push({id:B,timestamp:L,value:G,version:C.version,type:C.type}),--b<=0)break}}catch(C){Xe.error("Error getting history entry",L,C)}for(let L=y.length;L>0;)w.send(y[--L]);y[0]&&(w.startTime=y[0].timestamp)}else if(!m.omitCurrent)for(let{key:y,value:L,version:q,localTime:C}of i.getRange({start:N??!1,end:N==null?void 0:[N,Co.MAXIMUM_KEY],versions:!0}))L&&w.send({id:y,timestamp:C,value:L,version:q,type:"put"})}else{b&&!D&&(D=0);let y=this[Kr]?.localTime;if(y===Fh&&(i.cache?.delete(N),this[Kr]=i.getEntry(N),Xe.trace("re-retrieved record",y,this[Kr]?.localTime),y=this[Kr]?.localTime),Xe.trace("Subscription from",D,"from",N,y),D<y){let L=[],q=y;do{let C=u.get(q);if(C){m.omitCurrent=!0;let B=Lt(C),G=B.getValue(i,O,q);O&&(B.type="put"),L.push({id:N,value:G,timestamp:q,...B}),q=B.previousLocalTime}else break;b&&b--}while(q>D&&b!==0);for(let C=L.length;C>0;)w.send(L[--C]);w.startTime=y}!m.omitCurrent&&this.doesExist()&&w.send({id:N,timestamp:y,value:this,version:this[Tl],type:"put"})}return m.listener&&w.on("data",m.listener),w}doesExist(){return!!(this[_e]||this[hl])}publish(m,O){this._writePublish(m,O)}_writePublish(m,O){let w=Sn(this[Ae]),N=this[Le]||null;ja(N);let b=this[Ae];w.addWrite({key:N,store:i,entry:this[Kr],nodeName:b?.nodeName,validate:()=>{this.validate(m)},before:ae.publish?.bind(this,b,N,m),beforeIntermediate:Oe.publish?.bind(this,b,N,m),commit:(D,y,L)=>{y===void 0&&h&&!E&&JE(),p(N,y?.value??null,y,y?.version||D,0,!0,b,y?.expiresAt,"message",!1,m)}})}validate(m,O){let w,N=a((b,D,y)=>{if(D.type&&b!=null)if(O&&b.__op__&&(b=b.value),D.properties){typeof b!="object"&&(w||(w=[])).push(`Value ${Hn(b)} in property ${y} must be an object${D.type?" ("+D.type+")":""}`);let L=D.properties;for(let q=0,C=L.length;q<C;q++){let B=L[q],G=N(b[B.name],B,y+"."+B.name);G&&(b[B.name]=G)}}else switch(D.type){case"Int":(typeof b!="number"||b>>0!==b)&&(w||(w=[])).push(`Value ${Hn(b)} in property ${y} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof b!="number"||!(Math.floor(b)===b&&Math.abs(b)<=9007199254740992))&&(w||(w=[])).push(`Value ${Hn(b)} in property ${y} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof b!="number"&&(w||(w=[])).push(`Value ${Hn(b)} in property ${y} must be a number`);break;case"ID":typeof b=="string"||b?.length>0&&b.every?.(L=>typeof L=="string")||(w||(w=[])).push(`Value ${Hn(b)} in property ${y} must be a string, or an array of strings`);break;case"String":typeof b!="string"&&(w||(w=[])).push(`Value ${Hn(b)} in property ${y} must be a string`);break;case"Boolean":typeof b!="boolean"&&(w||(w=[])).push(`Value ${Hn(b)} in property ${y} must be a boolean`);break;case"Date":if(!(b instanceof Date)){if(typeof b=="string"||typeof b=="number")return new Date(b);(w||(w=[])).push(`Value ${Hn(b)} in property ${y} must be a Date`)}break;case"BigInt":if(typeof b!="bigint"){if(typeof b=="string"||typeof b=="number")return BigInt(b);(w||(w=[])).push(`Value ${Hn(b)} in property ${y} must be a bigint`)}break;case"Bytes":b instanceof Uint8Array||(w||(w=[])).push(`Value ${Hn(b)} in property ${y} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(b)){if(D.elements)for(let L=0,q=b.length;L<q;L++){let C=b[L],B=N(C,D.elements,y+"[*]");B&&(b[L]=B)}}else(w||(w=[])).push(`Value ${Hn(b)} in property ${y} must be a Buffer or Uint8Array`);break}D.nullable===!1&&b==null&&(w||(w=[])).push(`Property ${y} is required (and not does not allow null values)`)},"validateValue");for(let b=0,D=S.length;b<D;b++){let y=S[b];if(!y.relationship&&(!O||y.name in m)){let L=N(m[y.name],y,y.name);L&&(m[y.name]=L)}}if(w)throw new mn.ClientError(w.join(". "))}getUpdatedTime(){return this[Tl]}wasLoadedFromSource(){return g?!!this[iA]:void 0}static async addAttributes(m){let O=S.slice(0);for(let w of m){if(!w.name)throw new mn.ClientError("Attribute name is required");if(w.name.match(/[`/]/))throw new mn.ClientError("Attribute names cannot include backticks or forward slashes");O.push(w)}return ct({table:s,database:c,schemaDefined:_,attributes:O}),Qe.indexingOperation}static async removeAttributes(m){let O=S.filter(w=>!m.includes(w.name));return ct({table:s,database:c,schemaDefined:_,attributes:O}),Qe.indexingOperation}static getRecordCount(m){let O=i.getStats().entryCount,w=5e3,N=1e3,b;O>w&&!m?.exactCount&&(b=N);let D=0;for(let{value:y}of i.getRange({start:!0,lazy:!0,limit:b}))y!=null&&D++;if(b){let y=D;D=0;for(let{value:Me}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:b}))Me!=null&&D++;let L=b*2,q=(D+y)/L,C=Math.pow((D-y+1)/b/2,2)+q*(1-q)/L,B=Math.max(Math.sqrt(C)*O,1),G=Math.round(q*O),ie=Math.max(G-1.96*B,0),be=Math.min(G+1.96*B,O),Z=Math.pow(10,Math.round(Math.log10(B)));return Z>G&&(Z=Z/10),D=Math.round(G/Z)*Z,{recordCount:D,estimatedRange:[Math.round(ie),Math.round(be)]}}return{recordCount:D}}static updatedAttributes(){Vs=this.propertyResolvers={$id:(m,O,w)=>({value:w.key}),$updatedtime:(m,O,w)=>w.version,$record:(m,O,w)=>w?{value:m}:m};for(let m of this.attributes){m.resolve=null;let O=m.relationship;if(O)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),AA=!0,O.to)m.elements?.definition?(Vs[m.name]=m.resolve=(w,N,b)=>{let D=w[O.from?O.from:t],y=m.elements.definition.tableClass;return b?Ca({attribute:O.to,value:D},Sn(N).getReadTxn(),!1,y,!1).asArray:y.search([{attribute:O.to,value:D}],N).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,O.from&&(m.resolve.from=O.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(O.from){let w=m.definition||m.elements?.definition;w?(Vs[m.name]=m.resolve=(N,b,D)=>{let y=N[O.from];if(y!==void 0){if(m.elements){let L,q=y.map(C=>{let B=D?w.tableClass.primaryStore.getEntry(C,{transaction:Sn(b).getReadTxn()}):w.tableClass.get(C,b);return B?.then&&(L=!0),B});return O.filterMissing?L?Promise.all(q).then(C=>C.filter(lx)):q.filter(lx):L?Promise.all(q):q}return D?w.tableClass.primaryStore.getEntry(y,{transaction:Sn(b).getReadTxn()}):w.tableClass.get(y,b)}},m.set=(N,b)=>{if(Array.isArray(b)){let D=b.map(y=>y[Le]||y[w.tableClass.primaryKey]);N[O.from]=D}else{let D=b[Le]||b[w.tableClass.primaryKey];N[O.from]=D}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=O.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`)}AE(this,this)}static async deleteHistory(m=0){let O;for(let{key:w,value:N}of u.getRange({start:0,end:m}))await Sl(),Lt(N).tableId===n&&(O=u.remove(w));await O}static async*getHistory(m=0,O=1/0){for(let{key:w,value:N}of u.getRange({start:m,end:O})){await Sl();let b=Lt(N);b.tableId===n&&(yield{id:b.recordId,localTime:w,version:b.version,type:b.type,value:b.getValue(i,!0,w),user:b.user})}}static async getHistoryOfRecord(m){let O=[];if(m==null)throw new Error("An id is required");let w=i.getEntry(m);if(!w)return O;let N=w.localTime;if(!N)throw new Error("The entry does not have a local audit time");let b=0;do{await Sl();let D=u.get(N);if(D){let y=Lt(D);O.push({id:y.recordId,localTime:N,version:y.version,type:y.type,value:y.getValue(i,!0,N),user:y.user}),N=y.previousLocalTime}else break}while(b<1e3&&N);return O.reverse()}static cleanup(){K?.remove()}}Qe.updatedAttributes();let Zx=Qe.prototype;return Zx[Xne]=!0,d&&Qe.setTTLExpiration(d/1e3),Y&&eF(),Qe;function Dl(W,m,O){let w;for(let N in r){let b=r[N],D=b.isIndexing,y=O?.[N],L=m?.[N];if(y===L&&!D)continue;w=!0;let q=b.indexNulls,C=(0,gl.getIndexedValues)(L,q);if(C){ix&&b.prefetch(C.map(B=>({key:B,value:W})),cx);for(let B=0,G=C.length;B<G;B++)b.remove(C[B],W)}if(C=(0,gl.getIndexedValues)(y,q),C){ix&&b.prefetch(C.map(B=>({key:B,value:W})),cx);for(let B=0,G=C.length;B<G;B++)b.put(C[B],W)}}return w}a(Dl,"updateIndices");function ja(W){switch(typeof W){case"number":return!0;case"string":if(W.length<659)return!0;if(W.length>ax)throw new Error("Primary key size is too large: "+W.length);break;case"object":if(W===null)return!0;break;case"bigint":if(W<2n**64n&&W>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof W)}if((0,Co.writeKey)(W,Zne,0)>ax)throw new Error("Primary key size is too large: "+W.length);return!0}a(ja,"checkValidId");function WE(W,m,O,w,N){let b=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),O.transaction?.isDone)return N(null,W);let D=i.getEntry(W,O);return D&&m&&(D?.version>(m.lastModified||0)&&(m.lastModified=D.version),D?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=D.localTime)),N(D,W)},"whenPrefetched");return w?b():de>0?(de--,b()):new Promise((D,y)=>{de===0?(de--,i.prefetch([W],()=>{L(),q()})):(V.push(W),ce.push(q),V.length>jx&&(de--,L()));function L(){if(V.length>0){let C=ce;i.prefetch(V,()=>{de===-1?L():de++;for(let B of C)B()}),V=[],ce=[],xe>2&&xe--}else de=xe,xe<Xx&&xe++}a(L,"prefetch");function q(){try{D(b())}catch(C){y(C)}}a(q,"load")})}a(WE,"loadLocalRecord");function Ll(W){if(!W?.role)return;let m=W.role.permission;if(m.super_user)return ese;let O=m[c],w,N=O?.tables;if(N)return N[s];if(c==="data"&&(w=m[s])&&!w.tables)return w}a(Ll,"getTablePermissions");function QE(W,m,O,w){if(g){let N;if(O.noCache?N=!0:(m?(!m.value||m.metadataFlags&(ml|pl)||m.expiresAt&&m.expiresAt<Date.now())&&(N=!0):N=!0,rn(!N,"cache-hit",s)),N){let b=bA(W,m,O).then(D=>(D?.value?.[_e]&&Xe.error("Can not assign a record with a record property"),O&&(D?.version>(O.lastModified||0)&&(O.lastModified=D.version),O.lastRefreshed=Date.now()),D));if(O?.onlyIfCached||m?.value&&w?.allowStaleWhileRevalidate?.(m,W)){if(b.catch(D=>Xe.warn(D)),O?.onlyIfCached&&!w.doesExist())throw new mn.ServerError("Entry is not cached",504);return}else return b}}}a(QE,"ensureLoadedFromSource");function Sn(W){let m=W?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let O=m.next;if(!O)return m=m.next=new Xi,m.lmdbDb=i,m;m=O}while(!0)}else return new k_}a(Sn,"txnForContext");function zE(W,m,O){if(!W)return;KE=W;let w=W.value||W.deref?.()||(KE=i.getEntry(W.key))?.value;if(typeof m=="object"){let b=Vs,D=w;for(let y=0,L=m.length;y<L;y++){let q=m[y],C=b?.[q];D=C&&D?C(D,O,!0)?.value:D?.[q],b=C?.definition?.tableClass?.propertyResolvers}return D}let N=Vs[m];return N?N(w,O):w[m]}a(zE,"getAttributeValue");function OA(W,m,O,w,N){let b=N?.length,D={transaction:w,lazy:b>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},y;function L(q,C){let B=q?.value;if(!B)return wo.SKIP;for(let G=0;G<b;G++)if(!y?.includes(G)&&!N[G](B,q))return wo.SKIP;return C!==void 0&&(q.key=C),q}if(a(L,"processEntry"),b>0||!W.hasEntries){let q=W.map(C=>{if(y=null,typeof C=="object"&&C.key!==void 0)return b>0?L(C):C;if(C==null)return wo.SKIP;for(let B=0;B<b;B++){let ie=N[B].idFilter;if(ie){if(!ie(C))return wo.SKIP;y||(y=[]),y.push(B)}}return WE(C,O,D,!1,L)});return Array.isArray(W)&&(q=q.filter(C=>C!==wo.SKIP)),q.hasEntries=!0,q}return W}a(OA,"transformToEntries");async function bA(W,m,O){let w=m?.metadataFlags,N=m?.version,b,D;if(!i.attemptLock(W,N,()=>{clearTimeout(D);let C=i.getEntry(W);!C||!C.value||C.metadataFlags&(ml|pl)?b(bA(W,i.getEntry(W),O)):b(C)}))return new Promise(C=>{b=C,D=setTimeout(()=>{i.unlock(W,N)},Jne)});let y=m?.value,L={requestContext:O,replacingRecord:y,replacingVersion:N,source:null,resourceCache:O?.resourceCache},q=O?.responseHeaders;return new Promise((C,B)=>{let G;aA(Je(L,async ie=>{let be=performance.now(),Z,Me,oe;try{for(let Te of Qe.sources)if(Te.get&&(!Te.get.reliesOnPrototype||Te.prototype.get)&&(L.source=Te,Z=await Te.get(W,L),Z))break;oe=w&ml;let ee=L.lastModified||oe&&N;Me=oe||ee>N||!y,ee||(ee=(0,gl.getNextMonotonicTime)());let X=performance.now()-be;if(Br(X,"cache-resolution",s),q&&HT(q,"Server-Timing",`cache-resolve;dur=${X.toFixed(2)}`,!0),ie.timestamp=ee,d&&!L.expiresAt&&(L.expiresAt=Date.now()+d),Z){if(typeof Z!="object")throw new Error("Only objects can be cached and stored in tables");typeof Z.toJSON=="function"&&(Z=Z.toJSON()),t&&Z[t]!==W&&(Z[t]=W)}G=!0,C({version:ee,value:Z})}catch(ee){ee.message+=` while resolving record ${W} for ${s}`,y&&((ee.code==="ECONNRESET"||ee.code==="ECONNREFUSED"||ee.code==="EAI_AGAIN")&&!O?.mustRevalidate||O?.staleIfError&&(ee.statusCode===500||ee.statusCode===502||ee.statusCode===503||ee.statusCode===504))?(C({version:N,value:y}),Xe.trace(ee.message,"(returned stale record)")):B(ee),L.transaction.abort();return}if(O?.noCacheStore){L.transaction.abort();return}Sn(L).addWrite({key:W,store:i,entry:m,nodeName:"source",commit:(ee,X)=>{if(X?.version!==N)return;let Te=Dl(W,y,Z);Z?(Oe.put?.(L,W,Z),p(W,Z,X,ee,0,E&&Me||null,L,L.expiresAt,"put",!!oe)):(Oe.delete?.(L,W),E||h?p(W,null,X,ee,0,E&&Me||null,L,0,"delete",!!oe):i.remove(W,N))}})}),()=>{i.unlock(W,N)},ie=>{i.unlock(W,N),G&&Xe.error("Error committing cache update",ie)})})}a(bA,"getFromSource");function JE(){if(Ve!==Fn&&(Fn=Ve,(0,Io.getWorkerIndex)()===(0,Io.getWorkerCount)()-1)){if(Mo&&clearTimeout(Mo),!Ve)return;let W=new Date;W.setMonth(0),W.setDate(1),W.setHours(0),W.setMinutes(0),W.setSeconds(0);let m=Math.ceil((Date.now()-W.getTime())/Ve)*Ve+W.getTime(),O=a(w=>{Xe.trace(`Scheduled next cleanup scan at ${new Date(w)}ms`),Mo=setTimeout(()=>H=H.then(async()=>{if(O(Math.max(w+Ve,Date.now())),i.rootStore.status!=="open"){clearTimeout(Mo);return}let N=50,b=new Array(N),D=0;Xe.trace(`Starting cleanup scan for ${s}`);try{let y=0;for(let{key:L,value:q,version:C,expiresAt:B}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let G;q===null&&!E&&C+zne<Date.now()?G=i.remove(L,C):B&&B+f<Date.now()&&(G=Qe.evict(L,q,C),y++),G&&(await b[D],b[D]=G.catch(ie=>{Xe.error("Cleanup error",ie)}),++D>=N&&(D=0)),await Sl()}Xe.trace(`Finished cleanup scan for ${s}, evicted ${y} entries`)}catch(y){Xe.trace(`Error in cleanup scan for ${s}:`,y)}}),Math.min(w-Date.now(),2147483647)).unref()},"startNextTimer");O(m)}}a(JE,"scheduleCleanup");function NA(){K=u?.addDeleteRemovalCallback(n,W=>{let m=i.getEntry(W);m?.value===null&&i.remove(W,m.version)})}a(NA,"addDeleteRemoval");function eF(){(0,Io.getWorkerIndex)()===0&&setInterval(async()=>{try{let W=Y.name,m=r[W];if(!m)throw new Error(`expiresAt attribute ${Y} must be indexed`);for(let{value:O}of m.getRange({start:!0,end:Date.now(),versions:!0,snapshot:!1})){let w=i.getEntry(O);w?.value?.[W]<Date.now()&&Qe.evict(O,w.value,w.version),await Sl()}}catch(W){Xe.error("Error in evicting old records",W)}},Qne).unref()}a(eF,"runRecordExpirationEviction")}function oA(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 cx(){}function tse(e){dx=e}function yE(e,t){let r=t?.type;return e===null?e:e===""&&r&&r!=="String"&&r!=="Any"?null:r==="Int"||r==="Long"?e==="null"?null:parseInt(e):r==="Float"?e==="null"?null:parseFloat(e):r==="BigInt"?e==="null"?null:BigInt(e):r==="Boolean"?e==="true"?!0:e==="false"?!1:e:r==="Date"?(typeof e!="number"&&!rse.test(e)&&(e+="Z"),e==="null"?null:new Date(e)):!r||r==="Any"?(0,IE.autoCast)(e):e}function ux(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t;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 aA(e,t,r){return e?.then?e.then(t,r):t(e)}function wE(e,t){e[Kr]=t,e[_e]=t?.value??null,e[Tl]=t?.version}function lx(e){return e!=null}function Hn(e){try{return JSON.stringify(e)}catch{return e}}var xn,wo,gl,_x,Ol,mn,Rl,Al,Xe,Co,Io,IE,Wne,dx,Qne,zne,ix,Jne,Tl,Xne,Kr,hl,ox,jne,iA,Wa,ml,pl,Zne,ax,ese,Yme,rse,Sl,Mf=ge(()=>{xn=x(P()),wo=require("lmdb"),gl=x(yr()),_x=require("lodash");Rn();vp();Ol=x(te());sx();mn=x(re()),Rl=x(Ts()),Al=x(wn());Re();Tf();Xe=x(Q());Y_();ji();Co=require("ordered-binary"),Io=x(et());Mi();IE=x(J());Fo();Os();hE();Hu();Wne=new Uint8Array(9);Wne[8]=192;Qne=6e4,zne=864e5;Ol.initSync();ix=Ol.get(xn.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),Jne=1e4,Tl=Symbol.for("version"),Xne=Symbol.for("incremental-update"),Kr=Symbol("entry"),hl=Symbol("is-saving"),ox=1,jne=2,iA=Symbol("loaded-from-source"),Wa={isNotification:!0,ensureLoaded:!1},ml=1,pl=8,Zne=Buffer.allocUnsafeSlow(8192),ax=1978,ese={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},Yme=(0,IE.convertToMS)(Ol.get(xn.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(CE,"makeTable");a(oA,"attributesAsObject");a(cx,"noop");a(tse,"setServerUtilities");rse=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(yE,"coerceType");a(ux,"isDescendantId");Sl=a(()=>new Promise(setImmediate),"rest");a(aA,"when");a(wE,"updateResource");a(lx,"exists");a(Hn,"stringify")});var Ge={};Ye(Ge,{database:()=>Jc,databases:()=>tt,dropDatabase:()=>Gp,dropTableMeta:()=>cse,getDatabases:()=>Cn,getTables:()=>nse,onUpdatedTable:()=>NR,readMetaDb:()=>bl,resetDatabases:()=>sse,table:()=>ct,tables:()=>wr});function nse(){return PE||Cn(),wr||{}}function Cn(){if(PE)return tt;PE=!0,Ja=new Map;let e=(0,Xt.getHdbBasePath)()&&(0,je.join)((0,Xt.getHdbBasePath)(),Qr.DATABASES_DIR_NAME),t=(0,Xt.get)(Qr.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Xt.get)(Qr.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,Wr.existsSync)(e)?e:(0,je.join)((0,Xt.getHdbBasePath)(),Qr.LEGACY_DATABASES_DIR_NAME)),!!e){if((0,Wr.existsSync)(e))for(let r of(0,Wr.readdirSync)(e,{withFileTypes:!0})){let n=(0,je.basename)(r.name,".mdb");r.isFile()&&(0,je.extname)(r.name).toLowerCase()===".mdb"&&!t[n]?.path&&bl((0,je.join)(e,r.name),null,n)}if((0,Wr.existsSync)((0,za.getBaseSchemaPath)())){for(let r of(0,Wr.readdirSync)((0,za.getBaseSchemaPath)(),{withFileTypes:!0}))if(!r.isFile()){let n=(0,je.join)((0,za.getBaseSchemaPath)(),r.name),s=(0,je.join)((0,za.getTransactionAuditStoreBasePath)(),r.name);for(let i of(0,Wr.readdirSync)(n,{withFileTypes:!0}))if(i.isFile()&&(0,je.extname)(i.name).toLowerCase()===".mdb"){let o=(0,je.join)(s,i.name);bl((0,je.join)(n,i.name),(0,je.basename)(i.name,".mdb"),r.name,o,!0)}}}if(t)for(let r in t){let n=t[r],s=n.path;if((0,Wr.existsSync)(s))for(let o of(0,Wr.readdirSync)(s,{withFileTypes:!0}))o.isFile()&&(0,je.extname)(o.name).toLowerCase()===".mdb"&&bl((0,je.join)(s,o.name),(0,je.basename)(o.name,".mdb"),r);let i=n.tables;if(i)for(let o in i){let c=i[o],u=(0,je.join)(c.path,(0,je.basename)(o+".mdb"));(0,Wr.existsSync)(u)&&bl(u,o,r,null,!0)}}for(let r in tt){let n=Ja.get(r);if(n){let s=tt[r];r.includes("delete")&&pn.trace(`defined tables ${Array.from(n.keys())}`);for(let i in s)n.has(i)||(pn.trace(`delete table class ${i}`),delete s[i])}else if(delete tt[r],r==="data"){for(let s in wr)delete wr[s];delete wr[vE]}}return Ja=null,tt}}function sse(){PE=!1;for(let[,e]of yi)e.needsDeletion=!0;Cn();for(let[e,t]of yi)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),yi.delete(e));return tt}function bl(e,t,r=lA,n,s){let i=new cA.default(e,!1);try{let o=yi.get(e);o?o.needsDeletion=!1:(o=(0,LE.open)(i),yi.set(e,o));let c=new Do.default(!1),u=o.dbisDb||(o.dbisDb=o.openDB(DE.INTERNAL_DBIS_NAME,c)),_=o.auditStore;_||(n?(0,Wr.existsSync)(n)&&(i.path=n,_=(0,LE.open)(i),_.isLegacy=!0):_=EE(o));let l=mx(r),d=l[vE],f=new Map;for(let{key:E,value:h}of u.getRange({start:!1})){let[S,p]=E.toString().split("/");p===""?p=h.name:p||(p=S,S=t,h.name||(h.name=p,h.indexed=!h.is_hash_attribute)),d?.add(S);let R=f.get(S);R||f.set(S,R={attributes:[]}),(p==null||h.is_hash_attribute)&&(R.primary=h),p!=null&&R.attributes.push(h),Object.defineProperty(h,"key",{value:E,configurable:!0})}for(let[E,h]of f){let{attributes:S,primary:p}=h;if(!p){for(let V of S)if(V.is_hash_attribute||V.isPrimaryKey){p=V;break}if(!p){pn.fatal(`Unable to find a primary key attribute on table ${E}, with attributes: ${JSON.stringify(S)}`);continue}}let R=l[E],A={},g=[],v,H,M=typeof p.audit=="boolean"?p.audit:(0,Xt.get)(Qr.CONFIG_PARAMS.LOGGING_AUDITLOG),U=p.trackDeletes,Y=p.expiration,K=p.eviction;if(R)A=R.indices,g=R.attributes,R.schemaVersion++;else{v=p.tableId,v?v>=(u.get(Qa)||0)&&u.putSync(Qa,v+1):(p.tableId=v=u.get(Qa),v||(v=1),u.putSync(Qa,v+1),u.putSync(p.key,p));let V=new Do.default(!p.is_hash_attribute,p.is_hash_attribute);H=Xl(o.openDB(p.key,V)),H.rootStore=o,H.tableId=v}for(let V of S){V.attribute=V.name;try{if(!V.is_hash_attribute&&(V.indexed||V.attribute&&!V.name)){if(!A[V.name]){let de=new Do.default(!V.is_hash_attribute,V.is_hash_attribute);A[V.name]=o.openDB(V.key,de),A[V.name].indexNulls=V.indexNulls}let ce=g.find(de=>de.name===V.name);ce?g.splice(g.indexOf(ce),1,V):g.push(V)}}catch(ce){pn.error("Error trying to update attribute",V,g,A,ce)}}if(!R){R=px(l,E,CE({primaryStore:H,auditStore:_,audit:M,expirationMS:Y&&Y*1e3,evictionMS:K&&K*1e3,trackDeletes:U,tableName:E,tableId:v,primaryKey:p.name,databasePath:s?r+"/"+E:r,databaseName:r,indices:A,attributes:S,schemaDefined:p.schemaDefined,dbisDB:u})),R.schemaVersion=1;for(let V of _A)V(R)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function mx(e){let t=tt[e];if(t||(e==="data"?t=tt[e]=wr:e==="system"?Object.defineProperty(tt,"system",{value:t=Object.create(null),configurable:!0}):t=tt[e]=Object.create(null)),Ja&&!Ja.has(e)){let r=new Set;t[vE]=r,Ja.set(e,r)}return t}function px(e,t,r){return e[t]=r,r}function Jc({database:e,table:t}){e||(e=lA),Cn();let r=mx(e),n=(0,je.join)((0,Xt.getHdbBasePath)(),Qr.DATABASES_DIR_NAME),s=(0,Xt.get)(Qr.CONFIG_PARAMS.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,Xt.get)(Qr.CONFIG_PARAMS.STORAGE_PATH)||((0,Wr.existsSync)(n)?n:(0,je.join)((0,Xt.getHdbBasePath)(),Qr.LEGACY_DATABASES_DIR_NAME));let o=(0,je.join)(n,(i?t:e)+".mdb"),c=yi.get(o);if(!c){let u=new cA.default(o,!1);c=(0,LE.open)(u),yi.set(o,c)}return c}async function Gp(e){if(!tt[e])throw new Error("Schema does not exist");let t=tt[e];for(let r in t){let s=t[r].primaryStore.rootStore;yi.delete(s.path),s.status==="open"&&(await s.close(),await fx.remove(s.path))}if(e==="data"){for(let r in wr)delete wr[r];delete wr[vE]}delete tt[e]}function ct({table:e,database:t,expiration:r,eviction:n,scanInterval:s,attributes:i,audit:o,trackDeletes:c,schemaDefined:u,origin:_}){t||(t=lA);let l=Jc({database:t,table:e}),d=tt[t],f=d?.[e];if(l.status==="closed")throw new Error(`Can not use a closed data store for ${e}`);let E,h,S,p;u==null&&(u=!0);let R=new Do.default(!1);for(let U of i)U.attribute?(U.name=U.attribute,U.indexed=!0):U.attribute=U.name,U.expiresAt&&(U.indexed=!0);let A,g;if(f){if(E=f.primaryKey,f.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${e} class`);f.attributes.splice(0,f.attributes.length,...i)}else{let U=l.auditStore;U||(U=EE(l)),h=i.find(ce=>ce.isPrimaryKey)||{},E=h.name,h.is_hash_attribute=!0,h.schemaDefined=u,c&&(h.trackDeletes=!0),o=h.audit=typeof o=="boolean"?o:(0,Xt.get)(Qr.CONFIG_PARAMS.LOGGING_AUDITLOG),r&&(h.expiration=r),n&&(h.eviction=n),_&&(h.origins?h.origins.includes(_)||h.origins.push(_):h.origins=[_]),pn.trace(`${e} table loading, opening primary store`);let Y=new Do.default(!1,!0),K=e+"/",V=Xl(l.openDB(K,Y));V.rootStore=l,p=l.dbisDb=l.openDB(DE.INTERNAL_DBIS_NAME,R),V.tableId=p.get(Qa),V.tableId||(V.tableId=1),p.putSync(Qa,V.tableId+1),h.tableId=V.tableId,f=px(d,e,CE({primaryStore:V,auditStore:U,audit:o,trackDeletes:c,expirationMS:r&&r*1e3,evictionMS:n&&n*1e3,primaryKey:E,tableName:e,tableId:V.tableId,databasePath:t,databaseName:t,indices:{},attributes:i,schemaDefined:u,dbisDB:p})),f.schemaVersion=1,A=!0,M(),p.put(K,h)}S=f.indices,p=p||(l.dbisDb=l.openDB(DE.INTERNAL_DBIS_NAME,R)),f.dbisDB=p;let v=[];for(let{key:U,value:Y}of p.getRange({start:!0})){let[K,V]=U.toString().split("/");if(V===""&&(V=Y.name),V){if(K!==e)continue}else V=K;if(!i.find(de=>de.name===V)?.indexed&&Y.indexed&&!Y.isPrimaryKey){M(),A=!0,p.remove(U);let de=f.indices[K];de&&v.push(de)}}let H=[];try{for(let U of i||[]){if(U.relationship)continue;let Y=e+"/"+(U.name||"");Object.defineProperty(U,"key",{value:Y,configurable:!0});let K=p.get(Y);if(U.isPrimaryKey){if(K=K||p.get(Y=e+"/")||{},o!==f.audit||(+r||void 0)!==(+K.expiration||void 0)||(+n||void 0)!==(+K.eviction||void 0)){let ce=Object.assign({},K);typeof o=="boolean"&&(o&&f.enableAuditing(o),ce.audit=o),r&&(ce.expiration=+r),n&&(ce.eviction=+n),A=!0,M(),p.put(Y,ce)}continue}K?.attribute&&!K.name&&(K.indexed=!0);let V=!K||K.type!==U.type||K.indexed!==U.indexed||K.nullable!==U.nullable||JSON.stringify(K.attributes)!==JSON.stringify(U.attributes)||JSON.stringify(K.elements)!==JSON.stringify(U.elements);if(U.indexed){let ce=new Do.default(!0,!1),de=l.openDB(Y,ce);(V||K.indexingPID&&K.indexingPID!==process.pid||K.restartNumber<Nl.workerData?.restartNumber)&&(A=!0,M(),K=p.get(Y),(V||K.indexingPID&&K.indexingPID!==process.pid||K.restartNumber<Nl.workerData?.restartNumber)&&(A=!0,U.lastIndexedKey=K?.lastIndexedKey||!1,U.indexingPID=process.pid,de.isIndexing=!0,Object.defineProperty(U,"dbi",{value:de}),U.indexNulls===void 0&&(U.indexNulls=!0),H.push(U)),p.put(Y,U)),K?.indexNulls&&U.indexNulls===void 0&&(U.indexNulls=!0),de.indexNulls=U.indexNulls,S[U.name]=de}else V&&(A=!0,M(),p.put(Y,U))}}finally{g&&g()}if(A&&(f.schemaVersion++,f.updatedAttributes()),pn.trace(`${e} table loading, running index`),H.length>0||v.length>0?f.indexingOperation=ase(f,H,v):A&&UE.signalSchemaChange(new ME.SchemaEventMsg(process.pid,"schema-change",f.databaseName,f.tableName)),f.origin=_,A)for(let U of _A)U(f,_!=="cluster");return(r||n||s)&&f.setTTLExpiration({expiration:r,eviction:n,scanInterval:s}),pn.trace(`${e} table loaded`),f;function M(){g||l.transactionSync(()=>({then(U){g=U}}))}a(M,"startTxn")}async function ase(e,t,r){try{let n=e.schemaVersion;await UE.signalSchemaChange(new ME.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o=0,c=t.length;if(await new Promise(u=>setImmediate(u)),c>0){let u=0;for(let{key:_,value:l,version:d}of e.primaryStore.getRange({start:t[0].lastIndexedKey,lazy:c<4,versions:!0,snapshot:!1}))if(l){if(u++,s=e.primaryStore.ifVersion(_,d,()=>{for(let f=0;f<c;f++){let E=t[f],h=E.name,S=(0,Ex.getIndexedValues)(l[h]);if(S)for(let p=0,R=S.length;p<R;p++)E.dbi.put(S[p],_)}}),s.then(()=>u--,f=>{u--,pn.error(f)}),Nl.workerData&&Nl.workerData.restartNumber!==hx.restartNumber&&(i=!0),++o%100===0||i){for(let f of t)f.lastIndexedKey=_,e.dbisDB.put(f.key,f);if(i)return}u>ise?await s:u>ose&&await new Promise(f=>setImmediate(f))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await UE.signalSchemaChange(new ME.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName))}catch(n){pn.error("Error in indexing",n)}}function cse({table:e,database:t}){let r=Jc({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 NR(e){_A.push(e)}var Xt,DE,LE,je,Wr,za,Do,cA,Qr,fx,uA,Ex,UE,ME,Nl,pn,hx,lA,vE,wr,tt,Qa,_A,PE,yi,Ja,ise,ose,Re=ge(()=>{Xt=x(te()),DE=x(dt()),LE=require("lmdb"),je=require("path"),Wr=require("fs"),za=x(ze());Mf();Do=x(jl()),cA=x(e_()),Qr=x(P()),fx=x(require("fs-extra")),uA=require("../../index"),Ex=x(yr()),UE=x(Ts()),ME=x(wn()),Nl=require("worker_threads"),pn=x(Q()),hx=x(et());Mi();Fo();lA="data",vE=Symbol("defined-tables");(0,Xt.initSync)();wr=Object.create(null),tt=Object.create(null);(0,uA._assignPackageExport)("databases",tt);(0,uA._assignPackageExport)("tables",wr);Qa=Symbol.for("next-table-id"),_A=[],yi=new Map;a(nse,"getTables");a(Cn,"getDatabases");a(sse,"resetDatabases");a(bl,"readMetaDb");a(mx,"ensureDB");a(px,"setTable");a(Jc,"database");a(Gp,"dropDatabase");a(ct,"table");ise=1e3,ose=10;a(ase,"runIndexing");a(cse,"dropTableMeta");a(NR,"onUpdatedTable")});var J=T((epe,Lx)=>{"use strict";var wi=require("path"),Ax=require("fs-extra"),Or=Q(),Sx=require("fs-extra"),BE=require("os"),use=require("net"),lse=require("recursive-iterator"),at=P(),_se=sO(),Tx=require("papaparse"),HE=require("moment"),{inspect:dse}=require("util"),gx=require("is-number"),Zme=require("lodash"),fse=require("minimist"),Ese=require("https"),hse=require("http"),{hdb_errors:xE}=re(),mse=/^((\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)))$/,Ox=require("util").promisify(setTimeout),pse=100,Sse=5,Tse="",gse=4,Rx={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};Lx.exports={isEmpty:zr,isEmptyOrZeroLength:ls,arrayHasEmptyValues:Ose,arrayHasEmptyOrZeroLengthValues:bse,buildFolderPath:Nse,isBoolean:bx,errorizeMessage:Rse,stripFileExtension:wse,autoCast:Ise,autoCastJSON:Nx,autoCastJSONDeep:fA,removeDir:Cse,compareVersions:Dse,isCompatibleDataVersion:Lse,escapeRawValue:Use,unescapeValue:Mse,stringifyProps:Pse,timeoutPromise:Bse,isClusterOperation:xse,getClusterUser:Gse,checkGlobalSchemaTable:Fse,getHomeDir:wx,getPropsFilePath:vse,promisifyPapaParse:qse,removeBOM:Ix,createEventPromise:kse,checkProcessRunning:Vse,checkSchemaTableExist:$se,checkSchemaExists:Cx,checkTableExists:Dx,getStartOfTomorrowInSeconds:Yse,getLimitKey:Kse,isObject:yse,isNotEmptyAndHasValue:Ase,autoCasterIsNumberCheck:yx,backtickASTSchemaItems:Wse,isPortTaken:Hse,createForkArgs:Qse,autoCastBoolean:zse,async_set_timeout:Ox,getTableHashAttribute:Jse,doesSchemaExist:Xse,doesTableExist:jse,stringifyObj:Zse,ms_to_time:eie,changeExtension:tie,getEnvCliRootPath:EA,noBootFile:rie,httpRequest:nie,transformReq:sie,convertToMS:iie,PACKAGE_ROOT:at.PACKAGE_ROOT};function Rse(e){return e instanceof Error?e:new Error(e)}a(Rse,"errorizeMessage");function zr(e){return e==null}a(zr,"isEmpty");function Ase(e){return!zr(e)&&(e||e===0||e===""||bx(e))}a(Ase,"isNotEmptyAndHasValue");function ls(e){return zr(e)||e.length===0||e.size===0}a(ls,"isEmptyOrZeroLength");function Ose(e){if(zr(e))return!0;for(let t=0;t<e.length;t++)if(zr(e[t]))return!0;return!1}a(Ose,"arrayHasEmptyValues");function bse(e){if(ls(e))return!0;for(let t=0;t<e.length;t++)if(ls(e[t]))return!0;return!1}a(bse,"arrayHasEmptyOrZeroLengthValues");function Nse(...e){try{return e.join(wi.sep)}catch{console.error(e)}}a(Nse,"buildFolderPath");function bx(e){return zr(e)?!1:e===!0||e===!1}a(bx,"isBoolean");function yse(e){return zr(e)?!1:typeof e=="object"}a(yse,"isObject");function wse(e){return ls(e)?Tse:e.slice(0,-gse)}a(wse,"stripFileExtension");function Ise(e){return zr(e)||e===""||typeof e!="string"?e:Rx[e]!==void 0?Rx[e]:yx(e)===!0?Number(e):mse.test(e)?new Date(e):e}a(Ise,"autoCast");function Nx(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(Nx,"autoCastJSON");function fA(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=fA(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=fA(r);n!==r&&(e[t]=n)}return e}else return Nx(e)}a(fA,"autoCastJSONDeep");function yx(e){if(e.startsWith("0.")&&gx(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&gx(e))}a(yx,"autoCasterIsNumberCheck");async function Cse(e){if(ls(e))throw new Error(`Directory path: ${e} does not exist`);try{await Sx.emptyDir(e),await Sx.remove(e)}catch(t){throw Or.error(`Error removing files in ${e} -- ${t}`),t}}a(Cse,"removeDir");function Dse(e,t){if(ls(e)){Or.info("Invalid current version sent as parameter.");return}if(ls(t)){Or.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("."),u=Math.min(o.length,c.length);for(let _=0;_<u;_++)if(r=parseInt(o[_],10)-parseInt(c[_],10),r)return r;return o.length-c.length}a(Dse,"compareVersions");function Lse(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(Lse,"isCompatibleDataVersion");function Use(e){if(zr(e))return e;let t=String(e);return t==="."?at.UNICODE_PERIOD:t===".."?at.UNICODE_PERIOD+at.UNICODE_PERIOD:t.replace(at.FORWARD_SLASH_REGEX,at.UNICODE_FORWARD_SLASH)}a(Use,"escapeRawValue");function Mse(e){if(zr(e))return e;let t=String(e);return t===at.UNICODE_PERIOD?".":t===at.UNICODE_PERIOD+at.UNICODE_PERIOD?"..":String(e).replace(at.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(Mse,"unescapeValue");function Pse(e,t){if(zr(e))return Or.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+BE.EOL}!ls(n)&&n[0]===";"?r+=" "+n+s+BE.EOL:ls(n)||(r+=n+"="+s+BE.EOL)}catch{Or.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(Pse,"stringifyProps");function wx(){let e;try{e=BE.homedir()}catch{e=process.env.HOME}return e||(e="~/"),e}a(wx,"getHomeDir");function vse(){let e=wi.join(wx(),at.HDB_HOME_DIR_NAME,at.BOOT_PROPS_FILE_NAME);return Ax.existsSync(e)||(e=wi.join(__dirname,"../","hdb_boot_properties.file")),e}a(vse,"getPropsFilePath");function Bse(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:function(){clearTimeout(r)}}}a(Bse,"timeoutPromise");async function Hse(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=use.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(Hse,"isPortTaken");function xse(e){try{return at.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Or.error(`Error checking operation against cluster ops ${t}`)}return!1}a(xse,"isClusterOperation");function Fse(e,t){let r=(Re(),ne(Ge)).getDatabases();if(!r[e])return xE.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return xE.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Fse,"checkGlobalSchemaTable");function Gse(e,t){if(zr(t)){Or.warn("No CLUSTERING_USER defined, clustering disabled");return}if(zr(e)||ls(e)){Or.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){Or.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){Or.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(Gse,"getClusterUser");function qse(){Tx.parsePromise=function(e,t,r){return new Promise(function(n,s){Tx.parse(e,{header:!0,transformHeader:Ix,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(qse,"promisifyPapaParse");function Ix(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(Ix,"removeBOM");function kse(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;Or.info(`Got cluster status event response: ${dse(s)}`);try{i.cancel()}catch{Or.error("Error trying to cancel timeout.")}n(s)})})}a(kse,"createEventPromise");async function Vse(e){let t=!0,r=0;do await Ox(pse*r++),(await _se.findPs(e)).length>0&&(t=!1);while(t&&r<Sse);if(t)throw new Error(`process ${e} was not started`)}a(Vse,"checkProcessRunning");function $se(e,t){let r=Cx(e);if(r)return r;let n=Dx(e,t);if(n)return n}a($se,"checkSchemaTableExist");function Cx(e){let{getDatabases:t}=(Re(),ne(Ge));if(!t()[e])return xE.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(Cx,"checkSchemaExists");function Dx(e,t){let{getDatabases:r}=(Re(),ne(Ge));if(!r()[e][t])return xE.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Dx,"checkTableExists");function Yse(){let e=HE().utc().add(1,at.MOMENT_DAYS_TAG).startOf(at.MOMENT_DAYS_TAG).unix(),t=HE().utc().unix();return e-t}a(Yse,"getStartOfTomorrowInSeconds");function Kse(){return HE().utc().format("DD-MM-YYYY")}a(Kse,"getLimitKey");function Wse(e){try{let t=new lse(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){Or.error("Got an error back ticking items."),Or.error(t)}}a(Wse,"backtickASTSchemaItems");function Qse(e){return[e]}a(Qse,"createForkArgs");function zse(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(zse,"autoCastBoolean");function Jse(e,t){let{getDatabases:r}=(Re(),ne(Ge)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(Jse,"getTableHashAttribute");function Xse(e){let{getDatabases:t}=(Re(),ne(Ge));return t()[e]!==void 0}a(Xse,"doesSchemaExist");function jse(e,t){let{getDatabases:r}=(Re(),ne(Ge));return r()[e]?.[t]!==void 0}a(jse,"doesTableExist");function Zse(e){try{return JSON.stringify(e)}catch{return e}}a(Zse,"stringifyObj");function eie(e){let t=HE.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(eie,"ms_to_time");function tie(e,t){let r=wi.basename(e,wi.extname(e));return wi.join(wi.dirname(e),r+t)}a(tie,"changeExtension");function EA(){if(process.env[at.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[at.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=fse(process.argv);if(e[at.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[at.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(EA,"getEnvCliRootPath");var dA;function rie(){if(dA)return dA;let e=EA();EA()&&Ax.pathExistsSync(wi.join(e,at.HDB_CONFIG_FILE))&&(dA=!0)}a(rie,"noBootFile");function nie(e,t){let r;return e.protocol==="http:"?r=hse:r=Ese,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8");let c={body:"",headers:o.headers};o.on("data",u=>{c.body+=u}),o.on("end",()=>{n(c)})});i.on("error",o=>{s(o)}),i.write(JSON.stringify(t)),i.end()})}a(nie,"httpRequest");function sie(e){if(!e.schema&&!e.database){e.schema=at.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(sie,"transformReq");function iie(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(iie,"convertToMS")});var te=T((rpe,vx)=>{"use strict";var hA=require("fs-extra"),Lo=require("path"),Ux=require("os"),oie=require("properties-reader"),wl=Q(),yl=J(),ue=P(),FE=Lr(),aie="Error initializing environment manager",GE="BOOT_PROPS_FILE_PATH",Mx=!1,cie={[ue.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},ks={};vx.exports={BOOT_PROPS_FILE_PATH:GE,getHdbBasePath:uie,setHdbBasePath:lie,get:Px,initSync:die,setProperty:Ue,initTestEnvironment:fie};function uie(){return ks[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(uie,"getHdbBasePath");function lie(e){ks[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(lie,"setHdbBasePath");function Px(e){let t=FE.getConfigValue(e);return t===void 0?ks[e]:t}a(Px,"get");function Ue(e,t){cie[e]&&(ks[e]=t),FE.updateConfigObject(e,t)}a(Ue,"setProperty");function _ie(){let e;try{e=yl.getPropsFilePath(),hA.accessSync(e,hA.constants.F_OK|hA.constants.R_OK),Mx=!0;let t=oie(e);return ks[ue.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(ue.HDB_SETTINGS_NAMES.INSTALL_USER),ks[ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),ks[GE]=e,!0}catch{return wl.trace(`Environment manager found no properties file at ${e}`),!1}}a(_ie,"doesPropFileExist");function die(e=!1){try{(Mx||_ie()||yl.noBootFile())&&(FE.initConfig(e),ks[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=FE.getConfigValue(ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){wl.error(aie),wl.error(t),console.error(t),process.exit(1)}}a(die,"initSync");function fie(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,u=Lo.join(__dirname,"../../","unitTests");ks[GE]=Lo.join(u,"hdb_boot_properties.file"),Ue(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Lo.join(u,"settings.test")),Ue(ue.HDB_SETTINGS_NAMES.INSTALL_USER,Ux.userInfo()?Ux.userInfo().username:void 0),Ue(ue.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Ue(ue.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Lo.join(u,"envDir","log")),Ue(ue.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Ue(ue.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Ue(ue.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Ue(ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Lo.join(u,"envDir")),Ue(ue.CONFIG_PARAMS.STORAGE_PATH,Lo.join(u,"envDir")),s&&(Ue(ue.CONFIG_PARAMS.HTTP_SECUREPORT,Px(ue.CONFIG_PARAMS.HTTP_PORT)),Ue(ue.CONFIG_PARAMS.HTTP_PORT,null)),Ue(ue.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Ue(ue.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Ue(ue.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,yl.isEmpty(i)?!1:i),Ue(ue.CONFIG_PARAMS.HTTP_CORS,yl.isEmpty(i)?!1:i),Ue(ue.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Ue(ue.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Ue(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Ue(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Ue(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Lo.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Ue(ue.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,yl.isEmpty(c)?!1:c),o&&(Ue("CORS_ACCESSLIST",o),Ue(ue.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Ue(ue.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Ue(ue.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Ue(ue.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Ue(ue.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Ue(ue.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Ue(ue.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${GE}. Please check your boot props and settings files`;wl.fatal(r),wl.error(t)}}a(fie,"initTestEnvironment")});var ZB=T(Uo=>{var{isMainThread:qx,parentPort:Cl,threadId:qE}=require("worker_threads"),{Socket:Eie,createServer:hie}=require("net"),{createServer:mie,IncomingMessage:pie}=require("http"),{createServer:Sie}=require("https"),{readFileSync:Xa,unlinkSync:Bx,existsSync:Tie}=require("fs"),jt=Q(),De=te(),gt=P(),{server:YE}=(rr(),ne(Di)),{WebSocketServer:gie}=require("ws"),{createServer:Rie}=require("tls"),{getTicketKeys:Aie,restartNumber:Oie,getWorkerIndex:VE}=et(),{Headers:kx,appendHeader:bie}=(Hu(),ne(vM)),{recordAction:Il,recordActionBinary:Nie}=(Os(),ne(iu)),{Request:Vx,createReuseportFd:Hx}=(Qf(),ne(hR)),{checkMemoryLimit:yie}=Ki(),$x=require("tls"),xx=$x.createSecureContext;$x.createSecureContext=function(e){if(!e.cert||!e.key)return xx(e);let t={...e};delete t.key,delete t.cert;let r=xx(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var Yx=De.get(gt.CONFIG_PARAMS.THREADS_DEBUG);if(Yx){let e;if(qx)e=De.get(gt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){jt.info("Could not close debugger",t)}});else{let t=De.get(gt.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&VE()>=0&&(e=t+VE())}if(e){let t=De.get(gt.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=De.get(gt.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){jt.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE)try{require("inspector").open(9229)}catch(e){Oie<=1&&jt.trace("Could not start debugging on port 9229, you may already be debugging:",e.message)}process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)});var{HDB_SETTINGS_NAMES:spe,CONFIG_PARAMS:wie}=gt;De.initSync();var Iie=De.get(wie.HTTP_SESSIONAFFINITY),_s={};Uo.registerServer=gA;Uo.httpServer=RA;Uo.deliverSocket=TA;Uo.startServers=Kx;Uo.when_components_loaded=null;YE.http=RA;YE.request=Uie;YE.socket=Mie;YE.ws=Pie;var mA={},kE={},Cie,Ii={},$E={},Die=[],pA=[];function Kx(){return Uo.when_components_loaded=xR().loadRootComponents(!0).then(()=>{Cl?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)TA(n,r,s);else if(t.requestId)Lie(t);else if(t.type===gt.ITC_EVENT_TYPES.SHUTDOWN){jt.trace("received shutdown request",qE);for(let i in _s){let o=_s[i],c;if(o.closeIdleConnections){let _=Object.getOwnPropertySymbols(o).find(f=>f.description.includes("connections")),l=0,d=setInterval(()=>{l++;let f=l>=100,E=o[_][f?"all":"idle"]();if(E.length===0){f&&clearInterval(d);return}l===1?jt.info(`Closing ${E.length} idle connections`):f&&jt.warn(`Forcefully closing ${E.length} active connections`);for(let h=0,S=E.length;h<S;h++){let p=E[h].socket;p._httpMessage&&!p._httpMessage.finished&&!f||(f?p.destroySoon():p.end(`HTTP/1.1 408 Request Timeout\r
|
|
26
|
+
`},compressible:!1,q:.8});Bt.set("application/x-www-form-urlencoded",{deserialize(e){let t={};for(let[r,n]of new URLSearchParams(e))if(t.hasOwnProperty(r)){let s=t[r];Array.isArray(s)?s.push(n):t.key=[s,n]}else t[r]=n},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});wv={type:"application/json",serializeStream:hc,serialize:zu,deserialize:H7,q:.8};Bt.set("*/*",wv);Bt.set("",wv);a(H7,"tryJSONParse");a(bg,"registerContentHandlers");x7=require("fastify-plugin"),G7=x7(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=If(n.raw);s.type(c),s.serializer(function(u){return(o.serializeStream||o.serialize)(u,{headers:{set:(_,l)=>{s.header(_,l)}}})})}),r()},{name:"content-type-negotiation"});a(If,"findBestSerializer");Ov=gg.default.get(Rg.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(wf,"serialize");a(mi,"serializeMessage");a(F7,"streamToBuffer");a(mo,"getDeserializer");a(bv,"deserializerUnknownType");a(q7,"transformIterable")});function Ig(e,t,r,n,s,i,o,c){let u=e[0];if(t==="or"){let d=_(u);for(let E=1;E<e.length;E++){let h=e[E],p=_(h);d=d.concat(p)}let f=new Set;return d.filter(E=>{let h=E.key??E;return f.has(h)?!1:(f.add(h),!0)})}else{let d=_(u),f=l(e.slice(1),!0,u.estimated_count);return f.length>0?o(d,f):d}function _(d){return d.conditions?Ig(d.conditions,d.operator,r,n,s,i,o,c):Ca(d,n,d.descending||s.reverse===!0,r,s.allowFullScan,c)}a(_,"executeCondition");function l(d,f,E){return d.map((h,p)=>{if(h.conditions){let b=h.operator==="or",R=l(h.conditions,!b,E);return b?(L,H)=>R.some(P=>P(L,H)):(L,H)=>R.every(P=>P(L,H))}let S=(h.attribute||h[0])===r.primaryKey,T=Cg(h,r,i,c,S,E);return f&&p<d.length-1&&E&&(E=J7(r.primaryStore,h.estimated_count,E)),T}).filter(Boolean)}a(l,"mapConditionsToFilters")}function Ca(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,u=e.comparator;if(Array.isArray(o)){let b=o[0],R=vs(n.attributes,b);if(R.relationship){if(o.length<2)throw new Vr.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let L=R.definition?.tableClass||R.elements?.definition?.tableClass,H=new Map,P=Ca({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:u},t,r,L,s,H);if(R.relationship.to){i[o[0]]=H;let k=!!vs(L.attributes,R.relationship.to)?.elements;P=K7(P,R,L.primaryStore,k,H)}if(R.relationship.from){let k=a(B=>Ca({attribute:R.relationship.from,value:B},t,r,n,s,H),"searchEntry");R.elements?(i[o[0]]=H,P=W7(P,R,L.primaryStore,H,k)):P=P.flatMap(k)}return P}else if(o.length===1)o=o[0];else throw new Vr.ClientError("Unable to query by attribute "+JSON.stringify(o))}let _,l,d,f;c instanceof Date&&(c=c.getTime());let E;switch(wg[u]||u){case"lt":_=!0,l=c;break;case"le":_=!0,l=c,d=!0;break;case"gt":_=c,f=!0;break;case"ge":_=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],_=c,l=c.slice(0),l[l.length-1]=as.MAXIMUM_KEY;break;case"starts_with":_=c.toString(),l=c+"\uFFFF";break;case"between":_=c[0],_ instanceof Date&&(_=_.getTime()),l=c[1],l instanceof Date&&(l=l.getTime()),d=!0;break;case"equals":case void 0:_=c,l=c,d=!0;break;case"ne":if(c===null){_=c,f=!0;break}case"sort":case"contains":case"ends_with":_=!0,E=!0;break;default:throw new Vr.ClientError(`Unknown query comparator "${u}"`)}if(r){let b=_;_=l,l=b,b=!f,f=!d,d=b}let h=o===n.primaryKey||o==null,p=h?n.primaryStore:n.indices[o],S;if(!p||p.isIndexing||E||c===null&&!p.indexNulls){if(s===!1&&!p)throw new Vr.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&E)throw new Vr.ClientError(`Can not use ${u||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(p?.isIndexing)throw new Vr.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&!p.indexNulls)throw new Vr.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(S=Cg(e),!S)throw new Vr.ClientError(`Unknown search operator ${e.comparator}`)}let T={start:_,end:l,inclusiveEnd:d,exclusiveStart:f,values:!0,versions:h,transaction:t,reverse:r};if(h){let b=p.getRange(T).map(S?function({key:R,value:L}){return this.isSync?L&&S(L)?R:Ti.SKIP:new Promise((H,P)=>setImmediate(()=>{try{H(L&&S(L)?R:Ti.SKIP)}catch(k){P(k)}}))}:R=>R.value==null?Ti.SKIP:R);return b.hasEntries=!0,b}else return p?p.getRange(T).map(S?function({key:b,value:R}){return this.isSync?S({[o]:b})?R:Ti.SKIP:new Promise((L,H)=>setImmediate(()=>{try{L(S({[o]:b})?R:Ti.SKIP)}catch(P){H(P)}}))}:({value:b})=>b):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:b,value:R}){return this.isSync?R&&S(R)?b:Ti.SKIP:new Promise((L,H)=>setImmediate(()=>{try{L(R&&S(R)?b:Ti.SKIP)}catch(P){H(P)}}))})}function vs(e,t){if(Array.isArray(t))if(t.length>1){let r=vs(e,t[0]),n=(r?.definition?.tableClass||r?.elements.definition?.tableClass)?.attributes;return n?vs(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 K7(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;s.hasMappings=!0;let o;return{next(){if(!i){let u=t.relationship.to,_=a((l,d)=>{let f=l;Array.isArray(l)&&(f=Bn(l),o=!0);let E=s.get(f);E?E.push(d):s.set(f,E=[d]),l!==f&&(E.key=l)},"add_entry");for(let l of e){let d=l.value??r.get(l.key??l),f=d?.[u];if(f!=null&&!s.filters?.some(E=>!E(d)))if(n)for(let E=0;E<f.length;E++)_(f[E],l);else _(f,l)}return i=(o?s:s.keys())[Symbol.iterator](),this.next()}let c=i.next();return c.done?c:{value:o?c.value[1].key||c.value[0]:c.value}}}}})}function W7(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let u;if(o)for(;u=o.next(),!u.done;){let _=Bn(u.value);if(!c.has(_))return c.add(_),u}if(!i){let _=new Map;n.fromRecord=l=>l[t.relationship.from]?.filter?.(d=>_.has(Bn(d)));for(let l of e){if(n.filters){let d=r.get(l);if(n.filters.some(f=>!f(d)))continue}_.set(Bn(l),l)}return i=_.values()[Symbol.iterator](),this.next()}do{let _=i.next();return _.done?_:(o=s(_.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function Cg(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,u=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 l=c[0],d=vs(t.attributes,l),f=d.definition?.tableClass||d.elements.definition?.tableClass,E=n?.[l],h=Cg({attribute:c.length>2?c.slice(1):c[1],value:u,comparator:o},f,r,E?.[l]?.joined,c[1]===f.primaryKey,i);if(!h)return;if(E){E.filters||(E.filters=[]),E.filters.push(h);return}let p=t.propertyResolvers?.[l],S,T=a((b,R)=>{let L,H;if(p){if(p.from&&h.idFilter){if(!S)if(h.idFilter.idSet?.size===1){for(let k of h.idFilter.idSet)e={attribute:p.from,value:k};S=_(p.from,h.idFilter,!0,!0)}else S=_(p.from,h.idFilter,!1,!0);let P=S(b);return S.idFilter&&(T.idFilter=S.idFilter),P}H=p(b,r,R),L=H?.value}else L=b[l];return L?Array.isArray(L)?L.some(h):h(L,H):!1},"recordFilter");return T}}switch(u instanceof Date&&(u=u.getTime()),wg[o]||o){case yg.SEARCH_TYPES.EQUALS:case void 0:return _(c,l=>l===u,!0);case"contains":return _(c,l=>l?.toString().includes(u));case"ends_with":return _(c,l=>l?.toString().endsWith(u));case"starts_with":return _(c,l=>typeof l=="string"&&l.startsWith(u),!0);case"prefix":return Array.isArray(u)?u[u.length-1]==null&&(u=u.slice(0,-1)):u=[u],_(c,l=>{if(!Array.isArray(l))return!1;for(let d=0,f=u.length;d<f;d++)if(l[d]!==u[d])return!1;return!0},!0);case"between":return u[0]instanceof Date&&(u[0]=u[0].getTime()),u[1]instanceof Date&&(u[1]=u[1].getTime()),_(c,l=>(0,as.compareKeys)(l,u[0])>=0&&(0,as.compareKeys)(l,u[1])<=0,!0);case"gt":return _(c,l=>(0,as.compareKeys)(l,u)>0);case"ge":return _(c,l=>(0,as.compareKeys)(l,u)>=0);case"lt":return _(c,l=>(0,as.compareKeys)(l,u)<0);case"le":return _(c,l=>(0,as.compareKeys)(l,u)<=0);case"ne":return _(c,l=>(0,as.compareKeys)(l,u)!==0);case"sort":return()=>!0;default:throw new Vr.ClientError(`Unknown query comparator "${o}"`)}function _(l,d,f,E){let h;f=f&&!s&&t?.indices[l]&&i>3,f&&(e.estimated_count==null&&Df(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(f=!1));let p=0,S=3;function T(b){let R=b[l],L;if(typeof R!="object"||!R||E?L=d(R):Array.isArray(R)?L=R.some(d):R instanceof Date&&(L=d(R.getTime())),f&&(S++,!L&&!T.idFilter&&++p/S*(i-S)>h)){let H=Ca(e,r.transaction.getReadTxn(),!1,t).map(Bn),P=new Set(H);T.idFilter=k=>P.has(Bn(k)),T.idFilter.idSet=P}return L}return a(T,"recordFilter"),s&&(T.idFilter=d),T}a(_,"attributeComparator")}function Df(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/Ps(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=wg[n]||n,n===yg.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=vs(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=Df(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),u=e.indices[i.relationship.from];r.estimated_count=c+(u?c*Ps(e.indices[i.relationship.from])/(Ps(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=Ps(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=$7*Ps(e.primaryStore)+1:n==="between"?r.estimated_count=V7*Ps(e.primaryStore)+1:n==="sort"?r.estimated_count=Ps(e.primaryStore)+1:r.estimated_count=k7*Ps(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function Lf(e){if(e)if(gi=e,Ia.lastIndex=0,Q7.test(e))try{let t=Xu(new wa,"");if(Ar!==gi.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 ${Ar} in '${gi}'`,t}else{let t=new URLSearchParams(e);return t.conditions=t,t}}function Xu(e,t){let r=Ia,n,s,i,o,c,u=decodeURIComponent,_;for(;n=r.exec(gi);){Ar=r.lastIndex;let[,l,d]=n;if(o){if(l)throw new SyntaxError(`expected operator, but encountered '${l}'`);o=!1,c=!1}else c=!0;let f;switch(d){case"=":if(s){if(l.length<=2)i=l;else throw new SyntaxError(`invalid FIQL operator ${l}`);u=Dv}else{if(u=decodeURIComponent,i="equals",!l)throw new SyntaxError("attribute must be specified before equality comparator");s=ju(l)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=Y7[d],u=Ng[i]?Dv:decodeURIComponent,!l)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=ju(l);break;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,value:u(l)};i==="eq"&&Lv(h,l),Cf(e,_),e.conditions.push(h)}d==="&"&&(_="and"),d==="|"&&(_="or"),s=void 0;break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(ju(l)),s=void 0;break;case"(":Ia.lastIndex=Ar;let E=Xu(l?[]:new wa,")");switch(l){case"":Cf(e,_),e.conditions.push(E);break;case"limit":switch(E.length){case 1:e.limit=+E[0];break;case 2:e.offset=+E[0],e.limit=E[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(E[0])&&E.length===1&&!E[0].name?(e.select=E[0],e.select.asArray=!0):E.length===1?e.select=E[0]:E.length===2&&E[1]===""?e.select=E.slice(0,1):e.select=E;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=Mv(E);break;default:throw new SyntaxError(`unknown query function call ${l}`)}gi[Ar]===","?r.lastIndex=++Ar:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!l)throw new SyntaxError("property sets must have a defined parent property name");Ia.lastIndex=Ar,f=Xu([],"}"),f.name=l,e.push(f),gi[Ar]===","?r.lastIndex=++Ar:o=!0;break;case"[":Ia.lastIndex=Ar,l?(f=Xu(new wa,"]"),f.name=l):f=Xu(e.conditions?new wa:[],"]"),e.conditions?(Cf(e,_),e.conditions.push(f),s=null):e.push(f),gi[Ar]===","?r.lastIndex=++Ar:o=!0;break;case")":case"]":case"}":if(t===d[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:u(l)};i==="eq"&&Lv(h,l),Cf(e,_),e.conditions.push(h)}else if(l)throw new SyntaxError("no attribute or comparison specified")}else(l||e.length>0&&c)&&e.push(ju(l));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?z7:Ia,r.lastIndex=Ar),Ar===gi.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function Cf(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 ju(e){return e.indexOf(".")>-1?e.split(".").map(ju):decodeURIComponent(e)}function Dv(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(decodeURIComponent(r));if(t==="string")return decodeURIComponent(r);throw new Vr.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function Lv(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new Vr.ClientError("wildcard can only be used at the end of a string")}function Mv(e){let t=Uv(e[0]);return e.length>1&&(t.next=Mv(e.slice(1))),t}function Uv(e){if(Array.isArray(e)){let t=Uv(e[0]);return e[0]=t.attribute,t.attribute=e,t}if(typeof e=="string")switch(e[0]){case"-":return{attribute:e.slice(1),descending:!0};case"+":return{attribute:e.slice(1),descending:!1};default:return{attribute:e,descending:!1}}throw new SyntaxError(`Unknown sort type ${e}`)}function Bn(e){return Array.isArray(e)?e.join("\0"):e}function Ps(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function J7(e,t,r){return t*r/Ps(e)}var Vr,yg,as,Ti,k7,V7,$7,Y7,Ng,wg,Q7,Ia,z7,Ar,gi,wa,Mf=Re(()=>{Vr=x(ne()),yg=x(_t()),as=require("ordered-binary"),Ti=require("lmdb"),k7=.3,V7=.1,$7=.05,Y7={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},Ng={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(Ig,"executeConditions");a(Ca,"searchByIndex");a(vs,"findAttribute");a(K7,"joinTo");a(W7,"joinFrom");wg={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(Cg,"filterByType");a(Df,"estimateCondition");Q7=/[()[\]|!<>.]|(=\w*=)/,Ia=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,z7=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(Lf,"parseQuery");a(Xu,"parseBlock");a(Cf,"assignOperator");a(ju,"decodeProperty");a(Dv,"typedDecoding");a(Lv,"wildcardDecoding");a(Mv,"toSortObject");a(Uv,"toSortEntry");wa=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(Bn,"flattenKey");a(Ps,"estimatedEntryCount");a(J7,"intersectionEstimate")});function xv(e){let t={openapi:X7,info:{title:"HarperDB HTTP REST interface",version:(0,Hv.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)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:u}=n.Resource;if(c=c??"id",!c)continue;let _={},l=[];if(o)for(let{type:R,name:L,elements:H,relationship:P,definition:k}of o){if(P)R==="array"?_[L]={type:"array",items:{$ref:Ri+H.type}}:_[L]={$ref:Ri+R};else{let B=k??H?.definition;if(B){if(!t.components.schemas[B.type]){let J={};B.properties.forEach(Q=>{J[Q.name]=new Ug(Dg[Q.type],Q.type)}),t.components.schemas[B.type]=new Bv(J)}R==="array"?_[L]={type:"array",items:{$ref:Ri+B.type}}:_[L]={$ref:Ri+B.type}}else R==="array"?H.type==="Any"||H.type=="ID"?_[L]={type:"array",items:{format:H.type}}:_[L]={type:"array",items:new Ug(Dg[H.type],H.type)}:R==="Any"||R=="ID"?_[L]={format:R}:_[L]=new Ug(Dg[R],R)}l.push(new Pg(L,"query",_[L]))}let d=Object.keys(_),f=new Pg(c,"path",{format:"ID"});f.required=!0,f.description="primary key of record";let E=new Pg("property","path",{enum:d});E.required=!0,t.components.schemas[i]=new Bv(_);let h=u.post!==Resource.prototype.post||u.update,p=typeof u.put=="function",S=typeof u.get=="function",T=typeof u.delete=="function",b="/"+s+"/";h&&(t.paths[b]={},t.paths[b].post=new j7(i,r,"create a new record auto-assigning a primary key")),S&&(t.paths[b]||(t.paths[b]={}),t.paths[b].get=new Lg(l,r,{200:new Mg({$ref:Ri+i})},"search for records by the specified property name and value pairs")),T&&(t.paths[b]||(t.paths[b]={}),t.paths[b].delete=new vv(l,r,"delete all the records that match the provided query",{204:new Pv})),b="/"+s+"/{"+c+"}",S&&(t.paths[b]={},t.paths[b].get=new Lg([f],r,{200:new Mg({$ref:Ri+i})},"retrieve a record by its primary key")),p&&(t.paths[b]||(t.paths[b]={}),t.paths[b].put=new Z7([f],r,i,"create or update the record with the URL path that maps to the record's primary key")),T&&(t.paths[b]||(t.paths[b]={}),t.paths[b].delete=new vv([f],r,"delete a record with the given primary key",{204:new Pv})),S&&E.schema.enum.length>0&&(b="/"+s+"/{"+c+"}.{property}",t.paths[b]={},t.paths[b].get=new Lg([f,E],r,{200:new Mg({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function j7(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Ri+e}}}},this.security=t,this.responses={200:{description:vg,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function Lg(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function Mg(e){this.description=vg,this.content={"application/json":{schema:e}}}function Pv(){this.description="successfully processed request, no content returned to client"}function Z7(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Ri+r}}}},this.responses={200:{description:vg}}}function vv(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function Bv(e){this.type="object",this.properties=e}function Ug(e,t){this.type=e,this.format=t}function Pg(e,t,r){this.name=e,this.in=t,this.schema=r}var Hv,X7,Dg,Ri,vg,Gv=Re(()=>{Hv=x(Cd()),X7="3.0.3",Dg={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Ri="#/components/schemas/",vg="successful operation";a(xv,"generateJsonApi");a(j7,"Post");a(Lg,"Get");a(Mg,"Response200");a(Pv,"Response204");a(Z7,"Put");a(vv,"Delete");a(Bv,"ResourceSchema");a(Ug,"Type");a(Pg,"Parameter")});var Pf={};$e(Pf,{start:()=>ree});async function tee(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream"?"CONNECT":e.method;e.search&&Lf(e);let s=new hi;try{e.responseHeaders=s;let i=e.url.slice(1),o,c;if(i!==Fv){let h=Uf.getMatch(i);if(!h)return t(e);e.handlerPath=h.path,o={url:h.relativeURL,async:!0},c=h.Resource}let u=r["cache-control"];if(u){u=u.toLowerCase();let h=u.match(/max-age=(\d+)/)?.[1];h&&(e.expiresAt=h*1e3+Date.now()),u.includes("only-if-cached")&&(e.onlyIfCached=!0),u.includes("no-cache")&&(e.noCache=!0),u.includes("no-store")&&(e.noCacheStore=!0),u.includes("stale-if-error")&&(e.staleIfError=!0),u.includes("must-revalidate")&&(e.mustRevalidate=!0)}let _=await ze(e,()=>{if(n==="POST"||n==="PUT"||n==="PATCH"||n==="QUERY")try{e.data=mo(r["content-type"],!0)(e.body)}catch(h){throw new Da.ClientError(h,400)}if(e.authorize=!0,i===Fv&&n==="GET"){if(e?.user?.role?.permission?.super_user)return xv(Uf);throw new Da.ServerError("Forbidden",403)}switch(n){case"GET":case"HEAD":return c.get(o,e);case"POST":return c.post(o,e.data,e);case"PUT":return c.put(o,e.data,e);case"DELETE":return c.delete(o,e);case"PATCH":return c.patch(o,e.data,e);case"OPTIONS":s.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return c.connect(o,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return c.query(o,e.data,e);case"COPY":return c.copy(o,r.destination,e);case"MOVE":return c.move(o,r.destination,e);case"BREW":throw new Da.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Da.ServerError(`Method ${n} is not recognized`,501)}}),l=200,d;if(_==null)l=n==="GET"||n==="HEAD"?404:204,Bg.lastModified&&e.lastModified&&s.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d=e.lastModified){eee[0]=d;let h=String.fromCharCode(34,(Vt[0]&63)+62,(Vt[0]>>6)+(Vt[1]<<2&63)+62,(Vt[1]>>4)+(Vt[2]<<4&63)+62,(Vt[2]>>2)+62,(Vt[3]&63)+62,(Vt[3]>>6)+(Vt[4]<<2&63)+62,(Vt[4]>>4)+(Vt[5]<<4&63)+62,(Vt[5]>>2)+62,(Vt[6]&63)+62,(Vt[6]>>6)+(Vt[7]<<2&63)+62,34),p=r["if-none-match"];p&&h==p?(_?.onDone&&_.onDone(),l=304,_=void 0):s.setIfNone("ETag",h),Bg.lastModified&&s.setIfNone("Last-Modified",new Date(d).toUTCString())}e.createdResource&&(l=201),e.newLocation&&s.setIfNone("Location",e.newLocation);let f={status:l,headers:s,body:void 0},E=_?.wasLoadedFromSource?.();return E!==void 0&&(f.wasCacheMiss=E,!E&&d&&s.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||d))/1e3))),_!==void 0&&(f.body=wf(_,e,f),n==="HEAD"&&(f.body=void 0)),f}catch(i){i.statusCode?i.statusCode===500?po.warn(i):po.info(i):po.error(i),i.statusCode===405&&(i.method&&(i.message+=` to handle HTTP method ${i.method.toUpperCase()||""}`),i.allow&&(i.allow.push("trace","head","options"),s.setIfNone("Allow",i.allow.map(c=>c.toUpperCase()).join(", "))));let o={status:i.statusCode||500,headers:s,body:void 0};return o.body=wf(i.contentType?i:i.toString(),e,o),o}}function ree(e){Bg=e,!qv&&(qv=!0,Uf=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return tee(t,r)}),e.server.ws(async(t,r,n)=>{Zu++;let s=new Rn;kv||(kv=!0,tu(l=>{Zu>0&&l.push({metric:"ws-connections",connections:Zu,byThread:!0})}));let i;t.on("error",l=>{i=!0,po.warn(l)});let o;t.on("message",a(function(d){o||(o=mo(r.headers.asObject["content-type"]));let f=o(d);s.push(f)},"message"));let c;t.on("close",()=>{Zu--,sn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()}),await n;let u=r.url.slice(1),_=Uf.getMatch(u);if(sn(!!_,"connection","ws","connect"),!_)t.send(mi(`No resource was found to handle ${r.pathname}`,r));else{r.handlerPath=_.path,xr(h=>({count:h.count,total:Zu}),"connections",r.handlerPath,"connect","ws");let l={url:_.relativeURL,async:!0},d=_.Resource;c=(await ze(r,()=>d.connect(l,s,r)))[Symbol.asyncIterator]();let E;for(;!(E=await c.next()).done;){let h=mi(E.value,r);t.send(h),xr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}t.close()}))}var po,Da,Vt,eee,Bg,Fv,qv,Uf,kv,Zu,Vv=Re(()=>{ga();Os();po=x(K()),Da=x(ne());Mf();fc();Xi();vu();Gv();Vt=new Uint8Array(8),eee=new Float64Array(Vt.buffer,0,1),Bg={},Fv="openapi";a(tee,"http");Zu=0;a(ree,"start")});var Hg=g((BEe,$v)=>{var{recordAction:vf,recordActionBinary:nee}=(Os(),se(ru)),see=require("fastify-plugin"),iee=200;$v.exports=see(function(e,t,r){e.addHook("onResponse",async(n,s)=>{s.getResponseTime()}),e.addHook("onSend",async(n,s,i)=>{let o=s.getResponseTime(),c=performance.now(),u=s.request.routeOptions,_,l,d;u.config?.isOperation?(_=n.body?.operation,l="operation"):(_=u.url,l="fastify-route",d=u.method),vf(o,"duration",_,d,l),nee(s.raw.statusCode<400,"success",_,d,l);let f=iee;i?.pipe?(i.on("data",h=>{f+=h.length}),i.on("end",()=>{vf(performance.now()-c,"transfer",_,d,l),vf(f,"bytes-sent",_,d,l)})):(f+=i?.length||0,vf(f,"bytes-sent",_,d,l));let E=o.toFixed(3);s.header("Server-Timing",`db;dur=${E}`)}),r()},{name:"hdb-request-time"})});var Vg=g((GEe,Qv)=>{var Gf=require("clone"),Ff=tt(),oee=z(),Hf=U(),HEe=K(),xg=require("fs"),Fg=require("joi"),{string:xf}=Fg.types(),{hdb_errors:aee,handleHDBError:Bf}=ne(),{HDB_ERROR_MSGS:xEe,HTTP_STATUS_CODES:Gg}=aee,{common_validators:La}=Wn(),Yv=" is required",cee=["insert","update","upsert"],qg={database:{presence:!1,format:La.schema_format,length:La.schema_length},schema:{presence:!1,format:La.schema_format,length:La.schema_length},table:{presence:!0,format:La.schema_format,length:La.schema_length},action:{inclusion:{within:cee,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},uee={schema:xf.required(),table:xf.required(),action:xf.valid("insert","update","upsert")},{AWS_ACCESS_KEY:lee,AWS_SECRET:_ee,AWS_BUCKET:dee,AWS_FILE_KEY:fee,REGION:Eee}=Hf.S3_BUCKET_AUTH_KEYS,hee={s3:{presence:!0},[`s3.${lee}`]:{presence:!0,type:"String"},[`s3.${_ee}`]:{presence:!0,type:"String"},[`s3.${dee}`]:{presence:!0,type:"String"},[`s3.${fee}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${Eee}`]:{presence:!0,type:"String"}},Kv=Gf(qg);Kv.data.presence={message:Yv};var Wv=Gf(qg);Wv.file_path.presence={message:Yv};var mee=Object.assign(Gf(qg),hee),kg=Gf(uee);kg.csv_url=xf.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();kg.passthrough_headers=Fg.object();function pee(e){let t=Ff.validateObject(e,Kv);return qf(e,t)}a(pee,"dataObject");function See(e){let t=Ff.validateBySchema(e,Fg.object(kg));return qf(e,t)}a(See,"urlObject");function Tee(e){let t=Ff.validateObject(e,Wv);return qf(e,t)}a(Tee,"fileObject");function gee(e){let t=Ff.validateObject(e,mee);return qf(e,t)}a(gee,"s3FileObject");function qf(e,t){if(!t){let r=oee.checkGlobalSchemaTable(e.schema,e.table);if(r)return Bf(new Error,r,Gg.BAD_REQUEST);if(e.operation===Hf.OPERATIONS_ENUM.CSV_FILE_LOAD)try{xg.accessSync(e.file_path,xg.constants.R_OK|xg.constants.F_OK)}catch(n){return n.code===Hf.NODE_ERROR_CODES.ENOENT?Bf(n,`No such file or directory ${n.path}`,Gg.BAD_REQUEST):n.code===Hf.NODE_ERROR_CODES.EACCES?Bf(n,`Permission denied ${n.path}`,Gg.BAD_REQUEST):Bf(n)}}return t}a(qf,"postValidateChecks");Qv.exports={dataObject:pee,urlObject:See,fileObject:Tee,s3FileObject:gee}});var $g=g((qEe,zv)=>{"use strict";var el=K(),kf=U();async function Ree(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===kf.OPERATIONS_ENUM.INSERT||t.operation===kf.OPERATIONS_ENUM.UPDATE||t.operation===kf.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===kf.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(el.info(i.message),i):i.http_resp_msg?(el.error(`Error calling operation: ${e.name}`),el.error(i.http_resp_msg),i):(el.error(`Error calling operation: ${e.name}`),el.error(i),i)}}a(Ree,"callOperationFunctionAsAwait");zv.exports={callOperationFunctionAsAwait:Ree}});var Xv=g((VEe,Jv)=>{"use strict";var Yg=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}},Kg=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};Jv.exports={BulkLoadFileObject:Yg,BulkLoadDataObject:Kg}});var Zv=g((YEe,jv)=>{"use strict";var Wg=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};jv.exports=Wg});var Zg=g((XEe,m0)=>{"use strict";var Vf=rn(),Yf=Vg(),Aee=require("needle"),Hn=U(),WEe=rt(),Ma=z(),{handleHDBError:st,hdb_errors:c0}=ne(),{HTTP_STATUS_CODES:$t,HDB_ERROR_MSGS:It,CHECK_LOGS_WRAPPER:To}=c0,Ua=K(),Qg=require("papaparse");Ma.promisifyPapaParse();var xn=require("fs-extra"),Oee=require("path"),{chain:e0}=require("stream-chain"),t0=require("stream-json/streamers/StreamArray"),r0=require("stream-json/utils/Batch"),n0=require("stream-chain/utils/comp"),{finished:s0}=require("stream"),bee=re(),u0=$g(),yee=mg(),{BulkLoadFileObject:Jg,BulkLoadDataObject:Nee}=Xv(),Xg=og(),{verifyBulkLoadAttributePerms:l0}=Af(),QEe=Zv(),zEe=bt(),JEe=Ss(),{databases:Iee}=(Ae(),se(Fe)),{coerceType:wee}=(Kf(),se(eR)),i0="No records parsed from csv file.",So=`${bee.get("HDB_ROOT")}/tmp`,{schema_regex:Cee}=Wn(),o0=1024*1024*2,a0=5e3,Dee={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};m0.exports={csvDataLoad:Lee,csvURLLoad:Mee,csvFileLoad:Uee,importFromS3:Pee};async function Lee(e,t){let r=Yf.dataObject(e);if(r)throw st(r,r.message,$t.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=f0(e.schema,e.table),i=Qg.parse(e.data,{header:!0,skipEmptyLines:!0,transform:zg.bind(null,s),dynamicTyping:!1}),o=new Xg;e.hdb_user&&e.hdb_user.role&&e.hdb_user.role.permission&&e.hdb_user.role.permission.super_user!==!0&&l0(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 st(new Error,c,$t.BAD_REQUEST,void 0,void 0,!0);let u=new Nee(e.action,e.schema,e.table,i.data);return n=await u0.callOperationFunctionAsAwait(E0,u,null),n.message===i0?i0:h0(n.records,n.number_written)}catch(s){throw go(s)}}a(Lee,"csvDataLoad");async function Mee(e){let t=Yf.urlObject(e);if(t)throw st(t,t.message,$t.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${So}/${r}`;try{await vee(e,r)}catch(s){throw Ua.error(It.DOWNLOAD_FILE_ERR(r)+" - "+s),st(s,To(It.DOWNLOAD_FILE_ERR(r)))}try{let s=new Jg(this.job_operation_function.name,e.action,e.schema,e.table,n,Hn.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission),i=await jg(s);return await $f(n),i}catch(s){throw await $f(n),go(s)}}a(Mee,"csvURLLoad");async function Uee(e){let t=Yf.fileObject(e);if(t)throw st(t,t.message,$t.BAD_REQUEST,void 0,void 0,!0);let r=new Jg(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,Hn.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission);try{return await jg(r)}catch(n){throw go(n)}}a(Uee,"csvFileLoad");async function Pee(e){let t=Yf.s3FileObject(e);if(t)throw st(t,t.message,$t.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=Oee.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${So}/${s}`;let i=new Jg(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user.role.permission);await Bee(s,e);let o=await jg(i);return await $f(r),o}catch(n){throw await $f(r),go(n)}}a(Pee,"importFromS3");async function vee(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await Aee("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 st(n,s,n.statusCode,Hn.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}xee(r,e.csv_url),await Hee(t,r.raw)}a(vee,"downloadCSVFile");async function Bee(e,t){try{let r=`${So}/${e}`;await xn.mkdirp(So),await xn.writeFile(`${So}/${e}`,"",{flag:"a+"});let n=await xn.createWriteStream(r),s=await yee.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(){Ua.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Ua.error(It.S3_DOWNLOAD_ERR+" - "+r),st(r,To(It.S3_DOWNLOAD_ERR))}}a(Bee,"downloadFileFromS3");async function Hee(e,t){try{await xn.mkdirp(So),await xn.writeFile(`${So}/${e}`,t)}catch(r){throw Ua.error(It.WRITE_TEMP_FILE_ERR),st(r,To(It.DEFAULT_BULK_LOAD_ERR))}}a(Hee,"writeFileToTempFolder");async function $f(e){if(e)try{await xn.access(e),await xn.unlink(e)}catch{Ua.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a($f,"deleteTempFile");function xee(e,t){if(e.statusCode!==c0.HTTP_STATUS_CODES.OK)throw st(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,$t.BAD_REQUEST);if(!Dee[e.headers["content-type"]])throw st(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,$t.BAD_REQUEST);if(!e.raw)throw st(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,$t.BAD_REQUEST)}a(xee,"validateURLResponse");async function jg(e){try{let t;switch(e.file_type){case Hn.VALID_S3_FILE_TYPES.CSV:t=await Gee(e);break;case Hn.VALID_S3_FILE_TYPES.JSON:t=await Fee(e);break;default:throw st(new Error,It.DEFAULT_BULK_LOAD_ERR,$t.BAD_REQUEST,Hn.LOG_LEVELS.ERROR,It.INVALID_FILE_EXT_ERR(e))}return h0(t.records,t.number_written)}catch(t){throw go(t)}}a(jg,"fileLoad");async function _0(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 Vf.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&l0(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let u=st(c);r(u)}}a(_0,"validateChunk");async function d0(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Ma.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Ma.isEmpty(c)&&!Ma.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(u=>{Object.keys(u).forEach(_=>c.add(_))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},u=await u0.callOperationFunctionAsAwait(E0,c,null);t.records+=u.records,t.number_written+=u.number_written,s&&s.resume()}catch(c){let u=st(c,To(It.INSERT_CSV_ERR),$t.INTERNAL_SERVER_ERROR,Hn.LOG_LEVELS.ERROR,It.INSERT_CSV_ERR+" - "+c);r(u)}}a(d0,"insertChunk");async function Gee(e){let t={records:0,number_written:0},r=f0(e.schema,e.table);try{let n=new Xg,s=xn.createReadStream(e.file_path,{highWaterMark:o0});s.setEncoding("utf8"),await Qg.parsePromise(s,_0.bind(null,e,n),zg.bind(null,r));let i=n.getPermsResponse();if(i)throw st(new Error,i,$t.BAD_REQUEST);return s=xn.createReadStream(e.file_path,{highWaterMark:o0}),s.setEncoding("utf8"),await Qg.parsePromise(s,d0.bind(null,e,t),zg.bind(null,r)),s.destroy(),t}catch(n){throw st(n,To(It.PAPA_PARSE_ERR),$t.INTERNAL_SERVER_ERROR,Hn.LOG_LEVELS.ERROR,It.PAPA_PARSE_ERR+n)}}a(Gee,"callPapaParse");function f0(e,t){let r=Iee[e][t].attributes,n=new Map;for(let s of r)s.type&&n.set(s.name,i=>wee(i,s));return n}a(f0,"createTransformMap");function zg(e,t,r){let n=e.get(r);return n?n(t):Ma.autoCast(t)}a(zg,"typeFunction");async function Fee(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new Xg,s=e0([xn.createReadStream(e.file_path,{encoding:"utf-8"}),t0.withParser(),c=>c.value,new r0({batchSize:a0}),n0(async c=>{await _0(e,n,r,c)})]);await new Promise((c,u)=>{s0(s,_=>{_?u(_):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw st(new Error,i,$t.BAD_REQUEST);let o=e0([xn.createReadStream(e.file_path,{encoding:"utf-8"}),t0.withParser(),c=>c.value,new r0({batchSize:a0}),n0(async c=>{await d0(e,t,r,c)})]);return await new Promise((c,u)=>{s0(o,_=>{_?u(_):c()}),o.resume()}),t}catch(n){throw st(n,To(It.INSERT_JSON_ERR),$t.INTERNAL_SERVER_ERROR,Hn.LOG_LEVELS.ERROR,It.INSERT_JSON_ERR+n)}}a(Fee,"insertJson");async function E0(e){let t={};try{e.data&&e.data.length>0&&qee(e.data[0])?t=await kee(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Ua.info(t.message))}catch(r){throw go(r)}return t}a(E0,"callBulkFileLoad");function qee(e){let t=Object.keys(e);for(let r of t)if(!Cee.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(qee,"validateColumnNames");async function kee(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=Vf.insert;break;case"update":i=Vf.update;break;case"upsert":i=Vf.upsert;break;default:throw st(new Error,It.INVALID_ACTION_PARAM_ERR(n),$t.BAD_REQUEST,Hn.LOG_LEVELS.ERROR,It.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 l=global.hdb_schema[t][r].hash_attribute,d=e.length;for(;d--;)o.skipped_hashes.indexOf(e[d][l])>=0&&e.splice(d,1)}let u=Ma.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:u,new_attributes:o.new_attributes}}catch(o){throw go(o)}}a(kee,"bulkFileLoad");function h0(e,t){return`successfully loaded ${t} of ${e} records`}a(h0,"buildResponseMsg");function go(e){return st(e,To(It.DEFAULT_BULK_LOAD_ERR),$t.INTERNAL_SERVER_ERROR,Hn.LOG_LEVELS.ERROR,It.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(go,"buildTopLevelErrMsg")});var S0=g((ZEe,p0)=>{"use strict";var tR=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};p0.exports=tR});var R0=g((the,g0)=>{"use strict";var Vee=U(),T0=require("moment"),$ee=require("uuid").v4,rR=class{static{a(this,"JobObject")}constructor(){this.id=$ee(),this.type=void 0,this.start_datetime=T0().valueOf(),this.created_datetime=T0().valueOf(),this.end_datetime=void 0,this.status=Vee.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};g0.exports=rR});var nR=g((nhe,I0)=>{"use strict";var Yee=require("uuid").v4,b0=rn(),y0=Dr(),Kee=jn(),Wee=Zo(),Qee=S0(),it=U(),zee=R0(),Jee=HS(),dn=K(),Xee=Ic(),Pa=z(),{promisify:jee}=require("util"),Ro=require("moment"),Zee=bf(),Wf=Vg(),A0=Nm(),{deleteTransactionLogsBeforeValidator:ete}=tg(),{handleHDBError:tte,hdb_errors:rte}=ne(),{HTTP_STATUS_CODES:nte}=rte,O0=y0.searchByValue,ste=y0.searchByHash,ite=b0.insert,ote=jee(Zee.evaluateSQL),ate=b0.update;I0.exports={addJob:lte,updateJob:dte,handleGetJob:cte,handleGetJobsByStartDate:ute,getJobById:N0};async function cte(e){try{let t=await N0(e.id);return Pa.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}catch(t){let r=`There was an error getting job: ${t}`;throw dn.error("There was an error getting job",t),new Error(r)}}a(cte,"handleGetJob");async function ute(e){try{let t=await _te(e);if(dn.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=Ro(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Ro(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 dn.error(r),new Error(r)}}a(ute,"handleGetJobsByStartDate");async function lte(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||Pa.isEmptyOrZeroLength(e.operation)){let l="job parameter is invalid";return dn.info(l),t.error=l,t}if(!it.JOB_TYPE_ENUM[e.operation])return dn.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case it.OPERATIONS_ENUM.CSV_FILE_LOAD:n=Wf.fileObject(e);break;case it.OPERATIONS_ENUM.CSV_URL_LOAD:n=Wf.urlObject(e);break;case it.OPERATIONS_ENUM.CSV_DATA_LOAD:n=Wf.dataObject(e);break;case it.OPERATIONS_ENUM.IMPORT_FROM_S3:n=Wf.s3FileObject(e);break;case it.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case it.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=A0(e,"date");break;case it.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=A0(e,"timestamp");break;case it.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=ete(e);break;default:break}if(n)throw tte(n,n.message,nte.BAD_REQUEST,void 0,void 0,!0);let s=new zee;s.type=e.operation===it.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?it.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user.username;let i=new Kee(it.SYSTEM_SCHEMA_NAME,it.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await O0(i))}catch(l){let d=`There was an error inserting a new job: ${l}`;return dn.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Yee();try{o=await O0(i)}catch(l){let d=`There was an error inserting a new job: ${l}`;return dn.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return dn.error("Error creating a job, could not find a unique job id."),t}s.request=e;let u=new Xee(it.SYSTEM_SCHEMA_NAME,it.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),_;try{_=await ite(u)}catch(l){return dn.error(`There was an error inserting a job for job type: ${e.operation} -- ${l}`),t.success=!1,t}if(_.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let l=`Created a job with type ${s.type} and id ${s.id}`;t.message=l,t.createdJob=s,t.success=!0,dn.trace(l)}return t}a(lte,"addJob");async function _te(e){let t=Ro(e.from_date,Ro.ISO_8601),r=Ro(e.to_date,Ro.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 Qee(n,e.hdb_user);try{return await ote(s)}catch(i){throw dn.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(_te,"getJobsInDateRange");async function N0(e){if(Pa.isEmptyOrZeroLength(e))return Pa.errorizeMessage("Invalid job ID specified.");let t=new Wee(it.SYSTEM_SCHEMA_NAME,it.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await ste(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return dn.error(n),Pa.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(N0,"getJobById");async function dte(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(Pa.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===it.JOB_STATUS_ENUM.COMPLETE||e.status===it.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Ro().valueOf());let t=new Jee(it.SYSTEM_SCHEMA_NAME,it.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await ate(t),r}a(dte,"updateJob")});var U0=g((ihe,M0)=>{"use strict";var w0=z(),Or=U(),fte=require("moment"),Qf=Zg(),zf=K(),C0=nR(),D0=yf(),L0=qi(),Ete=Ze(),hte=Sf(),sR=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function mte(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(w0.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(w0.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Or.JOB_TYPE_ENUM.csv_file_load:await Bs(e,Qf.csvFileLoad);break;case Or.JOB_TYPE_ENUM.csv_url_load:await Bs(e,Qf.csvURLLoad);break;case Or.JOB_TYPE_ENUM.csv_data_load:await Bs(e,Qf.csvDataLoad);break;case Or.JOB_TYPE_ENUM.import_from_s3:await Bs(e,Qf.importFromS3);break;case Or.JOB_TYPE_ENUM.empty_trash:break;case Or.JOB_TYPE_ENUM.export_local:await Bs(e,D0.export_local);break;case Or.JOB_TYPE_ENUM.export_to_s3:await Bs(e,D0.export_to_s3);break;case Or.JOB_TYPE_ENUM.delete_files_before:case Or.JOB_TYPE_ENUM.delete_records_before:await Bs(e,L0.deleteFilesBefore);break;case Or.JOB_TYPE_ENUM.delete_audit_logs_before:await Bs(e,L0.deleteAuditLogsBefore);break;case Or.JOB_TYPE_ENUM.delete_transaction_logs_before:await Bs(e,hte.deleteTransactionLogsBefore);break;default:return`Invalid operation ${e.json.operation} specified`}}a(mte,"parseMessage");async function Bs(e,t){try{e.job.status=Or.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=fte().valueOf(),await C0.updateJob(e.job),await pte(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):zf.error(`There was an error running ${t.name} job with id ${e.job.id}`),zf.error(n),e.job.message=n,e.job.status=Or.JOB_STATUS_ENUM.ERROR;try{await C0.updateJob(e.job)}catch(s){throw zf.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Bs,"runJob");async function pte(e){zf.trace("launching job thread:",e),Ete.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:Object.assign({},process.env,{[Or.PROCESS_NAME_ENV_PROP]:`JOB-${e}`})})}a(pte,"launchJobThread");M0.exports={parseMessage:mte,RunnerMessage:sR}});var v0=g((ahe,P0)=>{"use strict";var iR=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};P0.exports=iR});var j0=g((uhe,_R)=>{"use strict";var eE=Dr(),cR=bf(),Jf=Zg(),Hs=pd(),Xf=Bi(),rl=qi(),Ste=AS(),tl=nn(),jf=LS(),Yt=eg(),Zf=K(),Tte=PS(),gte=vd(),B0=fT(),Rte=Hd(),Ate=hT(),Ote=mT(),bte=TT(),yte=RT(),oR=bT(),H0=yf(),Nte=Af(),uR=nR(),G=U(),{hdb_errors:sl,handleHDBError:nl}=ne(),{HTTP_STATUS_CODES:x0}=sl,aR=CT(),G0=rf(),Q0=require("util"),va=rn(),Ite=Xs(),wte=da(),F0=U0(),q0=hu(),k0=(af(),se(Bu)),V0=Ur(),$0=Sf(),Y0=df(),{setServerUtilities:Cte}=(Kf(),se(eR)),{CONTEXT:Dte}=(An(),se(gp)),{_assignPackageExport:Lte}=require("../../index"),{transformReq:Mte}=z(),{server:Ute}=(sr(),se(Ci)),jt=Zf.loggerWithTag("operation"),Pte=$g(),K0=eE.searchByHash,vte=eE.searchByValue,Bte=Q0.promisify(eE.search),Hte=Q0.promisify(cR.evaluateSQL),xte={[G.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[G.OPERATIONS_ENUM.CREATE_TABLE]:!0,[G.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[G.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[G.OPERATIONS_ENUM.DROP_TABLE]:!0,[G.OPERATIONS_ENUM.DROP_SCHEMA]:!0},$=v0();async function z0(e,t){try{if(e.body.operation!=="read_log"&&(Zf.log_level===G.LOG_LEVELS.INFO||Zf.log_level===G.LOG_LEVELS.DEBUG||Zf.log_level===G.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,...o}=e.body;jt.info(o)}}catch(n){jt.error(n)}let r=await Pte.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return xte[e.body.operation]&&Ite.setSchemaDataToGlobal(n=>{n&&jt.error(n)}),r}a(z0,"processLocalTransaction");var W0=Fte();_R.exports={chooseOperation:J0,getOperationFunction:X0,operation:lR,processLocalTransaction:z0};Cte(_R.exports);Ute.operation=lR;function J0(e){let t;try{t=X0(e)}catch(s){throw jt.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=cR.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=cR.checkASTPermissions(e,i);if(o)throw jt.error(`${x0.FORBIDDEN} from operation ${e.operation}`),jt.warn(`User '${e.hdb_user.username}' is not permitted to ${e.operation}`),nl(new Error,o,sl.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==G.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==G.OPERATIONS_ENUM.LOGIN&&e.operation!==G.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=Nte.verifyPerms(i,s);if(o)throw jt.error(`${x0.FORBIDDEN} from operation ${e.operation}`),jt.warn(`User '${i.hdb_user.username}' is not permitted to ${i.operation}`),nl(new Error,o,sl.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw nl(s,"There was an error when trying to choose an operation path")}return r}a(J0,"chooseOperation");function X0(e){if(jt.trace(`getOperationFunction with operation: ${e.operation}`),W0.has(e.operation))return W0.get(e.operation);throw nl(new Error,sl.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),sl.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(X0,"getOperationFunction");Lte("operation",lR);function lR(e,t){e.hdb_user=this[Dte]?.user,e.bypass_auth=!t;let r=J0(e);return z0({body:e},r)}a(lR,"operation");async function Gte(e){jt.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[G.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case G.OPERATIONS_ENUM.INSERT:o=await va.insert(i);break;case G.OPERATIONS_ENUM.UPDATE:o=await va.update(i);break;case G.OPERATIONS_ENUM.UPSERT:o=await va.upsert(i);break;case G.OPERATIONS_ENUM.DELETE:o=await rl.deleteRecord(i);break;default:jt.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){jt.info("Invalid operation in transaction"),jt.error(o)}}a(Gte,"catchup");async function cs(e){Mte(e);let t,r;try{r=await uR.addJob(e),t=r.createdJob,jt.info("addJob result",r);let n=new F0.RunnerMessage(t,e);return await F0.parseMessage(n),{message:`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 jt.error(s),nl(n,s)}}a(cs,"executeJob");function Fte(){let e=new Map;return e.set(G.OPERATIONS_ENUM.INSERT,new $(va.insert)),e.set(G.OPERATIONS_ENUM.UPDATE,new $(va.update)),e.set(G.OPERATIONS_ENUM.UPSERT,new $(va.upsert)),e.set(G.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new $(eE.searchByConditions)),e.set(G.OPERATIONS_ENUM.SEARCH_BY_HASH,new $(K0)),e.set(G.OPERATIONS_ENUM.SEARCH_BY_ID,new $(K0)),e.set(G.OPERATIONS_ENUM.SEARCH_BY_VALUE,new $(vte)),e.set(G.OPERATIONS_ENUM.SEARCH,new $(Bte)),e.set(G.OPERATIONS_ENUM.SQL,new $(Hte)),e.set(G.OPERATIONS_ENUM.CSV_DATA_LOAD,new $(cs,Jf.csvDataLoad)),e.set(G.OPERATIONS_ENUM.CSV_FILE_LOAD,new $(cs,Jf.csvFileLoad)),e.set(G.OPERATIONS_ENUM.CSV_URL_LOAD,new $(cs,Jf.csvURLLoad)),e.set(G.OPERATIONS_ENUM.IMPORT_FROM_S3,new $(cs,Jf.importFromS3)),e.set(G.OPERATIONS_ENUM.CREATE_SCHEMA,new $(Hs.createSchema)),e.set(G.OPERATIONS_ENUM.CREATE_DATABASE,new $(Hs.createSchema)),e.set(G.OPERATIONS_ENUM.CREATE_TABLE,new $(Hs.createTable)),e.set(G.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new $(Hs.createAttribute)),e.set(G.OPERATIONS_ENUM.DROP_SCHEMA,new $(Hs.dropSchema)),e.set(G.OPERATIONS_ENUM.DROP_DATABASE,new $(Hs.dropSchema)),e.set(G.OPERATIONS_ENUM.DROP_TABLE,new $(Hs.dropTable)),e.set(G.OPERATIONS_ENUM.DROP_ATTRIBUTE,new $(Hs.dropAttribute)),e.set(G.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new $(Xf.describeSchema)),e.set(G.OPERATIONS_ENUM.DESCRIBE_DATABASE,new $(Xf.describeSchema)),e.set(G.OPERATIONS_ENUM.DESCRIBE_TABLE,new $(Xf.describeTable)),e.set(G.OPERATIONS_ENUM.DESCRIBE_ALL,new $(Xf.describeAll)),e.set(G.OPERATIONS_ENUM.DELETE,new $(rl.deleteRecord)),e.set(G.OPERATIONS_ENUM.ADD_USER,new $(tl.addUser)),e.set(G.OPERATIONS_ENUM.ALTER_USER,new $(tl.alterUser)),e.set(G.OPERATIONS_ENUM.DROP_USER,new $(tl.dropUser)),e.set(G.OPERATIONS_ENUM.LIST_USERS,new $(tl.listUsersExternal)),e.set(G.OPERATIONS_ENUM.LIST_ROLES,new $(jf.listRoles)),e.set(G.OPERATIONS_ENUM.ADD_ROLE,new $(jf.addRole)),e.set(G.OPERATIONS_ENUM.ALTER_ROLE,new $(jf.alterRole)),e.set(G.OPERATIONS_ENUM.DROP_ROLE,new $(jf.dropRole)),e.set(G.OPERATIONS_ENUM.USER_INFO,new $(tl.userInfo)),e.set(G.OPERATIONS_ENUM.READ_LOG,new $(Tte)),e.set(G.OPERATIONS_ENUM.ADD_NODE,new $(gte)),e.set(G.OPERATIONS_ENUM.UPDATE_NODE,new $(B0)),e.set(G.OPERATIONS_ENUM.SET_NODE_REPLICATION,new $(B0)),e.set(G.OPERATIONS_ENUM.REMOVE_NODE,new $(Rte)),e.set(G.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new $(Ate)),e.set(G.OPERATIONS_ENUM.PURGE_STREAM,new $(Ote)),e.set(G.OPERATIONS_ENUM.SET_CONFIGURATION,new $(V0.setConfiguration)),e.set(G.OPERATIONS_ENUM.CLUSTER_STATUS,new $(bte.clusterStatus)),e.set(G.OPERATIONS_ENUM.CLUSTER_NETWORK,new $(yte)),e.set(G.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new $(oR.setRoutes)),e.set(G.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new $(oR.getRoutes)),e.set(G.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new $(oR.deleteRoutes)),e.set(G.OPERATIONS_ENUM.EXPORT_TO_S3,new $(cs,H0.export_to_s3)),e.set(G.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new $(cs,rl.deleteFilesBefore)),e.set(G.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new $(cs,rl.deleteFilesBefore)),e.set(G.OPERATIONS_ENUM.EXPORT_LOCAL,new $(cs,H0.export_local)),e.set(G.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new $(uR.handleGetJobsByStartDate)),e.set(G.OPERATIONS_ENUM.GET_JOB,new $(uR.handleGetJob)),e.set(G.OPERATIONS_ENUM.GET_FINGERPRINT,new $(aR.getFingerprint)),e.set(G.OPERATIONS_ENUM.SET_LICENSE,new $(aR.setLicense)),e.set(G.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new $(aR.getRegistrationInfo)),e.set(G.OPERATIONS_ENUM.RESTART,new $(G0.restart)),e.set(G.OPERATIONS_ENUM.RESTART_SERVICE,new $(G0.restartService)),e.set(G.OPERATIONS_ENUM.CATCHUP,new $(Gte)),e.set(G.OPERATIONS_ENUM.SYSTEM_INFORMATION,new $(wte.systemInformation)),e.set(G.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new $(cs,rl.deleteAuditLogsBefore)),e.set(G.OPERATIONS_ENUM.READ_AUDIT_LOG,new $(Ste)),e.set(G.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new $(q0.createTokens)),e.set(G.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new $(q0.refreshOperationToken)),e.set(G.OPERATIONS_ENUM.LOGIN,new $(k0.login)),e.set(G.OPERATIONS_ENUM.LOGOUT,new $(k0.logout)),e.set(G.OPERATIONS_ENUM.GET_CONFIGURATION,new $(V0.getConfiguration)),e.set(G.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new $(Yt.customFunctionsStatus)),e.set(G.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new $(Yt.getCustomFunctions)),e.set(G.OPERATIONS_ENUM.GET_COMPONENT_FILE,new $(Yt.getComponentFile)),e.set(G.OPERATIONS_ENUM.GET_COMPONENTS,new $(Yt.getComponents)),e.set(G.OPERATIONS_ENUM.SET_COMPONENT_FILE,new $(Yt.setComponentFile)),e.set(G.OPERATIONS_ENUM.DROP_COMPONENT,new $(Yt.dropComponent)),e.set(G.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new $(Yt.getCustomFunction)),e.set(G.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new $(Yt.setCustomFunction)),e.set(G.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new $(Yt.dropCustomFunction)),e.set(G.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new $(Yt.addComponent)),e.set(G.OPERATIONS_ENUM.ADD_COMPONENT,new $(Yt.addComponent)),e.set(G.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new $(Yt.dropCustomFunctionProject)),e.set(G.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new $(Yt.packageComponent)),e.set(G.OPERATIONS_ENUM.PACKAGE_COMPONENT,new $(Yt.packageComponent)),e.set(G.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new $(Yt.deployComponent)),e.set(G.OPERATIONS_ENUM.DEPLOY_COMPONENT,new $(Yt.deployComponent)),e.set(G.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new $($0.readTransactionLog)),e.set(G.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new $(cs,$0.deleteTransactionLogsBefore)),e.set(G.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new $(Y0.installModules)),e.set(G.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new $(Y0.auditModules)),e.set(G.OPERATIONS_ENUM.GET_BACKUP,new $(Hs.getBackup)),e}a(Fte,"initializeOperationFunctionMap")});var rE=g((_he,tB)=>{"use strict";var dR=U(),qte=z(),il=K(),{handleHDBError:fR,hdb_errors:tE}=ne(),{isMainThread:kte}=require("worker_threads"),{Readable:Vte}=require("stream"),Z0=require("os"),$te=require("util"),Yte=YS(),Kte=$te.promisify(Yte.authorize),eB=j0(),{createGzip:Wte,constants:Qte}=require("zlib");function zte(e){let t=`Found an uncaught exception with message: ${e.message}. ${Z0.EOL}Stack: ${e.stack} ${Z0.EOL}Terminating ${kte?"HDB":"thread"}.`;console.error(t),il.fatal(t),process.exit(1)}a(zte,"handleServerUncaughtException");function Jte(e,t,r){if(il[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:tE.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(Jte,"serverErrorHandler");function Xte(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=fR(new Error,"Invalid JSON.",tE.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(qte.isEmpty(e.body.operation)){let n=fR(new Error,"Request body must include an 'operation' property.",tE.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Xte,"reqBodyValidationHandler");function jte(e,t,r){let n;e.body.operation!==dR.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==dR.OPERATIONS_ENUM.LOGIN&&e.body.operation!==dR.OPERATIONS_ENUM.LOGOUT?Kte(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{il.warn(s),il.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r(fR(s,i,tE.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(jte,"authHandler");async function Zte(e,t,r=!1){let n;try{r&&(e.body.operation!=="configure_cluster"||e.body.operation!=="set_configuration")&&(e.body.bypass_auth=r),n=eB.chooseOperation(e.body);let s=await eB.processLocalTransaction(e,n);if(s instanceof Vte&&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(Wte({level:Qte.Z_BEST_SPEED})))}return s}catch(s){throw il.error(s),s}}a(Zte,"handlePostRequest");tB.exports={authHandler:jte,handlePostRequest:Zte,handleServerUncaughtException:zte,serverErrorHandler:Jte,reqBodyValidationHandler:Xte}});var iB=g((fhe,sB)=>{"use strict";var ere=require("fastify-plugin"),{handlePostRequest:rB,authHandler:tre,reqBodyValidationHandler:rre}=rE();async function nre(e){e.decorate("hdbCore",{preValidation:[rre,tre],request:t=>nB(rB(t,response)),requestWithoutAuthentication:(t,r)=>nB(rB(t,r,!0))})}a(nre,"hdbCore");async function nB(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(nB,"convertAsyncIterators");sB.exports=ere(nre)});var cB=g((mhe,aB)=>{"use strict";var hhe=require("fs"),ER=re();ER.initSync();var{CONFIG_PARAMS:oB}=U(),sre=1024*1024*1024;function ire(e){let t=ER.get(oB.HTTP_TIMEOUT),r=ER.get(oB.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:sre,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,https:e}}a(ire,"getServerOptions");aB.exports=ire});var _B=g((She,lB)=>{"use strict";var hR=re();hR.initSync();var{CONFIG_PARAMS:uB}=U();function ore(){let e=hR.get(uB.HTTP_CORSACCESSLIST),t=hR.get(uB.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(ore,"getCORSOptions");lB.exports=ore});var EB=g((ghe,fB)=>{"use strict";var dB=re();dB.initSync();var are=U();function cre(){return dB.get(are.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(cre,"getHeaderTimeoutConfig");fB.exports=cre});var pR={};$e(pR,{customFunctionsServer:()=>_re,ready:()=>CB,start:()=>lre});function lre(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){xs||(xs=wB(t),je.http((await xs).server));let o=await xs,c=(0,mR.dirname)(s),u=(0,mR.dirname)(n);if(u.startsWith("/")&&(u=u.slice(1)),!hB.has(c)){hB.add(c);try{o.register(fre(c,u))}catch(_){if(_.message==="Root plugin has already booted")ke.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw _}}},ready:CB}}async function _re(){try{ke.info("In Custom Functions Fastify server"+process.cwd()),ke.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),ke.debug(`Custom Functions server process ${process.pid} starting up.`),await dre();let e=RB.get(AB.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=xs=await wB(e)}catch(r){throw ke.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw ke.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){ke.error(`Custom Functions ${process.pid} Error: ${e}`),ke.error(e),process.exit(1)}}async function dre(){try{ke.info("Custom Functions starting configuration."),await OB.setUsersToGlobal(),ke.info("Custom Functions completed configuration.")}catch(e){ke.error(e)}}function fre(e,t){return async function(r){try{ke.info("Custom Functions starting buildRoutes"),ke.trace("Loading fastify routes folder "+e),(0,mB.existsSync)(e)&&r.register(gB.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:ke.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?ke.error(s.message):s&&ke.error(s),o()})}catch(n){ke.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function wB(e){ke.info("Custom Functions starting buildServer.");let t=(0,bB.default)(e),r=(0,pB.default)(t);r.server.headersTimeout=(0,NB.default)(),r.setErrorHandler(IB.serverErrorHandler);let n=(0,yB.default)();return n&&r.register(SB.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,u){r.server.emit("unhandled",c.raw,u.raw)}),o()}),r.register(TB.default),await r.register(ure),await r.after(),bg(r),ke.info("Custom Functions completed buildServer."),r}function CB(){if(xs)return xs.then?xs.then(e=>e.ready()):xs.ready()}var mR,mB,pB,SB,TB,gB,RB,AB,ke,ure,OB,bB,yB,NB,IB,xs,hB,DB=Re(()=>{mR=require("path"),mB=require("fs"),pB=x(require("fastify")),SB=x(require("@fastify/cors")),TB=x(Hg()),gB=x(require("@fastify/autoload")),RB=x(re()),AB=x(U()),ke=x(K()),ure=x(iB()),OB=x(nn()),bB=x(cB()),yB=x(_B()),NB=x(EB()),IB=x(rE());ga();sr();hB=new Set;a(lre,"start");a(_re,"customFunctionsServer");a(dre,"setUp");a(fre,"buildRouteFolder");a(wB,"buildServer");a(CB,"ready")});var SR={};$e(SR,{start:()=>Ere});function Ere(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,vB.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){MB||(MB=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=LB.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,UB.default)(s,(0,PB.realpathSync)(o))}}return i(s)},{runFirst:!0})),LB.set(r,n)}}}var UB,PB,vB,LB,MB,BB=Re(()=>{UB=x(require("send")),PB=require("fs"),vB=x(require("serve-static")),LB=new Map;a(Ere,"start")});function pre(e,t=1,r){if(TR++,(0,Ao.startWorker)("server/threads/threadServer.js",{name:iE.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function u(_){_.type===iE.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",u),o(n))}a(u,"onMessage"),n.on("message",u),n.on("error",c)});mre.push(s),await s,Ba.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=sE.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Ba.indexOf(n);o>-1&&Ba.splice(o,1)}if(a(i,"removeWorker"),Ha){let o=Ha;Ha=[];for(let c of o)FB[c.localPort](null,c)}}}),r){let n=setInterval(()=>{gR?gR=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Ao.shutdownWorkers)(),TR=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function qB(e=0,t){if(typeof e=="string")try{(0,oE.existsSync)(e)&&(0,oE.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=Sre:r=Tre(t):r=AR;let n=(0,xa.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=FB[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),gR=!0,r(o,(c,u)=>{if(!c){if(HB){let l=o._socket||new xa.Socket({handle:o,writable:!0,readable:!0});HB.deliverSocket(l,e,u),l.resume()}else TR>0?(Ha.length===0&&setTimeout(()=>{Ha.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),o.localPort=e,Ha.push(o)):(console.log("start up a dynamic thread to handle request"),pre(0));xr(!1,"socket-routed");return}c.requests++;let _=o.fd;if(_>=0)c.postMessage({port:e,fd:_,data:u});else{let l=o._socket||new xa.Socket({handle:o,writable:!0,readable:!0});Ore(l,c,e)}xr(!0,"socket-routed")})};let s=Xc();RR.info(`HarperDB ${s.version} Server running on port ${e}`)}return n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function AR(e,t){let r,n=0;for(let s of Ba){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=nE)return nE=i,t(r);n=i}nE=0,t(r)}function Sre(e,t){let r={};e.getpeername(r);let n=r.address,s=Ga.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);AR(e,o=>{Ga.set(n,{worker:o,lastUsed:i}),t(o)})}function Tre(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new xa.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let u=o.toString("latin1").match(t)?.[1],_=Ga.get(u),l=Date.now();if(_&&_.worker.threadId!==-1)return _.lastUsed=l,s(_.worker);AR(n,d=>{Ga.set(u,{worker:d,lastUsed:l}),s(d,o)})})}a(r,"findByHeaderAffinity")}function Rre(){nE=0;for(let e of Ba)e.expectedIdle=e.recentELU.idle+gre,e.requests=1;Ba.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function Ore(e,t,r){let n=Are++;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(),sE.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")),sE.delete(n)),s.event=="destroy"&&(e.destroy(),sE.delete(n))})}var Ao,xa,iE,RR,oE,GB,hre,Ba,Ha,FB,HB,TR,mre,gR,nE,xB,Ga,gre,sE,Are,kB=Re(()=>{Ao=x(Ze()),xa=require("net"),iE=x(U()),RR=x(K()),oE=require("fs");Os();GB=require("worker_threads"),hre=x(Yi()),Ba=[],Ha=[],FB=[],TR=0,mre=[];GB.isMainThread&&process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)});a(pre,"startHTTPWorker");a(qB,"startSocketServer");nE=0;a(AR,"findMostIdleWorker");xB=36e5,Ga=new Map;a(Sre,"findByRemoteAddressAffinity");a(Tre,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of Ga)r.lastUsed+xB<e&&Ga.delete(t)},xB).unref();gre=1e3;a(Rre,"updateWorkerIdleness");(0,Ao.setMonitorListener)(Rre);sE=new Map,Are=1;a(Ore,"proxySocket")});var NR={};$e(NR,{Request:()=>OR,createReuseportFd:()=>aE});var VB,OR,bR,yR,aE,cE=Re(()=>{VB=require("os"),OR=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 yR(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 bR(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},bR=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}},yR=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)}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,VB.platform)()!="win32"&&(aE=require("node-unix-socket").createReuseportFd)});var WB=g((vhe,KB)=>{"use strict";var bre=require("cluster"),Oo=re();Oo.initSync();var YB=U(),Dhe=require("util"),Gs=K(),Lhe=require("fs"),yre=require("fastify"),Mhe=Xc(),Nre=require("@fastify/cors"),Ire=require("@fastify/compress"),wre=require("@fastify/static"),Cre=Hg(),Dre=require("path"),{PACKAGE_ROOT:Lre}=U(),Mre=Xs(),Ure=z(),Pre=nn(),vre=Yi(),{server:Bre}=(sr(),se(Ci)),{node_request_key:Uhe}=(cE(),se(NR)),{authHandler:Hre,handlePostRequest:xre,serverErrorHandler:Gre,reqBodyValidationHandler:Fre}=rE(),Phe=require("net"),{registerContentHandlers:qre}=(ga(),se(Cv)),kre=6e4,Vre=1024*1024*1024,$re="TRUE",{CONFIG_PARAMS:ol}=YB,Fa;KB.exports={hdbServer:$B,start:$B};async function $B(e){try{Gs.info("In Fastify server"+process.cwd()),Gs.info(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Gs.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=bre.isMaster,await Yre();let t=e.securePort>0;Fa=Kre(t),await Fa.ready(),e||(e={}),e.isOperationsServer=!0;try{Bre.http(Fa.server,e),Fa.server.closeIdleConnections||await Fa.listen({port:0,host:"::"})}catch(r){throw Fa.close(),Gs.error(r),Gs.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Gs.fatal(t),process.exit(1)}}a($B,"operationsServer");async function Yre(){Gs.trace("Configuring HarperDB process."),Mre.setSchemaDataToGlobal(),await Pre.setUsersToGlobal(),await vre.getLicense()}a(Yre,"setUp");function Kre(e){Gs.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=Wre(e),r=yre(t);r.server.headersTimeout=zre(),r.setErrorHandler(Gre);let n=Qre();n&&r.register(Nre,n),r.register(function(i,o,c){i.setNotFoundHandler(function(u,_){r.server.emit("unhandled",u.raw,_.raw)}),c()}),r.register(Cre),r.register(Ire),r.register(wre,{root:Dre.join(Lre,"studio/build-local")}),qre(r);let s=Oo.get(YB.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!Ure.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[Fre,Hre],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),xre(i,o)}),r.get("/health",()=>"HarperDB is running."),Gs.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(Kre,"buildServer");function Wre(e){let t=Oo.get(ol.OPERATIONSAPI_NETWORK_TIMEOUT),r=Oo.get(ol.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:Vre,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(Wre,"getServerOptions");function Qre(){let e=Oo.get(ol.OPERATIONSAPI_NETWORK_CORS),t=Oo.get(ol.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===$re)&&(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(Qre,"getCORSOpts");function zre(){return Oo.get(ol.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??kre}a(zre,"getHeaderTimeoutConfig")});var MR={};$e(MR,{disableNATS:()=>Xre,publishToStream:()=>_E,setNATSReplicator:()=>IR,setPublishToStream:()=>jre,setSubscription:()=>LR,start:()=>Jre});function Jre(){al.default.get(cl.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&ene()}function Xre(e=!0){jB=e}function jre(e,t){_E=e,LR=t}function ene(){if(jB||process.env._DISABLE_NATS)return;let e=Dn(),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];IR(s,r,i)}}UR((r,n)=>{IR(r.tableName,r.databaseName,r),n&&eH(r)}),!QB&&(QB=!0)}function IR(e,t,r){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 Gt{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this[Me],record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this[Me]})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this[Me],record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this[Me],record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this[Me]})}static defineSchema(i){eH(i)}static subscribe(){let i=new Rn;return LR(t,e,i),i}static subscribeOnThisThread(i){return i<(al.default.get(cl.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??Zre)}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 uE(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=ZB;return i}a(n,"getNATSTransaction")}function eH(e){let t=al.default.get(cl.default.CONFIG_PARAMS.CLUSTERING_NODENAME);_E(`${CR.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,DR.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 zB,CR,DR,JB,XB,al,cl,lE,jB,_E,LR,Zre,ZB,QB,uE,wR,tH=Re(()=>{Ae();An();zB=x(bt()),CR=x(rt()),DR=x(Ss());fc();JB=x(lS()),XB=x(Ir()),al=x(re()),cl=x(U()),lE=x(K());a(Jre,"start");a(Xre,"disableNATS");_E=zB.publishToStream,LR=JB.setSubscription;a(jre,"setPublishToStream");Zre=2;a(ene,"assignReplicationSource");a(IR,"setNATSReplicator");a(eH,"publishSchema");uE=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=al.default.get(cl.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],u,_;for(let l of i){let d=l.table,f=l.operation=="put"?"upsert":l.operation;u||(lE.trace(`Sending transaction event ${f}`),_=u={operation:f,schema:s,table:d,__origin:{user:this.user?.username,timestamp:t,node_name:r}},u.hash_values=c,f!=="delete"&&f!=="invalidate"&&(u.records=o)),u.table===d&&u.operation===f?(o.push(l.record),c.push(l.id)):_=_.next={operation:f,table:d,id:l.id,record:l.record},l.expiresAt&&(_.expiresAt=l.expiresAt)}u&&n.push(_E(`${CR.SUBJECT_PREFIXES.TXN}.${s}.${u.table}`,(0,DR.createNatsTableStreamName)(s,u.table),void 0,u)?.catch(l=>{throw lE.error("An error has occurred trying to replicate transaction",u,l),l.statusCode=504,l}))}return Promise.all(n)}},wR=class extends uE{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,XB.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};ZB=new wR});async function iH({clientId:e,user:t,clean:r,will:n}){let s;if(e&&!r){let i=await PR.get(e,{returnNonexistent:!0});s=new HR(e,t,i),i&&(s.sessionWasPresent=!0)}else{if(e){let i=await PR.get(e);i&&i.delete()}s=new fE(e,t)}return n&&(n.id=e,n.user={username:t?.username},ul.put(n)),s}function vR(){return dE++,dE>65500&&(dE=1),dE}function BR(e,t,r=e){let{topic:n,retain:s}=e;e.data=t,e.async=!0,e.authorize=!0;let i=Ei.getMatch(n);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 ze(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var rH,Ai,nH,sH,PR,ul,dE,fE,HR,oH=Re(()=>{Ae();Pu();rH=x(Ir()),Ai=x(K());Xi();nH=x(Ze()),sH=x(aH());sr();PR=at({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"}]}}]}),ul=at({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,nH.getWorkerIndex)()===0&&(async()=>{await sH.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of ul.search({})){let t=e.data,r=Object.assign({},e);r.user?.username&&(r.user=await je.getUser(r.user.username)),ze(r,()=>{try{BR(r,t)}catch{(0,Ai.warn)("Failed to publish will",t)}ul.delete(e.id,r)})}})();a(iH,"getSession");dE=1;a(vR,"getNextMessageId");fE=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;subscriptions=[];awaitingAcks;sessionWasPresent;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("?"),u,_;if(c>-1?(u=s.slice(c),_=s.slice(0,c)):_=s,!_)throw new Error("No topic provided");if(_.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let l=this.subscriptions.find(T=>T.topic===s),d;l?(d=i>0,l.end(),this.subscriptions.splice(this.subscriptions.indexOf(l),1)):d=i===2;let f={search:u,async:!0,authorize:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,Ai.trace)("Resuming subscription from",s,"from",o);let E=Ei.getMatch(_);if(!E){let T=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw T.statusCode=404,T}if(f.url=E.relativeURL,f.url.indexOf("+")>-1||f.url.indexOf("#")>-1){let T=f.url.slice(1);if(T.indexOf("#")>-1&&T.indexOf("#")!==T.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(f.isCollection=!0,T.indexOf("+")===T.length-1)f.onlyChildren=!0,f.url="/"+T.slice(0,T.length-1);else{let b=T.split("/"),R;for(let P=0;P<b.length;P++)if(b[P].indexOf("+")>-1)if(b[P]==="+")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 L=!0;b[b.length-1]==="#"&&(b.length--,L=!1),R&&(n=a(P=>{let k=P.id;if(!Array.isArray(k)||L&&k.length!==b.length)return!1;for(let B=0;B<b.length;B++)if(b[B]!=="+"&&b[B]!==k[B])return!1;return!0},"filter"));let H=b.indexOf("+");f.url="/"+(H>-1?b.slice(0,H):b).concat("").join("/")}}let h=E.path,p=E.Resource,S=await ze(f,async()=>{let T=await p.subscribe(f);if(!T)throw new Error(`No subscription was returned from subscribe for topic ${s}`);if(!T[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);return(async()=>{for await(let b of T)try{let R;if(b.type&&b.type!=="put"&&b.type!=="delete"&&b.type!=="message"&&b.type!=="patch"||n&&!n(b))continue;r?(b.topic=s,R=this.needsAcknowledge(b)):(b.acknowledge?.(),R=vR());let L=b.id;Array.isArray(L)&&(L=Sa(L)),L==null&&(L=""),this.listener(h+"/"+L,b.value,R,t)}catch(R){(0,Ai.warn)(R)}})(),T});return S.topic=s,S.qos=t.qos,this.subscriptions.push(S),S}resume(){}needsAcknowledge(t){let r=vR();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,t.acknowledge)),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),!0}async publish(t,r){return t.user=this.user,BR(t,r)}setListener(t){this.listener=t}disconnect(t){let r={};ze(r,async()=>{if(!t){let n=await ul.get(this.sessionId,r);n?.doesExist()&&await BR(n,n.data,r)}await ul.delete(this.sessionId,r)}).catch(n=>{(0,Ai.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}};a(BR,"publish");HR=class extends fE{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.timestamp):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=vR(),n={topic:t.topic,timestamp:t.timestamp};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks.get(t);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,Ai.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.sessionRecord.subscriptions=this.subscriptions.map(i=>{let o=i.startTime;return o||(o=i.startTime=(0,rH.getNextMonotonicTime)()),(0,Ai.trace)("Added durable subscription",i.topic,o),{qos:i.qos,topic:i.topic,startTime:o}}),PR.put(this.sessionRecord)),t.qos}}});var FR={};$e(FR,{bypassAuth:()=>tne,start:()=>rne});function tne(){_H=!0}function rne({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){let o=e.mqtt={requireAuthentication:i,sessions:new Set},c,u=r?.mtls;return n&&(c=e.ws((_,l,d)=>{if(_.protocol==="mqtt"){$r.debug("Received WSS connection for MQTT from",_._socket.remoteAddress);let{onMessage:f,onClose:E}=uH(_,(h,p)=>{if(_.send(h),p&&_._socket.writableNeedDrain)return new Promise(S=>this._socket.once("drain",S))},l,Promise.resolve(d).then(()=>l?.user),o);_.on("message",f),_.on("close",E),_.on("error",h=>{$r.info("WebSocket error",h)})}},Object.assign({subProtocol:"mqtt"},n))),(t||s)&&(c=e.socket(async _=>{let l;if($r.debug("Received connection for MQTT from",_.remoteAddress),u){if(_.authorized)try{let E=u.user;E!==null?((E===void 0||E==="Common Name"||E==="CN")&&(E=_.getPeerCertificate().subject.CN),l=await e.getUser(E,null,null),(0,ll.get)(Yr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&xR.notify({username:l.username,status:Yr.AUTH_AUDIT_STATUS.SUCCESS,type:Yr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:_.remoteAddress})):$r.debug("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",_.remoteAddress)}catch(E){$r.error(E)}else if(u.required)return $r.info(`Unauthorized connection attempt, no authorized client certificate provided, error: ${_.authorizationError}`),_.end()}!l&&_H&&_.remoteAddress.includes("127.0.0.1")&&(l=await(0,lH.getSuperUser)(),$r.debug("Auto-authorizing local connection",l?.username));let{onMessage:d,onClose:f}=uH(_,E=>_.write(E),null,l,o);_.on("data",d),_.on("close",f),_.on("error",E=>{$r.info("Socket error",E)})},{port:t,securePort:s,mtls:u})),c}function uH(e,t,r,n,s){cH||(cH=!0,tu(d=>{EE>0&&d.push({metric:"mqtt-connections",connections:EE,byThread:!0})}));let i;EE++;let o,c={protocolVersion:4},u=(0,hE.parser)({protocolVersion:5});function _(d){u.parse(d)}a(_,"onMessage");function l(){EE--,i||(i=!0,o?.disconnect(),s.sessions.delete(o),sn(!1,"connection","mqtt","disconnect"))}return a(l,"onClose"),u.on("packet",async d=>{n?.then&&(n=await n),o?.then&&await o;try{switch(d.cmd){case"connect":if(c.protocolVersion=d.protocolVersion,d.username)try{n=await je.getUser(d.username,d.password.toString(),r),(0,ll.get)(Yr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&xR.notify({username:n.username,status:Yr.AUTH_AUDIT_STATUS.SUCCESS,type:Yr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch{return(0,ll.get)(Yr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&xR.error({username:n.username,status:Yr.AUTH_AUDIT_STATUS.FAILURE,type:Yr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),f({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return sn(!1,"connection","mqtt","connect"),f({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let R=e.deserialize||(e.deserialize=mo(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?R(d.will.payload):void 0,delete d.will.payload}o=iH({user:n,...d}),o=await o,s.sessions.add(o)}catch(R){return $r.error(R),sn(!1,"connection","mqtt","connect"),f({cmd:"connack",reasonCode:R.code||5,returnCode:R.code||128})}sn(!0,"connection","mqtt","connect"),f({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((R,L,H,P)=>{try{let k=R.indexOf("/",1),B=k>0?R.slice(0,k):R;f({cmd:"publish",topic:R,payload:E(L),messageId:H||Math.floor(Math.random()*1e8),qos:P.qos},B)}catch(k){$r.error(k),o?.disconnect(),s.sessions.delete(o)}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let h=[];for(let R of d.subscriptions){let L;try{L=(await o.addSubscription(R,R.qos>=1)).qos||0}catch(H){$r.error(H),L=c.protocolVersion<5?128:H.statusCode===403?135:H.statusCode===404?143:128}h.push(L)}await o.committed,f({cmd:"suback",granted:h,messageId:d.messageId});break;case"unsubscribe":{let R=[];for(let L of d.unsubscriptions)R.push(o.removeSubscription(L)?0:17);f({cmd:"unsuback",granted:R,messageId:d.messageId});break}case"pubrel":f({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let p=d.qos===2?"pubrec":"puback",S=e.deserialize||(e.deserialize=mo(r?.headers.get?.("content-type"))),T=d.payload?.length>0?S(d.payload):void 0,b;try{b=await o.publish(d,T)}catch(R){$r.warn(R),d.qos>0&&f({cmd:p,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&f({cmd:p,messageId:d.messageId,reasonCode:b===!1?144:0},d.topic);break;case"pubrec":f({cmd:"pubrel",messageId:d.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(d.messageId);break;case"pingreq":f({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.sessions.delete(o),sn(!0,"connection","mqtt","disconnect"),e.close?e.close():e.end();break}}catch(h){$r.error(h),f({cmd:"disconnect"})}function f(h,p){let S=(0,hE.generate)(h,c);t(S),xr(S.length,"bytes-sent",p,h.cmd,"mqtt")}a(f,"sendPacket");function E(h){return mi(h,r)}a(E,"serialize")}),{onMessage:_,onClose:l}}var hE,lH,ll,Yr,GR,xR,$r,_H,cH,EE,dH=Re(()=>{hE=require("mqtt-packet");oH();lH=x(nn());ga();Os();sr();ll=x(re()),Yr=x(U()),GR=x(K()),xR=(0,GR.loggerWithTag)("auth-event"),$r=(0,GR.loggerWithTag)("mqtt"),_H=(0,ll.get)(Yr.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(tne,"bypassAuth");a(rne,"start");EE=0;a(uH,"onSocket")});var hf={};$e(hf,{component_errors:()=>ka,loadComponent:()=>mE,loadComponentDirectories:()=>RH,setErrorReporter:()=>one});function RH(e,t){t&&(kR=t),e&&(VR=e);let r=[];if((0,Gn.existsSync)(qR)){let s=(0,Gn.readdirSync)(qR,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,St.join)(qR,o);r.push(mE(c,kR,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(mE(n,kR,n,!1,null,process.env.DEV_MODE)),Promise.all(r).then(()=>{gH=!0})}function one(e){dl=e}async function mE(e,t,r,n,s,i){if(!EH.has(e)){EH.set(e,!0),s&&(VR=s);try{let o;n&&(ka=new Map);let c=(0,St.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,Gn.existsSync)(c)?o=n?(0,TH.getConfigObj)():(0,hH.parseDocument)((0,Gn.readFileSync)(c,"utf8"),{simpleKeys:!0}).toJSON():o=$R;let u=[],_=n;for(let l in o){let d=o[l];if(ka.set(n?l:(0,St.basename)(e),!1),!d)continue;let f,E=d.package;try{if(E){let b=e,R;for(;!(0,Gn.existsSync)(R=(0,St.join)(b,"node_modules",l));)if(b=(0,St.dirname)(b),b.length<(0,SH.getHdbBasePath)().length){R=null;break}if(R)f=await mE(R,t,r,!1),_=!0;else throw new Error(`Unable to find package ${l}:${E}`)}else f=ine[l];if(!f)continue;u.push(f);let h=a(b=>(b.origin=r,at(b)),"ensureTable"),p=d.network||(d.port||d.securePort)&&d,S=p?.securePort||p?.https&&p.port,T=!p?.https&&p?.port;if(qa.isMainThread&&(f=await f.startOnMainThread?.({server:je,ensureTable:h,port:T,securePort:S,resources:t,...d})||f,n&&p))for(let b of[T,S])try{if(+b&&!fH.includes(b)){let R=YR.get(KR.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);R&&_l.default.warn("Session affinity is not recommended and may cause memory leaks"),(R||!aE)&&(fH.push(b),qB(b,R))}}catch(R){console.error("Error listening on socket",b,R,l)}if(t.isWorker&&(f=await f.start?.({server:je,ensureTable:h,port:T,securePort:S,resources:t,...d})||f),VR.set(f,!0),(f.handleFile||f.handleDirectory)&&d.files){if(d.files.includes(".."))throw(0,pH.handleHDBError)("Can not reference parent directories");let b=(0,St.join)(e,d.files).replace(/\\/g,"/"),R=b.indexOf("/*");if(R>-1&&d.files!==$R[l]?.files&&!(0,Gn.existsSync)(b.slice(0,R)))throw new Error(`The path '${b.slice(0,R)}' does not exist and cannot be used as the base of the resolved 'files' path value '${d.files}'`);let L=(0,St.basename)(e),H=d.path||"/";H=H.startsWith("/")?H:H.startsWith("./")?"/"+L+H.slice(2):H==="."?"/"+L:"/"+L+"/"+H;let P,k,B;if(d.root){let Q=d.root;Q.startsWith("/")&&(Q=Q.slice(1)),Q.endsWith("/")&&(Q=Q.slice(0,-1)),Q+="/",k=(0,St.join)(e,Q)}else(B=b.indexOf("/*"))>-1&&(k=b.slice(0,B+1),P=(0,St.relative)(e,k));let J=!1;if(qa.isMainThread&&f.setupDirectory&&(J=await f.setupDirectory?.(H,k,t)),t.isWorker&&f.handleDirectory&&(J=await f.handleDirectory?.(H,k,t)),J)continue;for(let Q of await(0,mH.default)(b,{onlyFiles:!1,objectMode:!0})){let{path:X,dirent:Te}=Q;_=!0;let ce=(0,St.relative)(e,X).replace(/\\/g,"/");if(P)if(ce.startsWith(P))ce=ce.slice(P.length+1);else throw new Error(`The root path '${d.root}' does not reference a valid part of the file path '${ce}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let de=H+(H.endsWith("/")?"":"/")+ce;try{if(Te.isFile()){let Le=await sne(X);qa.isMainThread&&await f.setupFile?.(Le,de,X,t),t.isWorker&&await f.handleFile?.(Le,de,X,t)}else qa.isMainThread&&await f.setupDirectory?.(de,X,t),t.isWorker&&await f.handleDirectory?.(de,X,t)}catch(Le){Le.message=`Could not load ${Te.isFile()?"file":"directory"} '${X}'${d.module?" using '"+d.module+"'":""} for application '${e}' due to: ${Le.message}`,dl?.(Le),((0,Va.getWorkerIndex)()===0?console:_l.default).error(Le),t.set(d.path||"/",new fl(Le)),ka.set(n?l:(0,St.basename)(e),Le.message)}}}}catch(h){h.message=`Could not load component '${l}' for application '${(0,St.basename)(e)}' due to: ${h.message}`,dl?.(h),((0,Va.getWorkerIndex)()===0?console:_l.default).error(h),t.set(d.path||"/",new fl(h),null,!0),ka.set(n?l:(0,St.basename)(e),h.message)}}if(qa.isMainThread&&!gH&&i&&(0,Va.watchDir)(e,async()=>RH()),o.extensionModule)return await Wl((0,St.join)(e,o.extensionModule));if(!_&&t.isWorker){let l=`${e} did not load any modules, resources, or files, is this a valid component?`;dl?.(new Error(l)),((0,Va.getWorkerIndex)()===0?console:_l.default).error(l),ka.set((0,St.basename)(e),l)}}catch(o){console.error(`Could not load application directory ${e}`,o),o.message=`Could not load application due to ${o.message}`,dl?.(o),t.set("",new fl(o))}}}var Gn,St,qa,hH,YR,KR,mH,Va,_l,pH,SH,nne,TH,sne,qR,VR,gH,kR,ka,ine,$R,fH,EH,dl,fl,mf=Re(()=>{Gn=require("fs"),St=require("path"),qa=require("worker_threads"),hH=require("yaml"),YR=x(re()),KR=x(U());$O();QO();zO();Vv();DB();BB();mH=x(require("fast-glob")),Va=x(Ze()),_l=x(K());yh();sr();pH=x(ne());An();Ae();kB();SH=x(re()),nne=x(WB());af();tH();dH();TH=x(Ur());cE();({readFile:sne}=Gn.promises),qR=YR.get(KR.CONFIG_PARAMS.COMPONENTSROOT),VR=new Map,ka=new Map;a(RH,"loadComponentDirectories");ine={REST:Pf,rest:Pf,graphqlSchema:bh,jsResource:Ih,fastifyRoutes:pR,login:Ch,static:SR,operationsApi:nne,customFunctions:{},http:{},clustering:MR,authentication:Bu,mqtt:FR},$R={rest:!0,graphqlSchema:{files:"*.graphql"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty($R,"static",{value:{files:"web/**"}});fH=[],EH=new Map;a(one,"setErrorReporter");a(mE,"loadComponent");fl=class extends Gt{constructor(r){super();this.error=r}static{a(this,"ErrorResource")}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 QR=g((_me,OH)=>{var{isMainThread:AH}=require("worker_threads"),{getTables:ane}=(Ae(),se(Fe)),{loadComponentDirectories:cne,loadComponent:une}=(mf(),se(hf)),{resetResources:lne}=(Pu(),se(jU)),_ne=XT(),dne=Ur(),{dirname:fne}=require("path"),{getConnection:Ene}=bt(),hne=re(),mne=U(),WR=new Map;async function pne(e=!1){!AH&&hne.get(mne.CONFIG_PARAMS.CLUSTERING_ENABLED)&&Ene();try{AH&&await _ne()}catch(n){console.error(n)}let t=lne();ane(),t.isWorker=e,await une(fne(dne.getConfigFilePath()),t,"hdb",!0,WR),await cne(WR,t);let r=[];for(let[n]of WR)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(pne,"loadRootComponents");OH.exports.loadRootComponents=pne});var Ze=g((fme,bi)=>{"use strict";var{Worker:Sne,MessageChannel:Tne,parentPort:us,isMainThread:ZR,threadId:gne,workerData:Fs}=require("worker_threads"),{PACKAGE_ROOT:Rne}=U(),{join:IH,isAbsolute:Ane,extname:One}=require("path"),{server:wH}=(sr(),se(Ci)),{watch:bne,readdir:yne}=require("fs/promises"),{totalmem:bH}=require("os"),El=U(),CH=re(),qs=K(),{randomBytes:Nne}=require("crypto"),{_assignPackageExport:Ine}=require("../../index"),wne=U(),yH=1024*1024,Oi=[],fn=[],Cne=50,eA=1e4,Dne="restart",DH="request_thread_info",LH="resource_report",MH="thread_info",UH="added-port",Lne="ack",zR;Ine("threads",fn);bi.exports={startWorker:JR,restartWorkers:rA,shutdownWorkers:Bne,workers:Oi,setMonitorListener:$ne,onMessageFromWorkers:Hne,onMessageByType:FH,broadcast:Gne,broadcastWithAcknowledgement:qne,setChildListenerByType:vne,getWorkerIndex:PH,getWorkerCount:vH,getTicketKeys:HH,setMainIsWorker:Une,setTerminateTimeout:Mne,restartNumber:Fs?.restartNumber||1};fn.onMessageByType=FH;fn.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=fn.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};var tA;function Mne(e){eA=e}a(Mne,"setTerminateTimeout");function PH(){return Fs?Fs.workerIndex:tA?0:void 0}a(PH,"getWorkerIndex");function vH(){return Fs?Fs.workerCount:tA?1:void 0}a(vH,"getWorkerCount");function Une(e){tA=e}a(Une,"setMainIsWorker");var BH=1,pE;function HH(){return pE||(pE=ZR?Nne(48):Fs.ticketKeys,pE)}a(HH,"getTicketKeys");Object.defineProperty(wH,"workerIndex",{get(){return PH()}});Object.defineProperty(wH,"workerCount",{get(){return vH()}});var xH={[DH](e,t){kne(t)},[LH](e,t){Vne(t,e)}};function JR(e,t={}){let r=process.constrainedMemory?.()||bH();r=Math.min(r,bH(),2e4*yH);let n=CH.get(El.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/yH/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let u of fn){let _=new Tne;_.existingPort=u,i.push(_),o.push(_.port2)}One(e)||(e+=".js");let c=new Sne(Ane(e)?e:IH(Rne,e),Object.assign({resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(u=>u.existingPort.threadId),workerIndex:t.workerIndex,workerCount:BH=t.threadCount,name:t.name,restartNumber:bi.exports.restartNumber,ticketKeys:HH()},transferList:o},t));for(let{port1:u,existingPort:_}of i)_.postMessage({type:UH,port:u,threadId:c.threadId},[u]);return TE(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>JR(e,t),c.on("error",u=>{console.error("Worker error:",u),qs.error("Worker error:",u)}),c.on("exit",u=>{Oi.splice(Oi.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<Cne?(t.unexpectedRestarts=c.unexpectedRestarts+1,JR(e,t)):qs.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",u=>{xH[u.type]?.(u,c)}),Oi.push(c),Kne(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(JR,"startWorker");var Pne=[El.THREAD_TYPES.HTTP];async function rA(e=null,t=Math.max(BH>3,1),r=!0){if(ZR){if(r){let{loadRootComponents:o}=QR();await o()}bi.exports.restartNumber++,t<1&&(t=t*Oi.length);let n=[],s=[];for(let o of Oi.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;qs.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:bi.exports.restartNumber,type:El.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=Pne.indexOf(o.name)>-1,u=new Promise(_=>{let l=setTimeout(()=>o.terminate(),eA*2).unref();o.on("exit",()=>{clearTimeout(l),n.splice(n.indexOf(u)),!c&&r&&o.startCopy(),_()})});if(n.push(u),c&&r){let _=o.startCopy(),l=new Promise(d=>{let f=a(E=>{E.type===wne.ITC_EVENT_TYPES.CHILD_STARTED&&(qs.trace("Worker has started",_.threadId),d(),s.splice(s.indexOf(l)),_.off("message",f))},"startListener");qs.trace("Waiting for worker to start",_.threadId),_.on("message",f)});s.push(l),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}=rf();r&&(e==="http"||!e)&&CH.get(El.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else us.postMessage({type:Dne,workerType:e})}a(rA,"restartWorkers");function vne(e,t){xH[e]=t}a(vne,"setChildListenerByType");function Bne(e){return rA(e,1/0,!1)}a(Bne,"shutdownWorkers");var GH=[];function Hne(e){GH.push(e)}a(Hne,"onMessageFromWorkers");var XR=new Map;function FH(e,t){let r=XR.get(e);r||XR.set(e,r=[]),r.push(t)}a(FH,"onMessageByType");var xne=10;async function Gne(e){let t=0;for(let r of fn)try{r.postMessage(e),t++>xne&&(t=0,await new Promise(setImmediate))}catch(n){qs.error("Unable to send message to worker",n)}}a(Gne,"broadcast");var SE=new Map,Fne=1;function qne(e){return new Promise(t=>{let r=0;for(let n of fn)try{let s=Fne++,i=a(()=>{SE.delete(s),--r===0&&t(),n!==us&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,SE.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of SE)o.port===n&&o()})),n.postMessage(e),r++}catch(s){qs.error("Unable to send message to worker",s)}r===0&&t()})}a(qne,"broadcastWithAcknowledgement");function kne(e){e.postMessage({type:MH,workers:qH()})}a(kne,"sendThreadInfo");function qH(){let e=Date.now();return Oi.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(qH,"getChildWorkerInfo");function Vne(e,t){e.resources=t,e.resources.updated=Date.now()}a(Vne,"recordResourceReport");var jR;function $ne(e){jR=e}a($ne,"setMonitorListener");var Yne=1e3,NH=!1;function Kne(){NH||(NH=!0,setInterval(()=>{for(let e of Oi){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}jR&&jR()},Yne).unref())}a(Kne,"startMonitoring");var Wne=1e3;if(us){TE(us);for(let e=0,t=Fs.addPorts.length;e<t;e++){let r=Fs.addPorts[e];r.threadId=Fs.addThreadIds[e],TE(r)}setInterval(()=>{let e=process.memoryUsage();us.postMessage({type:LH,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},Wne).unref(),zR=a(()=>new Promise((e,t)=>{us.on("message",r),us.postMessage({type:DH});function r(n){n.type===MH&&(us.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else zR=qH;bi.exports.getThreadInfo=zR;function TE(e,t){fn.push(e),e.on("message",r=>{if(r.type===UH)r.port.threadId=r.threadId,TE(r.port);else if(r.type===Lne){let n=SE.get(r.id);n&&n()}else{for(let s of GH)s(r,e);let n=XR.get(r.type);if(n)for(let s of n)try{s(r,e)}catch(i){qs.error(i)}}}).on("close",()=>{fn.splice(fn.indexOf(e),1)}).on("exit",()=>{fn.splice(fn.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(TE,"addPort");if(ZR){let e,t,r=a(async(n,s)=>{s&&(e=s);for(let i of await yne(n,{withFileTypes:!0}))i.isDirectory()&&i.name!=="node_modules"&&r(IH(n,i.name));try{for await(let{filename:i}of bne(n,{persistent:!1}))t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await rA(),console.log("Reloaded HarperDB components")},100)}catch(i){console.warn("Error trying to watch component directory",n,i)}},"watch_dir");bi.exports.watchDir=r,process.env.WATCH_DIR&&r(process.env.WATCH_DIR)}else us.on("message",async e=>{let{type:t}=e;t===El.ITC_EVENT_TYPES.SHUTDOWN&&(bi.exports.restartNumber=e.restartNumber,us.unref(),setTimeout(()=>{qs.warn("Thread did not voluntarily terminate",gne),process.exit(0)},eA).unref())})});var tC={};$e(tC,{AUDIT_STORE_OPTIONS:()=>XH,createAuditEntry:()=>jl,openAuditStore:()=>OE,readAuditEntry:()=>Dt,setAuditRetention:()=>zne,transactionKeyEncoder:()=>JH});function OE(e){let t=e.auditStore=e.openDB(WH.AUDIT_STORE_NAME,XH);t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,{remove(){delete r[i]}}};let n=null;function s(i=gE){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed")return;let o=0,c;try{for(let{key:u,value:_}of t.getRange({start:0,snapshot:!1,end:Date.now()-nA})){if((_[0]&15)===oA){let l=Dt(_),d=l.tableId;r[d]?.(l.recordId)}if(c=t.remove(u),await new Promise(setImmediate),++o>=Qne){i=10;break}}await c}finally{o===0&&(i=Math.min(i<<1,nA/10)),s(i)}},i).unref()}return a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,AE.getWorkerIndex)()===(0,AE.getWorkerCount)()-1&&s(gE),t}function zne(e,t=gE){nA=e,gE=t}function jl(e,t,r,n,s,i,o){let c=jH[i];if(!c)throw new Error(`Invalid audit entry type ${i}`);let u=1;n&&(n>1?$a.setFloat64(0,n):En.set(Kh),u=9),f(0),f(t),d(r),$a.setFloat64(u,e),u+=8,s?d(s):En[u++]=0,En[n?8:0]=c;let l=En.subarray(0,u);if(o)return Buffer.concat([l,o]);return l;function d(E){let h=u;u+=1,u=(0,Ya.writeKey)(E,En,u);let p=u-h-1;p>127?p>16383?(cA.error("Key or username was too large for audit entry",E),u=h+1,En[h]=0):(En.copyWithin(h+2,h+1,u),$a.setUint16(h,p|32768),u++):En[h]=p}function f(E){E<128?En[u++]=E:E<16384?($a.setUint16(u,E|32768),u+=2):E<1056964608?($a.setUint32(u,E|3221225472),u+=4):(En[u]=255,$a.setUint32(u+1,E),u+=5)}}function Dt(e){try{let t=e.dataView||(e.dataView=new aA(e.buffer,e.byteOffset,e.byteLength)),r;e[0]==66&&(r=t.readFloat64());let n=t.readInt(),s=t.readInt(),i=t.readInt(),o=t.readInt(),c=t.position,u=t.position+=o,_=t.readFloat64();o=t.readInt();let l=t.position,d=t.position+=o;return{type:jH[n&7],tableId:i,get recordId(){return KH(e,c,u)},version:_,previousLocalTime:r,get user(){return d>l?KH(e,l,d):void 0},getValue(f,E,h){if(n&sA||n&iA&&!E)return f.decoder.decode(e.subarray(t.position));if(n&iA&&h)return uA(f.getEntry(this.recordId),h,f)}}}catch{return cA.error("Reading audit entry error",e),{}}}function KH(e,t,r){let n=e.subarray(t,r);return(0,Ya.readKey)(n,0,r-t)}var Ya,RE,WH,QH,AE,zH,cA,En,$a,JH,XH,nA,Qne,gE,sA,iA,kH,oA,VH,$H,YH,jH,aA,Mi=Re(()=>{Ya=require("ordered-binary"),RE=x(re()),WH=x(_t()),QH=x(U()),AE=x(Ze()),zH=x(z());Ho();cA=x(K());bE();(0,RE.initSync)();En=Buffer.alloc(1024),$a=new DataView(En.buffer,En.byteOffset,1024),JH={writeKey(e,t,r){return e===Tc?(t.set(Tc,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Ya.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,Ya.readKey)(e,t,r)}},XH={encoding:"binary",keyEncoder:JH},nA=(0,zH.convertToMS)((0,RE.get)(QH.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,Qne=1e3,gE=1e4;a(OE,"openAuditStore");a(zne,"setAuditRetention");sA=16,iA=32,kH=1,oA=2,VH=3,$H=4,YH=5,jH={put:kH|sA,[kH]:"put",delete:oA,[oA]:"delete",message:VH|sA,[VH]:"message",invalidate:$H,[$H]:"invalidate",patch:YH|iA,[YH]:"patch"};a(jl,"createAuditEntry");a(Dt,"readAuditEntry");aA=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t=this.getUint8(this.position++);return 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{debugger}}};a(KH,"readKeySafely")});var lA={};$e(lA,{add:()=>yE,applyReverse:()=>ZH,getRecordAtTime:()=>uA,rebuildUpdateBefore:()=>NE});function yE(e,t,r){isNaN(e[t])?e[t]=r.value:e[t]+=r.value}function NE(e,t){let r=null;for(let n in e)if(n in t){let s=t[n];if(s?.__op__){let i=e[n];if(i?.__op__)if(i.__op__===s.__op__)r||(r={}),r[n]=i;else throw new Error("Can not merge updates with different operations");else r||(r={}),r[n]=i,yE(r,n,s)}}else r||(r={}),r[n]=e[n];return r}function ZH(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Jne[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=ex}}function uA(e,t,r){let n=r.rootStore.auditStore,s=Object.assign({},e.value),i=e.localTime;for(;i>t;){let u=n.get(i),_=Dt(u);switch(_.type){case"put":s=_.getValue(r);break;case"patch":ZH(s,_.getValue(r));break;case"delete":s=null}i=_.previousLocalTime}let o={},c=0;for(let u in s)s[u]===ex&&(o[u]=!0,c++);for(;c>0&&i>0;){let u=n.get(i),_=Dt(u),l;switch(_.type){case"put":l=_.getValue(r);break;case"patch":l=_.getValue(r);break}for(let d in l)o[d]&&(s[d]=l[d],o[d]=!1,c--);i=_.previousLocalTime}if(c>0)for(let u in o)s[u]=null;return s}var Jne,ex,bE=Re(()=>{Mi();a(yE,"add");yE.reverse=function(e,t,r){isNaN(e[t])||(e[t]-=r.value)};Jne={add:yE};a(NE,"rebuildUpdateBefore");a(ZH,"applyReverse");ex={};a(uA,"getRecordAtTime")});function Kr(e){return e[wt]||(e[wt]=Object.create(null))}function LE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,u,_;if(o.resolve)_={get(){return o.resolve(this,this[Oe])},set(l){return o.set(this,l)},configurable:!0};else{switch(o.type){case"String":u=a(function(l){if(!(typeof l=="string"||l==null&&o.nullable!==!1))throw new hn.ClientError(`${c} must be a string, attempt to assign ${l}`);Kr(this)[c]=l},"set");break;case"ID":u=a(function(l){if(!(typeof l=="string"||l?.length>0&&l.every?.(d=>typeof d=="string")||l==null&&o.nullable!==!1))throw new hn.ClientError(`${c} must be a string, attempt to assign ${l}`);Kr(this)[c]=l},"set");break;case"Float":case"Number":u=a(function(l){if(!(typeof l=="number"||l==null&&o.nullable!==!1))throw new hn.ClientError(`${c} must be a number, attempt to assign ${l}`);Kr(this)[c]=l},"set");break;case"Int":u=a(function(l){if(!(l>>0===l||l==null&&o.nullable!==!1))if(typeof l=="number"&&Math.abs((l>>0)-l)<=1)l=Math.round(l);else throw new hn.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${l}`);Kr(this)[c]=l},"set");break;case"Long":u=a(function(l){if(!(Math.round(l)===l&&Math.abs(l)<=9007199254740992||l==null&&o.nullable!==!1))if(typeof l=="number"&&Math.abs(l)<=9007199254740992)l=Math.round(l);else throw new hn.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${l}`);Kr(this)[c]=l},"set");break;case"BigInt":u=a(function(l){if(!(typeof l=="bigint"||l==null&&o.nullable!==!1))if(typeof l=="string"||typeof l=="number")l=BigInt(l);else throw new hn.ClientError(`${c} must be a number, attempt to assign ${l}`);Kr(this)[c]=l},"set");break;case"Boolean":u=a(function(l){if(!(typeof l=="boolean"||l==null&&o.nullable!==!1))throw new hn.ClientError(`${c} must be a boolean, attempt to assign ${l}`);Kr(this)[c]=l},"set");break;case"Date":u=a(function(l){if(!(l instanceof Date||l==null&&o.nullable!==!1))if(typeof l=="string"||typeof l=="number")l=new Date(l);else throw new hn.ClientError(`${c} must be a Date, attempt to assign ${l}`);Kr(this)[c]=l},"set");break;case"Bytes":u=a(function(l){if(!(l instanceof Uint8Array||l==null&&o.nullable!==!1))throw new hn.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${l}`);Kr(this)[c]=l},"set");break;case"Any":case void 0:u=a(function(l){Kr(this)[c]=l},"set");break;default:u=a(function(l){if(!(typeof l=="object"||l==null&&o.nullable!==!1))throw new hn.ClientError(`${c} must be an object, attempt to assign ${l}`);Kr(this)[c]=l},"set")}_={get(){let l=this[wt];if(l&&c in l){let f=l[c];if(f?.__op__){let E=this[_e]?.[c];return f.update(E)}return f}let d=this[_e]?.[c];if(d&&typeof d=="object"){let f=rx(d,o);if(f)return l||(l=this[wt]=Object.create(null)),l[c]=f}return d},set:u,enumerable:!0,configurable:!0}}_.get.isAttribute=!0,n[c]=_,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,_)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let u=this[wt];return u?.[o]!==void 0?u[o]:this[_e]?.[o]}),i("set",function(o,c){let u=n[o];if(u)return u.set.call(this,c);if(t.sealed)throw new hn.ClientError("Can not add a property to a sealed table schema");Kr(this)[o]=c}),i("deleteProperty",function(o){Kr(this)[o]=void 0}),i("toJSON",function(){let o=this[wt],c;for(let _ in o){c||(c=Object.assign({},this[_e]));let l=o[_];if(l?.__op__){let d=c[_];l=l.update(d)}c[_]=l}return Object.keys(this).length>0&&(c||(c=Object.assign({},this[_e])),Object.assign(c,this)),c||this[_e]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function rx(e,t){let r;switch(e.constructor){case Object:return t?((r=t.TrackedObject)||(t.TrackedObject=r=class{static{a(this,"TrackedObject")}constructor(s){if(s?.[_e])throw new Error("Can not track an already tracked object, check for circular references");this[_e]=s}},LE(r,t)),new r(e)):new IE(e);case Array:let n=new CE(e.length);n[_e]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=rx(o,t?.elements)),n[s]=o}return n;default:return e}}function J_(e){let t=e[wt],r;for(let s in t){r||(r=Object.assign({},e[_e]));let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=J_(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=Object.assign({},e[_e])),Object.assign(r,e)),r||e[_e]}function yo(e,t=e[wt]){let r;if(tx.call(e,_e)&&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=yo(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=Object.assign({},e[_e]));let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=lA[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=yo(s);r[n]=s}return r?Object.freeze(r):tx.call(e,_e)?e[_e]:e}function wE(e){let t=e[_e];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[bo]||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?.[_e]===s){if(wE(i))return!0}else return!0}}else{let r=e[wt];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[_e]===i){if(wE(s))return!0}else return!0}else return!0}}return!1}var hn,wt,IE,tx,bo,CE,DE,X_=Re(()=>{An();hn=x(ne());bE();wt=Symbol("own-data");a(Kr,"getChanges");a(LE,"assignTrackedAccessors");a(rx,"trackObject");IE=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[_e])throw new Error("Can not track an already tracked object, check for circular references");this[_e]=t}};LE(IE,{});a(J_,"collapseData");tx=Object.prototype.hasOwnProperty;a(yo,"deepFreeze");a(wE,"hasChanges");bo=Symbol.for("has-array-changes"),CE=class extends Array{static{a(this,"TrackedArray")}[bo];constructor(t){super(t)}splice(...t){return this[bo]=!0,super.splice(...t)}push(...t){return this[bo]=!0,super.push(...t)}pop(){return this[bo]=!0,super.pop()}unshift(...t){return this[bo]=!0,super.unshift(...t)}shift(){return this[bo]=!0,super.shift()}};CE.prototype.constructor=Array;DE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var gp={};$e(gp,{CONTEXT:()=>Oe,ID_PROPERTY:()=>Me,IS_COLLECTION:()=>mn,RECORD_PROPERTY:()=>_e,Resource:()=>Gt,snake_case:()=>jne,transformForSelect:()=>UE});function jne(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function nx(e,t){if(hl=!1,e==="")return null;if(e=e.slice(1),e.indexOf("/")===-1)return e===""?(hl=!0,null):(e.startsWith("$")&&(e=parseInt(e,36)),t.coerceId(decodeURIComponent(e)));let r=e.split("/"),n=new dA;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){hl=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}function Wr(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,u,_,l;if(r?(o?(l=i,o=o[Oe]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(l=s,c=l[this.primaryKey]??null,o=i[Oe]||i):l=i:(l=s,c=l[Me]??l[this.primaryKey]??null),c==null&&(_=!0)):i?o=i[Oe]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="string")c=s;else if(typeof s=="object"&&s)if(u=s,s[Symbol.iterator]){c=[],_=!0;for(let E of s){if(typeof E=="object"&&E)break;c.push(E)}c.length===0?c=null:(c.length===1&&(c=c[0]),u.slice&&(u=u.slice(c.length,u.length),u.length===0&&(u=null,_=!1)))}else{if(typeof(c=s.url)=="string"){let E=c.indexOf("?");if(E>-1){let p=this.parseQuery(c.slice(E+1));u?u=Object.assign(p,u):u=p,c=c.slice(0,E)}let h=this.parsePath(c,o,u);h?.id!==void 0?(h.query&&(u?u=Object.assign(h.query,u):u=h.query),_=h.isCollection,c=h.id):c=h}c===void 0&&(c=s.id??null,c==null&&(_=!0))}else c=s??null,c==null&&(_=!0);o||(o={});let d;if(u?.ensureLoaded!=null||u?.async||_?(d=Object.assign({},t),u?.ensureLoaded!=null&&(d.ensureLoaded=u.ensureLoaded),u?.async&&(d.async=u.async),_&&(d.isCollection=!0)):d=t,o.transaction){let E=this.getResource(c,o,d);return E.then?E.then(f):f(E)}else return ze(o,()=>{let E=this.getResource(c,o,d);return E.then?E.then(f):f(E)},d);function f(E){if(o.authorize){o.authorize=!1;let h=t.type==="read"?E.allowRead(o.user,u,o):t.type==="update"?E.doesExist?.()===!1?E.allowCreate(o.user,l,o):E.allowUpdate(o.user,l,o):t.type==="create"?E.allowCreate(o.user,l,o):E.allowDelete(o.user,u,o);if(h?.then)return h.then(p=>{if(!p)throw new ME(o.user);return typeof l?.then=="function"?l.then(S=>e(E,u,o,S)):e(E,u,o,l)});if(!h)throw new ME(o.user)}return typeof l?.then=="function"?l.then(h=>e(E,u,o,h)):e(E,u,o,l)}a(f,"authorizeActionOnResource")}}function Qr(e,t){let r=new ox.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 _A(e,t,r){let n=e[_e];if(n){let s=e[wt];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 UE(e,t){let r=t?.propertyResolvers,n=t[Oe],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):_A(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(u){if(u.then)return u.then(c);if(Array.isArray(u))return u.map(c);let _=[],l=i(_A(u,r,n));for(let d of e)_.push(l(d));return _},"transform");let o=e.forceNulls;return a(function c(u){if(u.then)return u.then(c);if(Array.isArray(u))return u.map(f=>f&&typeof f=="object"?c(f):f);let _={},l=i(_A(u,r,n)),d;for(let f of e){let E=l(f);E===void 0&&o&&(E=null),E?.then?(d||(d=[]),d.push(E.then(h=>_[f.name||f]=h))):_[f.name||f]=E}return d?Promise.all(d).then(()=>_):_},"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 u=s[c.name];if(!u){let l=r[c.name]?.definition?.tableClass;u=s[c.name]=UE(c.select||c,l)}let _=o(c.name);return u(_)}else return o(c);else return c}}a(i,"handleProperty")}var sx,ix,ox,Oe,Me,mn,_e,Xne,Gt,ME,hl,dA,An=Re(()=>{sx=require("crypto");fc();ix=require("../../index"),ox=x(ne());X_();Xi();Mf();Oe=Symbol.for("context"),Me=Symbol.for("primary-key"),mn=Symbol("is-collection"),_e=Symbol("stored-record"),Xne={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Gt=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[Me]=t;let n=r?.[Oe];this[Oe]=n!==void 0?n:r||null}static get=Wr(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let u;if((u=r?.select)&&c!=null&&!c.selectApplied){let _=UE(u,t.constructor);return typeof c?.map=="function"?c.map(_):_(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=Wr(function(t,r,n,s){if(Array.isArray(s)&&t[mn]){let i=[],o=n.authorize;for(let c of s){let u=t.constructor,_=u.getResource(c[u.primaryKey],n,{async:!0});_.then?i.push(_.then(l=>l.put(c,n))):i.push(_.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):Qr(t,"put")},{hasContent:!0,type:"update"});static patch=Wr(function(t,r,n,s){return t.patch?t.patch(s,r):Qr(t,"patch")},{hasContent:!0,type:"update"});static delete=Wr(function(t,r,n,s){return t.delete?t.delete(r):Qr(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,sx.randomUUID)()}static create(t,r,n){let s;return t==null?s=this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=[...t,this.getNewId()]:typeof t!="object"?s=[t,this.getNewId()]:(s=this.getNewId(),n=r,r=t),ze(n,()=>{let i=new this(s,n),o=i.update?i.update(r):Qr(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>s):s})}static invalidate=Wr(function(t,r,n,s){return t.invalidate?t.invalidate(r):Qr(t,"delete")},{hasContent:!1,type:"update"});static post=Wr(function(t,r,n,s){return t[Me]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=Wr(function(t,r,n,s){return t.connect?t.connect(s,r):Qr(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Wr(function(t,r,n,s){return t.subscribe?t.subscribe(r):Qr(t,"subscribe")},{type:"read"});static publish=Wr(function(t,r,n,s){return t[Me]!=null&&t.update?.(),t.publish?t.publish(s,r):Qr(t,"publish")},{hasContent:!0,type:"create"});static search=Wr(function(t,r,n,s){let i=t.search?t.search(r):Qr(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=UE(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=Wr(function(t,r,n,s){return t.search?t.search(s,r):Qr(t,"search")},{hasContent:!0,type:"read"});static copy=Wr(function(t,r,n,s){return t.copy?t.copy(s,r):Qr(t,"copy")},{type:"create"});static move=Wr(function(t,r,n,s){return t.move?t.move(s,r):Qr(t,"move")},{type:"delete"});post(t){if(this[mn])return this.constructor.create(this[Me],t,this[Oe]);Qr(this,"post")}static isCollection(t){return t?.[mn]}static coerceId(t){return t}static parseQuery(t){return Lf(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1);t=t.slice(0,s);let c=r?.headers&&Xne[o];if(c)r.headers.set("accept",c);else if(n)n.property=o;else return{query:{property:o},id:nx(t,this),isCollection:hl}}let i=nx(t,this);return hl?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[Oe],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 u;if(i.resourceCache?u=i.resourceCache:u=i.resourceCache=[],u.asMap){let _=u.asMap.get(t);if(s=_?.find(l=>l.constructor===c),s)return s;_||u.asMap.set(t,_=[]),_.push(s=new c(t,i))}else{if(s=u.find(_=>_[Me]===t&&_.constructor===c),s)return s;if(u.push(s=new c(t,i)),u.length>10){let _=new Map;for(let l of u){let d=l[Me],f=_.get(d);f?f.push(l):_.set(d,[l])}i.resourceCache.length=0,i.resourceCache.asMap=_}}}else s=new c(t,i);return o&&(s[mn]=!0),s}subscribe(t){return new Rn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Rn}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[Me]}getContext(){return this[Oe]}};Gt.prototype[Oe]=null;(0,ix._assignPackageExport)("Resource",Gt);a(jne,"snake_case");ME=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(nx,"pathToId");dA=class extends Array{static{a(this,"MulitPartId")}toString(){return this.join("/")}};a(Wr,"transactional");a(Qr,"missingMethod");a(_A,"selectFromObject");a(UE,"transformForSelect")});function cx(e,t,r,n){let s=e.primaryStore.env.path,i=e.primaryStore.tableId;Ka||((0,PE.onMessageByType)(ax,l=>{ux(l.path)}),Ka=Object.create(null));let o=Ka[s]||(Ka[s]=[]);o.auditStore=e.auditStore,o.lastTxnTime==null&&(o.lastTxnTime=Date.now());let c=o[i];c||(c=o[i]=new Map,c.envs=o,c.tableId=i,c.store=e.primaryStore),t=Sa(t);let u=new EA(r);u.startTime=n;let _=c.get(t);return _?_.push(u):(c.set(t,_=[u]),_.tables=c,_.key=t),u.subscriptions=_,u}function ux(e,t){if(!Ka)return;let r=Ka[e];if(!r)return;try{r.auditStore.resetReadTxn()}catch(s){throw s.message+=" in "+e,s}let n;for(let{key:s,value:i}of r.auditStore.getRange({start:r.lastTxnTime,exclusiveStart:!0})){r.lastTxnTime=s;let o=Dt(i),c=r[o.tableId];if(!c)continue;let u=o.recordId,_,l=Sa(o.recordId),d=0;do{let f=c.get(l);if(f){for(let h of f)if(!(d>0&&!(h.includeDescendants&&!(h.onlyChildren&&d>1)))){if(h.startTime>=s){(0,fA.info)("omitting",u,h.startTime,s);continue}try{if(h.crossThreads===!1&&!t)continue;let p;h.supportsTransactions&&h.txnInProgress!==o.version&&(p=!0,h.txnInProgress||(n?n.push(h):n=[h]),h.txnInProgress=o.version),h.listener(u,o,s,p)}catch(p){console.error(p),(0,fA.info)(p)}}}if(l==null)break;let E=l.lastIndexOf?.("/",l.length-2);E>-1?l=l.slice(0,E):l=null,d++}while(!0)}if(n)for(let s of n)s.txnInProgress=null,s.listener(null,{type:"end_txn"},r.lastTxnTime,!0)}function lx(e,t){let r=t||e,n=r.env;if(t&&!t.cache&&(t.cache=new Map),!n.hasBroadcastListener){n.hasBroadcastListener=!0;let s=n.path;r.on("aftercommit",()=>{(0,PE.broadcast)({type:ax,path:s}),ux(s,!0)})}}var fA,PE,ax,Ka,vme,EA,_x=Re(()=>{fA=x(K()),PE=x(Ze());fc();Pu();Mi();ax="transaction",vme=Buffer.alloc(4096);a(cx,"addSubscription");EA=class extends Rn{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,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(ux,"notifyFromTransactionData");a(lx,"listenToCommits")});var eR={};$e(eR,{coerceType:()=>vE,makeTable:()=>xE,setServerUtilities:()=>ase,updateResource:()=>BE});function xE(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:u,schemaDefined:_,dbisDB:l,sealed:d}=e,{expirationMS:f,evictionMS:E,audit:h,trackDeletes:p}=e,{attributes:S}=e;S||(S=[]),lx(i,u);let T=zh(i,n,u),b=0,R,L,H={},P=Promise.resolve(),k,B,J;for(let Y of S)(Y.assignCreatedTime||Y.name==="__createdtime__")&&(k=Y),(Y.assignUpdatedTime||Y.name==="__updatedtime__")&&(B=Y),Y.expiresAt&&(J=Y),Y.isPrimaryKey&&(H=Y);let Q,X=[],Te=[],ce=1,de=2,Le={},Be={},Ct=864e5,Ll,Ml,Vs,MA=!1,th,nG=i.getRange({start:!1,end:!1}).constructor,sG=10,iG=6;h&&vA();class We extends Gt{static name=s;static primaryStore=i;static auditStore=u;static primaryKey=t;static tableName=s;static indices=r;static audit=h;static databasePath=o;static databaseName=c;static attributes=S;static expirationTimer;static createdTimeProperty=k;static updatedTimeProperty=B;static propertyResolvers;static sources=[];static get expirationMS(){return f}static dbisDB=l;static schemaDefined=_;static sourcedFrom(m,O){O&&(this.sourceOptions=O,(O.expiration||O.eviction||O.scanInterval)&&this.setTTLExpiration(O)),O?.intermediateSource?(m.intermediateSource=!0,this.sources.unshift(m)):this.sources.push(m),L=m.get&&(!m.get.reliesOnPrototype||m.prototype.get);let I=a(D=>{let N=this.sources.slice(0,-1);if(N=N.filter(M=>M[D]&&(!M[D].reliesOnPrototype||M.prototype[D])),N.length>0)if(N.length===1){let M=N[0];return(F,C,v)=>{if(F?.source!==M)return M[D](C,v,F)}}else return(M,F,C)=>{let v=[];for(let q of N){if(M?.source===q)break;v.push(q[D](F,C,M))}return Promise.all(v)}},"getApplyToIntermediateSource"),y=this.sources[this.sources.length-1],A=a(D=>{if(y[D]&&(!y[D].reliesOnPrototype||y.prototype[D]))return(N,M,F)=>{if(!N?.source)return y[D](M,F,N)}},"getApplyToCanonicalSource");return Le={put:A("put"),patch:A("patch"),delete:A("delete"),publish:A("publish")},Be={put:I("put"),patch:I("patch"),delete:I("delete"),publish:I("publish"),invalidate:I("invalidate")},(async()=>{let D=!1,N=a(async(M,F)=>{let C=M.value,v=M.table?et[c][M.table]:We;if(c===qn.SYSTEM_SCHEMA_NAME&&(M.table===qn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||M.table===qn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(D=!0),M.id===void 0&&(M.id=C[v.primaryKey],M.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(M));M.source=m;let q=await v.getResource(M.id,F,Wa);switch(M.type){case"put":return q._writeUpdate(C,!0,Wa);case"patch":return q._writeUpdate(C,!1,Wa);case"delete":return q._writeDelete(Wa);case"publish":return q._writePublish(C,Wa);case"invalidate":return q.invalidate(Wa);default:Je.error("Unknown operation",M.type,M.id)}},"writeUpdate");try{let M=m.subscribe;M&&p==null&&(p=!0);let F=m.subscribeOnThisThread?m.subscribeOnThisThread((0,Io.getWorkerIndex)()):(0,Io.getWorkerIndex)()===0,C=M&&F&&await m.subscribe?.({crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0});if(C){let v;for await(let q of C)try{if(!(q.type==="transaction"?q.writes[0]:q)){Je.error("Bad subscription event",q);continue}if(q.source=m,v)if(q.beginTxn)v.resolve();else{N(q,v);continue}if(q.type==="end_txn")continue;let be=ze(q,()=>{if(q.type==="transaction"){let ee=[];for(let Pe of q.writes)try{ee.push(N(Pe,q))}catch(ae){throw ae.message+=" writing "+JSON.stringify(Pe)+" of event "+JSON.stringify(q),ae}return Promise.all(ee)}else if(q.type==="define_schema"){let ee=this.attributes.slice(0),Pe;for(let ae of q.attributes)ee.find(Ge=>Ge.name===ae.name)||(ee.push(ae),Pe=!0);Pe&&(at({table:s,database:c,attributes:ee,origin:"cluster"}),Al.signalSchemaChange(new Ol.SchemaEventMsg(process.pid,qn.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return q.beginTxn?(v=q,N(q,q),new Promise(ee=>{v.resolve=ee})):N(q,q)});D&&(await be,Al.signalUserChange(new Ol.UserEventMsg(process.pid))),q.onCommit&&(be?.then?be.then(q.onCommit):q.onCommit())}catch(oe){Je.error("error in subscription handler",oe)}}}catch(M){Je.error(M)}})(),this}static getResource(m,O,I){let y=super.getResource(m,O,I);if(m!=null){ja(m);try{if(y.hasOwnProperty(_e))return y;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let A=!I?.async||i.cache?.get(m),D=Tn(O),N=D.getReadTxn();if(N?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return rh(m,O,{transaction:N},A,M=>{if(M?BE(y,M):y[_e]=null,O.onlyIfCached&&O.noCacheStore){if(!y.doesExist())throw new pn.ServerError("Entry is not cached",504)}else if(I?.ensureLoaded){let F=nh(m,M,O,y);if(F)return D?.disregardReadTxn(),y[hA]=!0,pA(F,C=>(BE(y,C),y))}return y})}catch(A){throw A.message.includes("Unable to serialize object")&&(A.message+=": "+JSON.stringify(m)),A}}return y}ensureLoaded(){let m=nh(this[Me],this[zr],this[Oe]);if(m)return this[hA]=!0,pA(m,O=>{this[zr]=O,this[_e]=O.value,this[gl]=O.version})}static setTTLExpiration(m){if(typeof m=="number")f=m*1e3,E||(E=0);else if(m&&typeof m=="object")f=m.expiration*1e3,E=(m.eviction||0)*1e3,Ct=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(f<0)throw new Error("Expiration can not be negative");Ct=Ct||(f+E)/4,ih()}static enableAuditing(m=!0){h=m,m&&vA(),We.audit=m}static coerceId(m){return m===""?null:vE(m,H)}static async dropTable(){if(delete et[c][s],c===o){for(let m of S)l.remove(We.tableName+"/"+m.name),r[m.name]?.drop();l.remove(We.tableName+"/"),i.drop(),await l.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));Al.signalSchemaChange(new Ol.SchemaEventMsg(process.pid,qn.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this[mn])return this.search(m);if(this[Me]===null){if(m?.conditions)return this.search(m);let O=We.getRecordCount();return{recordCount:O.recordCount,estimatedRecordRange:O.estimatedRange,records:"./",name:s,database:c,attributes:S}}if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this[Oe]?.returnNonexistent)return this}allowRead(m,O){let I=Pl(m);if(I?.read){if(I.isSuperUser)return!0;let y=I.attribute_permissions,A=O?.select;if(y?.length>0||MA&&A){if(O||(O={}),A){let D=y?.length>0&&mA(y,"read");O.select=A.map(N=>{let M=N.name||N;if(!D||D[M]){let F=Vs[M]?.definition?.tableClass;if(F){if(N.name||(N={name:N}),!F.prototype.allowRead.call(null,m,N))return!1;if(!N.select)return N.name}return N}}).filter(Boolean)}else O.select=y.filter(D=>D.read&&!Vs[D.attribute_name]).map(D=>D.attribute_name);return O}else return!0}}allowUpdate(m,O){let I=Pl(m);if(I?.update){let y=I.attribute_permissions;if(y?.length>0){let A=mA(y,"update");for(let D in O)if(!A[D])return!1;for(let D of y){let N=D.attribute_name;!D.update&&!(N in O)&&(O[N]=this.getProperty(N))}}return!0}}allowCreate(m,O){if(this[mn]){let I=Pl(m);if(I?.insert){let y=I.attribute_permissions;if(y?.length>0){let A=mA(y,"insert");for(let D in O)if(!A[D])return!1}else return!0}}else return this.allowUpdate(m,{})}allowDelete(m){return Pl(m)?.delete}update(m,O){if(!Tn(this[Oe]))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&&(O?(Object.isFrozen(m)&&(m=Object.assign({},m)),this[_e]={},this[wt]=m):(y=this[wt],y&&(m=Object.assign(y,m)),this[wt]=y=m)),this._writeUpdate(this[wt],O),this}addTo(m,O){if(typeof O=="number")this[ml]===fx?this.set(m,(+this.getProperty(m)||0)+O):(this[ml]||this.update(),this.set(m,new DE(O)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,O){if(typeof O=="number")return this.addTo(m,-O);throw new Error("Can not subtract a non-numeric value")}invalidate(m){let O=this[Oe],I=this[Me];ja(I),Tn(this[Oe]).addWrite({key:I,store:i,invalidated:!0,entry:this[zr],nodeName:this[Oe]?.nodeName,before:Le.invalidate?.bind(this,O,I),beforeIntermediate:Be.invalidate?.bind(this,O,I),commit:(A,D)=>{if(D?.version>A)return;let N=null;for(let M in r)N||(N={}),N[M]=this.getProperty(M);T(I,N,this[zr],A,pl,h,this[Oe],0,"invalidate")}})}static evict(m,O,I){let y=this.Source,A;if(!((L||h)&&(!O||(A=i.getEntry(m),!A||!O)||A.version!==I))){if(L){if(i.hasLock(m,A.version))return;let D;for(let N in r)D||(D={}),D[N]=O[N];if(D)return T(m,D,A,I,Sl,null,null,0,null,!0)}return i.ifVersion(m,I,()=>{Ul(m,O,null)}),h?T(m,null,A,I,Sl,null,null,0,null,!0):i.remove(m,I)}}lock(){throw new Error("Not yet implemented")}static operation(m,O){return m.table||=s,m.schema||=c,Tx.operation(m,O)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,O,I){let y=this[Oe],A=Tn(y),D=this[Me];ja(D);let N=this[zr];this[ml]=O?fx:sse;let M={key:D,store:i,entry:N,nodeName:y?.nodeName,validate:F=>{m||(m=this[wt]),O||m&&wE(m)?y?.source||(A.checkOverloaded(),this.validate(m,!O),B&&(m[B.name]=B.type==="Date"?new Date(F):B.type==="String"?new Date(F).toISOString():F),O&&(t&&m[t]!==D&&(m[t]=D),k&&(N?.value?m[k.name]=N?.value[k.name]:m[k.name]=k.type==="Date"?new Date(F):k.type==="String"?new Date(F).toISOString():F),m=yo(m))):A.removeWrite(M)},before:O?Le.put?()=>Le.put(y,D,m):null:Le.patch?()=>Le.patch(y,D,m):Le.put?()=>Le.put(y,D,yo(this)):null,beforeIntermediate:O?Be.put?()=>Be.put(y,D,m):null:Be.patch?()=>Be.patch(y,D,m):Be.put?()=>Be.put(y,D,yo(this)):null,commit:(F,C,v)=>{if(v){if(y&&C?.version>(y.lastModified||0)&&(y.lastModified=C.version),this[zr]=C,C?.value?.[_e])throw new Error("Can not assign a record to a record, check for circular references");O||(this[_e]=C?.value??null)}this[wt]=m,this[gl]=F;let q=C?.value,oe=m;if(this[ml]=0,C?.version>=F)if(h){let ae=C.localTime,Ge=C.version;for(;oe&&(ae>F||Ge>=F&&ae>0);){let te=u.get(ae),j=Dt(te);if(Ge=j.version,Ge>F){if(j.type==="patch"){let ge=j.getValue(i);oe=NE(oe,ge)}else if(j.type==="put"||j.type==="delete")return}else if(Ge===F)return;ae=j.previousLocalTime}}else{if(O)return;oe=NE(oe,q)}let be;if(O?be=oe:(this[_e]=q,be=O?oe:yo(this,oe)),this[_e]=be,be?.[_e])throw new Error("Can not assign a record to a record, check for circular references");let ee;O||(ee=m),Ul(D,q,be);let Pe=O?"put":"patch";T(D,be,C,F,0,h,y,y.expiresAt||(f?f+Date.now():0),Pe,!1,ee)}};A.addWrite(M)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this[mn]){for await(let O of this.search(m))(await We.getResource(O[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this[_e]?this._writeDelete(m):!1}_writeDelete(m){let O=Tn(this[Oe]),I=this[Me];ja(I);let y=this[Oe];return O.addWrite({key:I,store:i,resource:this,nodeName:y?.nodeName,before:Le.delete?.bind(this,y,I),beforeIntermediate:Be.delete?.bind(this,y,I),commit:(A,D,N)=>{let M=D?.value;N&&(y&&D?.version>(y.lastModified||0)&&(y.lastModified=D.version),BE(this,D)),!(D?.version>A)&&(Ul(this[Me],M),Je.trace("Write delete entry",I,A),h||p?(T(I,null,this[zr],A,0,h,this[Oe],0,"delete"),h||ih()):i.remove(this[Me]))}}),!0}search(m){let O=this[Oe],I=Tn(O);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[Me]&&(y=[{attribute:null,comparator:"prefix",value:this[Me]}].concat(y));let A,D={};function N(j,ge){let He;switch(ge){case"and":case void 0:if(j.length<1)throw new Error('An "and" operator requires at least one condition');He=!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 "+ge)}let kn=He&&{},$s;for(let Ve of j){if(Ve.conditions){Ve.conditions=N(Ve.conditions,Ve.operator);continue}let Ht=Ve[0]??Ve.attribute,Zr=Ht==null?H:vs(S,Ht);if(Zr){if(He){let Vn=Bn(Ht),xt=kn[Vn];xt?(xt.push(Ve),$s=!0):kn[Vn]=[Ve]}(Zr.type||Ng[Ve.comparator])&&(Ve[1]===void 0?Ve.value=F(Ve.value,Zr):Ve[1]=F(Ve[1],Zr))}else if(Ht!=null)throw(0,pn.handleHDBError)(new Error,`${Ht} is not a defined attribute`,404)}if(m.enforceExecutionOrder)return j;if($s)for(let Ve in kn){let Ht=kn[Ve],Zr=Ht.length;if(Zr>1)for(let Vn=0;Vn<Zr;Vn++){let xt=Ht[Vn];if(xt.comparator==="ge"||xt.comparator==="greater_than_equal")for(let Ys=0;Ys<Zr;Ys++){let Mo=Ht[Ys];(Mo.comparator==="le"||Mo.comparator==="less_than_equal")&&(xt.comparator="between",xt.value=[xt.value,Mo.value],j.splice(j.indexOf(Mo),1))}if(xt.comparator==="equals"||!xt.comparator){for(let Ys=0;Ys<Zr;Ys++)if(Ys!==Vn){let Mo=Ht[Ys];j.splice(j.indexOf(Mo),1)}break}}}return j}a(N,"prepareConditions");function M(j,ge){if(m.enforceExecutionOrder)return j;for(let He of j)He.conditions&&(He.conditions=M(He.conditions,He.operator));return j.length>1&&ge!=="or"?(0,Sx.sortBy)(j,Df(We)):j}a(M,"orderConditions");function F(j,ge){return Array.isArray(j)?j.map(He=>vE(He,ge)):vE(j,ge)}a(F,"coerceTypedValues");let C=m.operator;(y.length>0||C)&&(y=N(y,C));let v=typeof m.sort=="object"&&m.sort,q;if(v&&C!=="or"){let j=v.attribute;if(A=y.find(ge=>Bn(ge.attribute)===Bn(j)),!A){if(!vs(S,j))throw(0,pn.handleHDBError)(new Error,`${Array.isArray(j)?j.join("."):j} is not a defined attribute`,404);A={attribute:j,comparator:"sort"},y.push(A)}A.descending=!!v.descending}y=M(y,C),v&&(y[0]===A?v.next&&(q={dbOrderedAttribute:v.attribute,attribute:v.next.attribute,descending:v.next.descending,next:v.next.next}):(A&&y.splice(y.indexOf(A),1),q=v));let oe=m.select;if(y.length===0&&(y=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:y,operator:C,postOrdering:q,selectApplied:!!oe};let be=I.useReadTxn(),ee=Ig(y,C,We,be,m,O,(j,ge)=>UA(j,oe,O,be,ge),D),Pe=m.ensureLoaded!==!1;q||(ee=te(ee));let ae=We.transformEntryForSelect(oe,O,be,D,Pe,!0),Ge=We.transformToOrderedSelect(ee,oe,q,be,O,ae);function te(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(te,"applyOffset"),q&&(Ge=te(Ge)),Ge.onDone=()=>{Ge.onDone=null,I.doneReadTxn()},Ge.selectApplied=!0,Ge.getColumns=()=>{if(oe){let j=[];for(let ge of oe)ge==="*"?j.push(...S.map(He=>He.name)):j.push(ge.name||ge);return j}return S.map(j=>j.name)},Ge}static transformToOrderedSelect(m,O,I,y,A,D){let N=new nG;if(I){m=UA(m,O,y,A,null);let M;N.iterate=function(){let C,v=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),q,oe=I.dbOrderedAttribute,be,ee,Pe=!0;function ae(te){let j=te.next&&ae(te.next),ge=te.descending;return(He,kn)=>{let $s=sh(He,te.attribute,y),Ve=sh(kn,te.attribute,y),Ht=ge?(0,wo.compareKeys)(Ve,$s):(0,wo.compareKeys)($s,Ve);return Ht===0?j?.(He,kn)||0:Ht}}a(ae,"createComparator");let Ge=ae(I);return{async next(){let te;if(C)if(te=C.next(),te.done){if(q)return N.onDone&&N.onDone(),te}else return{value:await D.call(this,te.value)};M=[],be&&M.push(be);do if(te=await v.next(),te.done){if(q=!0,M.length)break;return N.onDone&&N.onDone(),te}else{let j=te.value;if(j?.then&&(j=await j),oe){let ge=sh(j,oe,y);if(Pe)Pe=!1,ee=ge;else if(ge!==ee){ee=ge,be=j;break}}M.push(j)}while(!0);return I.isGrouped,M.sort(Ge),C=M[Symbol.iterator](),te=C.next(),te.done?(N.onDone&&N.onDone(),te):{value:await D.call(this,te.value)}},return(){N.onDone&&N.onDone(),v.return()},throw(){N.onDone&&N.onDone(),v.throw()}}};let F=a(C=>{if(typeof O=="object"&&Array.isArray(C.attribute))for(let v=0;v<O.length;v++){let q=O[v],oe;if(q.name===C.attribute[0]){for(oe=q.sort||(q.sort={});oe.next;)oe=oe.next;oe.attribute=C.attribute.slice(1),oe.descending=C.descending}else q===C.attribute[0]&&(O[v]=oe={name:q,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&F(C.next)},"applySortingOnSelect");F(I)}else N.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),N=N.map(D);return N}static transformEntryForSelect(m,O,I,y,A,D){if(m&&(m===t||m?.length===1&&m[0]===t)){let C=a(v=>v?.key??v,"transform");return m===t?C:m.asArray?v=>[C(v)]:v=>({[t]:C(v)})}let N;A&&L&&!m?.every(C=>{let v;return typeof C=="object"?v=C.name:v=C,r[v]||v===t})&&(N=!0);let M,F=a(function(C){let v;if(C!=null){if(th=C,v=C.value||C.deref?.(),!v&&(C.key===void 0||C.deref)){if(C=rh(C.key??C,O,{transaction:I,lazy:m?.length<4},this.isSync,q=>q),C?.then)return C.then(F.bind(this));v=C?.value}if(N&&(C.metadataFlags&(pl|Sl)||C.expiresAt&&C.expiresAt<Date.now())){let q=nh(C.key??C,C,O);if(q?.then)return q.then(F)}}if(v==null)return D?No.SKIP:v;if(m&&!(m[0]==="*"&&m.length===1)){let q,oe=a((ee,Pe)=>{let ae;typeof ee=="object"?ae=ee.name:ae=ee;let Ge=Vs?.[ae],te;if(Ge){let j=y?.[ae];if(j)if(j.hasMappings){let He=Ge.from?v[Ge.from]:Bn(C.key);te=j.get(He),te||(te=[])}else te=j.fromRecord?.(v);else te=Ge(v,O,C);let ge=a(He=>{if(He&&typeof He=="object"){let kn=Ge.definition?.tableClass||We;M||(M={});let $s=M[ae]||(M[ae]=kn.transformEntryForSelect(ae===ee?null:ee.select||(Array.isArray(ee)?ee:null),O,I,j,A));if(Array.isArray(He)){let Ve=[],Ht=kn.transformToOrderedSelect(He,ee.select,typeof ee.sort=="object"&&ee.sort,O,I,$s)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Zr=a(xt=>{for(;!xt.done;){if(xt?.then)return xt.then(Zr);Ve.push(xt.value),xt=Ht.next()}Pe(Ve,ae)},"nextValue"),Vn=Zr(Ht.next());Vn&&(q||(q=[]),q.push(Vn));return}else if(He=$s.call(this,He),He?.then){q||(q=[]),q.push(He.then(Ve=>Pe(Ve,ae)));return}}Pe(He,ae)},"handleResolvedValue");te?.then?(q||(q=[]),q.push(te.then(ge))):ge(te);return}else te=v[ae],te&&typeof te=="object"&&ae!==ee&&(te=We.transformEntryForSelect(ee.select||ee,O,I,null)({value:te}));Pe(te,ae)},"selectAttribute"),be;if(typeof m=="string")oe(m,ee=>{be=ee});else if(Array.isArray(m))if(m.asArray)be=[],m.forEach((ee,Pe)=>{ee==="*"?m[Pe]=v:oe(ee,ae=>be[Pe]=ae)});else{be={};let ee=m.forceNulls;for(let Pe of m)if(Pe==="*")for(let ae in v)be[ae]=v[ae];else oe(Pe,(ae,Ge)=>{ae===void 0&&ee&&(ae=null),be[Ge]=ae})}else throw new pn.ClientError("Invalid select"+m);return q?Promise.all(q).then(()=>be):be}return v},"transform");return F}async subscribe(m){if(!u)throw new Error("Can not subscribe to a table without an audit log");h||at({table:s,database:c,schemaDefined:_,attributes:S,audit:!0}),m||(m={});let O=!m.rawEvents,I=cx(We,this[Me]??null,function(N,M,F,C){try{let v=M.getValue?.(i,O);if(!v&&M.type==="patch"&&O){let q=i.getEntry(N);q?.version===M.version?v=q.value:v=M.getValue?.(i,!0,F),M.type="put"}this.send({id:N,timestamp:F,value:v,version:M.version,type:M.type,beginTxn:C})}catch(v){Je.error(v)}},m.startTime||0,this[mn]);this[mn]&&(I.includeDescendants=!0,m.onlyChildren&&(I.onlyChildren=!0)),m.crossThreads===!1&&(I.crossThreads=!1),m.supportsTransactions&&(I.supportsTransactions=!0);let y=this[Me],A=m.previousCount;A>1e3&&(A=1e3);let D=m.startTime;if(this[mn]){if(D){if(A)throw new pn.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:N,value:M}of u.getRange({start:D,exclusiveStart:!0})){let F=Dt(M);if(F.tableId!==n)continue;let C=F.recordId;if(y==null||mx(y,C)){let v=F.getValue(i,O,N);I.send({id:C,timestamp:N,value:v,version:F.version,type:F.type})}I.startTime=N}}else if(A){let N=[];for(let{key:M,value:F}of u.getRange({start:"z",end:!1,reverse:!0}))try{let C=Dt(F);if(C.tableId!==n)continue;let v=C.recordId;if(y==null||mx(y,v)){let q=C.getValue(i,O,M);if(N.push({id:v,timestamp:M,value:q,version:C.version,type:C.type}),--A<=0)break}}catch(C){Je.error("Error getting history entry",M,C)}for(let M=N.length;M>0;)I.send(N[--M]);N[0]&&(I.startTime=N[0].timestamp)}else if(!m.omitCurrent)for(let{key:N,value:M,version:F,localTime:C}of i.getRange({start:y??!1,end:y==null?void 0:[y,wo.MAXIMUM_KEY],versions:!0}))M&&I.send({id:N,timestamp:C,value:M,version:F,type:"put"})}else{A&&!D&&(D=0);let N=this[zr]?.localTime;if(N===Qh&&(i.cache?.delete(y),this[zr]=i.getEntry(y),Je.trace("re-retrieved record",N,this[zr]?.localTime),N=this[zr]?.localTime),Je.trace("Subscription from",D,"from",y,N),D<N){let M=[],F=N;do{let C=u.get(F);if(C){m.omitCurrent=!0;let v=Dt(C),q=v.getValue(i,O,F);O&&(v.type="put"),M.push({id:y,value:q,timestamp:F,...v}),F=v.previousLocalTime}else break;A&&A--}while(F>D&&A!==0);for(let C=M.length;C>0;)I.send(M[--C]);I.startTime=N}!m.omitCurrent&&this.doesExist()&&I.send({id:y,timestamp:N,value:this,version:this[gl],type:"put"})}return m.listener&&I.on("data",m.listener),I}doesExist(){return!!(this[_e]||this[ml])}publish(m,O){this._writePublish(m,O)}_writePublish(m,O){let I=Tn(this[Oe]),y=this[Me]||null;ja(y);let A=this[Oe];I.addWrite({key:y,store:i,entry:this[zr],nodeName:A?.nodeName,validate:()=>{A?.source||(I.checkOverloaded(),this.validate(m))},before:Le.publish?.bind(this,A,y,m),beforeIntermediate:Be.publish?.bind(this,A,y,m),commit:(D,N,M)=>{N===void 0&&p&&!h&&ih(),T(y,N?.value??null,N,N?.version||D,0,!0,A,N?.expiresAt,"message",!1,m)}})}validate(m,O){let I,y=a((A,D,N)=>{if(D.type&&A!=null)if(O&&A.__op__&&(A=A.value),D.properties){typeof A!="object"&&(I||(I=[])).push(`Value ${Fn(A)} in property ${N} must be an object${D.type?" ("+D.type+")":""}`);let M=D.properties;for(let F=0,C=M.length;F<C;F++){let v=M[F],q=y(A[v.name],v,N+"."+v.name);q&&(A[v.name]=q)}if(D.sealed&&A!=null&&typeof A=="object")for(let F in A)M.find(C=>C.name===F)||(I||(I=[])).push(`Property ${F} is not allowed within object in property ${N}`)}else switch(D.type){case"Int":(typeof A!="number"||A>>0!==A)&&(I||(I=[])).push(`Value ${Fn(A)} in property ${N} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof A!="number"||!(Math.floor(A)===A&&Math.abs(A)<=9007199254740992))&&(I||(I=[])).push(`Value ${Fn(A)} in property ${N} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof A!="number"&&(I||(I=[])).push(`Value ${Fn(A)} in property ${N} must be a number`);break;case"ID":typeof A=="string"||A?.length>0&&A.every?.(M=>typeof M=="string")||(I||(I=[])).push(`Value ${Fn(A)} in property ${N} must be a string, or an array of strings`);break;case"String":typeof A!="string"&&(I||(I=[])).push(`Value ${Fn(A)} in property ${N} must be a string`);break;case"Boolean":typeof A!="boolean"&&(I||(I=[])).push(`Value ${Fn(A)} in property ${N} must be a boolean`);break;case"Date":if(!(A instanceof Date)){if(typeof A=="string"||typeof A=="number")return new Date(A);(I||(I=[])).push(`Value ${Fn(A)} in property ${N} must be a Date`)}break;case"BigInt":if(typeof A!="bigint"){if(typeof A=="string"||typeof A=="number")return BigInt(A);(I||(I=[])).push(`Value ${Fn(A)} in property ${N} must be a bigint`)}break;case"Bytes":A instanceof Uint8Array||(I||(I=[])).push(`Value ${Fn(A)} in property ${N} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(A)){if(D.elements)for(let M=0,F=A.length;M<F;M++){let C=A[M],v=y(C,D.elements,N+"[*]");v&&(A[M]=v)}}else(I||(I=[])).push(`Value ${Fn(A)} in property ${N} must be a Buffer or Uint8Array`);break}D.nullable===!1&&A==null&&(I||(I=[])).push(`Property ${N} is required (and not does not allow null values)`)},"validateValue");for(let A=0,D=S.length;A<D;A++){let N=S[A];if(!N.relationship&&(!O||N.name in m)){let M=y(m[N.name],N,N.name);M&&(m[N.name]=M)}}if(d)for(let A in m)S.find(D=>D.name===A)||(I||(I=[])).push(`Property ${A} is not allowed`);if(I)throw new pn.ClientError(I.join(". "))}getUpdatedTime(){return this[gl]}wasLoadedFromSource(){return L?!!this[hA]:void 0}static async addAttributes(m){let O=S.slice(0);for(let I of m){if(!I.name)throw new pn.ClientError("Attribute name is required");if(I.name.match(/[`/]/))throw new pn.ClientError("Attribute names cannot include backticks or forward slashes");O.push(I)}return at({table:s,database:c,schemaDefined:_,attributes:O}),We.indexingOperation}static async removeAttributes(m){let O=S.filter(I=>!m.includes(I.name));return at({table:s,database:c,schemaDefined:_,attributes:O}),We.indexingOperation}static getRecordCount(m){let O=i.getStats().entryCount,I=5e3,y=1e3,A;O>I&&!m?.exactCount&&(A=y);let D=0;for(let{value:N}of i.getRange({start:!0,lazy:!0,limit:A}))N!=null&&D++;if(A){let N=D;D=0;for(let{value:Pe}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:A}))Pe!=null&&D++;let M=A*2,F=(D+N)/M,C=Math.pow((D-N+1)/A/2,2)+F*(1-F)/M,v=Math.max(Math.sqrt(C)*O,1),q=Math.round(F*O),oe=Math.max(q-1.96*v,0),be=Math.min(q+1.96*v,O),ee=Math.pow(10,Math.round(Math.log10(v)));return ee>q&&(ee=ee/10),D=Math.round(q/ee)*ee,{recordCount:D,estimatedRange:[Math.round(oe),Math.round(be)]}}return{recordCount:D}}static updatedAttributes(){Vs=this.propertyResolvers={$id:(m,O,I)=>({value:I.key}),$updatedtime:(m,O,I)=>I.version,$record:(m,O,I)=>I?{value:m}:m};for(let m of this.attributes){m.resolve=null;let O=m.relationship;if(O)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),MA=!0,O.to)m.elements?.definition?(Vs[m.name]=m.resolve=(I,y,A)=>{let D=I[O.from?O.from:t],N=m.elements.definition.tableClass;return A?Ca({attribute:O.to,value:D},Tn(y).getReadTxn(),!1,N,!1).asArray:N.search([{attribute:O.to,value:D}],y).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,O.from&&(m.resolve.from=O.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(O.from){let I=m.definition||m.elements?.definition;I?(Vs[m.name]=m.resolve=(y,A,D)=>{let N=y[O.from];if(N!==void 0){if(m.elements){let M,F=N.map(C=>{let v=D?I.tableClass.primaryStore.getEntry(C,{transaction:Tn(A).getReadTxn()}):I.tableClass.get(C,A);return v?.then&&(M=!0),v});return O.filterMissing?M?Promise.all(F).then(C=>C.filter(px)):F.filter(px):M?Promise.all(F):F}return D?I.tableClass.primaryStore.getEntry(N,{transaction:Tn(A).getReadTxn()}):I.tableClass.get(N,A)}},m.set=(y,A)=>{if(Array.isArray(A)){let D=A.map(N=>N[Me]||N[I.tableClass.primaryKey]);y[O.from]=D}else{let D=A[Me]||A[I.tableClass.primaryKey];y[O.from]=D}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=O.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`)}LE(this,this)}static async deleteHistory(m=0){let O;for(let{key:I,value:y}of u.getRange({start:0,end:m}))await Tl(),Dt(y).tableId===n&&(O=u.remove(I));await O}static async*getHistory(m=0,O=1/0){for(let{key:I,value:y}of u.getRange({start:m,end:O})){await Tl();let A=Dt(y);A.tableId===n&&(yield{id:A.recordId,localTime:I,version:A.version,type:A.type,value:A.getValue(i,!0,I),user:A.user})}}static async getHistoryOfRecord(m){let O=[];if(m==null)throw new Error("An id is required");let I=i.getEntry(m);if(!I)return O;let y=I.localTime;if(!y)throw new Error("The entry does not have a local audit time");let A=0;do{await Tl();let D=u.get(y);if(D){let N=Dt(D);O.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(A<1e3&&y);return O.reverse()}static cleanup(){Q?.remove()}}We.updatedAttributes();let oG=We.prototype;return oG[nse]=!0,f&&We.setTTLExpiration(f/1e3),J&&aG(),We;function Ul(Y,m,O){let I;for(let y in r){let A=r[y],D=A.isIndexing,N=O?.[y],M=m?.[y];if(N===M&&!D)continue;I=!0;let F=A.indexNulls,C=(0,Rl.getIndexedValues)(M,F);if(C){dx&&A.prefetch(C.map(v=>({key:v,value:Y})),hx);for(let v=0,q=C.length;v<q;v++)A.remove(C[v],Y)}if(C=(0,Rl.getIndexedValues)(N,F),C){dx&&A.prefetch(C.map(v=>({key:v,value:Y})),hx);for(let v=0,q=C.length;v<q;v++)A.put(C[v],Y)}}return I}a(Ul,"updateIndices");function ja(Y){switch(typeof Y){case"number":return!0;case"string":if(Y.length<659)return!0;if(Y.length>Ex)throw new Error("Primary key size is too large: "+Y.length);break;case"object":if(Y===null)return!0;break;case"bigint":if(Y<2n**64n&&Y>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof Y)}if((0,wo.writeKey)(Y,ise,0)>Ex)throw new Error("Primary key size is too large: "+Y.length);return!0}a(ja,"checkValidId");function rh(Y,m,O,I,y){let A=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),O.transaction?.isDone)return y(null,Y);let D=i.getEntry(Y,O);return D&&m&&(D?.version>(m.lastModified||0)&&(m.lastModified=D.version),D?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=D.localTime)),y(D,Y)},"whenPrefetched");return I?A():ce>0?(ce--,A()):new Promise((D,N)=>{ce===0?(ce--,i.prefetch([Y],()=>{M(),F()})):(X.push(Y),Te.push(F),X.length>iG&&(ce--,M()));function M(){if(X.length>0){let C=Te;i.prefetch(X,()=>{ce===-1?M():ce++;for(let v of C)v()}),X=[],Te=[],de>2&&de--}else ce=de,de<sG&&de++}a(M,"prefetch");function F(){try{D(A())}catch(C){N(C)}}a(F,"load")})}a(rh,"loadLocalRecord");function Pl(Y){if(!Y?.role)return;let m=Y.role.permission;if(m.super_user)return ose;let O=m[c],I,y=O?.tables;if(y)return y[s];if(c==="data"&&(I=m[s])&&!I.tables)return I}a(Pl,"getTablePermissions");function nh(Y,m,O,I){if(L){let y;if(O.noCache?y=!0:(m?(!m.value||m.metadataFlags&(pl|Sl)||m.expiresAt&&m.expiresAt<Date.now())&&(y=!0):y=!0,sn(!y,"cache-hit",s)),y){let A=PA(Y,m,O).then(D=>(D?.value?.[_e]&&Je.error("Can not assign a record with a record property"),O&&(D?.version>(O.lastModified||0)&&(O.lastModified=D.version),O.lastRefreshed=Date.now()),D));if(O?.onlyIfCached||m?.value&&I?.allowStaleWhileRevalidate?.(m,Y)){if(A.catch(D=>Je.warn(D)),O?.onlyIfCached&&!I.doesExist())throw new pn.ServerError("Entry is not cached",504);return}else return A}}}a(nh,"ensureLoadedFromSource");function Tn(Y){let m=Y?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let O=m.next;if(!O)return m=m.next=new Ji,m.lmdbDb=i,m;m=O}while(!0)}else return new Q_}a(Tn,"txnForContext");function sh(Y,m,O){if(!Y)return;th=Y;let I=Y.value||Y.deref?.()||(th=i.getEntry(Y.key))?.value;if(typeof m=="object"){let A=Vs,D=I;for(let N=0,M=m.length;N<M;N++){let F=m[N],C=A?.[F];D=C&&D?C(D,O,!0)?.value:D?.[F],A=C?.definition?.tableClass?.propertyResolvers}return D}let y=Vs[m];return y?y(I,O):I[m]}a(sh,"getAttributeValue");function UA(Y,m,O,I,y){let A=y?.length,D={transaction:I,lazy:A>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},N;function M(F,C){let v=F?.value;if(!v)return No.SKIP;for(let q=0;q<A;q++)if(!N?.includes(q)&&!y[q](v,F))return No.SKIP;return C!==void 0&&(F.key=C),F}if(a(M,"processEntry"),A>0||!Y.hasEntries){let F=Y.map(C=>{if(N=null,typeof C=="object"&&C.key!==void 0)return A>0?M(C):C;if(C==null)return No.SKIP;for(let v=0;v<A;v++){let oe=y[v].idFilter;if(oe){if(!oe(C))return No.SKIP;N||(N=[]),N.push(v)}}return rh(C,O,D,!1,M)});return Array.isArray(Y)&&(F=F.filter(C=>C!==No.SKIP)),F.hasEntries=!0,F}return Y}a(UA,"transformToEntries");async function PA(Y,m,O){let I=m?.metadataFlags,y=m?.version,A,D;if(!i.attemptLock(Y,y,()=>{clearTimeout(D);let C=i.getEntry(Y);!C||!C.value||C.metadataFlags&(pl|Sl)?A(PA(Y,i.getEntry(Y),O)):A(C)}))return new Promise(C=>{A=C,D=setTimeout(()=>{i.unlock(Y,y)},rse)});let N=m?.value,M={requestContext:O,replacingRecord:N,replacingVersion:y,source:null,resourceCache:O?.resourceCache},F=O?.responseHeaders;return new Promise((C,v)=>{let q;pA(ze(M,async oe=>{let be=performance.now(),ee,Pe,ae;try{for(let ge of We.sources)if(ge.get&&(!ge.get.reliesOnPrototype||ge.prototype.get)&&(M.source=ge,ee=await ge.get(Y,M),ee))break;ae=I&pl;let te=M.lastModified||ae&&y;Pe=ae||te>y||!N,te||(te=(0,Rl.getNextMonotonicTime)());let j=performance.now()-be;if(xr(j,"cache-resolution",s),F&&QT(F,"Server-Timing",`cache-resolve;dur=${j.toFixed(2)}`,!0),oe.timestamp=te,f&&!M.expiresAt&&(M.expiresAt=Date.now()+f),ee){if(typeof ee!="object")throw new Error("Only objects can be cached and stored in tables");typeof ee.toJSON=="function"&&(ee=ee.toJSON()),t&&ee[t]!==Y&&(ee[t]=Y)}q=!0,C({version:te,value:ee})}catch(te){te.message+=` while resolving record ${Y} for ${s}`,N&&((te.code==="ECONNRESET"||te.code==="ECONNREFUSED"||te.code==="EAI_AGAIN")&&!O?.mustRevalidate||O?.staleIfError&&(te.statusCode===500||te.statusCode===502||te.statusCode===503||te.statusCode===504))?(C({version:y,value:N}),Je.trace(te.message,"(returned stale record)")):v(te),M.transaction.abort();return}if(O?.noCacheStore){M.transaction.abort();return}Tn(M).addWrite({key:Y,store:i,entry:m,nodeName:"source",commit:(te,j)=>{if(j?.version!==y)return;let ge=Ul(Y,N,ee);ee?(Be.put?.(M,Y,ee),T(Y,ee,j,te,0,h&&Pe||null,M,M.expiresAt,"put",!!ae)):(Be.delete?.(M,Y),h||p?T(Y,null,j,te,0,h&&Pe||null,M,0,"delete",!!ae):i.remove(Y,y))}})}),()=>{i.unlock(Y,y)},oe=>{i.unlock(Y,y),q&&Je.error("Error committing cache update",oe)})})}a(PA,"getFromSource");function ih(){if(Ct!==Ll&&(Ll=Ct,(0,Io.getWorkerIndex)()===(0,Io.getWorkerCount)()-1)){if(Ml&&clearTimeout(Ml),!Ct)return;let Y=new Date;Y.setMonth(0),Y.setDate(1),Y.setHours(0),Y.setMinutes(0),Y.setSeconds(0);let m=Math.ceil((Date.now()-Y.getTime())/Ct)*Ct+Y.getTime(),O=a(I=>{Je.trace(`Scheduled next cleanup scan at ${new Date(I)}ms`),Ml=setTimeout(()=>P=P.then(async()=>{if(O(Math.max(I+Ct,Date.now())),i.rootStore.status!=="open"){clearTimeout(Ml);return}let y=50,A=new Array(y),D=0;Je.trace(`Starting cleanup scan for ${s}`);try{let N=0;for(let{key:M,value:F,version:C,expiresAt:v}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let q;F===null&&!h&&C+tse<Date.now()?q=i.remove(M,C):v&&v+E<Date.now()&&(q=We.evict(M,F,C),N++),q&&(await A[D],A[D]=q.catch(oe=>{Je.error("Cleanup error",oe)}),++D>=y&&(D=0)),await Tl()}Je.trace(`Finished cleanup scan for ${s}, evicted ${N} entries`)}catch(N){Je.trace(`Error in cleanup scan for ${s}:`,N)}}),Math.min(I-Date.now(),2147483647)).unref()},"startNextTimer");O(m)}}a(ih,"scheduleCleanup");function vA(){Q=u?.addDeleteRemovalCallback(n,Y=>{let m=i.getEntry(Y);m?.value===null&&i.remove(Y,m.version)})}a(vA,"addDeleteRemoval");function aG(){(0,Io.getWorkerIndex)()===0&&setInterval(async()=>{try{let Y=J.name,m=r[Y];if(!m)throw new Error(`expiresAt attribute ${J} must be indexed`);for(let{key:O,value:I}of m.getRange({start:!0,end:Date.now(),versions:!0,snapshot:!1})){let y=i.getEntry(I);y?.value?y.value[Y]<Date.now()&&We.evict(I,y.value,y.version):i.ifVersion(I,y?.version,()=>m.remove(O,I)),await Tl()}}catch(Y){Je.error("Error in evicting old records",Y)}},ese).unref()}a(aG,"runRecordExpirationEviction")}function mA(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 hx(){}function ase(e){Tx=e}function vE(e,t){let r=t?.type;return e===null?e:e===""&&r&&r!=="String"&&r!=="Any"?null:r==="Int"||r==="Long"?e==="null"?null:parseInt(e):r==="Float"?e==="null"?null:parseFloat(e):r==="BigInt"?e==="null"?null:BigInt(e):r==="Boolean"?e==="true"?!0:e==="false"?!1:e:r==="Date"?(typeof e!="number"&&!cse.test(e)&&(e+="Z"),e==="null"?null:new Date(e)):!r||r==="Any"?(0,HE.autoCast)(e):e}function mx(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t;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 pA(e,t,r){return e?.then?e.then(t,r):t(e)}function BE(e,t){e[zr]=t,e[_e]=t?.value??null,e[gl]=t?.version}function px(e){return e!=null}function Fn(e){try{return JSON.stringify(e)}catch{return e}}var qn,No,Rl,Sx,bl,pn,Al,Ol,Je,wo,Io,HE,Zne,Tx,ese,tse,dx,rse,gl,nse,zr,ml,fx,sse,hA,Wa,pl,Sl,ise,Ex,ose,Zme,cse,Tl,Kf=Re(()=>{qn=x(U()),No=require("lmdb"),Rl=x(Ir()),Sx=require("lodash");An();kp();bl=x(re());_x();pn=x(ne()),Al=x(Ts()),Ol=x(wn());Ae();Mf();Je=x(K());X_();Xi();wo=require("ordered-binary"),Io=x(Ze());Mi();HE=x(z());Ho();Os();bE();vu();Zne=new Uint8Array(9);Zne[8]=192;ese=6e4,tse=864e5;bl.initSync();dx=bl.get(qn.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),rse=1e4,gl=Symbol.for("version"),nse=Symbol.for("incremental-update"),zr=Symbol("entry"),ml=Symbol("is-saving"),fx=1,sse=2,hA=Symbol("loaded-from-source"),Wa={isNotification:!0,ensureLoaded:!1},pl=1,Sl=8,ise=Buffer.allocUnsafeSlow(8192),Ex=1978,ose={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},Zme=(0,HE.convertToMS)(bl.get(qn.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(xE,"makeTable");a(mA,"attributesAsObject");a(hx,"noop");a(ase,"setServerUtilities");cse=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(vE,"coerceType");a(mx,"isDescendantId");Tl=a(()=>new Promise(setImmediate),"rest");a(pA,"when");a(BE,"updateResource");a(px,"exists");a(Fn,"stringify")});var Fe={};$e(Fe,{database:()=>Wc,databases:()=>et,dropDatabase:()=>Wp,dropTableMeta:()=>Ese,getDatabases:()=>Dn,getTables:()=>use,onUpdatedTable:()=>UR,readMetaDb:()=>yl,resetDatabases:()=>lse,table:()=>at,tables:()=>wr});function use(){return VE||Dn(),wr||{}}function Dn(){if(VE)return et;VE=!0,Ja=new Map;let e=(0,Zt.getHdbBasePath)()&&(0,Xe.join)((0,Zt.getHdbBasePath)(),Xr.DATABASES_DIR_NAME),t=(0,Zt.get)(Xr.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Zt.get)(Xr.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,Jr.existsSync)(e)?e:(0,Xe.join)((0,Zt.getHdbBasePath)(),Xr.LEGACY_DATABASES_DIR_NAME)),!!e){if((0,Jr.existsSync)(e))for(let r of(0,Jr.readdirSync)(e,{withFileTypes:!0})){let n=(0,Xe.basename)(r.name,".mdb");r.isFile()&&(0,Xe.extname)(r.name).toLowerCase()===".mdb"&&!t[n]?.path&&yl((0,Xe.join)(e,r.name),null,n)}if((0,Jr.existsSync)((0,za.getBaseSchemaPath)())){for(let r of(0,Jr.readdirSync)((0,za.getBaseSchemaPath)(),{withFileTypes:!0}))if(!r.isFile()){let n=(0,Xe.join)((0,za.getBaseSchemaPath)(),r.name),s=(0,Xe.join)((0,za.getTransactionAuditStoreBasePath)(),r.name);for(let i of(0,Jr.readdirSync)(n,{withFileTypes:!0}))if(i.isFile()&&(0,Xe.extname)(i.name).toLowerCase()===".mdb"){let o=(0,Xe.join)(s,i.name);yl((0,Xe.join)(n,i.name),(0,Xe.basename)(i.name,".mdb"),r.name,o,!0)}}}if(t)for(let r in t){let n=t[r],s=n.path;if((0,Jr.existsSync)(s))for(let o of(0,Jr.readdirSync)(s,{withFileTypes:!0}))o.isFile()&&(0,Xe.extname)(o.name).toLowerCase()===".mdb"&&yl((0,Xe.join)(s,o.name),(0,Xe.basename)(o.name,".mdb"),r);let i=n.tables;if(i)for(let o in i){let c=i[o],u=(0,Xe.join)(c.path,(0,Xe.basename)(o+".mdb"));(0,Jr.existsSync)(u)&&yl(u,o,r,null,!0)}}for(let r in et){let n=Ja.get(r);if(n){let s=et[r];r.includes("delete")&&Sn.trace(`defined tables ${Array.from(n.keys())}`);for(let i in s)n.has(i)||(Sn.trace(`delete table class ${i}`),delete s[i])}else if(delete et[r],r==="data"){for(let s in wr)delete wr[s];delete wr[$E]}}return Ja=null,et}}function lse(){VE=!1;for(let[,e]of yi)e.needsDeletion=!0;Dn();for(let[e,t]of yi)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),yi.delete(e));return et}function yl(e,t,r=gA,n,s){let i=new SA.default(e,!1);try{let o=yi.get(e);o?o.needsDeletion=!1:(o=(0,FE.open)(i),yi.set(e,o));let c=new Co.default(!1),u=o.dbisDb||(o.dbisDb=o.openDB(GE.INTERNAL_DBIS_NAME,c)),_=o.auditStore;_||(n?(0,Jr.existsSync)(n)&&(i.path=n,_=(0,FE.open)(i),_.isLegacy=!0):_=OE(o));let l=Ox(r),d=l[$E],f=new Map;for(let{key:E,value:h}of u.getRange({start:!1})){let[p,S]=E.toString().split("/");S===""?S=h.name:S||(S=p,p=t,h.name||(h.name=S,h.indexed=!h.is_hash_attribute)),d?.add(p);let T=f.get(p);T||f.set(p,T={attributes:[]}),(S==null||h.is_hash_attribute)&&(T.primary=h),S!=null&&T.attributes.push(h),Object.defineProperty(h,"key",{value:E,configurable:!0})}for(let[E,h]of f){let{attributes:p,primary:S}=h;if(!S){for(let X of p)if(X.is_hash_attribute||X.isPrimaryKey){S=X;break}if(!S){Sn.fatal(`Unable to find a primary key attribute on table ${E}, with attributes: ${JSON.stringify(p)}`);continue}}let T=l[E],b={},R=[],L,H,P=typeof S.audit=="boolean"?S.audit:(0,Zt.get)(Xr.CONFIG_PARAMS.LOGGING_AUDITLOG),k=S.trackDeletes,B=S.expiration,J=S.eviction,Q=S.sealed;if(T)b=T.indices,R=T.attributes,T.schemaVersion++;else{L=S.tableId,L?L>=(u.get(Qa)||0)&&u.putSync(Qa,L+1):(S.tableId=L=u.get(Qa),L||(L=1),u.putSync(Qa,L+1),u.putSync(S.key,S));let X=new Co.default(!S.is_hash_attribute,S.is_hash_attribute);H=e_(o.openDB(S.key,X)),H.rootStore=o,H.tableId=L}for(let X of p){X.attribute=X.name;try{if(!X.is_hash_attribute&&(X.indexed||X.attribute&&!X.name)){if(!b[X.name]){let ce=new Co.default(!X.is_hash_attribute,X.is_hash_attribute);b[X.name]=o.openDB(X.key,ce),b[X.name].indexNulls=X.indexNulls}let Te=R.find(ce=>ce.name===X.name);Te?R.splice(R.indexOf(Te),1,X):R.push(X)}}catch(Te){Sn.error("Error trying to update attribute",X,R,b,Te)}}if(!T){T=bx(l,E,xE({primaryStore:H,auditStore:_,audit:P,sealed:Q,expirationMS:B&&B*1e3,evictionMS:J&&J*1e3,trackDeletes:k,tableName:E,tableId:L,primaryKey:S.name,databasePath:s?r+"/"+E:r,databaseName:r,indices:b,attributes:p,schemaDefined:S.schemaDefined,dbisDB:u})),T.schemaVersion=1;for(let X of RA)X(T)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function Ox(e){let t=et[e];if(t||(e==="data"?t=et[e]=wr:e==="system"?Object.defineProperty(et,"system",{value:t=Object.create(null),configurable:!0}):t=et[e]=Object.create(null)),Ja&&!Ja.has(e)){let r=new Set;t[$E]=r,Ja.set(e,r)}return t}function bx(e,t,r){return e[t]=r,r}function Wc({database:e,table:t}){e||(e=gA),Dn();let r=Ox(e),n=(0,Xe.join)((0,Zt.getHdbBasePath)(),Xr.DATABASES_DIR_NAME),s=(0,Zt.get)(Xr.CONFIG_PARAMS.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,Zt.get)(Xr.CONFIG_PARAMS.STORAGE_PATH)||((0,Jr.existsSync)(n)?n:(0,Xe.join)((0,Zt.getHdbBasePath)(),Xr.LEGACY_DATABASES_DIR_NAME));let o=(0,Xe.join)(n,(i?t:e)+".mdb"),c=yi.get(o);if(!c){let u=new SA.default(o,!1);c=(0,FE.open)(u),yi.set(o,c)}return c}async function Wp(e){if(!et[e])throw new Error("Schema does not exist");let t=et[e];for(let r in t){let s=t[r].primaryStore.rootStore;yi.delete(s.path),s.status==="open"&&(await s.close(),await gx.remove(s.path))}if(e==="data"){for(let r in wr)delete wr[r];delete wr[$E]}delete et[e]}function at({table:e,database:t,expiration:r,eviction:n,scanInterval:s,attributes:i,audit:o,sealed:c,trackDeletes:u,schemaDefined:_,origin:l}){t||(t=gA);let d=Wc({database:t,table:e}),f=et[t],E=f?.[e];if(d.status==="closed")throw new Error(`Can not use a closed data store for ${e}`);let h,p,S,T;_==null&&(_=!0);let b=new Co.default(!1);for(let B of i)B.attribute?(B.name=B.attribute,B.indexed=!0):B.attribute=B.name,B.expiresAt&&(B.indexed=!0);let R,L;if(E){if(h=E.primaryKey,E.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${e} class`);E.attributes.splice(0,E.attributes.length,...i)}else{let B=d.auditStore;B||(B=OE(d)),p=i.find(Te=>Te.isPrimaryKey)||{},h=p.name,p.is_hash_attribute=!0,p.schemaDefined=_,u&&(p.trackDeletes=!0),o=p.audit=typeof o=="boolean"?o:(0,Zt.get)(Xr.CONFIG_PARAMS.LOGGING_AUDITLOG),r&&(p.expiration=r),n&&(p.eviction=n),typeof c=="boolean"&&(p.sealed=c),l&&(p.origins?p.origins.includes(l)||p.origins.push(l):p.origins=[l]),Sn.trace(`${e} table loading, opening primary store`);let J=new Co.default(!1,!0),Q=e+"/",X=e_(d.openDB(Q,J));X.rootStore=d,T=d.dbisDb=d.openDB(GE.INTERNAL_DBIS_NAME,b),X.tableId=T.get(Qa),X.tableId||(X.tableId=1),T.putSync(Qa,X.tableId+1),p.tableId=X.tableId,E=bx(f,e,xE({primaryStore:X,auditStore:B,audit:o,sealed:c,trackDeletes:u,expirationMS:r&&r*1e3,evictionMS:n&&n*1e3,primaryKey:h,tableName:e,tableId:X.tableId,databasePath:t,databaseName:t,indices:{},attributes:i,schemaDefined:_,dbisDB:T})),E.schemaVersion=1,R=!0,k(),T.put(Q,p)}S=E.indices,T=T||(d.dbisDb=d.openDB(GE.INTERNAL_DBIS_NAME,b)),E.dbisDB=T;let H=[];for(let{key:B,value:J}of T.getRange({start:!0})){let[Q,X]=B.toString().split("/");if(X===""&&(X=J.name),X){if(Q!==e)continue}else X=Q;if(!i.find(ce=>ce.name===X)?.indexed&&J.indexed&&!J.isPrimaryKey){k(),R=!0,T.remove(B);let ce=E.indices[Q];ce&&H.push(ce)}}let P=[];try{for(let B of i||[]){if(B.relationship)continue;let J=e+"/"+(B.name||"");Object.defineProperty(B,"key",{value:J,configurable:!0});let Q=T.get(J);if(B.isPrimaryKey){if(Q=Q||T.get(J=e+"/")||{},o!==E.audit||c!==c||(+r||void 0)!==(+Q.expiration||void 0)||(+n||void 0)!==(+Q.eviction||void 0)){let Te=Object.assign({},Q);typeof o=="boolean"&&(o&&E.enableAuditing(o),Te.audit=o),r&&(Te.expiration=+r),n&&(Te.eviction=+n),c!==void 0&&(Te.sealed=c),R=!0,k(),T.put(J,Te)}continue}Q?.attribute&&!Q.name&&(Q.indexed=!0);let X=!Q||Q.type!==B.type||Q.indexed!==B.indexed||Q.nullable!==B.nullable||JSON.stringify(Q.attributes)!==JSON.stringify(B.attributes)||JSON.stringify(Q.elements)!==JSON.stringify(B.elements);if(B.indexed){let Te=new Co.default(!0,!1),ce=d.openDB(J,Te);(X||Q.indexingPID&&Q.indexingPID!==process.pid||Q.restartNumber<Nl.workerData?.restartNumber)&&(R=!0,k(),Q=T.get(J),(X||Q.indexingPID&&Q.indexingPID!==process.pid||Q.restartNumber<Nl.workerData?.restartNumber)&&(R=!0,B.lastIndexedKey=Q?.lastIndexedKey||!1,B.indexingPID=process.pid,ce.isIndexing=!0,Object.defineProperty(B,"dbi",{value:ce}),B.indexNulls===void 0&&(B.indexNulls=!0),P.push(B)),T.put(J,B)),Q?.indexNulls&&B.indexNulls===void 0&&(B.indexNulls=!0),ce.indexNulls=B.indexNulls,S[B.name]=ce}else X&&(R=!0,k(),T.put(J,B))}}finally{L&&L()}if(R&&(E.schemaVersion++,E.updatedAttributes()),Sn.trace(`${e} table loading, running index`),P.length>0||H.length>0?E.indexingOperation=fse(E,P,H):R&&qE.signalSchemaChange(new kE.SchemaEventMsg(process.pid,"schema-change",E.databaseName,E.tableName)),E.origin=l,R)for(let B of RA)B(E,l!=="cluster");return(r||n||s)&&E.setTTLExpiration({expiration:r,eviction:n,scanInterval:s}),Sn.trace(`${e} table loaded`),E;function k(){L||d.transactionSync(()=>({then(B){L=B}}))}a(k,"startTxn")}async function fse(e,t,r){try{let n=e.schemaVersion;await qE.signalSchemaChange(new kE.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o=0,c=t.length;if(await new Promise(u=>setImmediate(u)),c>0){let u=0;for(let{key:_,value:l,version:d}of e.primaryStore.getRange({start:t[0].lastIndexedKey,lazy:c<4,versions:!0,snapshot:!1}))if(l){if(u++,s=e.primaryStore.ifVersion(_,d,()=>{for(let f=0;f<c;f++){let E=t[f],h=E.name,p=(0,Rx.getIndexedValues)(l[h]);if(p)for(let S=0,T=p.length;S<T;S++)E.dbi.put(p[S],_)}}),s.then(()=>u--,f=>{u--,Sn.error(f)}),Nl.workerData&&Nl.workerData.restartNumber!==Ax.restartNumber&&(i=!0),++o%100===0||i){for(let f of t)f.lastIndexedKey=_,e.dbisDB.put(f.key,f);if(i)return}u>_se?await s:u>dse&&await new Promise(f=>setImmediate(f))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await qE.signalSchemaChange(new kE.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName))}catch(n){Sn.error("Error in indexing",n)}}function Ese({table:e,database:t}){let r=Wc({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 UR(e){RA.push(e)}var Zt,GE,FE,Xe,Jr,za,Co,SA,Xr,gx,TA,Rx,qE,kE,Nl,Sn,Ax,gA,$E,wr,et,Qa,RA,VE,yi,Ja,_se,dse,Ae=Re(()=>{Zt=x(re()),GE=x(_t()),FE=require("lmdb"),Xe=require("path"),Jr=require("fs"),za=x(Qe());Kf();Co=x(t_()),SA=x(n_()),Xr=x(U()),gx=x(require("fs-extra")),TA=require("../../index"),Rx=x(Ir()),qE=x(Ts()),kE=x(wn()),Nl=require("worker_threads"),Sn=x(K()),Ax=x(Ze());Mi();Ho();gA="data",$E=Symbol("defined-tables");(0,Zt.initSync)();wr=Object.create(null),et=Object.create(null);(0,TA._assignPackageExport)("databases",et);(0,TA._assignPackageExport)("tables",wr);Qa=Symbol.for("next-table-id"),RA=[],yi=new Map;a(use,"getTables");a(Dn,"getDatabases");a(lse,"resetDatabases");a(yl,"readMetaDb");a(Ox,"ensureDB");a(bx,"setTable");a(Wc,"database");a(Wp,"dropDatabase");a(at,"table");_se=1e3,dse=10;a(fse,"runIndexing");a(Ese,"dropTableMeta");a(UR,"onUpdatedTable")});var z=g((cpe,xx)=>{"use strict";var Ni=require("path"),Cx=require("fs-extra"),br=K(),yx=require("fs-extra"),YE=require("os"),hse=require("net"),mse=require("recursive-iterator"),ot=U(),pse=EO(),Nx=require("papaparse"),KE=require("moment"),{inspect:Sse}=require("util"),Ix=require("is-number"),ape=require("lodash"),Tse=require("minimist"),gse=require("https"),Rse=require("http"),{hdb_errors:WE}=ne(),Ase=/^((\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)))$/,Dx=require("util").promisify(setTimeout),Ose=100,bse=5,yse="",Nse=4,wx={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};xx.exports={isEmpty:jr,isEmptyOrZeroLength:ls,arrayHasEmptyValues:Cse,arrayHasEmptyOrZeroLengthValues:Dse,buildFolderPath:Lse,isBoolean:Lx,errorizeMessage:Ise,stripFileExtension:Use,autoCast:Pse,autoCastJSON:Mx,autoCastJSONDeep:OA,removeDir:vse,compareVersions:Bse,isCompatibleDataVersion:Hse,escapeRawValue:xse,unescapeValue:Gse,stringifyProps:Fse,timeoutPromise:kse,isClusterOperation:$se,getClusterUser:Kse,checkGlobalSchemaTable:Yse,getHomeDir:Px,getPropsFilePath:qse,promisifyPapaParse:Wse,removeBOM:vx,createEventPromise:Qse,checkProcessRunning:zse,checkSchemaTableExist:Jse,checkSchemaExists:Bx,checkTableExists:Hx,getStartOfTomorrowInSeconds:Xse,getLimitKey:jse,isObject:Mse,isNotEmptyAndHasValue:wse,autoCasterIsNumberCheck:Ux,backtickASTSchemaItems:Zse,isPortTaken:Vse,createForkArgs:eie,autoCastBoolean:tie,async_set_timeout:Dx,getTableHashAttribute:rie,doesSchemaExist:nie,doesTableExist:sie,stringifyObj:iie,ms_to_time:oie,changeExtension:aie,getEnvCliRootPath:bA,noBootFile:cie,httpRequest:uie,transformReq:lie,convertToMS:_ie,PACKAGE_ROOT:ot.PACKAGE_ROOT};function Ise(e){return e instanceof Error?e:new Error(e)}a(Ise,"errorizeMessage");function jr(e){return e==null}a(jr,"isEmpty");function wse(e){return!jr(e)&&(e||e===0||e===""||Lx(e))}a(wse,"isNotEmptyAndHasValue");function ls(e){return jr(e)||e.length===0||e.size===0}a(ls,"isEmptyOrZeroLength");function Cse(e){if(jr(e))return!0;for(let t=0;t<e.length;t++)if(jr(e[t]))return!0;return!1}a(Cse,"arrayHasEmptyValues");function Dse(e){if(ls(e))return!0;for(let t=0;t<e.length;t++)if(ls(e[t]))return!0;return!1}a(Dse,"arrayHasEmptyOrZeroLengthValues");function Lse(...e){try{return e.join(Ni.sep)}catch{console.error(e)}}a(Lse,"buildFolderPath");function Lx(e){return jr(e)?!1:e===!0||e===!1}a(Lx,"isBoolean");function Mse(e){return jr(e)?!1:typeof e=="object"}a(Mse,"isObject");function Use(e){return ls(e)?yse:e.slice(0,-Nse)}a(Use,"stripFileExtension");function Pse(e){return jr(e)||e===""||typeof e!="string"?e:wx[e]!==void 0?wx[e]:Ux(e)===!0?Number(e):Ase.test(e)?new Date(e):e}a(Pse,"autoCast");function Mx(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(Mx,"autoCastJSON");function OA(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=OA(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=OA(r);n!==r&&(e[t]=n)}return e}else return Mx(e)}a(OA,"autoCastJSONDeep");function Ux(e){if(e.startsWith("0.")&&Ix(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&Ix(e))}a(Ux,"autoCasterIsNumberCheck");async function vse(e){if(ls(e))throw new Error(`Directory path: ${e} does not exist`);try{await yx.emptyDir(e),await yx.remove(e)}catch(t){throw br.error(`Error removing files in ${e} -- ${t}`),t}}a(vse,"removeDir");function Bse(e,t){if(ls(e)){br.info("Invalid current version sent as parameter.");return}if(ls(t)){br.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("."),u=Math.min(o.length,c.length);for(let _=0;_<u;_++)if(r=parseInt(o[_],10)-parseInt(c[_],10),r)return r;return o.length-c.length}a(Bse,"compareVersions");function Hse(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(Hse,"isCompatibleDataVersion");function xse(e){if(jr(e))return e;let t=String(e);return t==="."?ot.UNICODE_PERIOD:t===".."?ot.UNICODE_PERIOD+ot.UNICODE_PERIOD:t.replace(ot.FORWARD_SLASH_REGEX,ot.UNICODE_FORWARD_SLASH)}a(xse,"escapeRawValue");function Gse(e){if(jr(e))return e;let t=String(e);return t===ot.UNICODE_PERIOD?".":t===ot.UNICODE_PERIOD+ot.UNICODE_PERIOD?"..":String(e).replace(ot.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(Gse,"unescapeValue");function Fse(e,t){if(jr(e))return br.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+YE.EOL}!ls(n)&&n[0]===";"?r+=" "+n+s+YE.EOL:ls(n)||(r+=n+"="+s+YE.EOL)}catch{br.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(Fse,"stringifyProps");function Px(){let e;try{e=YE.homedir()}catch{e=process.env.HOME}return e||(e="~/"),e}a(Px,"getHomeDir");function qse(){let e=Ni.join(Px(),ot.HDB_HOME_DIR_NAME,ot.BOOT_PROPS_FILE_NAME);return Cx.existsSync(e)||(e=Ni.join(__dirname,"../","hdb_boot_properties.file")),e}a(qse,"getPropsFilePath");function kse(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:function(){clearTimeout(r)}}}a(kse,"timeoutPromise");async function Vse(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=hse.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(Vse,"isPortTaken");function $se(e){try{return ot.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){br.error(`Error checking operation against cluster ops ${t}`)}return!1}a($se,"isClusterOperation");function Yse(e,t){let r=(Ae(),se(Fe)).getDatabases();if(!r[e])return WE.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return WE.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Yse,"checkGlobalSchemaTable");function Kse(e,t){if(jr(t)){br.warn("No CLUSTERING_USER defined, clustering disabled");return}if(jr(e)||ls(e)){br.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){br.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){br.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(Kse,"getClusterUser");function Wse(){Nx.parsePromise=function(e,t,r){return new Promise(function(n,s){Nx.parse(e,{header:!0,transformHeader:vx,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(Wse,"promisifyPapaParse");function vx(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(vx,"removeBOM");function Qse(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;br.info(`Got cluster status event response: ${Sse(s)}`);try{i.cancel()}catch{br.error("Error trying to cancel timeout.")}n(s)})})}a(Qse,"createEventPromise");async function zse(e){let t=!0,r=0;do await Dx(Ose*r++),(await pse.findPs(e)).length>0&&(t=!1);while(t&&r<bse);if(t)throw new Error(`process ${e} was not started`)}a(zse,"checkProcessRunning");function Jse(e,t){let r=Bx(e);if(r)return r;let n=Hx(e,t);if(n)return n}a(Jse,"checkSchemaTableExist");function Bx(e){let{getDatabases:t}=(Ae(),se(Fe));if(!t()[e])return WE.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(Bx,"checkSchemaExists");function Hx(e,t){let{getDatabases:r}=(Ae(),se(Fe));if(!r()[e][t])return WE.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Hx,"checkTableExists");function Xse(){let e=KE().utc().add(1,ot.MOMENT_DAYS_TAG).startOf(ot.MOMENT_DAYS_TAG).unix(),t=KE().utc().unix();return e-t}a(Xse,"getStartOfTomorrowInSeconds");function jse(){return KE().utc().format("DD-MM-YYYY")}a(jse,"getLimitKey");function Zse(e){try{let t=new mse(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){br.error("Got an error back ticking items."),br.error(t)}}a(Zse,"backtickASTSchemaItems");function eie(e){return[e]}a(eie,"createForkArgs");function tie(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(tie,"autoCastBoolean");function rie(e,t){let{getDatabases:r}=(Ae(),se(Fe)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(rie,"getTableHashAttribute");function nie(e){let{getDatabases:t}=(Ae(),se(Fe));return t()[e]!==void 0}a(nie,"doesSchemaExist");function sie(e,t){let{getDatabases:r}=(Ae(),se(Fe));return r()[e]?.[t]!==void 0}a(sie,"doesTableExist");function iie(e){try{return JSON.stringify(e)}catch{return e}}a(iie,"stringifyObj");function oie(e){let t=KE.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(oie,"ms_to_time");function aie(e,t){let r=Ni.basename(e,Ni.extname(e));return Ni.join(Ni.dirname(e),r+t)}a(aie,"changeExtension");function bA(){if(process.env[ot.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[ot.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=Tse(process.argv);if(e[ot.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[ot.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(bA,"getEnvCliRootPath");var AA;function cie(){if(AA)return AA;let e=bA();bA()&&Cx.pathExistsSync(Ni.join(e,ot.HDB_CONFIG_FILE))&&(AA=!0)}a(cie,"noBootFile");function uie(e,t){let r;return e.protocol==="http:"?r=Rse:r=gse,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8");let c={body:"",headers:o.headers};o.on("data",u=>{c.body+=u}),o.on("end",()=>{n(c)})});i.on("error",o=>{s(o)}),i.write(JSON.stringify(t)),i.end()})}a(uie,"httpRequest");function lie(e){if(!e.schema&&!e.database){e.schema=ot.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(lie,"transformReq");function _ie(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(_ie,"convertToMS")});var re=g((lpe,kx)=>{"use strict";var yA=require("fs-extra"),Do=require("path"),Gx=require("os"),die=require("properties-reader"),wl=K(),Il=z(),ue=U(),QE=Ur(),fie="Error initializing environment manager",zE="BOOT_PROPS_FILE_PATH",Fx=!1,Eie={[ue.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},ks={};kx.exports={BOOT_PROPS_FILE_PATH:zE,getHdbBasePath:hie,setHdbBasePath:mie,get:qx,initSync:Sie,setProperty:Ue,initTestEnvironment:Tie};function hie(){return ks[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(hie,"getHdbBasePath");function mie(e){ks[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(mie,"setHdbBasePath");function qx(e){let t=QE.getConfigValue(e);return t===void 0?ks[e]:t}a(qx,"get");function Ue(e,t){Eie[e]&&(ks[e]=t),QE.updateConfigObject(e,t)}a(Ue,"setProperty");function pie(){let e;try{e=Il.getPropsFilePath(),yA.accessSync(e,yA.constants.F_OK|yA.constants.R_OK),Fx=!0;let t=die(e);return ks[ue.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(ue.HDB_SETTINGS_NAMES.INSTALL_USER),ks[ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),ks[zE]=e,!0}catch{return wl.trace(`Environment manager found no properties file at ${e}`),!1}}a(pie,"doesPropFileExist");function Sie(e=!1){try{(Fx||pie()||Il.noBootFile())&&(QE.initConfig(e),ks[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=QE.getConfigValue(ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){wl.error(fie),wl.error(t),console.error(t),process.exit(1)}}a(Sie,"initSync");function Tie(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,u=Do.join(__dirname,"../../","unitTests");ks[zE]=Do.join(u,"hdb_boot_properties.file"),Ue(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Do.join(u,"settings.test")),Ue(ue.HDB_SETTINGS_NAMES.INSTALL_USER,Gx.userInfo()?Gx.userInfo().username:void 0),Ue(ue.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Ue(ue.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Do.join(u,"envDir","log")),Ue(ue.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Ue(ue.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Ue(ue.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Ue(ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Do.join(u,"envDir")),Ue(ue.CONFIG_PARAMS.STORAGE_PATH,Do.join(u,"envDir")),s&&(Ue(ue.CONFIG_PARAMS.HTTP_SECUREPORT,qx(ue.CONFIG_PARAMS.HTTP_PORT)),Ue(ue.CONFIG_PARAMS.HTTP_PORT,null)),Ue(ue.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Ue(ue.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Ue(ue.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Il.isEmpty(i)?!1:i),Ue(ue.CONFIG_PARAMS.HTTP_CORS,Il.isEmpty(i)?!1:i),Ue(ue.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Ue(ue.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Ue(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Ue(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Ue(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Do.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Ue(ue.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Il.isEmpty(c)?!1:c),o&&(Ue("CORS_ACCESSLIST",o),Ue(ue.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Ue(ue.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Ue(ue.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Ue(ue.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Ue(ue.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Ue(ue.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Ue(ue.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${zE}. Please check your boot props and settings files`;wl.fatal(r),wl.error(t)}}a(Tie,"initTestEnvironment")});var aH=g(Lo=>{var{isMainThread:Qx,parentPort:Dl,threadId:JE}=require("worker_threads"),{Socket:gie,createServer:Rie}=require("net"),{createServer:Aie,IncomingMessage:Oie}=require("http"),{createServer:bie}=require("https"),{readFileSync:Xa,unlinkSync:Vx,existsSync:yie}=require("fs"),er=K(),De=re(),Tt=U(),{server:eh}=(sr(),se(Ci)),{WebSocketServer:Nie}=require("ws"),{createServer:Iie}=require("tls"),{getTicketKeys:wie,restartNumber:Cie,getWorkerIndex:jE}=Ze(),{Headers:zx,appendHeader:Die}=(vu(),se(ZU)),{recordAction:Cl,recordActionBinary:Lie}=(Os(),se(ru)),{Request:Jx,createReuseportFd:$x}=(cE(),se(NR)),{checkMemoryLimit:Mie}=Yi(),Xx=require("tls"),Yx=Xx.createSecureContext;Xx.createSecureContext=function(e){if(!e.cert||!e.key)return Yx(e);let t={...e};delete t.key,delete t.cert;let r=Yx(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var jx=De.get(Tt.CONFIG_PARAMS.THREADS_DEBUG);if(jx){let e;if(Qx)e=De.get(Tt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){er.info("Could not close debugger",t)}});else{let t=De.get(Tt.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&jE()>=0&&(e=t+jE())}if(e){let t=De.get(Tt.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=De.get(Tt.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){er.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE)try{require("inspector").open(9229)}catch(e){Cie<=1&&er.trace("Could not start debugging on port 9229, you may already be debugging:",e.message)}process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)});var{HDB_SETTINGS_NAMES:dpe,CONFIG_PARAMS:Uie}=Tt;De.initSync();var Pie=De.get(Uie.HTTP_SESSIONAFFINITY),_s={};Lo.registerServer=DA;Lo.httpServer=LA;Lo.deliverSocket=CA;Lo.startServers=Zx;Lo.when_components_loaded=null;eh.http=LA;eh.request=xie;eh.socket=Gie;eh.ws=Fie;var NA={},XE={},vie,Ii={},ZE={},Bie=[],IA=[];function Zx(){return Lo.when_components_loaded=QR().loadRootComponents(!0).then(()=>{Dl?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)CA(n,r,s);else if(t.requestId)Hie(t);else if(t.type===Tt.ITC_EVENT_TYPES.SHUTDOWN){er.trace("received shutdown request",JE);for(let i in _s){let o=_s[i],c;if(o.closeIdleConnections){let _=Object.getOwnPropertySymbols(o).find(f=>f.description.includes("connections")),l=0,d=setInterval(()=>{l++;let f=l>=100,E=o[_][f?"all":"idle"]();if(E.length===0){f&&clearInterval(d);return}l===1?er.info(`Closing ${E.length} idle connections`):f&&er.warn(`Forcefully closing ${E.length} active connections`);for(let h=0,p=E.length;h<p;h++){let S=E[h].socket;S._httpMessage&&!S._httpMessage.finished&&!f||(f?S.destroySoon():S.end(`HTTP/1.1 408 Request Timeout\r
|
|
27
27
|
Connection: close\r
|
|
28
28
|
\r
|
|
29
|
-
`))}},25).unref()}o.close?.(()=>{if(De.get(
|
|
30
|
-
`)}a(
|
|
29
|
+
`))}},25).unref()}o.close?.(()=>{if(De.get(Tt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&jE()==0)try{Vx(De.get(Tt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,JE),o.cantCleanupProperly||er.warn("Had to forcefully exit the thread",JE),process.exit(0)},5e3).unref()})}if(jx||process.env.DEV_MODE)try{require("inspector").close()}catch(i){er.info("Could not close debugger",i)}}}).ref();let e=[];if($x&&!Pie)for(let t in _s){let r=_s[t];if(isNaN(t)&&jE()==0){yie(t)&&Vx(t),e.push(new Promise((s,i)=>{r.listen({path:t},()=>{s(),er.info("Domain socket listening on "+t)}).on("error",i)}));continue}let n;try{n=$x(+t,"::")}catch(s){console.error(`Unable to bind to port ${t}`,s);continue}e.push(new Promise((s,i)=>{r.listen({fd:n},()=>{s(),er.trace("Listening on port "+t,JE)}).on("error",i)}))}Promise.all(e).then(()=>{Dl?.postMessage({type:Tt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(Zx,"startServers");Qx||Zx();function CA(e,t,r){let n=e?.read?e:new gie({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=_s[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=_s[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(er.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(CA,"deliverSocket");var Kx=new Map;function Hie(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=Kx.get(s),r){case"connection":i=CA(void 0,t),Kx.set(s,i),i.write=(c,u,_)=>(Dl.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),_&&_(),!0),i.end=(c,u,_)=>(Dl.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),_&&_(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),Dl.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(Hie,"proxyRequest");function DA(e,t,r=!0){!+t&&t!==De.get(Tt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&(t=parseInt(De.get(Tt.CONFIG_PARAMS.HTTP_PORT),10));let n=_s[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",Wx),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else _s[t]=e;e.on("unhandled",Wx)}a(DA,"registerServer");function eG(e){let t=[],r=parseInt(e?.securePort);return r&&t.push({port:r,secure:!0}),r=parseInt(e?.port),r&&t.push({port:r,secure:!1}),t.length===0&&(t=[],De.get(Tt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:De.get(Tt.CONFIG_PARAMS.HTTP_PORT),secure:De.get(Tt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),De.get(Tt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:De.get(Tt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&De.get(Tt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:De.get(Tt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),secure:!1}),t}a(eG,"getPorts");function LA(e,t){for(let{port:r,secure:n}of eG(t))tG(r,n,t?.isOperationsServer),typeof e=="function"?IA[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||r}):(e.isSecure=n,DA(e,r,!1)),ZE[r]=wA(IA,r),vie=wA(Bie,r)}a(LA,"httpServer");function tG(e,t,r){if(!Ii[e]){let n=r?"operationsApi_network":"http",s={keepAliveTimeout:De.get(n+"_keepAliveTimeout"),headersTimeout:De.get(n+"_headersTimeout"),requestTimeout:De.get(n+"_timeout")},i=De.get(n+"_mtls"),o=De.get(n+"_mtls_required");if(t){n=r?"operationsApi_":"";let u=De.get(n+"tls_privateKey"),_=De.get(n+"tls_certificate"),l=De.get(n+"tls_certificateAuthority");Object.assign(s,{allowHTTP1:!0,key:Xa(u),ciphers:De.get("tls_ciphers"),cert:Xa(_),ca:l&&Xa(l),rejectUnauthorized:!!o,requestCert:!!i,ticketKeys:wie()})}let c=Mie();Ii[e]=(t?bie:Aie)(s,async(u,_)=>{try{let d=performance.now(),f=new Jx(u,_);r&&(f.isOperationsServer=!0);let E=await ZE[e](f);if(!E){if(f._nodeResponse.statusCode)return;E=rG(f)}if(c?E.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):E.headers?.set?.("Server","HarperDB"),E.status===-1){for(let H of E.headers||[])_.setHeader(H[0],H[1]);return u.baseRequest=f,_.baseResponse=E,Ii[e].emit("unhandled",u,_)}let h=E.status||200,p=performance.now(),S=p-d,T=E.body,b;if(!E.handlesHeaders){let H=E.headers||new zx;T?T.length>=0&&(typeof T=="string"?H.set("Content-Length",Buffer.byteLength(T)):H.set("Content-Length",T.length),b=!0):(H.set("Content-Length","0"),b=!0);let P=`hdb;dur=${S.toFixed(2)}`;E.wasCacheMiss&&(P+=", miss"),Die(H,"Server-Timing",P,!0),_.writeHead(h,H&&(H[Symbol.iterator]?Array.from(H):H)),b&&_.end(T)}let R=f.handlerPath,L=f.method;if(Cl(S,"duration",R,L,E.wasCacheMiss==null?void 0:E.wasCacheMiss?"cache-miss":"cache-hit"),Lie(h<400,"success",R,L),!b)if(T?.pipe){T.pipe(_),T.destroy&&_.on("close",()=>{T.destroy()});let H=0;T.on("data",P=>{H+=P.length}),T.on("end",()=>{Cl(performance.now()-p,"transfer",R,L),Cl(H,"bytes-sent",R,L)})}else T?.then?T.then(H=>{_.end(H)},l):_.end(T)}catch(d){l(d)}function l(d){let f=d.headers;_.writeHead(d.statusCode||500,f&&(f[Symbol.iterator]?Array.from(f):f)),_.end(d.toString()),d.statusCode?d.statusCode===500?er.warn(d):er.info(d):er.error(d)}a(l,"onError")}),i&&(Ii[e].mtlsConfig=i),t&&(Ii[e].on("secureConnection",u=>{u._parent.startTime&&Cl(performance.now()-u._parent.startTime,"tls-handshake",e),Cl(u.isSessionReused(),"tls-reused",e)}),Ii[e].isSecure=!0),DA(Ii[e],e)}return Ii[e]}a(tG,"getHTTPServer");function wA(e,t){let r=rG;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(wA,"makeCallbackChain");function rG(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new zx}}a(rG,"unhandled");function xie(e,t){LA(e,{requestOnly:!0,...t})}a(xie,"onRequest");function Gie(e,t){let r;if(t.securePort){let n=De.get("tls_privateKey"),s=De.get("tls_certificate"),i=t.mtls?.certificateAuthority||De.get("tls_certificateAuthority");r=Iie({ciphers:De.get("tls_ciphers"),key:Xa(n),cert:Xa(s),ca:i&&Xa(i),rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls},e),_s[t.securePort]=r}return t.port&&(r=Rie(e),_s[t.port]=r),r}a(Gie,"onSocket");Object.defineProperty(Oie.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.startsWith("Upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});function Fie(e,t){let r;for(let{port:n,secure:s}of eG(t)){XE[n]||(XE[n]=new Nie({server:r=tG(n,s)}),XE[n].on("connection",async(c,u)=>{try{let _=new Jx(u);_.isWebSocket=!0;let l=ZE[n](_),d=u.headers["sec-websocket-protocol"]||"",f=NA[n];if(d){let E;for(let h=0;h<f.length;h++){let p=f[h];p.protocol===d&&(E=!0,p.listener(c,_,l))}if(E)return}for(let E=0;E<f.length;E++){let h=f[E];h.protocol||h.listener(c,_,l)}}catch(_){er.warn("Error handling WebSocket connection",_)}}),XE[n].on("error",c=>{console.log("Error in setting up WebSocket server",c)}));let i=t?.subProtocol||"",o=NA[n];o||(o=NA[n]=[]),o.push({listener:e,protocol:i}),ZE[n]=wA(IA,n)}return r}a(Fie,"onWebSocket");function Wx(e,t){t.writeHead(404),t.end(`Not found
|
|
30
|
+
`)}a(Wx,"defaultNotFound")});module.exports=aH();
|