harperdb 4.3.21 → 4.4.0-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (32) hide show
  1. package/README.md +1 -1
  2. package/bin/harperdb.js +85 -72
  3. package/bin/lite.js +32 -22
  4. package/config/yaml/defaultConfig.yaml +9 -41
  5. package/config/yaml/defaultNatsConfig.yaml +36 -0
  6. package/json/systemSchema.json +32 -79
  7. package/launchServiceScripts/launchInstallNATSServer.js +4 -4
  8. package/launchServiceScripts/launchNatsIngestService.js +32 -22
  9. package/launchServiceScripts/launchNatsReplyService.js +32 -22
  10. package/launchServiceScripts/launchUpdateNodes4-0-0.js +32 -22
  11. package/npm-shrinkwrap.json +634 -312
  12. package/package.json +17 -15
  13. package/resources/DatabaseTransaction.d.ts +1 -0
  14. package/resources/RecordEncoder.d.ts +3 -1
  15. package/resources/Resource.d.ts +8 -1
  16. package/resources/ResourceInterface.d.ts +7 -3
  17. package/resources/Resources.d.ts +5 -4
  18. package/resources/Table.d.ts +47 -16
  19. package/resources/auditStore.d.ts +45 -1
  20. package/resources/databases.d.ts +54 -17
  21. package/resources/search.d.ts +6 -0
  22. package/resources/transactionBroadcast.d.ts +2 -1
  23. package/server/Server.d.ts +1 -1
  24. package/server/jobs/jobProcess.js +32 -22
  25. package/server/serverHelpers/Headers.d.ts +8 -0
  26. package/server/threads/threadServer.js +32 -22
  27. package/studio/build-local/asset-manifest.json +2 -2
  28. package/studio/build-local/index.html +1 -1
  29. package/studio/build-local/static/js/main.4fd117ad.js +2 -0
  30. package/utility/scripts/restartHdb.js +32 -22
  31. package/studio/build-local/static/js/main.a22f6951.js +0 -2
  32. /package/studio/build-local/static/js/{main.a22f6951.js.LICENSE.txt → main.4fd117ad.js.LICENSE.txt} +0 -0
@@ -1,32 +1,42 @@
1
- "use strict";var YG=Object.create;var cc=Object.defineProperty;var KG=Object.getOwnPropertyDescriptor;var WG=Object.getOwnPropertyNames;var QG=Object.getPrototypeOf,zG=Object.prototype.hasOwnProperty;var a=(e,t)=>cc(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),qe=(e,t)=>{for(var r in t)cc(e,r,{get:t[r],enumerable:!0})},XA=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of WG(t))!zG.call(e,s)&&s!==r&&cc(e,s,{get:()=>t[s],enumerable:!(n=KG(t,s))||n.enumerable});return e};var B=(e,t,r)=>(r=e!=null?YG(QG(e)):{},XA(t||!e||!e.__esModule?cc(r,"default",{value:e,enumerable:!0}):r,e)),ie=e=>XA(cc({},"__esModule",{value:!0}),e);var tO=g((voe,eO)=>{var JG=require("fast-glob"),{statSync:Ah,existsSync:Oh,readFileSync:jG,writeFileSync:XG}=require("fs"),{spawnSync:ZG,spawn:eF,execFileSync:Uoe}=require("child_process"),{isMainThread:tF}=require("worker_threads"),{join:js,relative:ZA}=require("path"),{PACKAGE_ROOT:On}=U(),{tmpdir:rF,platform:nF}=require("os");require("source-map-support").install();var sF=["resources","server","dataLayer","components"],lc="ts-build",bh,iF=__filename.endsWith("tsBuild.js");if(iF){if(tF){let r;try{Ah(js(On,lc)),r=!0}catch{}if(r)for(let n of JG.sync(sF.map(s=>s+"/**/*.ts"),{cwd:On})){let s=0,i=0;try{s=Ah(js(On,n)).mtimeMs-5e3,i=Ah(js(On,lc,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."),bh=!0;break}}else console.log("TypeScript modules are not compiled, compiling now"),bh=!0;if(bh){let n=js(On,"node_modules/.bin/tsc");nF()==="win32"&&(n+=".cmd");let s=ZG(n,{cwd:On});if(s.stdout?.length&&console.log(s.stdout.toString()),s.stderr?.length&&console.log(s.stderr.toString()),r){let i=js(rF(),"harperdb-tsc.pid"),o;if(Oh(i))try{process.kill(+jG(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=eF(n,["--watch"],{cwd:On,detached:!0,stdio:"ignore"});XG(i,c.pid.toString()),c.unref()}}}}let e=eO.constructor,t=e._findPath;e._findPath=function(r,n,s){if(r.startsWith(".")&&!s&&n.length===1&&n[0].startsWith(On)&&!n[0].includes("node_modules")){let i=ZA(On,n[0]),o;i.startsWith(lc)?o=js(On,ZA(lc,i)):o=js(On,lc,i);let c=js(o,r),l=c+".js";if(Oh(l))return l;if(c.includes(".")&&Oh(c))return c}return t(r,n,s)}}});var U=g((xoe,hO)=>{"use strict";var an=require("path"),oF=require("fs"),{relative:Boe,join:Hoe}=an,{existsSync:aF}=oF;function cF(){let e=__dirname;for(;!aF(an.join(e,"package.json"));){let t=an.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(cF,"getHDBPackageRoot");var Xs=cF(),rO="js",Zu=rO,lF="harperdb-config.yaml",uF="defaultConfig.yaml",_F="hdb",nO=`harperdb.${Zu}`,sO=`customFunctionsServer.${Zu}`,dF=`restartHdb.${Zu}`,Nh="HarperDB",Xu="Custom Functions",e_="Clustering Hub",t_="Clustering Leaf",fF="Clustering Ingest Service",EF="Clustering Reply Service",hF="foreground.pid",mF="hdb.pid",pF="data",SF={HDB:Nh,CLUSTERING_HUB:e_,CLUSTERING_LEAF:t_,CLUSTERING_INGEST_SERVICE:fF,CLUSTERING_REPLY_SERVICE:EF,CUSTOM_FUNCTIONS:Xu,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"},TF={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},gF={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},RF={harperdb:Nh,"clustering hub":e_,"clustering leaf":t_,"custom functions":Xu,custom_functions:Xu,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers"},AF={CLUSTERING_HUB_PROC_DESCRIPTOR:e_,CLUSTERING_LEAF_PROC_DESCRIPTOR:t_},yh={HDB:an.join(Xs,"server/harperdb"),CUSTOM_FUNCTIONS:an.join(Xs,"server/customFunctions"),CLUSTERING_HUB:an.join(Xs,"server/nats"),CLUSTERING_LEAF:an.join(Xs,"server/nats")},OF={HDB:an.join(yh.HDB,nO),CUSTOM_FUNCTIONS:an.join(yh.CUSTOM_FUNCTIONS,sO)},bF={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:an.join(Xs,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:an.join(Xs,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:an.join(Xs,"launchServiceScripts/launchUpdateNodes4-0-0.js")},yF={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},iO="support@harperdb.io",NF="customer-success@harperdb.io",oO=1,IF=4141,aO="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",wF="https://www.harperdb.io/product",CF=`For support, please submit a request at ${aO} or contact ${iO}`,cO=`For license support, please contact ${NF}`,DF="None of the specified records were found.",LF="hash attribute not found",MF=`Your current license only supports ${oO} role. ${cO}`,PF="Your current license only supports 3 connections to a node.",UF="127.0.0.1",vF=1,BF=/^\.$/,HF=/^\.\.$/,xF="U+002E",GF=/\//g,FF="U+002F",qF=/U\+002F/g,kF=/^U\+002E$/,VF=/^U\+002EU\+002E$/,$F="d",YF=999999,KF="*",WF="--max-old-space-size=",QF="system",zF="__hdb_hash",JF=".harperdb",jF=".hdb",XF="keys",ZF="hdb_boot_properties.file",eq=".updateConfig.json",tq="SIGTSTP",rq=24,nq=6e4,sq=448,iq="blob",oq="trash",aq="database",cq="schema",lq="transactions",uq=".count",_q="id",dq="PROCESS_NAME",lO={SETTINGS_PATH_KEY:"settings_path"},uO=require("lodash"),fq={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"},Eq={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},hq={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},mq={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"},pq={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"},Pr="hdb_internal:",Sq={CREATE_SCHEMA:Pr+"create_schema",CREATE_TABLE:Pr+"create_table",CREATE_ATTRIBUTE:Pr+"create_attribute",ADD_USER:Pr+"add_user",ALTER_USER:Pr+"alter_user",DROP_USER:Pr+"drop_user",HDB_NODES:Pr+"hdb_nodes",HDB_USERS:Pr+"hdb_users",HDB_WORKERS:Pr+"hdb_workers",CATCHUP:Pr+"catchup",SCHEMA_CATCHUP:Pr+"schema_catchup",WORKER_ROOM:Pr+"cluster_workers"},Tq={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"},gq="060493.ks",Rq=".license",Aq={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"},Oq={CSV:".csv",JSON:".json"},bq={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},yq={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},uc={};uc[Z.INSERT]=Z.INSERT;uc[Z.UPDATE]=Z.UPDATE;uc[Z.UPSERT]=Z.UPSERT;uc[Z.DELETE]=Z.DELETE;var He=Object.create(null);He[Z.DESCRIBE_ALL]=Z.DESCRIBE_ALL;He[Z.DESCRIBE_TABLE]=Z.DESCRIBE_TABLE;He[Z.DESCRIBE_SCHEMA]=Z.DESCRIBE_SCHEMA;He[Z.READ_LOG]=Z.READ_LOG;He[Z.ADD_NODE]=Z.ADD_NODE;He[Z.LIST_USERS]=Z.LIST_USERS;He[Z.LIST_ROLES]=Z.LIST_ROLES;He[Z.USER_INFO]=Z.USER_INFO;He[Z.SQL]=Z.SQL;He[Z.GET_JOB]=Z.GET_JOB;He[Z.SEARCH_JOBS_BY_START_DATE]=Z.SEARCH_JOBS_BY_START_DATE;He[Z.DELETE_FILES_BEFORE]=Z.DELETE_FILES_BEFORE;He[Z.EXPORT_LOCAL]=Z.EXPORT_LOCAL;He[Z.EXPORT_TO_S3]=Z.EXPORT_TO_S3;He[Z.CLUSTER_STATUS]=Z.CLUSTER_STATUS;He[Z.REMOVE_NODE]=Z.REMOVE_NODE;He[Z.RESTART]=Z.RESTART;He[Z.CUSTOM_FUNCTIONS_STATUS]=Z.CUSTOM_FUNCTIONS_STATUS;He[Z.GET_CUSTOM_FUNCTIONS]=Z.GET_CUSTOM_FUNCTIONS;He[Z.GET_CUSTOM_FUNCTION]=Z.GET_CUSTOM_FUNCTION;He[Z.SET_CUSTOM_FUNCTION]=Z.SET_CUSTOM_FUNCTION;He[Z.DROP_CUSTOM_FUNCTION]=Z.DROP_CUSTOM_FUNCTION;He[Z.ADD_CUSTOM_FUNCTION_PROJECT]=Z.ADD_CUSTOM_FUNCTION_PROJECT;He[Z.DROP_CUSTOM_FUNCTION_PROJECT]=Z.DROP_CUSTOM_FUNCTION_PROJECT;He[Z.PACKAGE_CUSTOM_FUNCTION_PROJECT]=Z.PACKAGE_CUSTOM_FUNCTION_PROJECT;He[Z.DEPLOY_CUSTOM_FUNCTION_PROJECT]=Z.DEPLOY_CUSTOM_FUNCTION_PROJECT;var Nq={DEV:"dev",RUN:"run",START:"start",INSTALL:"install",REGISTER:"register",STOP:"stop",RESTART:"restart",VERSION:"version",UPGRADE:"upgrade",HELP:"help",STATUS:"status",OPERATION:"operation",RENEWCERTS:"renew-certs",COPYDB:"copy-db"},Iq={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},_O={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"},wq=uO.invert(_O),Cq={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_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",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",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:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers",TLS:"tls",CLONED:"cloned"},dO={settings_path:lO.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_maxconsumemsgs:I.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS,clustering_leafserver_streams_maxingestthreads:I.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS,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,customfunctions_tls:I.TLS,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,http_maxheadersize:I.HTTP_MAXHEADERSIZE,http_threadrange:I.HTTP_THREADRANGE,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:I.OPERATIONSAPI_TLS,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,storage_maxtransactionqueuetime:I.STORAGE_MAXTRANSACTIONQUEUETIME,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:I.TLS,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];dO[t.toLowerCase()]=t}var Dq={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},Lq={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",restart_service:"restart_service"},Mq={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"},Pq={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},Uq={VERSION_DEFAULT:"2.2.0"},vq={DEVELOPMENT:8192,DEFAULT:512},Bq={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"},Hq={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"},xq={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},fO={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},Gq=Symbol("metadata"),Fq="__clustering__",qq=Object.values(fO),kq=15984864e5,EO={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},Vq=uO.invert(EO),$q={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"},Yq=111,Kq=`\r
2
- `,Wq={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},Qq=["*","%"],zq="unauthorized_access",Jq="func_val",jq={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},Xq={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},Zq={SHUTDOWN:"shutdown",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",SCHEMA:"schema",USER:"user",CLUSTER_STATUS_RESPONSE:"cluster_status_response",CLUSTER_STATUS_REQUEST:"cluster_status_request",METRICS:"metrics",GET_METRICS:"get_metrics",RESTART:"restart",START_JOB:"start_job",NATS_CONSUMER_UPDATE:"nats_consumer_update"},ek={HDB_CORE:"hdb_core",CUSTOM_FUNCTIONS:"custom_functions"},tk={HTTP:"http"},rk={STOPPED:"stopped",ONLINE:"online"},nk="3.x.x",sk={SUCCESS:"success",FAILURE:"failure"},ik={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"};hO.exports={LOCAL_HARPERDB_OPERATIONS:He,HDB_SUPPORT_ADDRESS:iO,HDB_SUPPORT_URL:aO,HDB_PRICING_URL:wF,SUPPORT_HELP_MSG:CF,LICENSE_HELP_MSG:cO,HDB_PROC_NAME:nO,HDB_PROC_DESCRIPTOR:Nh,CLUSTERING_LEAF_PROC_DESCRIPTOR:t_,CLUSTERING_HUB_PROC_DESCRIPTOR:e_,SYSTEM_SCHEMA_NAME:QF,HASH_FOLDER_NAME:zF,HDB_HOME_DIR_NAME:JF,UPDATE_FILE_NAME:eq,LICENSE_KEY_DIR_NAME:XF,BOOT_PROPS_FILE_NAME:ZF,JOB_TYPE_ENUM:Lq,JOB_STATUS_ENUM:Aq,SYSTEM_TABLE_NAMES:mq,SYSTEM_TABLE_HASH_ATTRIBUTES:pq,OPERATIONS_ENUM:Z,VALID_S3_FILE_TYPES:Oq,S3_BUCKET_AUTH_KEYS:bq,VALID_SQL_OPS_ENUM:yq,GEO_CONVERSION_ENUM:Iq,HDB_SETTINGS_NAMES:_O,HDB_SETTINGS_NAMES_REVERSE_LOOKUP:wq,SERVICE_ACTIONS_ENUM:Nq,CLUSTER_MESSAGE_TYPE_ENUM:Mq,CLUSTER_CONNECTION_DIRECTION_ENUM:Pq,CLUSTER_EVENTS_DEFS_ENUM:Bq,PERIOD_REGEX:BF,DOUBLE_PERIOD_REGEX:HF,UNICODE_PERIOD:xF,FORWARD_SLASH_REGEX:GF,UNICODE_FORWARD_SLASH:FF,ESCAPED_FORWARD_SLASH_REGEX:qF,ESCAPED_PERIOD_REGEX:kF,ESCAPED_DOUBLE_PERIOD_REGEX:VF,REG_KEY_FILE_NAME:gq,RESTART_TIMEOUT_MS:nq,HDB_FILE_PERMISSIONS:sq,DATABASES_DIR_NAME:aq,LEGACY_DATABASES_DIR_NAME:cq,TRANSACTIONS_DIR_NAME:lq,LIMIT_COUNT_NAME:uq,ID_ATTRIBUTE_STRING:_q,INSERT_MODULE_ENUM:Eq,UPGRADE_JSON_FIELD_NAMES_ENUM:hq,RESTART_CODE:tq,RESTART_CODE_NUM:rq,CLUSTER_OPERATIONS:uc,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:Tq,HDB_INTERNAL_SC_CHANNEL_PREFIX:Pr,INTERNAL_SC_CHANNELS:Sq,CLUSTERING_MESSAGE_TYPES:$q,HDB_FILE_SUFFIX:jF,BLOB_FOLDER_NAME:iq,HDB_TRASH_DIR:oq,ORIGINATOR_SET_VALUE:Yq,LICENSE_VALUES:Uq,RAM_ALLOCATION_ENUM:vq,TIME_STAMP_NAMES_ENUM:fO,TIME_STAMP_NAMES:qq,PERMS_UPDATE_RELEASE_TIMESTAMP:kq,SEARCH_NOT_FOUND_MESSAGE:DF,SEARCH_ATTRIBUTE_NOT_FOUND:LF,LICENSE_ROLE_DENIED_RESPONSE:MF,LICENSE_MAX_CONNS_REACHED:PF,BASIC_LICENSE_MAX_NON_CU_ROLES:oO,BASIC_LICENSE_CLUSTER_CONNECTION_LIMIT_WS_ERROR_CODE:IF,VALUE_SEARCH_COMPARATORS:EO,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:Vq,LICENSE_FILE_NAME:Rq,WEBSOCKET_CLOSE_CODE_DESCRIPTION_LOOKUP:Hq,NEW_LINE:Kq,BASIC_LICENSE_MAX_CLUSTER_USER_ROLES:vF,MOMENT_DAYS_TAG:$F,API_TURNOVER_SEC:YF,LOOPBACK:UF,CODE_EXTENSION:Zu,WILDCARD_SEARCH_VALUE:KF,NODE_ERROR_CODES:xq,JAVASCRIPT_EXTENSION:rO,PERMS_CRUD_ENUM:Wq,UNAUTHORIZED_PERMISSION_NAME:zq,SEARCH_WILDCARDS:Qq,FUNC_VAL:Jq,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:jq,JWT_ENUM:Xq,CLUSTERING_FLAG:Fq,ITC_EVENT_TYPES:Zq,CUSTOM_FUNCTION_PROC_NAME:sO,CUSTOM_FUNCTION_PROC_DESCRIPTOR:Xu,SERVICES:ek,THREAD_TYPES:tk,MEM_SETTING_KEY:WF,HDB_RESTART_SCRIPT:dF,PROCESS_DESCRIPTORS:SF,SERVICE_SERVERS:OF,SERVICE_SERVERS_CWD:yh,PROCESS_DESCRIPTORS_VALIDATE:RF,LAUNCH_SERVICE_SCRIPTS:bF,LOG_LEVELS:gF,PROCESS_NAME_ENV_PROP:dq,LOG_NAMES:TF,PM2_PROCESS_STATUSES:rk,CONFIG_PARAM_MAP:dO,CONFIG_PARAMS:I,HDB_CONFIG_FILE:lF,HDB_DEFAULT_CONFIG_FILE:uF,ROLE_TYPES_ENUM:yF,BOOT_PROP_PARAMS:lO,INSTALL_PROMPTS:fq,HDB_ROOT_DIR_NAME:_F,CLUSTERING_PROCESSES:AF,FOREGROUND_PID_FILE:hF,PACKAGE_ROOT:Xs,PRE_4_0_0_VERSION:nk,DATABASES_PARAM_CONFIG:Dq,METADATA_PROPERTY:Gq,AUTH_AUDIT_STATUS:sk,AUTH_AUDIT_TYPES:ik,HDB_PID_FILE:mF,DEFAULT_DATABASE_NAME:pF,LEGACY_CONFIG_PARAMS:Cq};tO()});var Ih=g((Foe,SO)=>{"use strict";var mO=require("minimist");SO.exports=ok;function ok(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=pO(process.env),n=pO(mO(process.argv))):(r=process.env,n=mO(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(ok,"assignCMDENVVariables");function pO(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(pO,"objKeysToLowerCase")});var Y=g((koe,Uh)=>{"use strict";var Ui=require("fs-extra"),{workerData:ak,threadId:ck}=require("worker_threads"),ps=require("path"),RO=require("yaml"),AO=require("properties-reader"),St=U(),TO=Ih(),lk=require("os"),{PACKAGE_ROOT:Ch}=U(),{_assignPackageExport:uk}=require("../../index"),dc={};for(let e in console)dc[e]||(dc[e]=console[e]);var cr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},OO={STDOUT:"stdOut",STDERR:"stdErr"},_k=ps.join(Ch,"logs"),dk=ps.join(Ch,"config/yaml/",St.HDB_DEFAULT_CONFIG_FILE),fk=1e4,ms,Kn,ar,r_,n_,fc,Fo,_c;_c===void 0&&bO();Uh.exports={notify:IO,fatal:wO,error:Ec,warn:Ph,info:s_,debug:Mh,trace:Lh,setLogLevel:gk,log_level:ar,loggerWithTag:Ek,suppressLogging:hk,initLogSettings:bO,setupConsoleLogging:yO,logCustomLevel:Sk,closeLogFile:Dh,getLogFilePath:()=>fc,OUTPUTS:OO,AuthAuditLog:Ok};uk("logger",Uh.exports);function bO(e=!1){try{if(_c===void 0||e){Dh();let t=Tk(),r=TO(["ROOTPATH"]);try{_c=AO(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!Ui.pathExistsSync(ps.join(r.ROOTPATH,St.HDB_CONFIG_FILE)))throw n}({level:ar,config_log_path:n_,to_file:ms,to_stream:Kn}=Rk(r.ROOTPATH?ps.join(r.ROOTPATH,St.HDB_CONFIG_FILE):_c.get("settings_path"))),r_=St.LOG_NAMES.HDB,fc=ps.join(n_,r_)}}catch(t){if(_c=void 0,t.code===St.NODE_ERROR_CODES.ENOENT||t.code===St.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=TO(Object.keys(St.CONFIG_PARAM_MAP),!0);for(let o in r){let c=St.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===St.CONFIG_PARAMS.LOGGING_LEVEL){ar=l;continue}if(c===St.CONFIG_PARAMS.LOGGING_STDSTREAMS){Kn=l;continue}c===St.CONFIG_PARAMS.LOGGING_FILE&&(ms=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=Ak();ms=ms===void 0?s:ms,ms=gO(ms),Kn=Kn===void 0?i:Kn,Kn=gO(Kn),ar=ar===void 0?n:ar,n_=_k,r_=St.LOG_NAMES.INSTALL,fc=ps.join(n_,r_);return}throw Ec("Error initializing log settings"),Ec(t),t}process.env.DEV_MODE&&(Kn=!0),yO()}a(bO,"initLogSettings");var wh=!0;function yO(){Go("error",Ec),Go("warn",Ph),Go("log",s_),Go("info",s_),Go("debug",Mh),Go("trace",Lh)}a(yO,"setupConsoleLogging");function Go(e,t){console[e]=function(...r){if(wh&&t(...r),!/PM2 log:|App \[/.test(r[0]))return dc[e](...r)}}a(Go,"logConsole");function Ek(e){let t={tagName:e.replace(/ /g,"-")};return{notify:r(IO),fatal:r(wO),error:r(Ec),warn:r(Ph),info:r(s_),debug:r(Mh),trace:r(Lh)};function r(n){return function(...s){return n(t,...s)}}}a(Ek,"loggerWithTag");function hk(e){try{wh=!1,e()}finally{wh=!0}}a(hk,"suppressLogging");var mk=ak?.name?.replace(/ /g,"-")||"main";function Ss(e,t){let r=new Date(Date.now()).toISOString(),n="",s=t.length,i=s-1,o=[e],c=0,l;for(typeof t[0]=="object"&&(t[0]?.tagName?(o.push(t[0]?.tagName),c++):t[0]?.serviceName&&(l=t[0]?.serviceName,c++)),o.unshift(l||mk+"/"+ck);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(Ss,"createLogRecord");function hc(e){ms&&NO(e),Kn&&process.stdout.write(e)}a(hc,"logStdOut");function i_(e){ms&&NO(e),Kn&&process.stderr.write(e)}a(i_,"logStdErr");function NO(e){pk(),Fo?Ui.appendFileSync(Fo,e):dc.log(e)}a(NO,"logToFile");function Dh(){try{Ui.closeSync(Fo)}catch{}Fo=null}a(Dh,"closeLogFile");function pk(){if(!Fo){try{if(!fc)debugger;Fo=Ui.openSync(fc,"a")}catch(e){dc.error(e)}setTimeout(()=>{Dh()},fk).unref()}}a(pk,"openLogFile");function s_(...e){cr[ar]<=cr.info&&hc(Ss("info",e))}a(s_,"info");function Lh(...e){cr[ar]<=cr.trace&&hc(Ss("trace",e))}a(Lh,"trace");function Ec(...e){cr[ar]<=cr.error&&i_(Ss("error",e))}a(Ec,"error");function Mh(...e){cr[ar]<=cr.debug&&hc(Ss("debug",e))}a(Mh,"debug");function IO(...e){cr[ar]<=cr.notify&&hc(Ss("notify",e))}a(IO,"notify");function wO(...e){cr[ar]<=cr.fatal&&i_(Ss("fatal",e))}a(wO,"fatal");function Ph(...e){cr[ar]<=cr.warn&&i_(Ss("warn",e))}a(Ph,"warn");function Sk(e,t,...r){t===OO.STDERR?i_(Ss(e,r)):hc(Ss(e,r))}a(Sk,"logCustomLevel");function Tk(){let e;try{e=lk.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=ps.join(e,St.HDB_HOME_DIR_NAME,St.BOOT_PROPS_FILE_NAME);return Ui.existsSync(t)||(t=ps.join(Ch,"utility/hdb_boot_properties.file")),t}a(Tk,"getPropsFilePath");function gk(e){ar=e}a(gk,"setLogLevel");function gO(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(gO,"autoCastBoolean");function Rk(e){try{if(e.includes("config/settings.js")){let o=AO(e);return{level:o.get(St.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:ps.dirname(o.get(St.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(St.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(St.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=RO.parseDocument(Ui.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===St.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(Rk,"getLogConfig");function Ak(){try{let e=RO.parseDocument(Ui.readFileSync(dk,"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(Ak,"getDefaultConfig");function Ok(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(Ok,"AuthAuditLog")});var DO=g(($oe,CO)=>{"use strict";var bk=require("util"),yk=require("path"),Nk=require("child_process"),Ik=bk.promisify(Nk.execFile),wk=1e3*1e3*10;CO.exports={findPs:Ck};async function Ck(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await Ik("ps",["wwxo",`pid,${r}`],{maxBuffer:wk});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:yk.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(Ck,"findPs")});var dt=g((Koe,MO)=>{"use strict";var Dk="__dbis__",Lk="__txns__",Mk="__environment_name__",Pk="__dbi_defintion__",Uk={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"},vk=["__createdtime__","__updatedtime__"],Bk="\uFFFF",LO={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},Hk=Object.values(LO);MO.exports={AUDIT_STORE_NAME:Lk,INTERNAL_DBIS_NAME:Dk,DBI_DEFINITION_NAME:Pk,SEARCH_TYPES:Uk,TIMESTAMP_NAMES:vk,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:Mk,TRANSACTIONS_DBI_NAMES_ENUM:LO,TRANSACTIONS_DBIS:Hk,OVERFLOW_MARKER:Bk}});var Ur=g((Woe,qO)=>{"use strict";var PO=U(),UO=dt(),vO={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},BO=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),HO={500:BO("There was an error processing your request."),400:"Invalid request"},xk=HO[vO.INTERNAL_SERVER_ERROR],Gk={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.`},Fk={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},qk={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"},kk={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 ${UO.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${UO.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"},Vk={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"},xO={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"},$k={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."},Yk={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`},Kk={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"},Wk={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},Qk={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`},GO={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.`},FO={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}`},zk={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."},Jk={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},jk={...xO,...qk,...Gk,...$k,...Yk,...Kk,...Wk,...Qk,...Vk,...GO,...FO,...zk,...Jk,...Fk};qO.exports={CHECK_LOGS_WRAPPER:BO,HDB_ERROR_MSGS:jk,DEFAULT_ERROR_MSGS:HO,DEFAULT_ERROR_RESP:xk,HTTP_STATUS_CODES:vO,LMDB_ERRORS_ENUM:kk,AUTHENTICATION_ERROR_MSGS:xO,VALIDATION_ERROR_MSGS:GO,ITC_ERRORS:FO}});var ne=g((zoe,$O)=>{"use strict";var qo=Ur(),Xk=Y(),Zk=U(),o_=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,kO),this.statusCode=n||qo.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(qo.DEFAULT_ERROR_MSGS[n]?qo.DEFAULT_ERROR_MSGS[n]:qo.DEFAULT_ERROR_MSGS[qo.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&&Xk[s](i)}},vh=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}},Bh=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function kO(e,t,r,n=Zk.LOG_LEVELS.ERROR,s=null,i=!1){if(VO(e))return e;let o=new o_(e,t,r,n,s);return i&&delete o.stack,o}a(kO,"handleHDBError");function VO(e){return e.__proto__.constructor.name===o_.name}a(VO,"isHDBError");$O.exports={isHDBError:VO,handleHDBError:kO,ClientError:vh,ServerError:Bh,hdb_errors:qo}});var KO=g((joe,YO)=>{"use strict";var eV={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
- `),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
- `)},tV="certificate.pem",rV="privateKey.pem",nV="ca.pem";YO.exports={CERTIFICATE_VALUES:eV,CERTIFICATE_PEM_NAME:tV,PRIVATEKEY_PEM_NAME:rV,CA_PEM_NAME:nV}});var st=g((Xoe,WO)=>{"use strict";var lr=require("validate.js");lr.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||lr.validators.type.checks[t](e)?null:` must be a '${t}' value`};lr.validators.type.checks={Object:function(e){return lr.isObject(e)&&!lr.isArray(e)},Array:lr.isArray,Integer:lr.isInteger,Number:lr.isNumber,String:lr.isString,Date:lr.isDate,Boolean:function(e){return typeof e=="boolean"}};lr.validators.hasValidFileExt=function(e,t){return lr.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};WO.exports={validateObject:sV,validateObjectAsync:iV,validateBySchema:oV};function sV(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=lr(e,t,{format:"flat"});return r?new Error(r):null}a(sV,"validateObject");async function iV(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await lr.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(iV,"validateObjectAsync");function oV(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(oV,"validateBySchema")});var Hh=g((tae,ZO)=>{"use strict";var jO=require("fs-extra"),oe=require("joi"),aV=require("os"),{boolean:be,string:Zt,number:Ze,array:a_}=oe.types(),{totalmem:QO}=require("os"),vi=require("path"),cV=Y(),c_=z(),eae=KO(),zO=U(),lV=st(),JO="log",uV="components",_V="Invalid logging.rotation.maxSize unit. Available units are G, M or K",dV="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",fV="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",EV="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",hV="rootPath config parameter is undefined",mV="clustering.enabled config parameter is undefined",Bi=Ze.min(0).required(),l_=a_.items({host:Zt.required(),port:Bi}).empty(null),Wn,XO=!1;ZO.exports={configValidator:pV,routesValidator:OV,route_constraints:l_};function pV(e,t=!1){if(XO=t,Wn=e.rootPath,c_.isEmpty(Wn))throw hV;let r=be.required(),n=Ze.min(0).max(1e3).empty(null).default(AV),s=Zt.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(mc),i=Zt.optional().empty(null),o=Zt.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=oe.string().empty(null).default(mc),l=oe.custom(TV).empty(null).default(mc),_=e.clustering?.enabled;if(c_.isEmpty(_))throw mV;let u=oe.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return _===!0?d=oe.object({enabled:r,hubServer:oe.object({cluster:oe.object({name:oe.required().empty(null),network:oe.object({port:Bi,routes:l_}).required()}).required(),leafNodes:oe.object({network:oe.object({port:Bi}).required()}).required(),network:oe.object({port:Bi}).required()}).required(),leafServer:oe.object({network:oe.object({port:Bi,routes:l_}).required(),streams:oe.object({maxAge:Ze.min(120).allow(null).optional(),maxBytes:Ze.min(1).allow(null).optional(),maxMsgs:Ze.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:oe.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:be.optional(),databaseLevel:be.optional(),tls:oe.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:be.required(),verify:be.optional()}),user:Zt.optional().empty(null)}).required():d=oe.object({enabled:r,tls:oe.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:be.required()})}).required(),oe.object({authentication:oe.object({authorizeLocal:be,cacheTTL:Ze.required(),enableSessions:be}),analytics:oe.object({aggregatePeriod:Ze}),componentsRoot:s.optional(),clustering:d,localStudio:oe.object({enabled:r}).required(),logging:oe.object({auditAuthEvents:oe.object({logFailed:be,logSuccessful:be}),file:be.required(),level:oe.valid("notify","fatal","error","warn","info","debug","trace"),rotation:oe.object({enabled:be.optional(),compress:be.optional(),interval:Zt.custom(RV).optional().empty(null),maxSize:Zt.custom(gV).optional().empty(null),path:Zt.optional().empty(null).default(mc)}).required(),root:s,stdStreams:be.required(),auditLog:be.required()}).required(),operationsApi:oe.object({network:oe.object({cors:be.optional(),corsAccessList:a_.optional(),headersTimeout:Ze.min(1).optional(),keepAliveTimeout:Ze.min(1).optional(),port:Ze.optional().empty(null),domainSocket:oe.optional().empty("hdb/operations-server").default(mc),securePort:Ze.optional().empty(null),timeout:Ze.min(1).optional()}).optional(),tls:oe.alternatives([oe.array().items(u),u])}).required(),rootPath:Zt.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:oe.object({network:oe.object({port:Bi,securePort:Bi,mtls:oe.alternatives([be.optional(),oe.object({user:Zt.optional(),certificateAuthority:i,required:be.optional()})])}).required(),webSocket:be.optional(),requireAuthentication:be.optional()}),http:oe.object({compressionThreshold:Ze.optional(),cors:be.optional(),corsAccessList:a_.optional(),headersTimeout:Ze.min(1).optional(),port:Ze.min(0).optional().empty(null),securePort:Ze.min(0).optional().empty(null),maxHeaderSize:Ze.optional(),mtls:oe.alternatives([be.optional(),oe.object({user:Zt.optional(),certificateAuthority:i,required:be.optional()})]),threadRange:oe.alternatives([a_.optional(),Zt.optional()])}).required(),threads:oe.alternatives(n.optional(),oe.object({count:n.optional(),debug:oe.alternatives(be.optional(),oe.object({startingPort:Ze.min(1).optional(),host:Zt.optional(),waitForDebugger:be.optional()})),maxHeapMemory:Ze.min(0).optional()})),storage:oe.object({writeAsync:be.required(),overlappingSync:be.optional(),caching:be.optional(),compression:oe.alternatives([be.optional(),oe.object({dictionary:Zt.optional(),threshold:Ze.optional()})]),compactOnStart:be.optional(),compactOnStartKeepBackup:be.optional(),noReadAhead:be.optional(),path:l,prefetchWrites:be.optional(),maxFreeSpaceToLoad:Ze.optional(),maxFreeSpaceToRetain:Ze.optional()}).required(),ignoreScripts:be.optional(),tls:oe.alternatives([oe.array().items(u),u])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(pV,"configValidator");function SV(e){return XO||jO.existsSync(e)?null:`Specified path ${e} does not exist.`}a(SV,"doesPathExist");function TV(e,t){oe.assert(e,Zt.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=SV(e);if(r)return t.message(r)}a(TV,"validatePath");function gV(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(_V);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(fV):e}a(gV,"validateRotationMaxSize");function RV(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(dV);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(EV):e}a(RV,"validateRotationInterval");function AV(e,t){let r=t.state.path.join("."),n=aV.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||QO();return i=Math.round(Math.min(i,QO())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),cV.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(AV,"setDefaultThreads");function mc(e,t){let r=t.state.path.join(".");if(!c_.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(c_.isEmpty(Wn))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return vi.join(Wn,uV);case"logging.root":return vi.join(Wn,JO);case"clustering.leafServer.streams.path":return vi.join(Wn,"clustering","leaf");case"storage.path":let n=vi.join(Wn,zO.LEGACY_DATABASES_DIR_NAME);return jO.existsSync(n)?n:vi.join(Wn,zO.DATABASES_DIR_NAME);case"logging.rotation.path":return vi.join(Wn,JO);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 OV(e){let t=oe.object({routes:l_});return lV.validateBySchema({routes:e},t)}a(OV,"routesValidator")});var Hi={};qe(Hi,{server:()=>it});var eb,it,ur=Re(()=>{eb=require("../../index"),it={};(0,eb._assignPackageExport)("server",it)});var dr=g((sae,lb)=>{"use strict";var Br=U(),vt=z(),It=Y(),{configValidator:bV,routesValidator:tb}=Hh(),_r=require("fs-extra"),yV=require("yaml"),bn=require("path"),NV=require("is-number"),nb=require("properties-reader"),IV=require("lodash"),{handleHDBError:wV}=ne(),{HTTP_STATUS_CODES:CV,HDB_ERROR_MSGS:u_}=Ur(),nae=require("minimist"),{server:DV}=(ur(),ie(Hi)),{DATABASES_PARAM_CONFIG:pc,CONFIG_PARAMS:vr,CONFIG_PARAM_MAP:yn}=Br,LV="Unable to get config value because config is uninitialized",MV="Config successfully initialized",PV="Error backing up config file",UV="Empty parameter sent to getConfigValue",sb=bn.join(Br.PACKAGE_ROOT,"config","yaml",Br.HDB_DEFAULT_CONFIG_FILE),vV="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",rb={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"},__,wt,d_;lb.exports={createConfigFile:BV,getDefaultConfig:HV,getConfigValue:ob,initConfig:Gh,flattenConfig:ko,updateConfigValue:ab,updateConfigObject:GV,getConfiguration:kV,setConfiguration:VV,readConfigFile:qh,getClusteringRoutes:$V,initOldConfig:cb,getConfigFromFile:YV,getConfigFilePath:xi,addConfig:KV,deleteConfigFromFile:WV,getConfigObj:QV};function BV(e,t=!1){let r=Zs(sb);__=ko(r.toJSON());let n;for(let c in e){let l=yn[c.toLowerCase()];if(l===vr.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(_=>({[_]:e[c][_]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let _=l.split("_"),u=xh(l,e[c]);l==="rootPath"&&u?.endsWith("/")&&(u=u.slice(0,-1));try{r.setIn([..._],u)}catch(d){It.error(d)}}}n&&ib(r,n),Fh(r,t);let s=r.toJSON();wt=ko(s);let i=r.getIn(["rootPath"]),o=bn.join(i,Br.HDB_CONFIG_FILE);_r.createFileSync(o),_r.writeFileSync(o,String(r)),It.trace(`Config file written to ${o}`)}a(BV,"createConfigFile");function ib(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!vt.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],l=[vr.DATABASES,s,pc.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[vr.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){It.error("Error parsing schemas CLI/env config arguments",n)}}a(ib,"setSchemasConfig");function HV(e){if(__===void 0){let r=Zs(sb);__=ko(r.toJSON())}let t=yn[e.toLowerCase()];if(t!==void 0)return __[t.toLowerCase()]}a(HV,"getDefaultConfig");function ob(e){if(e==null){It.error(UV);return}if(wt===void 0){It.trace(LV);return}let t=yn[e.toLowerCase()];if(t!==void 0)return wt[t.toLowerCase()]}a(ob,"getConfigValue");function xi(e=vt.getPropsFilePath()){let t=vt.getEnvCliRootPath();return t?bn.join(t,Br.HDB_CONFIG_FILE):nb(e).get(Br.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY)}a(xi,"getConfigFilePath");function Gh(e=!1){if(wt===void 0||e){let t;if(!vt.noBootFile()){t=vt.getPropsFilePath();try{_r.accessSync(t,_r.constants.F_OK|_r.constants.R_OK)}catch(i){throw It.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=xi(t),n;if(r.includes("config/settings.js"))try{cb(r);return}catch(i){if(i.code!==Br.NODE_ERROR_CODES.ENOENT)throw i}try{n=Zs(r)}catch(i){if(i.code===Br.NODE_ERROR_CODES.ENOENT){It.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 It.error(i),new Error(`Error reading HarperDB config file at ${r}`)}xV(n,r),Fh(n);let s=n.toJSON();if(DV.config=s,wt=ko(s),wt.logging_rotation_rotate)for(let i in rb)wt[i]&&It.error(`Config ${rb[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);It.trace(MV)}}a(Gh,"initConfig");function xV(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],bn.join(r,"database")),n=!0),e.hasIn(["clustering","leafServer","streams","path"])||(e.setIn(["clustering","leafServer","streams","path"],bn.join(r,"clustering","leaf")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],bn.join(r,"log")),n=!0),e.hasIn(["clustering","tls","verify"])||(e.setIn(["clustering","tls","verify"],!0),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n&&(It.trace("Updating config file with missing config params"),_r.writeFileSync(t,String(e)))}a(xV,"checkForUpdatedConfig");function Fh(e,t=!1){let r=e.toJSON();r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads);let n=bV(r,t);if(n.error)throw u_.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket)}a(Fh,"validateConfig");function GV(e,t){wt===void 0&&(wt={});let r=yn[e.toLowerCase()];if(r===void 0){It.trace(`Unable to update config object because config param '${e}' does not exist`);return}wt[r.toLowerCase()]=t}a(GV,"updateConfigObject");function ab(e,t,r=void 0,n=!1,s=!1,i=!1){wt===void 0&&Gh();let o=ob(yn.hdb_root),c=bn.join(o,Br.HDB_CONFIG_FILE),l=Zs(c),_;if(r===void 0&&e.toLowerCase()===vr.DATABASES)_=t;else if(r===void 0){let E;if(i)E=e;else if(E=yn[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=xh(E,t);l.setIn([...f],h)}else for(let E in r){let f=yn[E.toLowerCase()];if(f===vr.HTTP_SECUREPORT&&r[E]===wt[vr.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===vr.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===wt[vr.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===vr.DATABASES){_=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),p=Br.LEGACY_CONFIG_PARAMS[E.toUpperCase()];p&&p.startsWith("customFunctions")&&l.hasIn(p.split("_"))&&(f=p,h=p.split("_"));let S=xh(f,r[E]);f==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],S)}catch(T){It.error(T)}}}_&&ib(l,_),Fh(l);let u=l.getIn(["rootPath"]),d=bn.join(u,Br.HDB_CONFIG_FILE);n===!0&&FV(c,u),_r.writeFileSync(d,String(l)),s&&(wt=ko(l.toJSON())),It.trace(`Config parameter: ${e} updated with value: ${t}`)}a(ab,"updateConfigValue");function FV(e,t){try{let r=bn.join(t,"backup",`${Br.HDB_CONFIG_FILE}.bak`);_r.copySync(e,r),It.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){It.error(PV),It.error(r)}}a(FV,"backupConfigFile");var qV=["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)),d_=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])&&!qV.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!vr[l.toUpperCase()]&&yn[l]&&(s[yn[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(ko,"flattenConfig");function xh(e,t){if(e===vr.CLUSTERING_NODENAME||e===vr.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(NV(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||vt.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 vt.autoCast(t)}a(xh,"castConfigValue");function kV(){let e=vt.getPropsFilePath(),t=xi(e);return Zs(t).toJSON()}a(kV,"getConfiguration");async function VV(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return ab(void 0,void 0,s,!0),vV}catch(i){throw typeof i=="string"||i instanceof String?wV(i,i,CV.BAD_REQUEST,void 0,void 0,!0):i}}a(VV,"setConfiguration");function qh(){let e=vt.getPropsFilePath();try{_r.accessSync(e,_r.constants.F_OK|_r.constants.R_OK)}catch(n){if(!vt.noBootFile())throw It.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=xi(e);return Zs(t).toJSON()}a(qh,"readConfigFile");function Zs(e){return yV.parseDocument(_r.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Zs,"parseYamlDoc");function $V(){let e=qh(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=vt.isEmptyOrZeroLength(t)?[]:t;let r=tb(t);if(r)throw u_.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=vt.isEmptyOrZeroLength(n)?[]:n;let s=tb(n);if(s)throw u_.CONFIG_VALIDATION(s.message);if(!vt.isEmptyOrZeroLength(n)&&!vt.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!vt.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw u_.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a($V,"getClusteringRoutes");function cb(e){let t=nb(e);wt={};for(let r in yn){let n=t.get(r.toUpperCase());if(vt.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=yn[r].toLowerCase();s===vr.LOGGING_ROOT?wt[s]=bn.dirname(n):wt[s]=n}return wt}a(cb,"initOldConfig");function YV(e){let t=qh();return IV.get(t,e.replaceAll("_","."))}a(YV,"getConfigFromFile");async function KV(e,t){let r=Zs(xi());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await _r.writeFile(xi(),String(r))}a(KV,"addConfig");function WV(e){let t=xi(vt.getPropsFilePath()),r=Zs(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=bn.join(n,Br.HDB_CONFIG_FILE);_r.writeFileSync(s,String(r))}a(WV,"deleteConfigFromFile");function QV(){return d_||(Gh(),d_)}a(QV,"getConfigObj")});var te=g((oae,Eb)=>{"use strict";var kh=require("fs-extra"),Gi=require("path"),ub=require("os"),zV=require("properties-reader"),Tc=Y(),Sc=z(),ue=U(),f_=dr(),JV="Error initializing environment manager",E_="BOOT_PROPS_FILE_PATH",_b=!1,jV={[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},Ts={};Eb.exports={BOOT_PROPS_FILE_PATH:E_,getHdbBasePath:XV,setHdbBasePath:ZV,get:db,initSync:t$,setProperty:Le,initTestEnvironment:n$,setCloneVar:r$};function XV(){return Ts[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(XV,"getHdbBasePath");function ZV(e){Ts[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(ZV,"setHdbBasePath");function db(e){let t=f_.getConfigValue(e);return t===void 0?Ts[e]:t}a(db,"get");function Le(e,t){jV[e]&&(Ts[e]=t),f_.updateConfigObject(e,t)}a(Le,"setProperty");function e$(){let e;try{e=Sc.getPropsFilePath(),kh.accessSync(e,kh.constants.F_OK|kh.constants.R_OK),_b=!0;let t=zV(e);return Ts[ue.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(ue.HDB_SETTINGS_NAMES.INSTALL_USER),Ts[ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),Ts[E_]=e,!0}catch{return Tc.trace(`Environment manager found no properties file at ${e}`),!1}}a(e$,"doesPropFileExist");function t$(e=!1){try{(_b||e$()||Sc.noBootFile())&&!fb&&(f_.initConfig(e),Ts[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=f_.getConfigValue(ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Tc.error(JV),Tc.error(t),console.error(t),process.exit(1)}}a(t$,"initSync");var fb=!1;function r$(e){fb=e}a(r$,"setCloneVar");function n$(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=Gi.join(__dirname,"../../","unitTests");Ts[E_]=Gi.join(l,"hdb_boot_properties.file"),Le(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Gi.join(l,"settings.test")),Le(ue.HDB_SETTINGS_NAMES.INSTALL_USER,ub.userInfo()?ub.userInfo().username:void 0),Le(ue.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Le(ue.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Gi.join(l,"envDir","log")),Le(ue.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Le(ue.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Le(ue.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Le(ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Gi.join(l,"envDir")),Le(ue.CONFIG_PARAMS.STORAGE_PATH,Gi.join(l,"envDir")),s&&(Le(ue.CONFIG_PARAMS.HTTP_SECUREPORT,db(ue.CONFIG_PARAMS.HTTP_PORT)),Le(ue.CONFIG_PARAMS.HTTP_PORT,null)),Le(ue.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Le(ue.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Le(ue.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Sc.isEmpty(i)?!1:i),Le(ue.CONFIG_PARAMS.HTTP_CORS,Sc.isEmpty(i)?!1:i),Le(ue.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Le(ue.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Le(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Le(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Le(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Gi.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Le(ue.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Sc.isEmpty(c)?!1:c),o&&(Le("CORS_ACCESSLIST",o),Le(ue.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Le(ue.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Le(ue.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Le(ue.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Le(ue.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Le(ue.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Le(ue.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${E_}. Please check your boot props and settings files`;Tc.fatal(r),Tc.error(t)}}a(n$,"initTestEnvironment")});var ze=g((cae,Rb)=>{"use strict";var bc=U(),s$=z(),fr=te(),yc=require("path"),i$=require("minimist"),hb=require("fs-extra"),mb=require("lodash");fr.initSync();var{CONFIG_PARAMS:ei,DATABASES_PARAM_CONFIG:gc,SYSTEM_SCHEMA_NAME:h_}=bc,Rc,Ac,Oc;function pb(){if(Rc!==void 0)return Rc;if(fr.getHdbBasePath()!==void 0)return Rc=fr.get(ei.STORAGE_PATH)||yc.join(fr.getHdbBasePath(),bc.DATABASES_DIR_NAME),Rc}a(pb,"getBaseSchemaPath");function Sb(){if(Ac!==void 0)return Ac;if(fr.getHdbBasePath()!==void 0)return Ac=gb(h_),Ac}a(Sb,"getSystemSchemaPath");function Tb(){if(Oc!==void 0)return Oc;if(fr.getHdbBasePath()!==void 0)return Oc=fr.get(bc.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||yc.join(fr.getHdbBasePath(),bc.TRANSACTIONS_DIR_NAME),Oc}a(Tb,"getTransactionAuditStoreBasePath");function o$(e,t){let r=fr.get(ei.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||yc.join(Tb(),e.toString())}a(o$,"getTransactionAuditStorePath");function gb(e,t){e=e.toString(),t=t&&t.toString();let r=fr.get(bc.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||yc.join(pb(),e)}a(gb,"getSchemaPath");function a$(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,i$(process.argv));let n=r[ei.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!s$.isObject(n))throw o;i=n}for(let o of i){let c=o[h_];if(!c)continue;let l=fr.get(ei.DATABASES);l=l??{};let _=c?.tables?.[t]?.[gc.PATH];if(_)return mb.set(l,[h_,gc.TABLES,t,gc.PATH],_),fr.setProperty(ei.DATABASES,l),_;let u=c?.[gc.PATH];if(u)return mb.set(l,[h_,gc.PATH],u),fr.setProperty(ei.DATABASES,l),u}}let s=r[ei.STORAGE_PATH.toUpperCase()];if(s){if(!hb.pathExistsSync(s))throw new Error(s+" does not exist");let i=yc.join(s,e);return hb.mkdirsSync(i),fr.setProperty(ei.STORAGE_PATH,s),i}return Sb()}a(a$,"initSystemSchemaPaths");function c$(){Rc=void 0,Ac=void 0,Oc=void 0}a(c$,"resetPaths");Rb.exports={getBaseSchemaPath:pb,getSystemSchemaPath:Sb,getTransactionAuditStorePath:o$,getTransactionAuditStoreBasePath:Tb,getSchemaPath:gb,initSystemSchemaPaths:a$,resetPaths:c$}});var Hr=g((dae,Nb)=>{"use strict";var l$=Ur().LMDB_ERRORS_ENUM,uae=require("lmdb"),u$=dt(),_ae=require("buffer").Buffer,{OVERFLOW_MARKER:Ab,MAX_SEARCH_KEY_LENGTH:m_}=u$,Ob=["number","string","symbol","boolean","bigint"];function _$(e){if(e=e?.primaryStore||e,!e)throw new Error(l$.ENV_REQUIRED)}a(_$,"validateEnv");function d$(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(d$,"stringifyData");function f$(e){return e instanceof Date?e.valueOf():e}a(f$,"convertKeyValueToWrite");function E$(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(Ob.includes(typeof e))return e.length>m_?[e.slice(0,m_)+Ab]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(Ob.includes(typeof i))i.length>m_?r.push(i.slice(0,m_)+Ab):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(E$,"getIndexedValues");var p_=0,bb=0;function yb(){bb=Date.now()-performance.now()}a(yb,"adjustStartTime");yb();var h$=6e4;setInterval(yb,h$).unref();function m$(){let e=performance.now()+bb;return e>p_?(p_=e,e):(p_+=488e-6,p_)}a(m$,"getNextMonotonicTime");Nb.exports={validateEnv:_$,stringifyData:d$,convertKeyValueToWrite:f$,getNextMonotonicTime:m$,getIndexedValues:E$}});var Ib,Nn,Vh,Nc=Re(()=>{Ib=require("events"),Nn=class extends Ib.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;[Symbol.asyncIterator](){let t=new Vh;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)}},Vh=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 Kh={};qe(Kh,{loadGQLSchema:()=>T$,start:()=>Yh,startOnMainThread:()=>S$});function Yh({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:_,StringValueNode:u}=await import("graphql"),d=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let S of d.definitions)switch(S.kind){case l.OBJECT_TYPE_DEFINITION:let H=function(v){if(v.kind==="NonNullType"){let Q=H(v.type);return Q.nullable=!1,Q}if(v.kind==="ListType")return{type:"array",elements:H(v.type)};let M={type:v.name?.value};return Object.defineProperty(M,"location",{value:v.loc.startToken}),M};a(H,"getProperty");let T=S.name.value,R=[],b={table:null,database:null,properties:R};E.set(T,b);for(let v of S.directives){if(v.name.value==="table"){for(let q of v.arguments)b[q.name.value]=q.value.value;b.schema&&(b.database=b.schema),b.table||(b.table=T),b.audit&&(b.audit=b.audit!=="false"),b.attributes=b.properties,f.push(b)}if(v.name.value==="sealed"&&(b.sealed=!0),v.name.value==="export"){b.export=!0;for(let q of v.arguments)q.name.value==="name"&&(b.export={name:q.value.value})}}let C=!1;for(let v of S.fields){let q=H(v.type);q.name=v.name.value,R.push(q);for(let M of v.directives)if(M.name.value==="primaryKey")C?console.warn("Can not define two attributes as a primary key"):(q.isPrimaryKey=!0,C=!0);else if(M.name.value==="indexed")q.indexed=!0;else if(M.name.value==="relationship"){let Q={};for(let J of M.arguments)Q[J.name.value]=J.value.value;q.relationship=Q}else if(M.name.value==="createdTime")q.assignCreatedTime=!0;else if(M.name.value==="updatedTime")q.assignUpdatedTime=!0;else if(M.name.value==="expiresAt")q.expiresAt=!0;else if(M.name.value==="allow"){let Q=q.authorizedRoles=[];for(let J of M.arguments)J.name.value==="role"&&Q.push(J.value.value)}}b.type=T,T==="Query"&&(h=b)}function p(S){let T=E.get(S.type);T?(Object.defineProperty(S,"properties",{value:T.properties}),Object.defineProperty(S,"definition",{value:T})):S.type==="array"?p(S.elements):p$.includes(S.type)||(0,wb.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 E.values())for(let T of S.properties)p(T);for(let S of f)S.tableClass=e(S),S.export&&(S.export.name===""?i.set((0,$h.dirname)(n),S.tableClass):i.set((0,$h.dirname)(n)+"/"+(S.export.name||S.type),S.tableClass))}}var $h,wb,p$,S$,T$,Cb=Re(()=>{$h=require("path");Ae();wb=B(ot()),p$=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];a(Yh,"start");S$=Yh,T$=Yh({ensureTable:ft}).handleFile});async function S_(e){let t=(0,Mb.pathToFileURL)(e).toString();return g$?(Ic||(Ic=R$(O$)),(await(await Ic).import(t)).namespace):import(t)}async function R$(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),Ic=new Compartment({console,Math,Date,fetch:A$,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,Lb.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:$t,tables:xr,databases:at})}};let n=await(0,Db.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),Ic}function A$(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 O$(){return{Resource:$t,tables:xr}}var Db,Lb,Mb,g$,Ic,Wh=Re(()=>{In();Ae();Db=require("fs/promises"),Lb=require("path"),Mb=require("url"),g$=!1;a(S_,"secureImport");a(R$,"getCompartment");a(A$,"secureOnlyFetch");a(O$,"getGlobalVars")});var zh={};qe(zh,{handleFile:()=>b$});async function b$(e,t,r,n){let s=new Map,i=await S_(r);c(i.default)&&n.set((0,Qh.dirname)(t),i.default),o(i,(0,Qh.dirname)(t));function o(l,_){for(let u in l){let d=l[u];c(d)?n.set(_+"/"+u,d):typeof d=="object"&&o(d,_+"/"+u)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var Qh,Pb=Re(()=>{Wh();Qh=require("path");a(b$,"handleFile")});var jh={};qe(jh,{start:()=>y$});function y$({resources:e}){e.set("login",Jh),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var Jh,Ub=Re(()=>{In();a(y$,"start");Jh=class extends $t{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 qb={};qe(qb,{parse:()=>Zh,streamAsJSON:()=>wc,stringify:()=>Fi});function wc(e){return new Xh({value:e})}function vb(e){return console.error(e),JSON.stringify(e.toString())}function Bb(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Fi(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===Gb)return Fb(e);if(t.resolution)return t.resolution.then(()=>Fi(e));throw t}}function Fb(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+=Fb(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Fi(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Zh(e){return w$.test(e)?N$.parse(e):JSON.parse(e)}var Hb,xb,N$,I$,Gb,Xh,w$,em=Re(()=>{Hb=require("stream"),xb=B(require("json-bigint-fixes")),N$=(0,xb.default)({useNativeBigInt:!0}),I$=1e4,Gb={};BigInt.prototype.toJSON=function(){throw Gb};a(wc,"streamAsJSON");Xh=class extends Hb.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),vb)}catch(s){yield vb(s)}else yield Fi(t)}else yield Fi(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);Bb(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>I$?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 Bb(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(vb,"handleError");a(Bb,"when");a(Fi,"stringify");a(Fb,"jsStringify");w$=/[[,:]\s*-?\d{16,}/;a(Zh,"parse")});var ey=g((wae,Zb)=>{"use strict";var tm=require("recursive-iterator"),C$=require("alasql"),rm=require("clone"),kb=z(),{handleHDBError:Vb,hdb_errors:D$}=ne(),{HDB_ERROR_MSGS:$b,HTTP_STATUS_CODES:Yb}=D$,{getDatabases:L$}=(Ae(),ie(ke)),M$=["DISTINCT_ARRAY"],Kb=Symbol("validateTables"),nm=Symbol("validateTable"),Iae=Symbol("getAllColumns"),Wb=Symbol("validateAllColumns"),T_=Symbol("findColumn"),Qb=Symbol("validateOrderBy"),Cc=Symbol("validateSegment"),sm=Symbol("validateColumn"),zb=Symbol("setColumnsForTable"),Jb=Symbol("checkColumnsForAsterisk"),jb=Symbol("validateGroupBy"),Xb=Symbol("hasColumns"),im=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[Kb](),this[Jb](),this[Wb]()}[Kb](){if(this[Xb]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[nm](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[nm](t.table)})}}[Xb](){let t=!1,r=new tm(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[nm](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=L$();if(!r[t.databaseid])throw Vb(new Error,$b.SCHEMA_NOT_FOUND(t.databaseid),Yb.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw Vb(new Error,$b.TABLE_NOT_FOUND(t.databaseid,t.tableid),Yb.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=rm(s);i.table=rm(t),this.attributes.push(i)})}[T_](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)}[Jb](){let t=new tm(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[zb](r.tableid)}[zb](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new C$.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[Wb](){this[Cc](this.statement.columns,!1),this[Cc](this.statement.joins,!1),this[Cc](this.statement.where,!1),this[jb](this.statement.group,!1),this[Cc](this.statement.order,!0)}[Cc](t,r){if(!t)return;let n=new tm(t),s=[];for(let{node:i,path:o}of n)!kb.isEmpty(i)&&!kb.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[Qb](i):s.push(this[sm](i)));return s}[jb](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&M$.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=rm(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[T_](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[T_](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`}[Qb](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[sm](t)}[sm](t){let r=this[T_](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]}};Zb.exports=im});var ry=g((Dae,ty)=>{"use strict";var om=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")}};ty.exports=om});var sy=g((Mae,ny)=>{"use strict";var am=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};ny.exports=am});var cy={};qe(cy,{HAS_EXPIRATION:()=>Em,LAST_TIMESTAMP_PLACEHOLDER:()=>Mc,LOCAL_TIMESTAMP:()=>P$,METADATA:()=>Dc,NO_TIMESTAMP:()=>lm,PENDING_LOCAL_TIME:()=>hm,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>fm,RecordEncoder:()=>dm,TIMESTAMP_ASSIGN_LAST:()=>v$,TIMESTAMP_ASSIGN_NEW:()=>oy,TIMESTAMP_ASSIGN_PREVIOUS:()=>ay,TIMESTAMP_PLACEHOLDER:()=>g_,TIMESTAMP_RECORD_PREVIOUS:()=>um,getUpdateRecord:()=>mm,handleLocalTimeForGets:()=>b_});function H$(){return Lc[0]=Lc[0]^64,U$.getFloat64(0)}function b_(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),l=c?.value,_=l?.[Dc];return _>=0&&(c.metadataFlags=_,c.localTime=l.localTime,c.value=l.value,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[Dc]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let l=c.value,_=l[Dc];return _>=0&&(c.metadataFlags=_,c.localTime=l.localTime,c.value=l.value,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,qi.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<qi.length;l++){let _=qi[l].deref();(!_||_.isDone||_.isCommitted)&&qi.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function mm(e,t,r){return function(n,s,i,o,c=-1,l,_,u,d="put",E,f){if(E||l==null?Vo=i?.localTime?um|ay:lm:Vo=l?i?.localTime?um|16384:oy|16384:lm,u>0&&(c|=Em),A_=c,_m=u,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Vo>0},p;try{E&&(h.ifVersion=p=i?.version??null);let S=e.put(n,s,h);if(l){let T=_?.user?.username;if(f&&(R_=e.encoder.encode(f)),E&&i?.localTime){let R=i?.localTime,b=r.get(R);if(b){let C=Bt(b).previousLocalTime;return r.put(R,O_(o,t,n,C,T,d,R_),{ifVersion:p}),S}}r.put(Mc,O_(o,t,n,i?.localTime?1:0,T,d,R_),{append:d!=="invalidate",instructedWrite:!0,ifVersion:p})}return S}catch(S){throw S.message+=" id: "+n+" options: "+h,S}}}var iy,cm,g_,Mc,fm,P$,Dc,Lc,U$,lm,oy,v$,ay,um,Em,hm,B$,R_,Vo,A_,_m,dm,qi,Pc=Re(()=>{iy=require("msgpackr");ti();cm=B(Y()),g_=new Uint8Array([1,1,1,1,4,64,0,0]),Mc=new Uint8Array([1,1,1,1,1,0,0,0]),fm=new Uint8Array([1,1,1,1,3,64,0,0]),P$=Symbol("local-timestamp"),Dc=Symbol("metadata"),Lc=new Uint8Array(8),U$=new DataView(Lc.buffer,0,8),lm=0,oy=0,v$=1,ay=3,um=4,Em=16,hm=1,Vo=0,A_=-1,_m=0,dm=class extends iy.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(n,s){if(Vo||A_>=0){let i=0,o=Vo;o&&(i+=8,Vo=0);let c=A_,l=_m;c>=0&&(i+=2,A_=-1,l&&(i+=8,_m=0));let _=B$=r.call(this,n,s|2048|i);R_=_.subarray((_.start||0)+i,_.end);let u=_.start||0;return o&&(g_[4]=o,g_[5]=o>>8,_.set(g_,u),u+=8),c>=0&&(_[u++]=c,_[u++]=0,l&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(u,l)),_}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,l;if(i===2){if(t.copy)t.copy(Lc,0,c),c+=8;else for(let d=0;d<8;d++)Lc[d]=t[c++];l=H$(),i=t[c]}let _;i<32&&(o=i,c+=2,o&Em&&(_=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8));let u=super.decode(t.subarray(c,s),s-c);return{localTime:l,value:u,[Dc]:o,expiresAt:_}}return super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(H$,"getTimestamp");a(b_,"handleLocalTimeForGets");qi=[];setInterval(()=>{for(let e=0;e<qi.length;e++){let t=qi[e].deref();!t||t.isDone||t.isCommitted?qi.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(cm.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):cm.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(mm,"getUpdateRecord")});var Uc=g((Hae,uy)=>{"use strict";var ly=te(),x$=U(),{RecordEncoder:G$}=(Pc(),ie(cy)),Bae=require("fs");ly.initSync();var F$=ly.get(x$.CONFIG_PARAMS.STORAGE_CACHING)!==!1,pm=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=F$&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:G$})}};uy.exports=pm});var vc=g((Gae,_y)=>{"use strict";var Gr=te(),cn=U();Gr.initSync();var y_=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.eventTurnBatching=!1,this.noSync=Gr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Gr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Gr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Gr.get(cn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Gr.get(cn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Gr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Gr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Gr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Gr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Gr.get(cn.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Gr.get(cn.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Gr.get(cn.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};_y.exports=y_;y_.MAX_DBS=1e4});var Ke=g((qae,Ry)=>{"use strict";var Tm=require("lmdb"),wn=require("fs-extra"),Fr=require("path"),N_=Hr(),Ey=Y(),Er=Ur().LMDB_ERRORS_ENUM,I_=sy(),gm=Uc(),hy=vc(),ri=dt(),dy=U(),{table:q$,resetDatabases:k$}=(Ae(),ie(ke)),fy=te(),Cn=ri.INTERNAL_DBIS_NAME,my=ri.DBI_DEFINITION_NAME,V$="data.mdb",$$="lock.mdb",Bc=".mdb",Y$="-lock",Sm=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ln(t,r),this.key_type=this.dbi[ri.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[ri.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new Tm.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function w_(e,t){if(e===void 0)throw new Error(Er.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Er.ENV_NAME_REQUIRED)}a(w_,"pathEnvNameValidation");async function Rm(e,t,r=!0){try{await wn.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Er.INVALID_BASE_PATH):n}try{let n=Fr.join(e,t+Bc);return await wn.access(n,wn.constants.R_OK|wn.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await wn.access(Fr.join(e,t,V$),wn.constants.R_OK|wn.constants.F_OK),Fr.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Er.INVALID_ENVIRONMENT)}else throw new Error(Er.INVALID_ENVIRONMENT);throw n}}a(Rm,"validateEnvironmentPath");function C_(e,t){if(N_.validateEnv(e),t===void 0)throw new Error(Er.DBI_NAME_REQUIRED)}a(C_,"validateEnvDBIName");async function K$(e,t,r=!1,n=!1){w_(e,t);let s=Fr.basename(e);t=t.toString();let i=fy.get(dy.CONFIG_PARAMS.DATABASES);i||fy.setProperty(dy.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await Rm(e,t,n),py(e,t,r)}catch(o){if(o.message===Er.INVALID_ENVIRONMENT){let c=Fr.join(e,t);await wn.mkdirp(n?c:e);let l=new hy(n?c:c+Bc,!1),_=Tm.open(l);_.dbis=Object.create(null);let u=new gm(!1);_.openDB(Cn,u),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=Am(e,t,r);return _[ri.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=_,_}throw o}}a(K$,"createEnvironment");async function W$(e,t,r,n=!0){w_(e,t),t=t.toString();let s=Fr.join(e,t);return q$({table:t,database:Fr.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(W$,"copyEnvironment");async function py(e,t,r=!1){w_(e,t),t=t.toString();let n=Am(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=Fr.join(e,t+Bc),o=s!=i,c=new hy(s,o),l=Tm.open(c);l.dbis=Object.create(null);let _=Ty(l);for(let u=0;u<_.length;u++)ln(l,_[u]);return l[ri.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(py,"openEnvironment");async function Q$(e,t,r=!1){w_(e,t),t=t.toString();let n=Fr.join(e,t+Bc),s=await Rm(e,t);if(global.lmdb_map!==void 0){let i=Am(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await Sy(o),delete global.lmdb_map[i]}}await wn.remove(s),await wn.remove(s===n?s+Y$:Fr.join(Fr.dirname(s),$$))}a(Q$,"deleteEnvironment");async function Sy(e){N_.validateEnv(e);let t=e[ri.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(Sy,"closeEnvironment");function Am(e,t,r=!1){let s=`${Fr.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(Am,"getCachedEnvironmentName");function z$(e){N_.validateEnv(e);let t=Object.create(null),r=ln(e,Cn);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Cn)try{t[n]=Object.assign(new I_,s)}catch{Ey.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(z$,"listDBIDefinitions");function Ty(e){N_.validateEnv(e);let t=[],r=ln(e,Cn);for(let{key:n}of r.getRange({start:!1}))n!==Cn&&t.push(n);return t}a(Ty,"listDBIs");function J$(e,t){let n=ln(e,Cn).getEntry(t),s=new I_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{Ey.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(J$,"getDBIDefinition");function gy(e,t,r,n=!r){if(C_(e,t),t=t.toString(),t===Cn)throw new Error(Er.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ln(e,t)}catch(s){if(s.message===Er.DBI_DOES_NOT_EXIST){let i=new gm(r,n===!0),o=e.openDB(t,i),c=new I_(r===!0,n);return o[my]=c,ln(e,Cn).putSync(t,c),e.dbis[t]=o,o}throw s}}a(gy,"createDBI");function ln(e,t){if(C_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Cn?r=J$(e,t):r=new I_,r===void 0)throw new Error(Er.DBI_DOES_NOT_EXIST);let n;try{let s=new gm(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(Er.DBI_DOES_NOT_EXIST):s}return n[my]=r,e.dbis[t]=n,n}a(ln,"openDBI");function j$(e,t){C_(e,t),t=t.toString();let r=ln(e,t),n=r.getStats();return r[ri.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(j$,"statDBI");async function X$(e,t){try{let r=Fr.join(e,t+Bc);return(await wn.stat(r)).size}catch{throw new Error(Er.INVALID_ENVIRONMENT)}}a(X$,"environmentDataSize");function Z$(e,t){if(C_(e,t),t=t.toString(),t===Cn)throw new Error(Er.CANNOT_DROP_INTERNAL_DBIS_NAME);ln(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ln(e,Cn).removeSync(t)}a(Z$,"dropDBI");function e1(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{ln(e,i)}catch(o){if(o.message===Er.DBI_DOES_NOT_EXIST)gy(e,i,i!==t,i===t),n=!0;else throw o}}n&&k$()}a(e1,"initializeDBIs");Ry.exports={openDBI:ln,openEnvironment:py,createEnvironment:K$,listDBIs:Ty,listDBIDefinitions:z$,createDBI:gy,dropDBI:Z$,statDBI:j$,deleteEnvironment:Q$,initializeDBIs:e1,TransactionCursor:Sm,environmentDataSize:X$,copyEnvironment:W$,closeEnvironment:Sy}});var Oy=g((Vae,Ay)=>{"use strict";var Om=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};Ay.exports=Om});var yy=g((Yae,by)=>{"use strict";var bm=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}};by.exports=bm});var Iy=g((Wae,Ny)=>{"use strict";var ym=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};Ny.exports=ym});var $o=g((Xae,Dy)=>{"use strict";var t1=Ke(),r1=Oy(),n1=yy(),s1=Iy(),Qn=Hr(),Hc=Ur().LMDB_ERRORS_ENUM,i1=dt(),gs=U(),o1=z(),a1=require("uuid"),zae=require("lmdb"),{handleHDBError:c1,hdb_errors:l1}=ne(),{OVERFLOW_MARKER:Jae,MAX_SEARCH_KEY_LENGTH:jae}=i1,wy=te();wy.initSync();var D_=wy.get(gs.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),Nm=gs.TIME_STAMP_NAMES_ENUM.CREATED_TIME,ki=gs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function u1(e,t,r,n,s=Qn.getNextMonotonicTime()){Dm(e,t,r,n),Im(e,t,r);let i=new r1,o=[],c=[];for(let l=0;l<n.length;l++){let _=n[l];Cy(_,!0,s);let u=_1(e,t,r,_),d=_[t];o.push(u),c.push(d)}return wm(o,c,n,i,s)}a(u1,"insertRecords");function _1(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 u=c([[{}]]);Array.isArray(u)&&(c=u[0][gs.FUNC_VAL],n[o]=c)}let l=Qn.getIndexedValues(c),_=e.dbis[o];if(l){D_&&_.prefetch(l.map(u=>({key:u,value:s})),L_);for(let u=0,d=l.length;u<d;u++)_.put(l[u],s)}}D_&&e.dbis[t].prefetch([s],L_),e.dbis[t].put(s,n,n[ki])})}a(_1,"insertRecord");function d1(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(d1,"removeSkippedRecords");function Cy(e,t,r){let n=r>0;(n||!Number.isInteger(e[ki]))&&(e[ki]=r||(r=Qn.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[Nm]))&&(e[Nm]=r||Qn.getNextMonotonicTime()):delete e[Nm]}a(Cy,"setTimestamps");function Im(e,t,r){r.indexOf(gs.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(gs.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(gs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(gs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),t1.initializeDBIs(e,t,r)}a(Im,"initializeTransaction");async function f1(e,t,r,n,s=Qn.getNextMonotonicTime()){Dm(e,t,r,n),Im(e,t,r);let i=new n1,o=[],c=[],l=[];for(let _=0;_<n.length;_++){let u=n[_],d=u[t],E;try{E=Cm(e,t,u,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(_);continue}c.push(E),l.push(d)}return wm(c,l,n,i,s,o)}a(f1,"updateRecords");async function E1(e,t,r,n,s=Qn.getNextMonotonicTime()){try{Dm(e,t,r,n)}catch(l){throw c1(l,l.message,l1.HTTP_STATUS_CODES.BAD_REQUEST)}Im(e,t,r);let i=new s1,o=[],c=[];for(let l=0;l<n.length;l++){let _=n[l],u;o1.isEmpty(_[t])?(u=a1.v4(),_[t]=u):u=_[t];let d=Cm(e,t,_,u,i,!1,s);o.push(d),c.push(u)}return wm(o,c,n,i,s)}a(E1,"upsertRecords");async function wm(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||Qn.getNextMonotonicTime(),d1(r,i),n}a(wm,"finalizeWrite");function Cm(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),_=l?.value,u=_;if(!_){if(i)return!1;_={}}if(Cy(r,!u,o),Number.isInteger(r[ki])&&_[ki]>r[ki])return!1;u&&s.original_records.push(_);let d,E=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 b=p([[_]]);Array.isArray(b)&&(p=b[0][gs.FUNC_VAL],r[h]=p)}if(p===T)continue;let R=Qn.getIndexedValues(T);if(R){D_&&S.prefetch(R.map(b=>({key:b,value:n})),L_);for(let b=0,C=R.length;b<C;b++)S.remove(R[b],n)}if(R=Qn.getIndexedValues(p),R){D_&&S.prefetch(R.map(b=>({key:b,value:n})),L_);for(let b=0,C=R.length;b<C;b++)S.put(R[b],n)}}let f=Object.assign({},_,r);c.put(n,f,f[ki])},"do_put");return l?d=c.ifVersion(n,l.version,E):d=c.ifNoExists(n,E),d.then(f=>f?!0:Cm(e,t,r,n,s,i,o))}a(Cm,"updateUpsertRecord");function h1(e,t,r){if(Qn.validateEnv(e),t===void 0)throw new Error(Hc.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Hc.WRITE_ATTRIBUTES_REQUIRED):new Error(Hc.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(h1,"validateBasic");function Dm(e,t,r,n){if(h1(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Hc.RECORDS_REQUIRED):new Error(Hc.RECORDS_MUST_BE_ARRAY)}a(Dm,"validateWrite");function L_(){}a(L_,"noop");Dy.exports={insertRecords:u1,updateRecords:f1,upsertRecords:E1}});var Vi=g((ece,m1)=>{m1.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"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var Jn=g((tce,Py)=>{"use strict";var My=z(),Ly=U(),Yo=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,zn=require("joi"),ni={schema_format:{pattern:Yo,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},p1=zn.alternatives(zn.string().min(1).max(ni.schema_length.maximum).pattern(Yo).messages({"string.pattern.base":"{:#label} "+ni.schema_format.message}),zn.number(),zn.array()).required(),S1=zn.alternatives(zn.string().min(1).max(ni.schema_length.maximum).pattern(Yo).messages({"string.pattern.base":"{:#label} "+ni.schema_format.message}),zn.number()),T1=zn.alternatives(zn.string().min(1).max(ni.schema_length.maximum).pattern(Yo).messages({"string.pattern.base":"{:#label} "+ni.schema_format.message}),zn.number()).required();function g1(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ni.schema_length.maximum?`'${e}' maximum of 250 characters`:Yo.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(g1,"checkValidTable");function R1(e,t){return My.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(R1,"validateSchemaExists");function A1(e,t){let r=t.state.ancestors[0].schema;return My.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(A1,"validateTableExists");function O1(e,t){return e.toLowerCase()===Ly.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${Ly.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(O1,"validateSchemaName");Py.exports={common_validators:ni,schema_regex:Yo,hdb_schema_table:p1,validateSchemaExists:R1,validateTableExists:A1,validateSchemaName:O1,checkValidTable:g1,hdb_database:S1,hdb_table:T1}});var M_=g((nce,Uy)=>{var{common_validators:jn}=Jn(),Gc=st(),xc="is required",Tt={database:{presence:!1,format:jn.schema_format,length:jn.schema_length},schema:{presence:!1,format:jn.schema_format,length:jn.schema_length},table:{presence:!0,format:jn.schema_format,length:jn.schema_length},attribute:{presence:!0,format:jn.schema_format,length:jn.schema_length},hash_attribute:{presence:!0,format:jn.schema_format,length:jn.schema_length}};function Fc(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(Fc,"makeAttributesStrings");function b1(e){return e=Fc(e),Tt.table.presence=!1,Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,Gc.validateObject(e,Tt)}a(b1,"schema_object");function y1(e){return e=Fc(e),Tt.table.presence={message:xc},Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,Gc.validateObject(e,Tt)}a(y1,"table_object");function N1(e){return e=Fc(e),Tt.table.presence={message:xc},Tt.attribute.presence=!1,Gc.validateObject(e,Tt)}a(N1,"create_table_object");function I1(e){return e=Fc(e),Tt.table.presence={message:xc},Tt.attribute.presence={message:xc},Tt.hash_attribute.presence=!1,Gc.validateObject(e,Tt)}a(I1,"attribute_object");function w1(e){return e=Fc(e),Tt.table.presence={message:xc},Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,Gc.validateObject(e,Tt)}a(w1,"describe_table");function C1(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(C1,"validateTableResidence");Uy.exports={schema_object:b1,create_table_object:N1,table_object:y1,attribute_object:I1,describe_table:w1,validateTableResidence:C1}});var By=g((ice,vy)=>{"use strict";var D1=require("uuid"),Lm=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||D1.v4(),this.schema_table=`${this.schema}.${this.table}`}};vy.exports=Lm});var P_=g((ace,Hy)=>{"use strict";var L1=By(),Mm=class extends L1{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}};Hy.exports=Mm});var Gy=g((lce,xy)=>{"use strict";xy.exports=P1;var M1="inserted";function P1(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===M1?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(P1,"returnObject")});var U_=g((_ce,$y)=>{"use strict";var U1=U(),Pm=Ke(),v1=$o(),{getSystemSchemaPath:B1,getSchemaPath:H1}=ze(),x1=Vi(),G1=M_(),F1=P_(),q1=Gy(),{handleHDBError:Fy,hdb_errors:ky}=ne(),qy=z(),{HTTP_STATUS_CODES:k1}=ky,Um=x1.hdb_attribute,Vy=[];for(let e=0;e<Um.attributes.length;e++)Vy.push(Um.attributes[e].attribute);var V1="inserted";$y.exports=$1;async function $1(e){let t=G1.attribute_object(e);if(t)throw Fy(new Error,t.message,ky.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&qy.checkGlobalSchemaTable(e.schema,e.table);if(r)throw Fy(new Error,r,k1.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=qy.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 F1(e.schema,e.table,e.attribute,e.id);try{let i=await Pm.openEnvironment(H1(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}`);Pm.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await Pm.openEnvironment(B1(),U1.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await v1.insertRecords(o,Um.hash_attribute,Vy,[s]);return q1(V1,c,{records:[s]},l)}catch(i){throw i}}a($1,"lmdbCreateAttribute")});var Bm=g((fce,Ky)=>{var{hdb_table:Y1,hdb_database:Yy}=Jn(),K1=st(),vm=require("joi"),W1={undefined:"undefined",null:"null"},Q1=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||W1[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"),z1=vm.object({database:Yy,schema:Yy,table:Y1,records:vm.array().items(vm.object().custom(Q1)).required()});Ky.exports=function(e){return K1.validateBySchema(e,z1)}});var qc=g((mce,Qy)=>{"use strict";var Rs=z(),Wy=Y(),hce=Bm(),{getDatabases:J1}=(Ae(),ie(ke)),{ClientError:$i}=ne();Qy.exports=j1;function j1(e){if(Rs.isEmpty(e))throw new $i("invalid update parameters defined.");if(Rs.isEmptyOrZeroLength(e.schema))throw new $i("invalid schema specified.");if(Rs.isEmptyOrZeroLength(e.table))throw new $i("invalid table specified.");if(!Array.isArray(e.records))throw new $i("records must be an array");let t=J1()[e.schema]?.[e.table];if(Rs.isEmpty(t))throw new $i(`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&&Rs.isEmptyOrZeroLength(o[r]))throw Wy.error("a valid hash attribute must be provided with update record:",o),new $i("a valid hash attribute must be provided with update record, check log for more info");if(!Rs.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw Wy.error(`a valid hash value must be provided with ${e.operation} record:`,o),new $i(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!Rs.isEmpty(o[r])&&o[r]!==""&&n.has(Rs.autoCast(o[r]))&&(o.skip=!0),n.add(Rs.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(j1,"insertUpdateValidate")});var kc=g((Sce,zy)=>{"use strict";var X1=U().OPERATIONS_ENUM,Hm=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=X1.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};zy.exports=Hm});var Vc=g((Rce,jy)=>{"use strict";var gce=kc(),v_=U(),xm=z(),Jy=Y(),Z1=require("uuid"),{handleHDBError:B_,hdb_errors:eY}=ne(),{HDB_ERROR_MSGS:H_,HTTP_STATUS_CODES:x_}=eY;jy.exports=tY;function tY(e,t,r){for(let s=0;s<t.length;s++)rY(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];nY(i,r,e.operation)}}a(tY,"processRows");function rY(e){if(Buffer.byteLength(String(e))>v_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw B_(new Error,H_.ATTR_NAME_LENGTH_ERR(e),x_.BAD_REQUEST,void 0,void 0,!0);if(xm.isEmptyOrZeroLength(e)||xm.isEmpty(e.trim()))throw B_(new Error,H_.ATTR_NAME_NULLISH_ERR,x_.BAD_REQUEST,void 0,void 0,!0)}a(rY,"validateAttribute");function nY(e,t,r){if(!e.hasOwnProperty(t)||xm.isEmptyOrZeroLength(e[t])){if(r===v_.OPERATIONS_ENUM.INSERT||r===v_.OPERATIONS_ENUM.UPSERT){e[t]=Z1.v4();return}throw Jy.error("Update transaction aborted due to record with no hash value:",e),B_(new Error,H_.RECORD_MISSING_HASH_ERR,x_.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>v_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Jy.error(e),B_(new Error,H_.HASH_VAL_LENGTH_ERR,x_.BAD_REQUEST,void 0,void 0,!0)}a(nY,"validateHash")});var Zy=g((Oce,Xy)=>{"use strict";var Gm=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};Xy.exports=Gm});var rN=g((yce,tN)=>{"use strict";var Fm=Ke(),sY=Y(),eN=Ur().LMDB_ERRORS_ENUM;tN.exports=iY;async function iY(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!==eN.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!==eN.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){sY.error(t)}}a(iY,"cleanLMDBMap")});var As=g((Ice,oN)=>{"use strict";var $c=require("crypto"),oY=te(),{CONFIG_PARAMS:aY}=U(),sN="aes-256-cbc",cY=32,lY=16,qm=64,iN=32,uY=qm+iN,nN=new Map;oN.exports={encrypt:_Y,decrypt:dY,createNatsTableStreamName:fY};function _Y(e){let t=$c.randomBytes(cY),r=$c.randomBytes(lY),n=$c.createCipheriv(sN,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(_Y,"encrypt");function dY(e){let t=e.substr(0,qm),r=e.substr(qm,iN),n=e.substr(uY,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=$c.createDecipheriv(sN,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(dY,"decrypt");function fY(e,t){let r=oY.get(aY.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=nN.get(r);return n||(n=$c.createHash("md5").update(r).digest("hex"),nN.set(r,n)),n}a(fY,"createNatsTableStreamName")});var si=g((Dce,cN)=>{"use strict";var Cce=qr(),Yc=Y(),aN=M_(),EY=As(),G_=z(),{handleHDBError:F_,hdb_errors:hY}=ne(),{HDB_ERROR_MSGS:q_,HTTP_STATUS_CODES:km}=hY,mY=te();mY.initSync();var{getDatabases:Vm}=(Ae(),ie(ke)),pY=require("fs-extra");cN.exports={describeAll:SY,describeTable:k_,describeSchema:TY};async function SY(e){try{let t=G_.isEmptyOrZeroLength(e),r,n;t||(r=e.hdb_user.role.permission,n=r.super_user||r.cluster_user);let s=Vm(),i={},o={},c=[],l=e?.exact_count;for(let u in s){i[u]=!0,!t&&!n&&(o[u]=e.hdb_user.role.permission[u].describe);let d=s[u];for(let E in d)try{let f;if(t||n)f=await k_({schema:u,table:E,exact_count:l});else if(r&&r[u].describe&&r[u].tables[E].describe){let h=r[u].tables[E].attribute_permissions;f=await k_({schema:u,table:E,exact_count:l},h)}f&&c.push(f)}catch(f){Yc.error(f)}}let _={};for(let u in c)t||n?(_[c[u].schema]==null&&(_[c[u].schema]={}),_[c[u].schema][c[u].name]=c[u],i[c[u].schema]&&delete i[c[u].schema]):o[c[u].schema]&&(_[c[u].schema]==null&&(_[c[u].schema]={}),_[c[u].schema][c[u].name]=c[u],i[c[u].schema]&&delete i[c[u].schema]);for(let u in i)t||n?_[u]={}:o[u]&&(_[u]={});return _}catch(t){return Yc.error("Got an error in describeAll"),Yc.error(t),F_(new Error,q_.DESCRIBE_ALL_ERR)}}a(SY,"describeAll");async function k_(e,t){G_.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=aN.describe_table(e);if(i)throw i;let c=Vm()[r];if(!c)throw F_(new Error,q_.SCHEMA_NOT_FOUND(e.schema),km.NOT_FOUND);let l=c[n];if(!l)throw F_(new Error,q_.TABLE_NOT_FOUND(e.schema,e.table),km.NOT_FOUND);function _(f){u.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(h=>({type:h.type,name:h.name})):void 0}))}a(_,"pushAtt");let u=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&_(h)})}else l.attributes?.forEach(f=>_(f));let d;try{d=(await pY.stat(l.primaryStore.env.path)).size}catch(f){Yc.warn("unable to get database size",f)}let E={schema:r,name:l.tableName,hash_attribute:l.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:u,db_size:d};E.clustering_stream_name=EY.createNatsTableStreamName(E.schema,E.name);try{let f=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.estimated_record_range=f.estimatedRange;let h=l.auditStore;if(h)for(let p of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=p[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let p of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=p}catch(f){Yc.warn(`unable to stat table dbi due to ${f}`)}return E}a(k_,"descTable");async function TY(e){G_.transformReq(e);let t=aN.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=Vm()[n];if(!i)throw F_(new Error,q_.SCHEMA_NOT_FOUND(e.schema),km.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),G_.isEmpty(l)||l.describe){let _=await k_({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);_&&(o[_.name]=_)}}return o}a(TY,"describeSchema")});var Os=g((Uce,fN)=>{var gY=Vi(),{callbackify:uN,promisify:RY}=require("util"),{getDatabases:_N}=(Ae(),ie(ke));fN.exports={setSchemaDataToGlobal:lN,getTableSchema:AY,getSystemSchema:OY,setSchemaDataToGlobalAsync:RY(lN)};var dN=si(),Mce=uN(dN.describeAll),Pce=uN(dN.describeTable);function lN(e){global.hdb_schema=_N(),e&&e()}a(lN,"setSchemaDataToGlobal");function AY(e,t,r){let n=_N()[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(AY,"getTableSchema");function OY(){return gY}a(OY,"getSystemSchema")});var un=g((Bce,pN)=>{"use strict";var $_=Bm(),Yt=z(),bY=require("util"),Y_=Dn(),yY=Os(),EN=Y(),{handleHDBError:Yi,hdb_errors:NY}=ne(),{HTTP_STATUS_CODES:Ki}=NY,IY=bY.promisify(yY.getTableSchema),wY="updated",hN="inserted",mN="upserted";pN.exports={insert:DY,update:LY,upsert:MY,validation:CY,flush:PY};async function CY(e){if(Yt.isEmpty(e))throw new Error("invalid update parameters defined.");if(Yt.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Yt.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await IY(e.schema,e.table),r=$_(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&&Yt.isEmptyOrZeroLength(c[n]))throw EN.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(!Yt.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw EN.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Yt.isEmpty(c[n])&&c[n]!==""&&s.has(Yt.autoCast(c[n]))&&(c.skip=!0),s.add(Yt.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(CY,"validation");async function DY(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=$_(e);if(t)throw Yi(new Error,t.message,Ki.BAD_REQUEST);Yt.transformReq(e);let r=Yt.checkSchemaTableExist(e.schema,e.table);if(r)throw Yi(new Error,r,Ki.BAD_REQUEST);let n=await Y_.createRecords(e);return V_(hN,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(DY,"insertData");async function LY(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=$_(e);if(t)throw Yi(new Error,t.message,Ki.BAD_REQUEST);Yt.transformReq(e);let r=Yt.checkSchemaTableExist(e.schema,e.table);if(r)throw Yi(new Error,r,Ki.BAD_REQUEST);let n=await Y_.updateRecords(e);return Yt.isEmpty(n.existing_rows)?V_(wY,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):V_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(LY,"updateData");async function MY(e){if(e.operation!=="upsert")throw Yi(new Error,"invalid operation, must be upsert",Ki.INTERNAL_SERVER_ERROR);let t=$_(e);if(t)throw Yi(new Error,t.message,Ki.BAD_REQUEST);Yt.transformReq(e);let r=Yt.checkSchemaTableExist(e.schema,e.table);if(r)throw Yi(new Error,r,Ki.BAD_REQUEST);let n=await Y_.upsertRecords(e);return V_(mN,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(MY,"upsertData");function V_(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===hN?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===mN?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(V_,"returnObject");function PY(e){return Yt.transformReq(e),Y_.flush(e.schema,e.table)}a(PY,"flush")});var Ym=g((xce,gN)=>{var UY=st(),$m=require("joi"),{hdb_table:vY,hdb_database:SN}=Jn(),TN={schema:SN,database:SN,table:vY},BY={date:$m.date().iso().required()},HY={timestamp:$m.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};gN.exports=function(e,t){let r=t==="timestamp"?{...TN,...HY}:{...TN,...BY},n=$m.object(r);return UY.validateBySchema(e,n)}});var ON=g((Gce,AN)=>{var xY=st(),Km=require("joi"),{hdb_table:GY,hdb_database:RN}=Jn(),FY=Km.object({schema:RN,database:RN,table:GY,hash_values:Km.array().required(),ids:Km.array()});AN.exports=function(e){return xY.validateBySchema(e,FY)}});var yN=g((Fce,bN)=>{"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}},Qm=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}},zm=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};bN.exports={InsertObject:Wm,NoSQLSeachObject:Qm,DeleteResponseObject:zm}});var zi=g((kce,DN)=>{"use strict";var IN=Ym(),qY=ON(),Wi=z(),NN=require("moment"),wN=Y(),{promisify:kY,callbackify:VY}=require("util"),Qi=U(),$Y=Os(),Jm=kY($Y.getTableSchema),jm=Dn(),{DeleteResponseObject:YY}=yN(),{handleHDBError:ii,hdb_errors:KY}=ne(),{HDB_ERROR_MSGS:K_,HTTP_STATUS_CODES:oi}=KY,WY="records successfully deleted",QY=VY(CN);DN.exports={delete:QY,deleteRecord:CN,deleteFilesBefore:zY,deleteAuditLogsBefore:JY};async function zY(e){let t=IN(e,"date");if(t)throw ii(t,t.message,oi.BAD_REQUEST,void 0,void 0,!0);if(Wi.transformReq(e),!NN(e.date,NN.ISO_8601).isValid())throw ii(new Error,K_.INVALID_DATE,oi.BAD_REQUEST,Qi.LOG_LEVELS.ERROR,K_.INVALID_DATE,!0);let n=Wi.checkSchemaTableExist(e.schema,e.table);if(n)throw ii(new Error,n,oi.NOT_FOUND,Qi.LOG_LEVELS.ERROR,n,!0);let s=await jm.deleteRecordsBefore(e);if(await Jm(e.schema,e.table),wN.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(zY,"deleteFilesBefore");async function JY(e){let t=IN(e,"timestamp");if(t)throw ii(t,t.message,oi.BAD_REQUEST,void 0,void 0,!0);if(Wi.transformReq(e),isNaN(e.timestamp))throw ii(new Error,K_.INVALID_VALUE("Timestamp"),oi.BAD_REQUEST,Qi.LOG_LEVELS.ERROR,K_.INVALID_VALUE("Timestamp"),!0);let r=Wi.checkSchemaTableExist(e.schema,e.table);if(r)throw ii(new Error,r,oi.NOT_FOUND,Qi.LOG_LEVELS.ERROR,r,!0);let n=await jm.deleteAuditLogsBefore(e);return await Jm(e.schema,e.table),wN.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(JY,"deleteAuditLogsBefore");async function CN(e){e.ids&&(e.hash_values=e.ids);let t=qY(e);if(t)throw ii(t,t.message,oi.BAD_REQUEST,void 0,void 0,!0);Wi.transformReq(e);let r=Wi.checkSchemaTableExist(e.schema,e.table);if(r)throw ii(new Error,r,oi.NOT_FOUND,Qi.LOG_LEVELS.ERROR,r,!0);try{await Jm(e.schema,e.table);let n=await jm.deleteRecords(e);return Wi.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${WY}`),n}catch(n){if(n.message===Qi.SEARCH_NOT_FOUND_MESSAGE){let s=new YY;return s.message=Qi.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(CN,"deleteRecord")});var W_=g(($ce,PN)=>{var jY=require("crypto"),LN=9;function XY(e){let t=eK(LN),r=MN(e+t);return t+r}a(XY,"createHash");function ZY(e,t){let r=e?.substr(0,LN),n=r+MN(t+r);return e===n}a(ZY,"validateHash");function eK(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(eK,"generateSalt");function MN(e){return jY.createHash("md5").update(e).digest("hex")}a(MN,"md5");PN.exports={hash:XY,validate:ZY}});var vN=g((Kce,UN)=>{var Xm=st(),er={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 tK(e){return er.password.presence=!0,er.username.presence=!0,er.role.presence=!0,er.active.presence=!0,Xm.validateObject(e,er)}a(tK,"addUserValidation");function rK(e){return er.password.presence=!1,er.username.presence=!0,er.role.presence=!1,er.active.presence=!1,Xm.validateObject(e,er)}a(rK,"alterUserValidation");function nK(e){return er.password.presence=!1,er.username.presence=!0,er.role.presence=!1,er.active.presence=!1,Xm.validateObject(e,er)}a(nK,"dropUserValidation");UN.exports={addUserValidation:tK,alterUserValidation:rK,dropUserValidation:nK}});var ct=g((zce,HN)=>{"use strict";var{platform:Qce}=require("os"),sK="nats-server.zip",Zm="nats-server",iK=process.platform==="win32"?`${Zm}.exe`:Zm,oK=/^[^\s.,*>]+$/,BN="__request__",aK=a(e=>`${e}.${BN}`,"REQUEST_SUBJECT"),cK={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},lK={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},uK={HUB:"hub.pid",LEAF:"leaf.pid"},_K={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},dK={SUCCESS:"success",ERROR:"error"},fK={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},EK={TXN:"txn",MSGID:"msgid"},Ko={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},hK={[Ko.ERR]:1,[Ko.WRN]:2,[Ko.INF]:3,[Ko.DBG]:4,[Ko.TRC]:5},mK={debug:"-D",trace:"-DVV"};HN.exports={NATS_SERVER_ZIP:sK,NATS_SERVER_NAME:Zm,NATS_BINARY_NAME:iK,PID_FILES:uK,NATS_CONFIG_FILES:lK,SERVER_SUFFIX:_K,NATS_TERM_CONSTRAINTS_RX:oK,REQUEST_SUFFIX:BN,UPDATE_REMOTE_RESPONSE_STATUSES:dK,CLUSTER_STATUS_STATUSES:fK,REQUEST_SUBJECT:aK,SUBJECT_PREFIXES:EK,MSG_HEADERS:cK,LOG_LEVELS:Ko,LOG_LEVEL_FLAGS:mK,LOG_LEVEL_HIERARCHY:hK}});var GN=g((jce,xN)=>{"use strict";var Q_=U(),z_=class{static{a(this,"BaseLicense")}constructor(t=0,r=Q_.RAM_ALLOCATION_ENUM.DEFAULT,n=Q_.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},ep=class extends z_{static{a(this,"ExtendedLicense")}constructor(t=0,r=Q_.RAM_ALLOCATION_ENUM.DEFAULT,n=Q_.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};xN.exports={BaseLicense:z_,ExtendedLicense:ep}});var Ji=g((Zce,YN)=>{"use strict";var Qo=require("fs-extra"),qN=W_(),kN=require("crypto"),pK=require("moment"),SK=require("uuid").v4,tr=Y(),rp=require("path"),TK=z(),ai=U(),{totalmem:FN}=require("os"),gK=GN().ExtendedLicense,Wo="invalid license key format",RK="061183",AK="mofi25",OK="aes-256-cbc",bK=16,yK=32,VN=te();VN.initSync();var tp;YN.exports={validateLicense:$N,generateFingerPrint:IK,licenseSearch:ip,getLicense:DK,checkMemoryLimit:LK};function np(){return rp.join(VN.getHdbBasePath(),ai.LICENSE_KEY_DIR_NAME,ai.LICENSE_FILE_NAME)}a(np,"getLicenseDirPath");function NK(){let e=np();return rp.join(e,ai.LICENSE_FILE_NAME)}a(NK,"getLicenseFilePath");function sp(){let e=np();return rp.join(e,ai.REG_KEY_FILE_NAME)}a(sp,"getFingerPrintFilePath");async function IK(){let e=sp();try{return await Qo.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await wK();throw tr.error(`Error writing fingerprint file to ${e}`),tr.error(t),new Error("There was an error generating the fingerprint")}}a(IK,"generateFingerPrint");async function wK(){let e=SK(),t=qN.hash(e),r=sp();try{await Qo.mkdirp(np()),await Qo.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw tr.error(`Error writing fingerprint file to ${r}`),tr.error(n),new Error("There was an error generating the fingerprint")}return t}a(wK,"writeFingerprint");function $N(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:ai.RAM_ALLOCATION_ENUM.DEFAULT,version:ai.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return tr.error("empty license key passed to validate."),r;let n=sp(),s=!1;try{s=Qo.statSync(n)}catch(i){tr.error(i)}if(s){let i;try{i=Qo.readFileSync(n,"utf8")}catch{tr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(AK),c=o[1];c=Buffer.concat([Buffer.from(c)],bK);let l=Buffer.concat([Buffer.from(i)],yK),_=kN.createDecipheriv(OK,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let u=null;try{u=_.update(o[0],"hex","utf8"),u.trim(),u+=_.final("utf8")}catch{let f=CK(o[0],i);if(f)u=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Wo),tr.error(Wo),new Error(Wo)}let d;if(isNaN(u))try{d=JSON.parse(u),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(Wo),tr.error(Wo),new Error(Wo)}else r.exp_date=u;r.exp_date<pK().valueOf()&&(r.valid_date=!1),qN.validate(o[1],`${RK}${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||tr.error("Invalid licence"),r}a($N,"validateLicense");function CK(e,t){try{let r=kN.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{tr.warn("Check old license failed")}}a(CK,"checkOldLicense");function ip(){let e=new gK,t=[];try{t=Qo.readFileSync(NK(),"utf-8").split(ai.NEW_LINE)}catch(r){r.code==="ENOENT"?tr.info("no license file found"):tr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(TK.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=$N(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){tr.error("There was an error parsing the license string."),tr.error(s),e.ram_allocation=ai.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return tp=e,e}a(ip,"licenseSearch");async function DK(){return tp||await ip(),tp}a(DK,"getLicense");function LK(){let e=ip().ram_allocation,t=process.constrainedMemory?.()||FN();if(t=Math.round(Math.min(t,FN())/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(LK,"checkMemoryLimit")});var Vr=g((sle,aI)=>{"use strict";var zN="username is required",JN="nothing to update, must supply active, role or password to update",jN="password cannot be an empty string",XN="If role is specified, it cannot be empty.",ZN="active must be true or false";aI.exports={addUser:FK,alterUser:qK,dropUser:VK,getSuperUser:WK,userInfo:$K,listUsers:j_,listUsersExternal:YK,setUsersToGlobal:Jo,findAndValidateUser:iI,getClusterUser:QK,USERNAME_REQUIRED:zN,ALTERUSER_NOTHING_TO_UPDATE:JN,EMPTY_PASSWORD:jN,EMPTY_ROLE:XN,ACTIVE_BOOLEAN:ZN};var eI=un(),MK=zi(),cp=W_(),tI=vN(),rI=qr(),lp=bs(),kr=z(),nI=require("validate.js"),Oe=Y(),{promisify:PK}=require("util"),up=As(),KN=U(),WN=ct(),UK=dr(),tle=te(),rle=Ji(),vK=Vi(),{table:nle}=(Ae(),ie(ke)),{handleHDBError:Xn,hdb_errors:BK}=ne(),{HTTP_STATUS_CODES:Zn,AUTHENTICATION_ERROR_MSGS:op,HDB_ERROR_MSGS:zo}=BK,{UserEventMsg:_p}=Ln(),ap=require("lodash"),{server:dp}=(ur(),ie(Hi)),HK=Y();dp.getUser=(e,t)=>iI(e,t,t!=null);var sI={username:!0,active:!0,role:!0,password:!0},QN=new Map,J_=rI.searchByValue,xK=rI.searchByHash,GK=PK(MK.delete);async function FK(e){let t=nI.cleanAttributes(e,sI),r=tI.addUserValidation(t);if(r)throw Xn(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 J_(n),s=s&&Array.from(s)}catch(l){throw Oe.error("There was an error searching for a role in add user"),Oe.error(l),l}if(!s||s.length<1)throw Xn(new Error,zo.ROLE_NAME_NOT_FOUND(t.role),Zn.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Xn(new Error,zo.DUP_ROLES_FOUND(t.role),Zn.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=up.encrypt(t.password)),t.password=cp.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await eI.insert(i)}catch(l){throw Oe.error("There was an error searching for a user."),Oe.error(l),l}Oe.debug(o);try{await Jo()}catch(l){throw Oe.error("Got an error setting users to global"),Oe.error(l),l}if(o.skipped_hashes.length===1)throw Xn(new Error,zo.USER_ALREADY_EXISTS(t.username),Zn.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],lp.signalUserChange(new _p(process.pid)),`${c.username} successfully added`}a(FK,"addUser");async function qK(e){let t=nI.cleanAttributes(e,sI);if(kr.isEmptyOrZeroLength(t.username))throw new Error(zN);if(kr.isEmptyOrZeroLength(t.password)&&kr.isEmptyOrZeroLength(t.role)&&kr.isEmptyOrZeroLength(t.active))throw new Error(JN);if(!kr.isEmpty(t.password)&&kr.isEmptyOrZeroLength(t.password.trim()))throw new Error(jN);if(!kr.isEmpty(t.active)&&!kr.isBoolean(t.active))throw new Error(ZN);let r=kK(t.username);if(!kr.isEmpty(t.password)&&!kr.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=up.encrypt(t.password)),t.password=cp.hash(t.password)),t.role==="")throw new Error(XN);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 J_(i)||[])}catch(c){throw Oe.error("Got an error searching for a role."),Oe.error(c),c}if(!o||o.length===0){let c=zo.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Oe.error(c),Xn(new Error,c,Zn.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=zo.ALTER_USER_DUP_ROLES(t.role);throw Oe.error(c),Xn(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 eI.update(n)}catch(i){throw Oe.error("Error during update."),Oe.error(i),i}try{await Jo()}catch(i){throw Oe.error("Got an error setting users to global"),Oe.error(i),i}return lp.signalUserChange(new _p(process.pid)),s}a(qK,"alterUser");function kK(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(kK,"isClusterUser");async function VK(e){try{let t=tI.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(kr.isEmpty(global.hdb_users.get(e.username)))throw Xn(new Error,zo.USER_NOT_EXIST(e.username),Zn.NOT_FOUND,void 0,void 0,!0);let n;try{n=await GK(r)}catch(s){throw Oe.error("Got an error deleting a user."),Oe.error(s),s}Oe.debug(n);try{await Jo()}catch(s){throw Oe.error("Got an error setting users to global."),Oe.error(s),s}return lp.signalUserChange(new _p(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(VK,"dropUser");async function $K(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=ap.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await xK(r)}catch(s){throw Oe.error("Got an error searching for a role."),Oe.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Oe.error(r),r}return t}a($K,"userInfo");async function YK(){let e;try{e=await j_()}catch(t){throw Oe.error("Got an error listing users."),Oe.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(YK,"listUsersExternal");async function j_(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await J_(e)}catch(o){throw Oe.error("Got an error searching for roles."),Oe.error(o),o}let r={};for(let o of t)r[o.id]=ap.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 J_(n)}catch(o){throw Oe.error("Got an error searching for users."),Oe.error(o),o}let i=new Map;for(let o of s)o=ap.cloneDeep(o),o.role=r[o.role],KK(o.role),i.set(o.username,o);return i}catch(e){throw Oe.error("got an error listing users"),Oe.error(e),kr.errorizeMessage(e)}return null}a(j_,"listUsers");function KK(e){try{if(!e){Oe.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(vK)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Oe.error("Got an error trying to set system permissions."),Oe.error(t)}}a(KK,"appendSystemTablesToRole");async function Jo(){try{let e=await j_();global.hdb_users=e}catch(e){throw Oe.error(e),e}}a(Jo,"setUsersToGlobal");async function iI(e,t,r=!0){global.hdb_users||await Jo();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Xn(new Error,op.GENERIC_AUTH_FAIL,Zn.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Xn(new Error,op.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(QN.get(t)===n.password)return s;if(cp.validate(n.password,t))QN.set(t,n.password);else throw Xn(new Error,op.GENERIC_AUTH_FAIL,Zn.UNAUTHORIZED,void 0,void 0,!0)}return s}a(iI,"findAndValidateUser");async function WK(){global.hdb_users||await Jo();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(WK,"getSuperUser");async function QK(){let e=await j_(),t=UK.getConfigFromFile(KN.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!kr.isEmpty(r)&&r?.role?.role===KN.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=up.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+WN.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+WN.SERVER_SUFFIX.ADMIN,r}a(QK,"getClusterUser");var oI=[];dp.invalidateUser=function(e){for(let t of oI)try{t(e)}catch(r){HK.error("Error invalidating user",r)}};dp.onInvalidatedUser=function(e){oI.push(e)}});var Wc=g((cle,_I)=>{"use strict";var ji=Y(),$r=U(),zK=rN(),ole=Os(),ale=si(),JK=Vr(),{validateEvent:cI}=Ln(),Kc=Dn(),jK=require("process"),{resetDatabases:XK}=(Ae(),ie(ke)),ZK={[$r.ITC_EVENT_TYPES.SCHEMA]:eW,[$r.ITC_EVENT_TYPES.USER]:uI};async function eW(e){let t=cI(e);if(t){ji.error(t);return}ji.trace("ITC schemaHandler received schema event:",e),await zK(e.message),await tW(e.message)}a(eW,"schemaHandler");async function tW(e){try{Kc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Kc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Kc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=XK();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){ji.error(t)}}a(tW,"syncSchemaMetadata");var lI=[];async function uI(e){try{try{Kc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Kc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){ji.warn(r)}let t=cI(e);if(t){ji.error(t);return}ji.trace(`ITC userHandler ${$r.HDB_ITC_CLIENT_PREFIX}${jK.pid} received user event:`,e),await JK.setUsersToGlobal();for(let r of lI)r()}catch(t){ji.error(t)}}a(uI,"userHandler");uI.addListener=function(e){lI.push(e)};_I.exports=ZK});var Ln=g((Ele,fI)=>{"use strict";var ule=Y(),fp=z(),rW=U(),{ITC_ERRORS:Qc}=Ur(),{parentPort:_le,threadId:nW,isMainThread:sW,workerData:dle}=require("worker_threads"),{onMessageFromWorkers:iW,broadcast:fle,broadcastWithAcknowledgement:oW}=ot();fI.exports={sendItcEvent:aW,validateEvent:dI,SchemaEventMsg:cW,UserEventMsg:lW};var X_;iW(async(e,t)=>{X_=X_||Wc(),dI(e),X_[e.type]&&await X_[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function aW(e){return!sW&&e.message&&(e.message.originator=nW),oW(e)}a(aW,"sendItcEvent");function dI(e){if(typeof e!="object")return Qc.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||fp.isEmpty(e.type))return Qc.MISSING_TYPE;if(!e.hasOwnProperty("message")||fp.isEmpty(e.message))return Qc.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||fp.isEmpty(e.message.originator))return Qc.MISSING_ORIGIN;if(rW.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Qc.INVALID_EVENT(e.type)}a(dI,"validateEvent");function cW(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(cW,"SchemaEventMsg");function lW(e){this.originator=e}a(lW,"UserEventMsg")});var bs=g((ple,pI)=>{"use strict";var EI=U(),mle=z(),Z_=Y(),hI=Zy(),jo,{sendItcEvent:mI}=Ln();function uW(e){try{Z_.trace("signalSchemaChange called with message:",e),jo=jo||Wc();let t=new hI(EI.ITC_EVENT_TYPES.SCHEMA,e);return jo.schema(t),mI(t)}catch(t){Z_.error(t)}}a(uW,"signalSchemaChange");function _W(e){try{Z_.trace("signalUserChange called with message:",e),jo=jo||Wc();let t=new hI(EI.ITC_EVENT_TYPES.USER,e);return jo.user(t),mI(t)}catch(t){Z_.error(t)}}a(_W,"signalUserChange");pI.exports={signalSchemaChange:uW,signalUserChange:_W}});var ed=g((Tle,TI)=>{"use strict";var SI=z(),dW=U(),fW=Y(),EW=U_(),hW=P_(),mW=bs(),{SchemaEventMsg:pW}=Ln(),SW="already exists in";TI.exports=TW;async function TW(e,t,r){if(SI.isEmptyOrZeroLength(r))return r;let n=[];SI.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 gW(e,t.schema,t.name,i)})),s}a(TW,"lmdbCheckForNewAttributes");async function gW(e,t,r,n){let s=new hW(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await RW(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(SW))fW.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(gW,"createNewAttribute");async function RW(e){let t;return t=await EW(e),mW.signalSchemaChange(new pW(process.pid,dW.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(RW,"createAttribute")});var Xo=g((Rle,gI)=>{"use strict";var Ep=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}};gI.exports=Ep});var AI=g((Ole,RI)=>{"use strict";var AW=Xo(),OW=U().OPERATIONS_ENUM,hp=class extends AW{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(OW.INSERT,r,n,s,i),this.records=t}};RI.exports=hp});var bI=g((yle,OI)=>{"use strict";var bW=Xo(),yW=U().OPERATIONS_ENUM,mp=class extends bW{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(yW.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};OI.exports=mp});var NI=g((Ile,yI)=>{"use strict";var NW=Xo(),IW=U().OPERATIONS_ENUM,pp=class extends NW{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(IW.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};yI.exports=pp});var wI=g((Cle,II)=>{"use strict";var wW=Xo(),CW=U().OPERATIONS_ENUM,Sp=class extends wW{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(CW.DELETE,n,s,t,i),this.original_records=r}};II.exports=Sp});var zc=g((Mle,MI)=>{"use strict";var Lle=require("path"),CI=Ke(),DW=AI(),LW=bI(),MW=NI(),PW=wI(),Zo=dt(),DI=z(),{CONFIG_PARAMS:UW}=U(),LI=te();LI.initSync();var td=U().OPERATIONS_ENUM,{getTransactionAuditStorePath:vW}=ze();MI.exports=BW;async function BW(e,t){if(LI.get(UW.LOGGING_AUDITLOG)===!1)return;let r=vW(e.schema,e.table),n=await CI.openEnvironment(r,e.table,!0),s=HW(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){CI.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),DI.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(BW,"writeTransaction");function HW(e,t){let r=DI.isEmpty(e.hdb_user)?void 0:e.hdb_user.username;if(e.operation===td.INSERT)return new DW(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===td.UPDATE)return new LW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===td.UPSERT)return new MW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===td.DELETE)return new PW(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(HW,"createTransactionObject")});var Tp=g((vle,PI)=>{"use strict";var xW=qc(),Ule=kc(),Jc=U(),GW=Vc(),FW=$o().insertRecords,qW=Ke(),kW=Y(),VW=ed(),{getSchemaPath:$W}=ze(),YW=zc();PI.exports=KW;async function KW(e){try{let{schema_table:t,attributes:r}=xW(e);GW(e,r,t.hash_attribute),e.schema!==Jc.SYSTEM_SCHEMA_NAME&&(r.includes(Jc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Jc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Jc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Jc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await VW(e.hdb_auth_header,t,r),s=$W(e.schema,e.table),i=await qW.openEnvironment(s,e.table),o=await FW(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await YW(e,o)}catch(c){kW.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(KW,"lmdbCreateRecords")});var BI=g((Hle,vI)=>{"use strict";var UI=U(),WW=Tp(),QW=kc(),zW=require("fs-extra"),{getSchemaPath:JW}=ze();vI.exports=jW;async function jW(e){let t=[{name:e.schema,createddate:Date.now()}],r=new QW(UI.SYSTEM_SCHEMA_NAME,UI.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await WW(r),await zW.mkdirp(JW(e.schema))}a(jW,"lmdbCreateSchema")});var xI=g((Gle,HI)=>{"use strict";var gp=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=gp});var kI=g(($le,qI)=>{"use strict";var GI=Ke(),Rp=Hr(),Ap=Ur().LMDB_ERRORS_ENUM,XW=dt(),FI=Y(),qle=z(),ZW=require("lmdb"),eQ=xI(),tQ=U(),{OVERFLOW_MARKER:kle,MAX_SEARCH_KEY_LENGTH:Vle}=XW,rQ=tQ.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function nQ(e,t,r,n){if(Rp.validateEnv(e),t===void 0)throw new Error(Ap.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Ap.IDS_REQUIRED):new Error(Ap.IDS_MUST_BE_ITERABLE);try{let s=GI.listDBIs(e);GI.initializeDBIs(e,t,s);let i=new eQ,o,c=[],l=[];for(let E=0,f=r.length;E<f;E++)try{o=r[E];let h=e.dbis[t].get(o);if(!h||n&&h[rQ]>n){i.skipped.push(o);continue}let p=e.dbis[t].ifVersion(o,ZW.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 R=e.dbis[T],b=h[T];if(b!=null)try{let C=Rp.getIndexedValues(b);if(C)for(let H=0,v=C.length;H<v;H++)R.remove(C[H],o)}catch{FI.warn(`cannot delete from attribute: ${T}, ${b}:${o}`)}}});c.push(p),l.push(o),i.original_records.push(h)}catch(h){FI.warn(h),i.skipped.push(o)}let _=[],u=await Promise.all(c);for(let E=0,f=u.length;E<f;E++)u[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),_.push(E));let d=0;for(let E=0;E<_.length;E++){let f=_[E];i.original_records.splice(f-d,1),d++}return i.txn_time=Rp.getNextMonotonicTime(),i}catch(s){throw s}}a(nQ,"deleteRecords");qI.exports={deleteRecords:nQ}});var jc=g((Kle,$I)=>{"use strict";var ea=z(),sQ=kI(),iQ=Ke(),{getSchemaPath:oQ}=ze(),aQ=zc(),cQ=Y();$I.exports=lQ;async function lQ(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(ea.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(ea.isEmptyOrZeroLength(e.hash_values)&&!ea.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];ea.isEmpty(l)||e.hash_values.push(l)}}if(ea.isEmptyOrZeroLength(e.hash_values))return VI([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(ea.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=oQ(e.schema,e.table),i=await iQ.openEnvironment(s,e.table),o=await sQ.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await aQ(e,o)}catch(c){cQ.error(`unable to write transaction due to ${c.message}`)}return VI(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(lQ,"lmdbDeleteRecords");function VI(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(VI,"createDeleteResponse")});var bp=g((zle,YI)=>{"use strict";var uQ=U(),Qle=Hr();function Op(e,t){let r=Object.create(null);if(t.length===1&&uQ.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(Op,"parseRow");function _Q(e,t,r,n){let s=Op(r,e);n.push(s)}a(_Q,"searchAll");function dQ(e,t,r,n){let s=Op(r,e);n[t]=s}a(dQ,"searchAllToMap");function fQ(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(fQ,"iterateDBI");function Xi(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(Xi,"pushResults");function EQ(e,t,r,n,s,i){t.toString().endsWith(e)&&Xi(t,r,n,s,i)}a(EQ,"endsWith");function hQ(e,t,r,n,s,i){t.toString().includes(e)&&Xi(t,r,n,s,i)}a(hQ,"contains");function mQ(e,t,r,n,s,i){t>e&&Xi(t,r,n,s,i)}a(mQ,"greaterThanCompare");function pQ(e,t,r,n,s,i){t>=e&&Xi(t,r,n,s,i)}a(pQ,"greaterThanEqualCompare");function SQ(e,t,r,n,s,i){t<e&&Xi(t,r,n,s,i)}a(SQ,"lessThanCompare");function TQ(e,t,r,n,s,i){t<=e&&Xi(t,r,n,s,i)}a(TQ,"lessThanEqualCompare");YI.exports={parseRow:Op,searchAll:_Q,searchAllToMap:dQ,iterateDBI:fQ,endsWith:EQ,contains:hQ,greaterThanCompare:mQ,greaterThanEqualCompare:pQ,lessThanCompare:SQ,lessThanEqualCompare:TQ,pushResults:Xi}});var ta=g((eue,XI)=>{"use strict";var ci=Ke(),jle=Y(),Yr=Hr(),rd=dt(),Et=Ur().LMDB_ERRORS_ENUM,Xle=z(),gQ=U(),nd=bp(),{parseRow:RQ}=nd,Zle=require("lmdb"),{OVERFLOW_MARKER:KI,MAX_SEARCH_KEY_LENGTH:AQ}=rd;function WI(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(WI,"iterateFullIndex");function Xc(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,_=!1){return Zi(e,t,r,(u,d,E,f)=>{let R={transaction:u,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!_,exclusiveStart:i===!0?_:l};return f===r?(R.values=!1,d.getRange(R).map(b=>({value:b}))):d.getRange(R)})}a(Xc,"iterateRangeBetween");function Zi(e,t,r,n){let s=e.database||e,i=ci.openDBI(s,r);i[rd.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&ci.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 QI(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(KI)){if(!s)if(r)s=ci.openDBI(e,r);else{let l=ci.listDBIs(e);for(let _=0,u=l.length;_<u&&(s=ci.openDBI(e,l[_]),!s[rd.DBI_DEFINITION_NAME].is_hash_attribute);_++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(QI,"getOverflowCheck");function OQ(e,t,r,n=!1,s=void 0,i=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);return Zi(e,t,t,(o,c,l)=>(sd(r),r=Zc(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(_=>RQ(_.value,r))))}a(OQ,"searchAll");function bQ(e,t,r,n=!1,s=void 0,i=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);sd(r),r=Zc(e.database||e,r);let o=new Map;for(let{key:c,value:l}of WI(e,t,t,n,s,i))o.set(c,nd.parseRow(l,r));return o}a(bQ,"searchAllToMap");function yQ(e,t,r=!1,n=void 0,s=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=WI(e,void 0,t,r,n,s),c=o.transaction,l=QI(c.database,c,void 0,t);for(let{key:_,value:u}of o){let d=l(_,u);i[d]===void 0&&(i[d]=[]),i[d].push(u)}return i}a(yQ,"iterateDBI");function NQ(e,t){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);return ci.statDBI(e,t).entryCount}a(NQ,"countAll");function IQ(e,t,r,n,s=!1,i=void 0,o=void 0){return li(e,r,n),Zi(e,t,r,(c,l,_,u)=>(n=Yr.convertKeyValueToWrite(n),u===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(IQ,"equals");function wQ(e,t,r){return li(e,t,r),ci.openDBI(e,t).getValuesCount(r)}a(wQ,"count");function CQ(e,t,r,n,s=!1,i=void 0,o=void 0){return li(e,r,n),Zi(e,null,r,(c,l)=>{n=Yr.convertKeyValueToWrite(n);let _=!0;typeof n=="number"&&(_=!1);let u;if(s===!0){let d;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){d=E;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),u=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==d){if(f.toString().startsWith(n))return E;if(_===!0)return u.DONE}}),u.filter(E=>E)}else return u=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(_===!0)return u.DONE}),_?u:u.filter(d=>d)})}a(CQ,"startsWith");function DQ(e,t,r,n,s=!1,i=void 0,o=void 0){return zI(e,t,r,n,s,i,o,!0)}a(DQ,"endsWith");function zI(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return li(e,r,n),Zi(e,null,r,(l,_,u,d)=>{let E=QI(u,l,d,r);return o=Number.isInteger(o)?o:0,_.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(KI)?_.getValues(f,{transaction:l}).map(p=>{let S=E(f,p);if(c?S.endsWith(n):S.includes(n))return{key:S,value:p}}).filter(p=>p):(c?h.endsWith(n):h.includes(n))?_[rd.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:_.getValues(f,{transaction:l}).map(p=>({key:f,value:p})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(zI,"contains");function LQ(e,t,r,n,s=!1,i=void 0,o=void 0){li(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Xc(e,t,r,n,l,s,i,o,!0,!1)}a(LQ,"greaterThan");function MQ(e,t,r,n,s=!1,i=void 0,o=void 0){li(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Xc(e,t,r,n,l,s,i,o,!1,!1)}a(MQ,"greaterThanEqual");function PQ(e,t,r,n,s=!1,i=void 0,o=void 0){li(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Xc(e,t,r,l,n,s,i,o,!1,!0)}a(PQ,"lessThan");function UQ(e,t,r,n,s=!1,i=void 0,o=void 0){li(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Xc(e,t,r,l,n,s,i,o,!1,!1)}a(UQ,"lessThanEqual");function vQ(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Yr.validateEnv(e),r===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Et.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Et.END_VALUE_REQUIRED);if(n=Yr.convertKeyValueToWrite(n),s=Yr.convertKeyValueToWrite(s),n>s)throw new Error(Et.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Xc(e,t,r,n,s,i,o,c)}a(vQ,"between");function BQ(e,t,r,n){Yr.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(sd(r),r=Zc(s,r),n===void 0)throw new Error(Et.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=nd.parseRow(c,r)),o}a(BQ,"searchByHash");function HQ(e,t,r){Yr.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Et.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(HQ,"checkHashExists");function xQ(e,t,r,n,s=[]){return jI(e,t,r,n,s),JI(e,t,r,n,s).map(i=>i[1])}a(xQ,"batchSearchByHash");function GQ(e,t,r,n,s=[]){jI(e,t,r,n,s);let i=new Map;for(let[o,c]of JI(e,t,r,n,s))i.set(o,c);return i}a(GQ,"batchSearchByHashToMap");function JI(e,t,r,n,s=[]){return Zi(e,t,t,(i,o,c)=>{r=Zc(c,r);let l=r.length<3;return n.map(_=>{let u=c.dbis[t].get(_,{transaction:i,lazy:l});if(u)return[_,nd.parseRow(u,r)];s.push(_)}).filter(_=>_)})}a(JI,"batchHashSearch");function jI(e,t,r,n,s){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(sd(r),n==null)throw new Error(Et.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Et.IDS_MUST_BE_ITERABLE)}a(jI,"initializeBatchSearchByHash");function sd(e){if(!Array.isArray(e))throw e===void 0?new Error(Et.FETCH_ATTRIBUTES_REQUIRED):new Error(Et.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(sd,"validateFetchAttributes");function li(e,t,r){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Et.SEARCH_VALUE_REQUIRED);if(r?.length>AQ)throw new Error(Et.SEARCH_VALUE_TOO_LARGE)}a(li,"validateComparisonFunctions");function Zc(e,t){return t.length===1&&gQ.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=ci.listDBIs(e)),t}a(Zc,"setGetWholeRowAttributes");XI.exports={searchAll:OQ,searchAllToMap:bQ,count:wQ,countAll:NQ,equals:IQ,startsWith:CQ,endsWith:DQ,contains:zI,searchByHash:BQ,setGetWholeRowAttributes:Zc,batchSearchByHash:xQ,batchSearchByHashToMap:GQ,checkHashExists:HQ,iterateDBI:yQ,greaterThan:LQ,greaterThanEqual:MQ,lessThan:PQ,lessThanEqual:UQ,between:vQ}});var ra=g((rue,nw)=>{var ZI=require("lodash"),ew=st(),fe=require("joi"),FQ=z(),{hdb_schema_table:el,checkValidTable:tw,hdb_table:rw,hdb_database:id}=Jn(),{handleHDBError:qQ,hdb_errors:kQ}=ne(),{getDatabases:VQ}=(Ae(),ie(ke)),{HTTP_STATUS_CODES:$Q}=kQ,YQ=fe.object({database:id,schema:id,table:rw,search_attribute:el,search_value:fe.any().required(),get_attributes:fe.array().min(1).items(fe.alternatives(el,fe.object())).optional(),desc:fe.bool(),limit:fe.number().integer().min(1),offset:fe.number().integer().min(0)}),KQ=fe.object({database:id,schema:id,table:rw,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(el,fe.object())).optional(),sort:fe.object({attribute:fe.alternatives(el,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(el,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()});nw.exports=function(e,t){let r=null;switch(t){case"value":r=ew.validateBySchema(e,YQ);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(tw("database",e.schema)),i(tw("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=ew.validateBySchema(e,KQ);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=FQ.checkGlobalSchemaTable(e.schema,e.table);if(s)return qQ(new Error,s,$Q.NOT_FOUND);let o=VQ()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(u=>{for(let d=0,E=u.conditions.length;d<E;d++){let f=u.conditions[d];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let _=ZI.filter(c,u=>u!=="*"&&u.attribute!=="*"&&!Array.isArray(u)&&!u.name&&!ZI.some(o,d=>d===u||d.attribute===u||d.attribute===u.attribute));if(_&&_.length>0){let u=_.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var yp=g((sue,sw)=>{"use strict";var WQ=Ke(),QQ=ra(),{getSchemaPath:zQ}=ze();sw.exports=JQ;function JQ(e){let t=QQ(e,"hashes");if(t)throw t;let r=zQ(e.schema,e.table);return WQ.openEnvironment(r,e.table)}a(JQ,"initialize")});var Np=g((oue,iw)=>{"use strict";var jQ=ta(),XQ=yp();iw.exports=ZQ;async function ZQ(e){let t=await XQ(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return jQ.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(ZQ,"lmdbGetDataByHash")});var na=g((cue,ow)=>{"use strict";var Ip=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};ow.exports=Ip});var cw=g((_ue,aw)=>{"use strict";var uue=na(),ez=ta(),tz=yp();aw.exports=rz;async function rz(e){let t=await tz(e),r=global.hdb_schema[e.schema][e.table];return ez.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(rz,"lmdbSearchByHash")});var es=g((fue,lw)=>{"use strict";var wp=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,_=void 0,u=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=_,this.offset=u}};lw.exports=wp});var od=g((hue,hw)=>{"use strict";var rr=ta(),nz=Ke(),sz=z(),Ee=dt(),eo=U(),iz=Vi(),uw=Ur().LMDB_ERRORS_ENUM,{getSchemaPath:oz}=ze(),ys=eo.SEARCH_WILDCARDS;async function az(e,t,r){let n;e.schema===eo.SYSTEM_SCHEMA_NAME?n=iz[e.table]:n=global.hdb_schema[e.schema][e.table];let s=Ew(e,n.hash_attribute,r,t);return dw(e,s,n.hash_attribute,r)}a(az,"prepSearch");async function dw(e,t,r,n){let s=oz(e.schema,e.table),i=await nz.openEnvironment(s,e.table),o=fw(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(cz(e,r)===!1){let u=e.search_attribute;if(u===r)return n?_w(o,()=>!0):o.map(E=>({[r]:E.key}));let d=a(E=>({[r]:E.value,[u]:E.key}),"toObject");return n?_w(o,d):o.map(d)}let _=e.search_attribute===r?o.map(u=>u.key):o.map(u=>u.value);return n===!0?rr.batchSearchByHashToMap(c,r,e.get_attributes,_):rr.batchSearchByHash(c,r,e.get_attributes,_)}a(dw,"executeSearch");function fw(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case Ee.SEARCH_TYPES.EQUALS:s=rr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case Ee.SEARCH_TYPES.CONTAINS:s=rr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case Ee.SEARCH_TYPES.ENDS_WITH:case Ee.SEARCH_TYPES._ENDS_WITH:s=rr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Ee.SEARCH_TYPES.STARTS_WITH:case Ee.SEARCH_TYPES._STARTS_WITH:s=rr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return rr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return rr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ee.SEARCH_TYPES.SEARCH_ALL:return rr.searchAll(e,n,t.get_attributes,o,c,l);case Ee.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return rr.searchAllToMap(e,n,t.get_attributes,o,c,l);case Ee.SEARCH_TYPES.BETWEEN:s=rr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case Ee.SEARCH_TYPES.GREATER_THAN:case Ee.SEARCH_TYPES._GREATER_THAN:s=rr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Ee.SEARCH_TYPES.GREATER_THAN_EQUAL:case Ee.SEARCH_TYPES._GREATER_THAN_EQUAL:s=rr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case Ee.SEARCH_TYPES.LESS_THAN:case Ee.SEARCH_TYPES._LESS_THAN:s=rr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Ee.SEARCH_TYPES.LESS_THAN_EQUAL:case Ee.SEARCH_TYPES._LESS_THAN_EQUAL:s=rr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(fw,"searchByType");function _w(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(_w,"createMapFromIterable");function cz(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(cz,"checkToFetchMore");function Ew(e,t,r,n){if(sz.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),ys.indexOf(s)>-1)return r===!0?Ee.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Ee.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(ys[0])<0&&s.indexOf(ys[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(ys.indexOf(i)>=0&&ys.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),Ee.SEARCH_TYPES.CONTAINS;if(ys.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Ee.SEARCH_TYPES.ENDS_WITH;if(ys.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),Ee.SEARCH_TYPES.STARTS_WITH;if(s.includes(ys[0])||s.includes(ys[1]))return Ee.SEARCH_TYPES.EQUALS;throw new Error(uw.UNKNOWN_SEARCH_TYPE)}else switch(n){case eo.VALUE_SEARCH_COMPARATORS.BETWEEN:return Ee.SEARCH_TYPES.BETWEEN;case eo.VALUE_SEARCH_COMPARATORS.GREATER:return Ee.SEARCH_TYPES.GREATER_THAN;case eo.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Ee.SEARCH_TYPES.GREATER_THAN_EQUAL;case eo.VALUE_SEARCH_COMPARATORS.LESS:return Ee.SEARCH_TYPES.LESS_THAN;case eo.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Ee.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(uw.UNKNOWN_SEARCH_TYPE)}}a(Ew,"createSearchTypeFromSearchObject");hw.exports={executeSearch:dw,createSearchTypeFromSearchObject:Ew,prepSearch:az,searchByType:fw}});var pw=g((Sue,mw)=>{"use strict";var pue=es(),lz=ra(),uz=z(),_z=U(),dz=od();mw.exports=fz;function fz(e,t){if(!uz.isEmpty(t)&&_z.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=lz(e,"value");if(n)throw n;return dz.prepSearch(e,t,!0)}a(fz,"lmdbGetDataByValue")});var tl=g((Rue,Sw)=>{"use strict";var gue=es(),Ez=ra(),hz=z(),mz=U(),pz=od();Sw.exports=Sz;async function Sz(e,t){if(!hz.isEmpty(t)&&mz.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=Ez(e,"value");if(n)throw n;return pz.prepSearch(e,t,!1)}a(Sz,"lmdbSearchByValue")});var gw=g((bue,Tw)=>{"use strict";var Oue=dt(),Cp=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}},Dp=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Lp=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};Tw.exports={SearchByConditionsObject:Cp,SearchCondition:Dp,SortAttribute:Lp}});var yw=g((wue,bw)=>{"use strict";var Nue=gw().SearchByConditionsObject,Tz=es(),gz=ra(),Mp=ta(),ad=dt(),{Resource:Iue}=(In(),ie(Pp)),Ow=od(),Rz=bp(),Az=require("lodash"),{getSchemaPath:Oz}=ze(),Rw=Ke(),{handleHDBError:bz,hdb_errors:yz}=ne(),{HTTP_STATUS_CODES:Nz}=yz,Iz=1e8;bw.exports=wz;async function wz(e){let t=gz(e,"conditions");if(t)throw bz(t,t.message,Nz.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=Oz(e.schema,e.table),n=await Rw.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let _ of e.conditions)Rw.openDBI(n,_.search_attribute);let i=Az.sortBy(e.conditions,_=>{if(_.estimated_count===void 0){let u=_.search_type;u===ad.SEARCH_TYPES.EQUALS?_.estimated_count=Mp.count(n,_.search_attribute,_.search_value):u===ad.SEARCH_TYPES.CONTAINS||u===ad.SEARCH_TYPES.ENDS_WITH?_.estimated_count=1/0:_.estimated_count=Iz}return _.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await Aw(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let _=n.dbis[s.hash_attribute],u=i.slice(1).map(Ow.filterByType),d=u.length,E=Mp.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>_.get(f,{transaction:o,lazy:!0})),d>0&&(l=l.filter(f=>{for(let h=0;h<d;h++)if(!u[h](f))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(f=>Rz.parseRow(f,E))}else{for(let d=1;d<i.length;d++){let E=i[d],f=await Aw(o,e,E,s.hash_attribute);c=c.concat(f)}let _=new Set,u=e.offset||0;c=c.filter(d=>_.has(d)?!1:(_.add(d),!0)).slice(u,e.limit&&e.limit+u),l=Mp.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(wz,"lmdbSearchByConditions");async function Aw(e,t,r,n){let s=new Tz(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===ad.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,Ow.searchByType(e,s,i,n).map(o=>o.value)}a(Aw,"executeConditionSearch")});var rl=g((Due,Nw)=>{"use strict";var Cz=U().OPERATIONS_ENUM,Up=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=Cz.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Nw.exports=Up});var vp=g((Mue,Uw)=>{"use strict";var Dw=es(),Lw=rl(),Mw=tl(),Pw=jc(),hr=U(),Iw=z(),ww=Ke(),{getTransactionAuditStorePath:Dz,getSchemaPath:Lz}=ze(),Cw=Y();Uw.exports=Mz;async function Mz(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 Pz(e),await Uz(e);let t=Lz(e.schema,e.table);try{await ww.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Cw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=Dz(e.schema,e.table);await ww.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Cw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(Mz,"lmdbDropTable");async function Pz(e){let t=new Dw(hr.SYSTEM_SCHEMA_NAME,hr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Mw(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 Lw(hr.SYSTEM_SCHEMA_NAME,hr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await Pw(s)}a(Pz,"deleteAttributesFromSystem");async function Uz(e){let t=new Dw(hr.SYSTEM_SCHEMA_NAME,hr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Mw(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 Lw(hr.SYSTEM_SCHEMA_NAME,hr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await Pw(s)}catch(i){throw i}}a(Uz,"dropTableFromSystem")});var Bw=g((Uue,vw)=>{"use strict";var vz=require("fs-extra"),Bz=es(),Hz=na(),xz=rl(),Gz=vp(),Fz=jc(),qz=Np(),kz=tl(),Ns=U(),{getSchemaPath:Vz}=ze(),{handleHDBError:$z,hdb_errors:Yz}=ne(),{HDB_ERROR_MSGS:Kz,HTTP_STATUS_CODES:Wz}=Yz;vw.exports=Qz;async function Qz(e){let t;try{t=await zz(e.schema);let r=new Bz(Ns.SYSTEM_SCHEMA_NAME,Ns.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await kz(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await Gz(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new xz(Ns.SYSTEM_SCHEMA_NAME,Ns.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await Fz(s);let i=Vz(t);await vz.remove(i)}catch(r){throw r}}a(Qz,"lmdbDropSchema");async function zz(e){let t=new Hz(Ns.SYSTEM_SCHEMA_NAME,Ns.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await qz(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw $z(new Error,Kz.SCHEMA_NOT_FOUND(e),Wz.NOT_FOUND,void 0,void 0,!0);return n}a(zz,"validateDropSchema")});var Hp=g((Bue,Hw)=>{"use strict";var Bp=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Hw.exports=Bp});var Gw=g((Gue,xw)=>{"use strict";var Jz=require("fs-extra"),cd=Ke(),{getTransactionAuditStorePath:jz}=ze(),xp=dt(),xue=Hp();xw.exports=Xz;async function Xz(e){let t;try{let r=jz(e.schema,e.table);await Jz.mkdirp(r),t=await cd.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{cd.createDBI(t,xp.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),cd.createDBI(t,xp.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),cd.createDBI(t,xp.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(Xz,"createTransactionsAuditEnvironment")});var Vw=g((que,kw)=>{"use strict";var Gp=U(),Fw=Ke(),Zz=$o(),{getSystemSchemaPath:eJ,getSchemaPath:tJ}=ze(),rJ=Vi(),nJ=U_(),Fp=P_(),sJ=Y(),iJ=Gw(),kp=rJ.hdb_table,qw=[];for(let e=0;e<kp.attributes.length;e++)qw.push(kp.attributes[e].attribute);kw.exports=oJ;async function oJ(e,t){let r=tJ(t.schema,t.table),n=new Fp(t.schema,t.table,Gp.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Fp(t.schema,t.table,Gp.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Fp(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Fw.createEnvironment(r,t.table),e!==void 0){let o=await Fw.openEnvironment(eJ(),Gp.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await Zz.insertRecords(o,kp.hash_attribute,qw,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await qp(n),await qp(s),await qp(i)}await iJ(t)}catch(o){throw o}}a(oJ,"lmdbCreateTable");async function qp(e){try{await nJ(e)}catch(t){sJ.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(qp,"createAttribute")});var Yw=g((Vue,$w)=>{"use strict";var aJ=qc(),cJ=Vc(),lJ=ed(),nl=U(),uJ=$o().updateRecords,_J=Ke(),{getSchemaPath:dJ}=ze(),fJ=zc(),EJ=Y();$w.exports=hJ;async function hJ(e){try{let{schema_table:t,attributes:r}=aJ(e);cJ(e,r,t.hash_attribute),e.schema!==nl.SYSTEM_SCHEMA_NAME&&(r.includes(nl.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(nl.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(nl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(nl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await lJ(e.hdb_auth_header,t,r),s=dJ(e.schema,e.table),i=await _J.openEnvironment(s,e.table),o=await uJ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await fJ(e,o)}catch(c){EJ.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(hJ,"lmdbUpdateRecords")});var Ww=g((Yue,Kw)=>{"use strict";var mJ=U().OPERATIONS_ENUM,Vp=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=mJ.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Kw.exports=Vp});var zw=g((Que,Qw)=>{"use strict";var Wue=Ww(),pJ=qc(),SJ=Vc(),TJ=ed(),sl=U(),gJ=$o().upsertRecords,RJ=Ke(),{getSchemaPath:AJ}=ze(),OJ=zc(),bJ=Y(),{handleHDBError:yJ,hdb_errors:NJ}=ne();Qw.exports=IJ;async function IJ(e){let t;try{t=pJ(e)}catch(l){throw yJ(l,l.message,NJ.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;SJ(e,n,r.hash_attribute),e.schema!==sl.SYSTEM_SCHEMA_NAME&&(n.includes(sl.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(sl.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(sl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(sl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await TJ(e.hdb_auth_header,r,n),i=AJ(e.schema,e.table),o=await RJ.openEnvironment(i,e.table),c=await gJ(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await OJ(e,c)}catch(l){bJ.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(IJ,"lmdbUpsertRecords")});var jw=g((Jue,Jw)=>{"use strict";var $p=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};Jw.exports=$p});var Zw=g((Xue,Xw)=>{"use strict";var Yp=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}};Xw.exports=Yp});var rC=g((t_e,tC)=>{"use strict";var Kp=Ke(),{getTransactionAuditStorePath:wJ}=ze(),e_e=jw(),il=dt(),CJ=z(),eC=Zw(),DJ=require("util").promisify,LJ=DJ(setTimeout),MJ=1e4,PJ=100;tC.exports=UJ;async function UJ(e){let t=wJ(e.schema,e.table),r=await Kp.openEnvironment(t,e.table,!0),n=Kp.listDBIs(r);Kp.initializeDBIs(r,il.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new eC;do s=await vJ(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 LJ(PJ);while(s.transactions_deleted>0);return i}a(UJ,"deleteAuditLogsBefore");async function vJ(e,t){let r=new eC;try{let n=e.dbis[il.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[il.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];CJ.isEmpty(c)||(s=e.dbis[il.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[il.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>MJ)break}return await s,r}catch(n){throw n}}a(vJ,"deleteTransactions")});var sC=g((n_e,nC)=>{"use strict";var Wp=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};nC.exports=Wp});var oC=g((o_e,iC)=>{"use strict";var BJ=es(),HJ=rl(),i_e=sC(),ts=U(),xJ=z(),Qp=Ke(),GJ=Vi(),FJ=tl(),qJ=jc(),{getSchemaPath:kJ}=ze();iC.exports=VJ;async function VJ(e,t=!0){let r;e.schema===ts.SYSTEM_SCHEMA_NAME?r=GJ[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await YJ(e),s=kJ(e.schema,e.table),i=await Qp.openEnvironment(s,e.table);return t===!0&&await $J(e,i,r.hash_attribute),Qp.dropDBI(i,e.attribute),n}a(VJ,"lmdbDropAttribute");async function $J(e,t,r){let n=Qp.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let _={};for(let u in c)u!==i&&(_[u]=c[u]);s=t.dbis[r].put(o,_,l)}await s}a($J,"removeAttributeFromAllObjects");async function YJ(e){let t=new BJ(ts.SYSTEM_SCHEMA_NAME,ts.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,ts.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[ts.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,ts.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await FJ(t)).filter(o=>o[ts.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(xJ.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[ts.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new HJ(ts.SYSTEM_SCHEMA_NAME,ts.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return qJ(i)}a(YJ,"dropAttributeFromSystem")});var dC=g((l_e,_C)=>{"use strict";var zp=Ke(),sa=dt(),c_e=Hr(),Jp=U(),aC=z(),{getTransactionAuditStorePath:KJ}=ze(),WJ=ta(),ld=Xo(),QJ=Y();_C.exports=zJ;async function zJ(e){let t=KJ(e.schema,e.table),r=await zp.openEnvironment(t,e.table,!0),n=zp.listDBIs(r);zp.initializeDBIs(r,sa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Jp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return cC(r,e.search_values);case Jp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,jJ(r,e.search_values,s);case Jp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return JJ(r,e.search_values);default:return cC(r)}}a(zJ,"readAuditLog");function cC(e,t=[0,Date.now()]){aC.isEmpty(t[0])&&(t[0]=0),aC.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[sa.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 ld,s))}a(cC,"searchTransactionsByTimestamp");function JJ(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[sa.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,uC(e,i))}return Object.fromEntries(r)}a(JJ,"searchTransactionsByUsername");function jJ(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let _=t[c],u=WJ.equals(e,sa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,sa.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,_);for(let{value:d}of u){let E=Number(d);n.has(E)?n.get(E).push(_.toString()):n.set(E,[_.toString()])}}let s=Array.from(n.keys()),i=uC(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],_=l.timestamp,u=n.get(_);lC(l,"records",r,u,o),lC(l,"original_records",r,u,o)}return Object.fromEntries(o)}a(jJ,"searchTransactionsByHashValues");function lC(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let _=s.get(l),u=_[_.length-1];if(u.timestamp===i)u[t]=[c];else{let d=new ld(e.operation,e.user_name,i,void 0);d[t]=[c],_.push(d)}}else{let _=new ld(e.operation,e.user_name,i,void 0);_[t]=[c],s.set(l,[_])}}}a(lC,"loopRecords");function uC(e,t){let r=[];try{let n=e.dbis[sa.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 ld,i);r.push(o)}}catch(i){QJ.warn(i)}return r}catch(n){throw n}}a(uC,"batchSearchTransactions")});var EC=g((f_e,fC)=>{"use strict";var{getSchemaPath:__e}=ze(),d_e=Ke(),{database:XJ}=(Ae(),ie(ke));fC.exports={writeTransaction:ZJ};async function ZJ(e,t,r){return XJ({database:e,table:t}).transaction(r)}a(ZJ,"writeTransaction")});var SC=g((h_e,pC)=>{"use strict";var{getSchemaPath:hC}=ze(),mC=Ke();pC.exports={flush:e2,resetReadTxn:t2};async function e2(e,t){return(await mC.openEnvironment(hC(e,t),t.toString())).flushed}a(e2,"flush");async function t2(e,t){try{(await mC.openEnvironment(hC(e,t),t.toString())).resetReadTxn()}catch{}}a(t2,"resetReadTxn")});var AC=g((p_e,RC)=>{"use strict";var{Readable:r2}=require("stream"),{getDatabases:n2}=(Ae(),ie(ke)),{readSync:s2,openSync:i2,createReadStream:TC}=require("fs"),{open:o2}=require("lmdb"),gC=Uc(),a2=vc(),{AUDIT_STORE_OPTIONS:c2}=(ti(),ie(OC)),{INTERNAL_DBIS_NAME:l2,AUDIT_STORE_NAME:u2}=dt();RC.exports=d2;var jp=32768,_2=100;async function d2(e){let t=e.database||e.schema||"data",r=n2()[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 u=_.dbisDB,d=o2({noSync:!0,maxDbs:a2.MAX_DBS}),E,f=d.openDB(l2,new gC(!1)),h=u.useReadTransaction(),p=0,S=a(async function(R,b){b.encoding="binary",b.encoder=void 0;let C=d.openDB(R,b),H=u.openDB(R,b);for(let{key:v,version:q,value:M}of H.getRange({start:null,transaction:h,versions:H.useVersions}))E=C.put(v,M,q),p++%_2===0&&(await new Promise(Q=>setTimeout(Q,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:R,value:b}of u.getRange({transaction:h,start:!1}))if(s.some(C=>R.startsWith?.(C+"/"))){f.put(R,b);let[,C]=R.split("/"),H=!C,v=new gC(!H,H);await S(R,v)}e.include_audit&&await S(u2,Object.assign({},c2)),await E;let T=TC(d.path);return T.headers=l(),T.on("close",()=>{h.done(),d.close()}),T}let o=r[Object.keys(r)[0]].primaryStore,c=i2(o.path);return o.transaction(()=>{let _=Buffer.alloc(jp);s2(c,_,0,jp),o.resetReadTxn();let u=o.useReadTransaction();u.renew();let d=TC(null,{fd:c,start:jp}),E=new r2.from(async function*(){yield _;for await(let f of d)u.openTimer&&(u.openTimer=0),yield f;u.done()}());return E.headers=l(),E});function l(){let _=new Map;return _.set("content-type","application/octet-stream"),_.set("content-disposition",`attachment; filename="${t}"`),_.set("date",n),_}}a(d2,"getBackup")});var NC=g((T_e,yC)=>{"use strict";var f2=Y(),{handleHDBError:E2}=ne(),h2=ry(),m2=U_(),p2=Tp(),S2=BI(),T2=jc(),g2=Np(),R2=cw(),A2=pw(),O2=tl(),b2=yw(),y2=Bw(),N2=Vw(),I2=Yw(),w2=zw(),C2=rC(),D2=vp(),L2=oC(),M2=dC(),P2=EC(),bC=SC(),U2=AC(),Xp=class extends h2{static{a(this,"LMDBBridge")}async searchByConditions(t){return b2(t)}async getDataByHash(t){return await g2(t)}async searchByHash(t){return await R2(t)}async getDataByValue(t,r){return await A2(t,r)}async searchByValue(t){return await O2(t)}async createSchema(t){return await S2(t)}async dropSchema(t){return await y2(t)}async createTable(t,r){return await N2(t,r)}async dropTable(t){return await D2(t)}async createAttribute(t){return await m2(t)}async createRecords(t){return await p2(t)}async updateRecords(t){return await I2(t)}async upsertRecords(t){try{return await w2(t)}catch(r){throw E2(r,null,null,f2.ERR,r)}}async deleteRecords(t){return await T2(t)}async dropAttribute(t){return await L2(t)}async deleteAuditLogsBefore(t){return await C2(t)}async readAuditLog(t){return await M2(t)}writeTransaction(t,r,n){return P2.writeTransaction(t,r,n)}flush(t,r){return bC.flush(t,r)}resetReadTxn(t,r){return bC.resetReadTxn(t,r)}getBackup(t){return U2(t)}};yC.exports=Xp});function x2(){H2=setInterval(function(){for(let e of Zp)if(e.stale){let t=e[ye]?.url;DC.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},B2).unref()}var eS,CC,DC,LC,MC,PC,IC,Zp,v2,ol,wC,to,ud,B2,H2,tS=Re(()=>{eS=B(Hr()),CC=B(ne()),DC=B(Y());In();LC=B(te()),MC=B(U()),PC=B(z()),IC=100,Zp=new Set,v2=(0,PC.convertToMS)(LC.get(MC.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3,to=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxnsUsed=1,this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxn.openTimer&&(this.readTxn.openTimer=0),Zp.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(Zp.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(ol&&!this.overloadChecked&&performance.now()-wC>v2)throw new CC.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp=t.timestamp||(0,eS.getNextMonotonicTime)());let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let f=d;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=d;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let p=d;p<this.validated;p++){let S=this.writes[p];if(!S)continue;let T=S[f===0?"before":"beforeIntermediate"];if(T){let R=T();h?h.push?h.push(R):h=[h,R]:h=R}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(d){throw this.abort(),d}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(d=>d);let c=a(d=>{d.commit(r,d.entry,n)},"doWrite"),l=a(()=>{let d=this.writes[o++];if(d)if(d.key){n>0&&(d.entry=d.store.getEntry(d.key));let E=d.store.ifVersion(d.key,d.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),_=this.lmdbDb;if(this.writes.length>0&&(_?.retryRisk&&(_.retryRisk*=.99),this.writes.length+(_?.retryRisk||0)<IC>>n?l():s=this.writes[0].store.transaction(()=>{for(let d of this.writes)d.entry=d.store.getEntry(d.key),c(d);return!0})),s)return ol||(ol=s,wC=performance.now(),ol.then(()=>{ol=null})),s.then(d=>d?(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}))):(_&&(_.retryRisk=(_.retryRisk||0)+IC/2),t?t.retries=n+1:t={retries:1},this.commit(t)));let u={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(E=>({txnTime:r,next:E}));u.next=d}return u}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},ud=class extends to{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,eS.getNextMonotonicTime)())}getReadTxn(){}},B2=3e4;a(x2,"startMonitoringTxns");x2()});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 to;e.timestamp&&(n.timestamp=e.timestamp),n[ye]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var UC,ro=Re(()=>{UC=require("../../index");In();tS();a(Je,"transaction");(0,UC._assignPackageExport)("transaction",Je);Je.commit=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Je.abort=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var VC={};qe(VC,{ResourceBridge:()=>sS});function iS({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 BC(e,t){let r=rs(e),n=iS(e,r);if(!r)throw new Mn.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,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let _=c[l++],u=await r.get({id:_,lazy:s,select:n},i);return u=u&&dd(u),t?{value:{key:_,value:u}}:{value:u}}else return o(),{done:!0}},return(_){return o(),{value:_,done:!0}},throw(_){return o(),{done:!0}}}}}}function rs(e){let t=e.database||e.schema||F2,r=mr()[t];if(!r)throw(0,Mn.handleHDBError)(new Error,G2.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function HC(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*xC(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:l}=s;n?.timestamp===c?(n.hash_values.push(o),n.records.push(l)):(n&&(yield n),n={operation:i,user_name:s.user,timestamp:c,hash_values:[o],records:[l]})}n&&(yield n)}var GC,_d,Mn,FC,qC,Pn,rS,nS,kC,G2,F2,q2,k2,vC,sS,$C=Re(()=>{"use strict";GC=B(NC()),_d=B(ra()),Mn=B(ne());Ae();FC=B(qc()),qC=B(Vc()),Pn=B(U()),rS=B(bs()),nS=B(Ln()),kC=B(z());ro();fd();({HDB_ERROR_MSGS:G2}=Mn.hdb_errors),F2="data",q2=1e4,k2=10,sS=class extends GC.default{static{a(this,"ResourceBridge")}constructor(t){super(t),vC=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,_d.default)(t,"conditions");if(r)throw(0,Mn.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=rs(t);if(!n)throw new Mn.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:iS(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 Mn.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}ft({database:r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await rs(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=rs(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(_=>{if(!_){let{value:u,version:d}=r.primaryStore.getEntry(o);return i(o,u,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(_=>setImmediate(_));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){rs(t).dropTable()}createSchema(t){return ia({database:t.schema,table:null}),rS.signalSchemaChange(new nS.SchemaEventMsg(process.pid,Pn.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await oS(t.schema),rS.signalSchemaChange(new nS.SchemaEventMsg(process.pid,Pn.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,vC.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,FC.default)(t);(0,qC.default)(t,n,r.primaryKey);let s,i=mr()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt};return Je(o,async c=>{if(!i.schemaDefined){s=[];for(let u of n)i.attributes.find(E=>E.name==u)||s.push(u);s.length>0&&await i.addAttributes(s.map(u=>({name:u,indexed:!0})))}let l=[],_=[];for(let u of t.records){let d=await i.get(u[i.primaryKey],o);if(t.requires_existing&&!d||t.requires_no_existing&&d){_.push(u[i.primaryKey]);continue}d&&(d=dd(d));for(let E in u)if(Object.prototype.hasOwnProperty.call(u,E)){let f=u[E];if(typeof f=="function")try{let h=f([[d]]);Array.isArray(h)&&(f=h[0].func_val,u[E]=f)}catch(h){throw h.message+="Trying to set key "+E+" on object"+JSON.stringify(u),h}}if(d)for(let E in d)Object.prototype.hasOwnProperty.call(u,E)||(u[E]=d[E]);await i.put(u,o),l.push(u[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:_}})}async deleteRecords(t){let r=mr()[t.schema][t.table],n={user:t.hdb_user};return Je(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return HC(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=mr()[t.schema][t.table];if(!r.createdTimeProperty)throw new Mn.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:Pn.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],_=a(async()=>{let u=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...u.deleted_hashes),o.push(...u.skipped_hashes),await(0,kC.async_set_timeout)(k2),l=[],s=!0},"chunkDelete");for await(let u of n)l.push(u[r.primaryKey]),c++,c%q2===0&&await _();return l.length>0&&await _(),s?HC(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,_d.default)(t,"hashes");if(r)throw r;return BC(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of BC(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Pn.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,_d.default)(t,"value");if(n)throw n;let s=rs(t);if(!s)throw new Mn.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===Pn.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:iS(t,s)})}async getDataByValue(t,r){let n=new Map,s=rs(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){rs({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return rs(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=rs(t),n={};switch(t.search_type){case Pn.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 Pn.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of xC(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return xC(r,t.search_values?.[0],t.search_values?.[1])}}};a(iS,"getSelect");a(BC,"getRecords");a(rs,"getTable");a(HC,"createDeleteResponse");a(xC,"groupRecordsInHistory")});var Dn=g((U_e,YC)=>{"use strict";var{ResourceBridge:V2}=($C(),ie(VC)),$2=te();$2.initSync();var Ed;function Y2(){return Ed||(Ed=new V2,Ed)}a(Y2,"getBridge");YC.exports=Y2()});var zC=g((B_e,QC)=>{"use strict";var KC=require("lodash"),al=require("mathjs"),K2=require("jsonata"),WC=z();QC.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?KC.uniqWith(e,KC.isEqual):e,searchJSON:W2,mad:cl.bind(null,al.mad),mean:cl.bind(null,al.mean),mode:cl.bind(null,al.mode),prod:cl.bind(null,al.prod),median:cl.bind(null,al.median)};function cl(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(cl,"aggregateFunction");function W2(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(WC.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),WC.isEmpty(this.__ala__.res[r])){let n=K2(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(W2,"searchJSON")});var jC=g((x_e,JC)=>{"use strict";var gt=require("moment"),aS="YYYY-MM-DDTHH:mm:ss.SSSZZ";gt.suppressDeprecationWarnings=!0;JC.exports={current_date:()=>gt().utc().format("YYYY-MM-DD"),current_time:()=>gt().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return gt(e).utc().format("YYYY");case"month":return gt(e).utc().format("MM");case"day":return gt(e).utc().format("DD");case"hour":return gt(e).utc().format("HH");case"minute":return gt(e).utc().format("mm");case"second":return gt(e).utc().format("ss");case"millisecond":return gt(e).utc().format("SSS");default:break}},date:e=>gt(e).utc().format(aS),date_format:(e,t)=>gt(e).utc().format(t),date_add:(e,t,r)=>gt(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>gt(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=gt(e).utc(),s=gt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>gt().utc().valueOf(),get_server_time:()=>gt().format(aS),offset_utc:(e,t)=>gt(e).utc().utcOffset(t).format(aS)}});var tD=g((G_e,eD)=>{"use strict";var Q2=require("@turf/area"),z2=require("@turf/length"),J2=require("@turf/circle"),j2=require("@turf/difference"),X2=require("@turf/distance"),Z2=require("@turf/boolean-contains"),e4=require("@turf/boolean-equal"),t4=require("@turf/boolean-disjoint"),r4=require("@turf/helpers"),XC=U(),Se=z(),Is=Y();eD.exports={geoArea:n4,geoLength:s4,geoCircle:i4,geoDifference:o4,geoDistance:ZC,geoNear:a4,geoContains:c4,geoEqual:l4,geoCrosses:u4,geoConvert:_4};function n4(e){if(Se.isEmpty(e))return NaN;typeof e=="string"&&(e=Se.autoCastJSON(e));try{return Q2.default(e)}catch(t){return Is.trace(t,e),NaN}}a(n4,"geoArea");function s4(e,t){if(Se.isEmpty(e))return NaN;typeof e=="string"&&(e=Se.autoCastJSON(e));try{return z2.default(e,{units:t||"kilometers"})}catch(r){return Is.trace(r,e),NaN}}a(s4,"geoLength");function i4(e,t,r){if(Se.isEmpty(e))return NaN;if(Se.isEmpty(t))return NaN;typeof e=="string"&&(e=Se.autoCastJSON(e));try{return J2.default(e,t,{units:r||"kilometers"})}catch(n){return Is.trace(n,e,t),NaN}}a(i4,"geoCircle");function o4(e,t){if(Se.isEmpty(e))return NaN;if(Se.isEmpty(t))return NaN;typeof e=="string"&&(e=Se.autoCastJSON(e)),typeof t=="string"&&(t=Se.autoCastJSON(t));try{return j2(e,t)}catch(r){return Is.trace(r,e,t),NaN}}a(o4,"geoDifference");function ZC(e,t,r){if(Se.isEmpty(e))return NaN;if(Se.isEmpty(t))return NaN;typeof e=="string"&&(e=Se.autoCastJSON(e)),typeof t=="string"&&(t=Se.autoCastJSON(t));try{return X2.default(e,t,{units:r||"kilometers"})}catch(n){return Is.trace(n,e,t),NaN}}a(ZC,"geoDistance");function a4(e,t,r,n){if(Se.isEmpty(e)||Se.isEmpty(t))return!1;if(Se.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Se.autoCastJSON(e)),typeof t=="string"&&(t=Se.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return ZC(e,t,n)<=r}catch(s){return Is.trace(s,e,t),!1}}a(a4,"geoNear");function c4(e,t){if(Se.isEmpty(e)||Se.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Se.autoCastJSON(e)),typeof t=="string"&&(t=Se.autoCastJSON(t));try{return Z2.default(e,t)}catch(r){return Is.trace(r,e,t),!1}}a(c4,"geoContains");function l4(e,t){if(Se.isEmpty(e)||Se.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Se.autoCastJSON(e)),typeof t=="string"&&(t=Se.autoCastJSON(t));try{return e4.default(e,t)}catch(r){return Is.trace(r,e,t),!1}}a(l4,"geoEqual");function u4(e,t){if(Se.isEmpty(e)||Se.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Se.autoCastJSON(e)),typeof t=="string"&&(t=Se.autoCastJSON(t));try{return!t4.default(e,t)}catch(r){return Is.trace(r,e,t),!1}}a(u4,"geoCrosses");function _4(e,t,r){if(Se.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Se.isEmpty(t))throw new Error("geo_type is required");if(Se.isEmpty(XC.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(XC.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Se.autoCastJSON(e)),r4[t](e,r)}a(_4,"geoConvert")});var hd=g((q_e,rD)=>{var no=zC(),Kr=jC(),ns=tD();rD.exports=e=>{e.aggr.mad=e.aggr.MAD=no.mad,e.aggr.mean=e.aggr.MEAN=no.mean,e.aggr.mode=e.aggr.MODE=no.mode,e.aggr.prod=e.aggr.PROD=no.prod,e.aggr.median=e.aggr.MEDIAN=no.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=no.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=no.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Kr.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Kr.current_time,e.fn.extract=e.fn.EXTRACT=Kr.extract,e.fn.date=e.fn.DATE=Kr.date,e.fn.date_format=e.fn.DATE_FORMAT=Kr.date_format,e.fn.date_add=e.fn.DATE_ADD=Kr.date_add,e.fn.date_sub=e.fn.DATE_SUB=Kr.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Kr.date_diff,e.fn.now=e.fn.NOW=Kr.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Kr.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Kr.get_server_time,e.fn.getdate=e.fn.GETDATE=Kr.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Kr.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=ns.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=ns.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=ns.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=ns.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=ns.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=ns.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=ns.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=ns.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=ns.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=ns.geoNear}});var oD=g((k_e,iD)=>{"use strict";var ll=require("lodash"),pr=require("alasql");pr.options.cache=!1;var d4=hd(),nD=require("clone"),md=require("recursive-iterator"),_e=Y(),De=z(),oa=Dn(),f4=U(),{hdb_errors:E4}=ne(),{getDatabases:sD}=(Ae(),ie(ke)),h4="IS NULL",Un="There was a problem performing this search. Please check the logs and try again.";d4(pr);var cS=class{static{a(this,"SQLSearch")}constructor(t,r){if(De.isEmpty(t))throw _e.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(),De.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!De.isEmptyOrZeroLength(n))return _e.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw _e.error("Error thrown from checkEmptySQL in SQLSearch class method search."),_e.error(n),new Error(Un)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw _e.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),_e.error(n),new Error(Un)}if(Object.keys(this.data).length===0)return _e.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw _e.error("Error thrown from processJoins in SQLSearch class method search."),_e.error(n),new Error(Un)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw _e.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),_e.error(n),new Error(Un)}try{return t=await this._finalSQL(),t}catch(n){throw _e.error("Error thrown from finalSQL in SQLSearch class method search."),_e.error(n),new Error(Un)}}_getColumns(){let t=new md(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(nD(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=ll.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=sD()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(De.isEmpty(this.statement.where)){_e.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new md(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!De.isEmpty(r)&&r.right)if(De.isNotEmptyAndHasValue(r.right.value)){let n=De.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new pr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=De.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new pr.yy.LogicValue({value:i}):n instanceof pr.yy.StringValue&&De.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new pr.yy.NumValue({value:i}))});if(t){_e.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new md(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(!De.isEmpty(f4.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(De.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(De.isEmptyOrZeroLength(r.left.columnid)||De.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(De.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"=":!De.isEmpty(r.right.value)||!De.isEmpty(r.left.value)?n.add(De.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let _=0;_<l.length;_++)if(l[_].value)n.add(l[_].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(De.isEmptyOrZeroLength(this.all_table_attributes)&&De.isEmptyOrZeroLength(this.statement.from)&&De.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&&ll.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(De.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);De.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(De.isEmptyOrZeroLength(this.all_table_attributes)&&!De.isEmptyOrZeroLength(this.columns.columns))return t;if(De.isEmptyOrZeroLength(this.all_table_attributes)&&De.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await pr.promise(r)}catch(r){throw _e.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),_e.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(nD(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(De.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(h4)>-1&&this.tables.forEach(s=>{let i={columnid:sD()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=ll.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,_=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!De.isEmpty(this.exact_search_values[_])&&!this.exact_search_values[_].ignore&&!De.isEmptyOrZeroLength(this.exact_search_values[_].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[_].values);let u=await oa.getDataByHash(c);for(let d of c.hash_values)u.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(u){throw _e.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),_e.error(u),new Error(Un)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[_].values).map(async u=>{let d=Object.assign({},c);d.search_value=u;let E=await oa.getDataByValue(d);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(u){throw _e.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),_e.error(u),new Error(Un)}else if(!De.isEmpty(this.comparator_search_values[_])&&!this.comparator_search_values[_].ignore&&!De.isEmptyOrZeroLength(this.comparator_search_values[_].comparators))try{let u=this.comparator_search_values[_].comparators;for(let d=0,E=u.length;d<E;d++){let f=u[d];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await oa.getDataByValue(c,f.operation);if(l)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(u){throw _e.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),_e.error(u),new Error(Un)}else try{c.search_attribute=s.attribute,c.search_value="*";let u=await oa.getDataByValue(c);if(l)for(let[d]of u)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,E]of u)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,E[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,d))}catch(u){throw _e.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),_e.error(u),new Error(Un)}}}_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 pr.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 pr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new pr.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 pr.yy.FuncValue:new pr.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,p=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${p}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${p}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let _="";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(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let u="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(u=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${_} ${u} ${d}`,h=this._convertColumnsToIndexes(f,s);E=await pr.promise(h,t),t=null}catch(f){throw _e.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),_e.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let p=E[f];o.forEach(S=>{p[S.key]!==null&&p[S.key]!==void 0&&S.keys.add(p[S.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),p=ll.difference(h,[...f.keys].map(S=>S.toString()));for(let S=0,T=p.length;S<T;S++){let R=p[S];delete this.data[`${f.schema}_${f.table}`].__merged_data[R]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new md(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=ll.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 _e.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),_e.error(i),new Error(Un)}}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 u in i)o.push(i[u][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await oa.getDataByHash(c),_=s.columns.length;for(let u=0,d=o.length;u<d;u++){let E=o[u],f=l.get(E);for(let h=0;h<_;h++){let p=s.columns[h],S=f[p]===void 0?null:f[p];this.data[n].__merged_data[E].push(S)}}}}catch(r){throw _e.error("Error thrown from getDataByHash function in SQLSearch class method getData."),_e.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();_e.trace(`Final SQL: ${s}`),n=await pr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),_e.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw _e.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),_e.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 _e.error(E4.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),_e.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],_=new RegExp(`${l}.\`${o}\``,"g"),u=`${l}.[${c}]`;n=n.replace(_,u)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),_=`[${c}]`;n=n.replace(l,_)});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 oa.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]=Object.assign({},r[s])),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw _e.error("There was an error when processing this SQL operation. Check your logs"),_e.error(o),new Error(Un)}}return Object.values(Object.values(this.data)[0].__merged_data)}};iD.exports=cS});var qr=g(($_e,aD)=>{"use strict";var m4=ey();aD.exports={searchByConditions:S4,searchByHash:T4,searchByValue:g4,search:R4};var lS=Dn(),{transformReq:uS}=z(),p4=oD();async function S4(e){return uS(e),lS.searchByConditions(e)}a(S4,"searchByConditions");async function T4(e){uS(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of lS.searchByHash(e))r&&t.push(r);return t}a(T4,"searchByHash");async function g4(e){uS(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of lS.searchByValue(e))t.push(r);return t}a(g4,"searchByValue");function R4(e,t){try{let r=new m4(e);r.validate(),new p4(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(R4,"search")});var pd=g((K_e,cD)=>{"use strict";var A4=Dn();cD.exports={writeTransaction:O4};function O4(e,t,r){return A4.writeTransaction(e,t,r)}a(O4,"writeTransaction")});var dD=g((z_e,_D)=>{"use strict";var b4=qr(),y4=Os(),lD=Y(),N4=un(),Q_e=pd(),I4=require("clone"),dS=require("alasql"),w4=hd(),uD=require("util"),C4=uD.promisify(y4.getTableSchema),D4=uD.promisify(b4.search),L4=U(),_S=z();w4(dS);_D.exports={update:P4};var M4="There was a problem performing this update. Please check the logs and try again.";async function P4({statement:e,hdb_user:t}){let r=await C4(e.table.databaseid,e.table.tableid),n=U4(e.columns);_S.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=I4(s),c=_S.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,_=dS.parse(l).statements[0],u=await D4(_),d=v4(n,u);return B4(o,d,t)}a(P4,"update");function U4(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=dS.compile(`SELECT ${r.expression.toString()} AS [${L4.FUNC_VAL}] FROM ?`)}),t}catch(t){throw lD.error(t),new Error(M4)}}a(U4,"createUpdateRecord");function v4(e,t){return _S.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(v4,"buildUpdateRecords");async function B4(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await N4.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){lD.error(`Error delete new_attributes from update response: ${i}`)}return s}a(B4,"updateRecords")});var ED=g((Z_e,fD)=>{var H4=require("alasql"),x4=qr(),G4=Y(),F4=Dn(),ES=require("util"),fS=z(),q4=U(),k4=Os(),j_e=pd(),X_e=un(),V4="record",$4="successfully deleted",Y4=ES.callbackify(z4),K4=ES.promisify(x4.search),W4=ES.promisify(k4.getTableSchema);fD.exports={convertDelete:Y4};function Q4(e){return`${e.deleted_hashes.length} ${V4}${e.deleted_hashes.length===1?"":"s"} ${$4}`}a(Q4,"generateReturnMessage");async function z4({statement:e,hdb_user:t}){let r=await W4(e.table.databaseid,e.table.tableid);fS.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=fS.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=H4.parse(o).statements[0],l={operation:q4.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await K4(c);let _=await F4.deleteRecords(l);return fS.isEmptyOrZeroLength(_.message)&&(_.message=Q4(_)),delete _.txn_time,_}catch(_){throw G4.error(_),_.hdb_code?_.message:_}}a(z4,"convertDelete")});var TD=g((tde,SD)=>{"use strict";var J4=si(),{hdb_errors:hD}=ne(),{getDatabases:mD}=(Ae(),ie(ke));SD.exports={checkSchemaExists:pD,checkSchemaTableExists:j4,schema_describe:J4};async function pD(e){if(!mD()[e])return hD.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(pD,"checkSchemaExists");async function j4(e,t){let r=await pD(e);if(r)return r;if(!mD()[e][t])return hD.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(j4,"checkSchemaTableExists")});var ul=g((nde,X4)=>{X4.exports={name:"harperdb",version:"4.3.21",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive",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/client-s3":"3.635.0","@aws-sdk/lib-storage":"3.635.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.7.1","@fastify/compress":"~6.5.0","@fastify/cors":"~8.5.0","@fastify/static":"~6.12.0","@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.8",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.26.2","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.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.0.14",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",mkcert:"1.5.1",moment:"2.30.1","mqtt-packet":"~8.2.1",msgpackr:"1.10.1",nats:"2.19.0",needle:"3.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.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.4.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.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.22.9","tar-fs":"2.1.1",ulidx:"0.5.0",uuid:"9.0.1","validate.js":"0.13.1",ws:"8.17.1",yaml:"2.4.1"},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.8",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.20.2",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.3.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",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.4.2","why-is-node-still-running":"^1.0.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","utf-8-validate":"^5.0.10"}}});var hl={};qe(hl,{addAnalyticsListener:()=>El,recordAction:()=>Sr,recordActionBinary:()=>Wr,setAnalyticsEnabled:()=>Z4});function Z4(e){wD=e}function Sr(e,t,r,n,s){if(!wD)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=gd.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let _=c;o.values=c=new Float32Array(l*2),c.set(_),c.index=l+1}c[l]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},gd.set(i,o)}Sd||e3()}function Wr(e,t,r,n,s){Sr(!!e,t,r,n,s)}function El(e){LD.push(e)}function e3(){Sd=performance.now(),setTimeout(async()=>{let e=performance.now()-Sd;Sd=0;let t=[],r={time:Date.now(),period:e,threadId:so.threadId,metrics:t};for(let[s,i]of gd){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,_=[],u;for(let d of MD){let E=Math.floor(c*d),f=o[E-1];if(E>l){let h=E-l;if(f===u){let p=_[_.length-1];typeof p=="number"?_[_.length-1]={value:p,count:1+h}:p.count+=h}else _.push(h>1?{value:f,count:h}:f),u=f;l=E}}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 PD()}let n=process.memoryUsage();t.push({metric:"memory",threadId:so.threadId,byThread:!0,...n});for(let s of LD)s(t);gd=new Map,so.parentPort?so.parentPort.postMessage({type:DD,report:r}):BD({report:r})},CD).unref()}async function t3(e,t=6e4){let r=pS(),n=UD(),s=new Promise(p=>{let S=performance.now();setImmediate(()=>{let T=performance.now();T-S>5e3&&(0,_l.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,_l.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,l=new Map,_=[],u;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;u=p;let{metrics:T,threadId:R}=S;for(let b of T||[]){let{path:C,method:H,type:v,metric:q,count:M,total:Q,distribution:J,threads:j,...ae}=b;M||(M=1);let ce=q+(C?"-"+C:"");H!==void 0&&(ce+="-"+H),v!==void 0&&(ce+="-"+v);let ge=c.get(ce);if(ge){if(ge.threads){let Ne=ge.threads[R];if(Ne)ge=Ne;else{ge.threads[R]=Object.assign({},ae);continue}}ge.count||(ge.count=1);let Ge=ge.count;for(let Ne in ae){let ve=ae[Ne];typeof ve=="number"&&(ge[Ne]=(ge[Ne]*Ge+ve*M)/(Ge+M))}ge.count+=M,Q>=0&&(ge.total+=Q,ge.ratio=ge.total/ge.count)}else ge=Object.assign({period:t},b),delete ge.distribution,c.set(ce,ge),ge.byThread&&(ge.threads=[],ge.threads[R]=Object.assign({},ae),_.push(ge));if(J){J=J.map(Ne=>typeof Ne=="number"?{value:Ne,count:1}:Ne);let Ge=l.get(ce);Ge?Ge.push(...J):l.set(ce,J)}}await PD()}for(let p of _){let{path:S,method:T,type:R,metric:b,count:C,total:H,distribution:v,threads:q,...M}=p;q=q.filter(Q=>Q);for(let Q in M){if(typeof p[Q]!="number")continue;let J=0;for(let j of q){let ae=j[Q];typeof ae=="number"&&(J+=ae)}p[Q]=J}p.count=q.length,delete p.threads,delete p.byThread}for(let[p,S]of l){let T=c.get(p);S.sort((Ne,ve)=>Ne.value>ve.value?1:-1);let R=T.count-1,b=[],C=0,H=0,v;for(let Ne of MD){let ve=R*Ne;for(;C<ve;)v=S[H++],C+=v.count,H===1&&C--;let Qu=S[H>1?H-2:0];v||(v=S[0]),b.push(v.value-(v.value-Qu.value)*(C-ve)/v.count)}let[q,M,Q,J,j,ae,ce,ge,Ge]=b;Object.assign(T,{p1:q,p10:M,p25:Q,median:J,p75:j,p90:ae,p95:ce,p99:ge,p999:Ge})}let d;for(let[p,S]of c)S.id=(0,Td.getNextMonotonicTime)(),S.time=u,n.primaryStore.put(S.id,S,{append:!0}).then(T=>{T||n.primaryStore.put(S.id,S)}),d=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(d||h*10>f){let p=(0,Td.getNextMonotonicTime)(),S={id:p,metric:"main-thread-utilization",idle:f-gD,active:h-RD,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(p,S,{append:!0}).then(T=>{T||n.primaryStore.put(p,S)})}gD=f,RD=h}async function AD(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function pS(){return OD||(OD=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function UD(){return bD||(bD=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function s3(){vD=!0;let e=(0,fl.get)(mS.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await t3(CD,e),await AD(pS(),r3),await AD(UD(),n3)},Math.min(e/2,2147483647)).unref()}function BD(e,t){let r=e.report;r.threadId=t?.threadId||so.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(yD+=n.mean*n.count);r.totalBytesProcessed=yD,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(ND.get(t))}),ND.set(t,t.performance.eventLoopUtilization())),r.id=(0,Td.getNextMonotonicTime)(),pS().primaryStore.put(r.id,r),vD||s3(),i3&&(HD=a3(r))}async function a3(e){if(await HD,!ui){let r=(0,dl.dirname)((0,_l.getLogFilePath)());try{ui=await(0,hS.open)((0,dl.join)(r,"analytics.log"),"r+")}catch{ui=await(0,hS.open)((0,dl.join)(r,"analytics.log"),"w+")}}let t=(await ui.stat()).size;if(t>o3){let r=Buffer.alloc(t);await ui.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await ui.write(r,{position:0}),await ui.truncate(r.length),t=r.length}await ui.write(JSON.stringify(e)+`
8
- `,t)}var so,ID,_l,dl,hS,Td,fl,mS,gd,wD,Sd,CD,DD,LD,MD,gD,RD,PD,r3,n3,OD,bD,vD,yD,ND,i3,HD,ui,o3,ws=Re(()=>{so=require("worker_threads"),ID=B(ot());Ae();_l=B(Y()),dl=require("path"),hS=require("fs/promises"),Td=B(Hr()),fl=B(te()),mS=B(U());ur();(0,fl.initSync)();gd=new Map,wD=(0,fl.get)(mS.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(Z4,"setAnalyticsEnabled");a(Sr,"recordAction");it.recordAnalytics=Sr;a(Wr,"recordActionBinary");Sd=0,CD=1e3,DD="analytics-report",LD=[];a(El,"addAnalyticsListener");MD=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(e3,"sendAnalytics");a(t3,"aggregation");gD=0,RD=0,PD=a(()=>new Promise(setImmediate),"rest");a(AD,"cleanup");r3=36e5,n3=31536e6;a(pS,"getRawAnalyticsTable");a(UD,"getAnalyticsTable");(0,ID.setChildListenerByType)(DD,BD);a(s3,"startScheduledTasks");yD=0,ND=new Map,i3=!1;a(BD,"recordAnalytics");o3=1e6;a(a3,"logAnalytics")});var AS=g((mde,QD)=>{"use strict";var{decode:c3}=require("msgpackr"),{isMainThread:fde,parentPort:Ede,threadId:hde}=require("worker_threads"),Od=Rt(),aa=ct(),gS=U(),nr=Y(),TS=te(),l3=U(),{onMessageByType:u3}=ot(),FD=As(),{recordAction:_3,recordActionBinary:d3}=(ws(),ie(hl)),{publishToStream:f3}=Od,{ConsumerEvents:xD}=require("nats"),E3=qr(),{promisify:h3}=require("util"),qD=h3(setTimeout),bd=1e4,yd,Ad,m3,p3,kD,ml=new Map,ca=new Map;QD.exports={initialize:VD,ingestConsumer:RS,setSubscription:S3,setIgnoreOrigin:R3,getDatabaseSubscriptions:g3,updateConsumer:$D};async function VD(){u3(gS.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await $D(n)}),kD=!0,nr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await Od.getNATSReferences();yd=e,Ad=e.info.server_name,m3=t,p3=r}a(VD,"initialize");async function $D(e){if(e.status==="start"){let{js:t,jsm:r}=await YD(e.node_domain_name);RS(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=ml.get(e.stream_name+e.node_domain_name);t&&(nr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),ml.set(e.stream_name+e.node_domain_name,"close")),ca.get(e.node_domain_name)==="failed"&&ca.set(e.node_domain_name,"close")}}a($D,"updateConsumer");var Nd=new Map;function S3(e,t,r){let n=Nd.get(e);n||Nd.set(e,n=new Map),n.set(t,r),kD||VD().then(T3)}a(S3,"setSubscription");async function T3(){let e=await E3.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+aa.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions)if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await YD(r),!n))break;let{schema:o,table:c}=i,l=FD.createNatsTableStreamName(o,c);RS(l,n,s,r)}}}a(T3,"accessConsumers");async function YD(e){let t,r,n=1;for(;!r;)try{t=await yd.jetstream({domain:e}),r=await yd.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(ca.get(e)==="close")break;ca.set(e,"failed"),n%10===1&&nr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<bd?n++*100:bd;await qD(i)}return{js:t,jsm:r}}a(YD,"connectToRemoteJS");function g3(){return Nd}a(g3,"getDatabaseSubscriptions");var KD;function R3(e){KD=e}a(R3,"setIgnoreOrigin");var WD=100,GD=new Array(WD),Rd=0;async function RS(e,t,r,n){let{connection:s}=await Od.getNATSReferences();yd=s,Ad=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,Ad),nr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(_){if(ca.get(n)==="close")break;o%10===1&&nr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",_.message),_.code==="404"&&(nr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await Od.createConsumer(r,e,Ad,new Date(Date.now()).toISOString()));let u=o++*100<bd?o++*100:bd;await qD(u)}let c=!1,l;for(;!c;){if(ml.get(e+n)==="close"||ca.get(n)==="close"){ml.delete(e+n),c=!0;continue}l=await i.consume({max_messages:TS.get(gS.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),ml.set(e+n,l);let _=!1;(async()=>{for await(let u of await l.status())if(u.type===xD.ConsumerDeleted&&(await l.close(),c=!0),u.type===xD.HeartbeatsMissed){let d=u.data;nr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(nr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),_=!0)}})();try{for await(let u of l)await GD[Rd],GD[Rd]=A3(u).catch(d=>{nr.error(d)}),++Rd>=WD&&(Rd=0)}catch(u){u.message==="consumer deleted"?(nr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):nr.error("Error consuming clustering ingest, restarting consumer",u)}}}a(RS,"ingestConsumer");async function A3(e){let t=c3(e.data);_3(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),nr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=TS.get(gS.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(aa.MSG_HEADERS.TRANSACTED_NODES)&&r.values(aa.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(aa.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!KD),d3(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(aa.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:_,records:u,hash_values:d,__origin:E,expiresAt:f}=t;nr.trace("processing message:",o,c,_,(u?"records: "+u.map(C=>C?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),nr.trace(`messageProcessor nats msg id: ${e.headers.get(aa.MSG_HEADERS.NATS_MSG_ID)}`);let h;u||(u=d);let p=new Promise(C=>h=C),{timestamp:S,user:T,node_name:R}=E||{},b=Nd.get(c)?.get(_);if(!b)throw new Error("Missing table for replication message",_);if(o==="define_schema")t.type=o,t.onCommit=h,b.send(t);else if(u.length===1&&!l)b.send({type:SS(o),value:u[0],id:d?.[0],expiresAt:f,timestamp:S,table:_,onCommit:h,user:T,nodeName:R});else{let C=u.map((H,v)=>({type:SS(o),value:H,expiresAt:f,id:d?.[v],table:_}));for(;l;)C.push({type:SS(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;b.send({type:"transaction",writes:C,table:_,timestamp:S,onCommit:h,user:T,nodeName:R})}TS.get(l3.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&f3(e.subject.split(".").slice(0,-1).join("."),FD.createNatsTableStreamName(c,_),e.headers,e.data),await p}catch(o){nr.error(o)}e.ack()}a(A3,"messageProcessor");function SS(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(SS,"convertOperation")});var Rt=g((Ode,_L)=>{"use strict";var Ht=te();Ht.initSync();var O3=require("fs-extra"),b3=require("semver"),Tl=require("path"),{monotonicFactory:y3}=require("ulidx"),JD=y3(),N3=require("util"),jD=require("child_process"),I3=N3.promisify(jD.exec),w3=jD.spawn,Kt=ct(),Ie=U(),Id=z(),vn=Y(),wd=As(),C3=pd(),pl=dr(),{broadcast:D3,onMessageByType:L3,getWorkerIndex:M3}=ot(),{isMainThread:XD}=require("worker_threads"),{Encoder:P3,decode:NS}=require("msgpackr"),ZD=new P3,{isEmpty:co}=Id,eL=Vr(),Sde=48*36e11;XD&&L3(Ie.ITC_EVENT_TYPES.RESTART,()=>{Tr=void 0,ao=void 0});var{connect:U3,StorageType:v3,RetentionPolicy:B3,AckPolicy:IS,DeliverPolicy:wS,DiscardPolicy:H3,NatsConnection:Tde,JetStreamManager:gde,JetStreamClient:Rde,StringCodec:Ade,JSONCodec:x3,createInbox:CS,headers:G3,ErrorCode:zD}=require("nats"),{PACKAGE_ROOT:F3}=U(),q3=ul(),{recordAction:k3}=(ws(),ie(hl)),tL=x3(),V3="clustering",$3=q3.engines[Kt.NATS_SERVER_NAME],Y3=Tl.join(F3,"dependencies"),yS=Tl.join(Y3,`${process.platform}-${process.arch}`,Kt.NATS_BINARY_NAME),OS,bS,Sl,io,oo;_L.exports={runCommand:rL,checkNATSServerInstalled:K3,createConnection:DS,getConnection:gl,getJetStreamManager:Rl,getJetStream:sL,getNATSReferences:ss,getServerList:Q3,createLocalStream:LS,listStreams:iL,deleteLocalStream:z3,getServerConfig:la,listRemoteStreams:J3,viewStream:j3,viewStreamIterator:X3,publishToStream:Z3,request:rj,reloadNATS:MS,reloadNATSHub:nj,reloadNATSLeaf:sj,extractServerName:tj,requestErrorHandler:ij,createLocalTableStream:lL,createTableStreams:cj,purgeTableStream:uL,purgeSchemaTableStreams:lj,getStreamInfo:uj,updateLocalStreams:dj,closeConnection:W3,getJsmServerName:Cd,addNatsMsgHeader:oL,clearClientCache:nL,updateRemoteConsumer:oj,createConsumer:aL,updateConsumerIterator:aj};async function rL(e,t=void 0){let{stdout:r,stderr:n}=await I3(e,{cwd:t});if(n)throw new Error(n.replace(`
1
+ "use strict";var zV=Object.create;var zl=Object.defineProperty;var jV=Object.getOwnPropertyDescriptor;var JV=Object.getOwnPropertyNames;var XV=Object.getPrototypeOf,ZV=Object.prototype.hasOwnProperty;var a=(e,t)=>zl(e,"name",{value:t,configurable:!0});var Oe=(e,t)=>()=>(e&&(t=e(e=0)),t);var I=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),Ze=(e,t)=>{for(var r in t)zl(e,r,{get:t[r],enumerable:!0})},GO=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of JV(t))!ZV.call(e,s)&&s!==r&&zl(e,s,{get:()=>t[s],enumerable:!(n=jV(t,s))||n.enumerable});return e};var U=(e,t,r)=>(r=e!=null?zV(XV(e)):{},GO(t||!e||!e.__esModule?zl(r,"default",{value:e,enumerable:!0}):r,e)),ae=e=>GO(zl({},"__esModule",{value:!0}),e);var $O=I((Xde,VO)=>{var e$=require("fast-glob"),{statSync:Wp,existsSync:Qp,readFileSync:t$,writeFileSync:r$}=require("fs"),{spawnSync:n$,spawn:s$,execFileSync:Jde}=require("child_process"),{isMainThread:i$}=require("worker_threads"),{join:Qi,relative:qO}=require("path"),{PACKAGE_ROOT:as}=B(),{tmpdir:o$,platform:a$}=require("os");require("source-map-support").install();var c$=["resources","server","dataLayer","components"],jl="ts-build",zp,l$=__filename.endsWith("tsBuild.js");if(l$){if(i$){let r;try{Wp(Qi(as,jl)),r=!0}catch{}if(r)for(let n of e$.sync(c$.map(s=>s+"/**/*.ts"),{cwd:as})){let s=0,i=0;try{s=Wp(Qi(as,n)).mtimeMs-5e3,i=Wp(Qi(as,jl,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."),zp=!0;break}}else console.log("TypeScript modules are not compiled, compiling now"),zp=!0;if(zp){let n=Qi(as,"node_modules/.bin/tsc");a$()==="win32"&&(n+=".cmd");let s=n$(n,{cwd:as});if(s.stdout?.length&&console.log(s.stdout.toString()),s.stderr?.length&&console.log(s.stderr.toString()),r){let i=Qi(o$(),"harperdb-tsc.pid"),o;if(Qp(i))try{process.kill(+t$(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=s$(n,["--watch"],{cwd:as,detached:!0,stdio:"ignore"});r$(i,c.pid.toString()),c.unref()}}}}let e=VO.constructor,t=e._findPath;e._findPath=function(r,n,s){if(r.startsWith(".")&&!s&&n.length===1&&n[0].startsWith(as)&&!n[0].includes("node_modules")){let i=qO(as,n[0]),o;i.startsWith(jl)?o=Qi(as,qO(jl,i)):o=Qi(as,jl,i);let c=Qi(o,r),l=c+".js";if(Qp(l))return l;if(c.includes(".")&&Qp(c))return c}return t(r,n,s)}}});var B=I((tfe,sN)=>{"use strict";var kn=require("path"),u$=require("fs"),{relative:Zde,join:efe}=kn,{existsSync:d$}=u$;function f$(){let e=__dirname;for(;!d$(kn.join(e,"package.json"));){let t=kn.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(f$,"getHDBPackageRoot");var zi=f$(),YO="js",o_=YO,_$="harperdb-config.yaml",E$="defaultConfig.yaml",h$="hdb",KO=`harperdb.${o_}`,WO=`customFunctionsServer.${o_}`,m$=`restartHdb.${o_}`,Jp="HarperDB",i_="Custom Functions",a_="Clustering Hub",c_="Clustering Leaf",p$="Clustering Ingest Service",S$="Clustering Reply Service",T$="foreground.pid",g$="hdb.pid",R$="data",A$={HDB:Jp,CLUSTERING_HUB:a_,CLUSTERING_LEAF:c_,CLUSTERING_INGEST_SERVICE:p$,CLUSTERING_REPLY_SERVICE:S$,CUSTOM_FUNCTIONS:i_,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"},b$={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},y$={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},O$={harperdb:Jp,"clustering hub":a_,"clustering leaf":c_,"custom functions":i_,custom_functions:i_,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},N$={CLUSTERING_HUB_PROC_DESCRIPTOR:a_,CLUSTERING_LEAF_PROC_DESCRIPTOR:c_},jp={HDB:kn.join(zi,"server/harperdb"),CUSTOM_FUNCTIONS:kn.join(zi,"server/customFunctions"),CLUSTERING_HUB:kn.join(zi,"server/nats"),CLUSTERING_LEAF:kn.join(zi,"server/nats")},I$={HDB:kn.join(jp.HDB,KO),CUSTOM_FUNCTIONS:kn.join(jp.CUSTOM_FUNCTIONS,WO)},w$={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:kn.join(zi,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:kn.join(zi,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:kn.join(zi,"launchServiceScripts/launchUpdateNodes4-0-0.js")},C$={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},QO="support@harperdb.io",D$="customer-success@harperdb.io",zO=1,L$=4141,jO="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",P$="https://www.harperdb.io/product",M$=`For support, please submit a request at ${jO} or contact ${QO}`,JO=`For license support, please contact ${D$}`,U$="None of the specified records were found.",v$="hash attribute not found",x$=`Your current license only supports ${zO} role. ${JO}`,B$="Your current license only supports 3 connections to a node.",H$="127.0.0.1",k$=1,F$=/^\.$/,G$=/^\.\.$/,q$="U+002E",V$=/\//g,$$="U+002F",Y$=/U\+002F/g,K$=/^U\+002E$/,W$=/^U\+002EU\+002E$/,Q$="d",z$=999999,j$="*",J$="--max-old-space-size=",X$="system",Z$="__hdb_hash",e1=".harperdb",t1=".hdb",r1="keys",n1="hdb_boot_properties.file",s1=".updateConfig.json",i1="SIGTSTP",o1=24,a1=6e4,c1=448,l1="blob",u1="trash",d1="database",f1="schema",_1="transactions",E1=".count",h1="id",m1="PROCESS_NAME",XO={SETTINGS_PATH_KEY:"settings_path"},ZO=require("lodash"),p1={TC_AGREEMENT:"TC_AGREEMENT",CLUSTERING_USER:"CLUSTERING_USER",CLUSTERING_PASSWORD:"CLUSTERING_PASSWORD",HDB_ADMIN_USERNAME:"HDB_ADMIN_USERNAME",HDB_ADMIN_PASSWORD:"HDB_ADMIN_PASSWORD",OPERATIONSAPI_ROOT:"OPERATIONSAPI_ROOT",ROOTPATH:"ROOTPATH",CLUSTERING_NODENAME:"CLUSTERING_NODENAME",CLUSTERING_ENABLED:"CLUSTERING_ENABLED",HDB_CONFIG:"HDB_CONFIG",DEFAULTS_MODE:"DEFAULTS_MODE",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",CLUSTERING_PORT:"CLUSTERING_PORT",HDB_ROOT:"HDB_ROOT",SERVER_PORT:"SERVER_PORT",NODE_NAME:"NODE_NAME",CLUSTERING:"CLUSTERING"},S1={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},T1={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},g1={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"},R1={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"},_n="hdb_internal:",A1={CREATE_SCHEMA:_n+"create_schema",CREATE_TABLE:_n+"create_table",CREATE_ATTRIBUTE:_n+"create_attribute",ADD_USER:_n+"add_user",ALTER_USER:_n+"alter_user",DROP_USER:_n+"drop_user",HDB_NODES:_n+"hdb_nodes",HDB_USERS:_n+"hdb_users",HDB_WORKERS:_n+"hdb_workers",CATCHUP:_n+"catchup",SCHEMA_CATCHUP:_n+"schema_catchup",WORKER_ROOM:_n+"cluster_workers"},b1={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"},y1="060493.ks",O1=".license",N1={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},oe={INSERT:"insert",UPDATE:"update",UPSERT:"upsert",SEARCH_BY_CONDITIONS:"search_by_conditions",SEARCH_BY_HASH:"search_by_hash",SEARCH_BY_ID:"search_by_id",SEARCH_BY_VALUE:"search_by_value",SEARCH:"search",SQL:"sql",CSV_DATA_LOAD:"csv_data_load",CSV_FILE_LOAD:"csv_file_load",CSV_URL_LOAD:"csv_url_load",CREATE_SCHEMA:"create_schema",CREATE_DATABASE:"create_database",CREATE_TABLE:"create_table",CREATE_ATTRIBUTE:"create_attribute",DROP_SCHEMA:"drop_schema",DROP_DATABASE:"drop_database",DROP_TABLE:"drop_table",DESCRIBE_SCHEMA:"describe_schema",DESCRIBE_DATABASE:"describe_database",DESCRIBE_TABLE:"describe_table",DESCRIBE_ALL:"describe_all",DELETE:"delete",ADD_USER:"add_user",ALTER_USER:"alter_user",DROP_USER:"drop_user",LIST_USERS:"list_users",LIST_ROLES:"list_roles",ADD_ROLE:"add_role",ALTER_ROLE:"alter_role",DROP_ROLE:"drop_role",USER_INFO:"user_info",READ_LOG:"read_log",ADD_NODE:"add_node",UPDATE_NODE:"update_node",SET_NODE_REPLICATION:"set_node_replication",EXPORT_TO_S3:"export_to_s3",IMPORT_FROM_S3:"import_from_s3",DELETE_FILES_BEFORE:"delete_files_before",DELETE_RECORDS_BEFORE:"delete_records_before",EXPORT_LOCAL:"export_local",SEARCH_JOBS_BY_START_DATE:"search_jobs_by_start_date",GET_JOB:"get_job",DELETE_JOB:"delete_job",UPDATE_JOB:"update_job",GET_FINGERPRINT:"get_fingerprint",SET_LICENSE:"set_license",GET_REGISTRATION_INFO:"registration_info",CONFIGURE_CLUSTER:"configure_cluster",SET_CONFIGURATION:"set_configuration",CLUSTER_STATUS:"cluster_status",CLUSTER_NETWORK:"cluster_network",DROP_ATTRIBUTE:"drop_attribute",REMOVE_NODE:"remove_node",RESTART:"restart",RESTART_SERVICE:"restart_service",CATCHUP:"catchup",SYSTEM_INFORMATION:"system_information",DELETE_AUDIT_LOGS_BEFORE:"delete_audit_logs_before",READ_AUDIT_LOG:"read_audit_log",CREATE_AUTHENTICATION_TOKENS:"create_authentication_tokens",LOGIN:"login",LOGOUT:"logout",REFRESH_OPERATION_TOKEN:"refresh_operation_token",GET_CONFIGURATION:"get_configuration",CUSTOM_FUNCTIONS_STATUS:"custom_functions_status",GET_CUSTOM_FUNCTIONS:"get_custom_functions",GET_CUSTOM_FUNCTION:"get_custom_function",SET_CUSTOM_FUNCTION:"set_custom_function",GET_COMPONENTS:"get_components",GET_COMPONENT_FILE:"get_component_file",SET_COMPONENT_FILE:"set_component_file",DROP_COMPONENT:"drop_component",DROP_CUSTOM_FUNCTION:"drop_custom_function",ADD_CUSTOM_FUNCTION_PROJECT:"add_custom_function_project",ADD_COMPONENT:"add_component",DROP_CUSTOM_FUNCTION_PROJECT:"drop_custom_function_project",PACKAGE_CUSTOM_FUNCTION_PROJECT:"package_custom_function_project",DEPLOY_CUSTOM_FUNCTION_PROJECT:"deploy_custom_function_project",PACKAGE_COMPONENT:"package_component",DEPLOY_COMPONENT:"deploy_component",CLUSTER_SET_ROUTES:"cluster_set_routes",CLUSTER_DELETE_ROUTES:"cluster_delete_routes",CLUSTER_GET_ROUTES:"cluster_get_routes",READ_TRANSACTION_LOG:"read_transaction_log",DELETE_TRANSACTION_LOGS_BEFORE:"delete_transaction_logs_before",INSTALL_NODE_MODULES:"install_node_modules",AUDIT_NODE_MODULES:"audit_node_modules",PURGE_STREAM:"purge_stream",GET_BACKUP:"get_backup",SIGN_CERTIFICATE:"sign_certificate",CREATE_CSR:"create_csr",LIST_CERTIFICATES:"list_certificates",ADD_CERTIFICATES:"add_certificate",REMOVE_CERTIFICATE:"remove_certificate",ADD_NODE_BACK:"add_node_back",REMOVE_NODE_BACK:"remove_node_back",ADD_SSH_KEY:"add_ssh_key",UPDATE_SSH_KEY:"update_ssh_key",DELETE_SSH_KEY:"delete_ssh_key",LIST_SSH_KEYS:"list_ssh_keys",SET_SSH_KNOWN_HOSTS:"set_ssh_known_hosts",GET_SSH_KNOWN_HOSTS:"get_ssh_known_hosts"},I1={CSV:".csv",JSON:".json"},w1={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},C1={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},Jl={};Jl[oe.INSERT]=oe.INSERT;Jl[oe.UPDATE]=oe.UPDATE;Jl[oe.UPSERT]=oe.UPSERT;Jl[oe.DELETE]=oe.DELETE;var ze=Object.create(null);ze[oe.DESCRIBE_ALL]=oe.DESCRIBE_ALL;ze[oe.DESCRIBE_TABLE]=oe.DESCRIBE_TABLE;ze[oe.DESCRIBE_SCHEMA]=oe.DESCRIBE_SCHEMA;ze[oe.READ_LOG]=oe.READ_LOG;ze[oe.ADD_NODE]=oe.ADD_NODE;ze[oe.LIST_USERS]=oe.LIST_USERS;ze[oe.LIST_ROLES]=oe.LIST_ROLES;ze[oe.USER_INFO]=oe.USER_INFO;ze[oe.SQL]=oe.SQL;ze[oe.GET_JOB]=oe.GET_JOB;ze[oe.SEARCH_JOBS_BY_START_DATE]=oe.SEARCH_JOBS_BY_START_DATE;ze[oe.DELETE_FILES_BEFORE]=oe.DELETE_FILES_BEFORE;ze[oe.EXPORT_LOCAL]=oe.EXPORT_LOCAL;ze[oe.EXPORT_TO_S3]=oe.EXPORT_TO_S3;ze[oe.CLUSTER_STATUS]=oe.CLUSTER_STATUS;ze[oe.REMOVE_NODE]=oe.REMOVE_NODE;ze[oe.RESTART]=oe.RESTART;ze[oe.CUSTOM_FUNCTIONS_STATUS]=oe.CUSTOM_FUNCTIONS_STATUS;ze[oe.GET_CUSTOM_FUNCTIONS]=oe.GET_CUSTOM_FUNCTIONS;ze[oe.GET_CUSTOM_FUNCTION]=oe.GET_CUSTOM_FUNCTION;ze[oe.SET_CUSTOM_FUNCTION]=oe.SET_CUSTOM_FUNCTION;ze[oe.DROP_CUSTOM_FUNCTION]=oe.DROP_CUSTOM_FUNCTION;ze[oe.ADD_CUSTOM_FUNCTION_PROJECT]=oe.ADD_CUSTOM_FUNCTION_PROJECT;ze[oe.DROP_CUSTOM_FUNCTION_PROJECT]=oe.DROP_CUSTOM_FUNCTION_PROJECT;ze[oe.PACKAGE_CUSTOM_FUNCTION_PROJECT]=oe.PACKAGE_CUSTOM_FUNCTION_PROJECT;ze[oe.DEPLOY_CUSTOM_FUNCTION_PROJECT]=oe.DEPLOY_CUSTOM_FUNCTION_PROJECT;ze[oe.ADD_SSH_KEY]=oe.ADD_SSH_KEY;ze[oe.UPDATE_SSH_KEY]=oe.UPDATE_SSH_KEY;ze[oe.DELETE_SSH_KEY]=oe.DELETE_SSH_KEY;var D1={DEV:"dev",RUN:"run",START:"start",INSTALL:"install",REGISTER:"register",STOP:"stop",RESTART:"restart",VERSION:"version",UPGRADE:"upgrade",HELP:"help",STATUS:"status",OPERATION:"operation",RENEWCERTS:"renew-certs",COPYDB:"copy-db"},L1={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},eN={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"},P1=ZO.invert(eN),M1={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"},D={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",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",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:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",REPLICATION:"replication",REPLICATION_HOSTNAME:"replication_hostname",REPLICATION_URL:"replication_url",REPLICATION_PORT:"replication_port",REPLICATION_SECUREPORT:"replication_securePort",REPLICATION_ROUTES:"replication_routes",REPLICATION_DATABASES:"replication_databases",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers",TLS:"tls",CLONED:"cloned"},tN={settings_path:XO.SETTINGS_PATH_KEY,hdb_root_key:D.ROOTPATH,hdb_root:D.ROOTPATH,rootpath:D.ROOTPATH,server_port_key:D.OPERATIONSAPI_NETWORK_PORT,server_port:D.OPERATIONSAPI_NETWORK_PORT,cert_key:D.TLS_CERTIFICATE,certificate:D.TLS_CERTIFICATE,private_key_key:D.TLS_PRIVATEKEY,private_key:D.TLS_PRIVATEKEY,http_secure_enabled_key:D.OPERATIONSAPI_NETWORK_HTTPS,https_on:D.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:D.OPERATIONSAPI_NETWORK_CORS,cors_on:D.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:D.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:D.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:D.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:D.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:D.LOGGING_LEVEL,log_level:D.LOGGING_LEVEL,log_path_key:D.LOGGING_ROOT,log_path:D.LOGGING_ROOT,clustering_node_name_key:D.CLUSTERING_NODENAME,node_name:D.CLUSTERING_NODENAME,clustering_enabled_key:D.CLUSTERING_ENABLED,clustering:D.CLUSTERING_ENABLED,max_http_threads:D.THREADS_COUNT,max_hdb_processes:D.THREADS_COUNT,server_timeout_key:D.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:D.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:D.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:D.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:D.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:D.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:D.LOGGING_AUDITLOG,disable_transaction_log:D.LOGGING_AUDITLOG,operation_token_timeout_key:D.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:D.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:D.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:D.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:D.HTTP_PORT,custom_functions_port:D.HTTP_PORT,custom_functions_directory_key:D.COMPONENTSROOT,custom_functions_directory:D.COMPONENTSROOT,max_custom_function_processes:D.THREADS_COUNT,log_to_file:D.LOGGING_FILE,log_to_stdstreams:D.LOGGING_STDSTREAMS,local_studio_on:D.LOCALSTUDIO_ENABLED,clustering_port:D.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:D.CLUSTERING_USER,clustering_enabled:D.CLUSTERING_ENABLED,clustering_hubserver_cluster_name:D.CLUSTERING_HUBSERVER_CLUSTER_NAME,clustering_hubserver_cluster_network_port:D.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_hubserver_cluster_network_routes:D.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,clustering_hubserver_leafnodes_network_port:D.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT,clustering_hubserver_network_port:D.CLUSTERING_HUBSERVER_NETWORK_PORT,clustering_leafserver_network_port:D.CLUSTERING_LEAFSERVER_NETWORK_PORT,clustering_leafserver_network_routes:D.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,clustering_leafserver_streams_maxage:D.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE,clustering_leafserver_streams_maxbytes:D.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES,clustering_leafserver_streams_maxconsumemsgs:D.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS,clustering_leafserver_streams_maxingestthreads:D.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS,clustering_leafserver_streams_maxmsgs:D.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS,clustering_leafserver_streams_path:D.CLUSTERING_LEAFSERVER_STREAMS_PATH,clustering_nodename:D.CLUSTERING_NODENAME,clustering_tls_certificate:D.CLUSTERING_TLS_CERTIFICATE,clustering_tls_privatekey:D.CLUSTERING_TLS_PRIVATEKEY,clustering_tls_certificateauthority:D.CLUSTERING_TLS_CERT_AUTH,clustering_tls_insecure:D.CLUSTERING_TLS_INSECURE,clustering_tls_verify:D.CLUSTERING_TLS_VERIFY,clustering_loglevel:D.CLUSTERING_LOGLEVEL,clustering_republishmessages:D.CLUSTERING_REPUBLISHMESSAGES,clustering_databaselevel:D.CLUSTERING_DATABASELEVEL,customfunctions_network_port:D.HTTP_PORT,customfunctions_tls_certificate:D.TLS_CERTIFICATE,customfunctions_network_cors:D.HTTP_CORS,customfunctions_network_corsaccesslist:D.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:D.HTTP_HEADERSTIMEOUT,customfunctions_network_https:D.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:D.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:D.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:D.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:D.HTTP_TIMEOUT,customfunctions_tls:D.TLS,http_threads:D.THREADS_COUNT,threads:D.THREADS_COUNT,threads_count:D.THREADS_COUNT,threads_debug:D.THREADS_DEBUG,threads_debug_startingport:D.THREADS_DEBUG_STARTINGPORT,threads_debug_port:D.THREADS_DEBUG_PORT,threads_debug_host:D.THREADS_DEBUG_HOST,threads_debug_waitfordebugger:D.THREADS_DEBUG_WAITFORDEBUGGER,threads_maxheapmemory:D.THREADS_MAXHEAPMEMORY,http_session_affinity:D.HTTP_SESSIONAFFINITY,http_compressionthreshold:D.HTTP_COMPRESSIONTHRESHOLD,http_cors:D.HTTP_CORS,http_corsaccesslist:D.HTTP_CORSACCESSLIST,http_headerstimeout:D.HTTP_HEADERSTIMEOUT,http_keepalivetimeout:D.HTTP_KEEPALIVETIMEOUT,http_timeout:D.HTTP_TIMEOUT,http_port:D.HTTP_PORT,http_secureport:D.HTTP_SECUREPORT,http_mtls:D.HTTP_MTLS,http_mtls_user:D.HTTP_MTLS_USER,http_mtls_required:D.HTTP_MTLS_REQUIRED,http_maxheadersize:D.HTTP_MAXHEADERSIZE,http_threadrange:D.HTTP_THREADRANGE,customfunctions_processes:D.THREADS_COUNT,customfunctions_root:D.COMPONENTSROOT,localstudio_enabled:D.LOCALSTUDIO_ENABLED,logging_file:D.LOGGING_FILE,logging_level:D.LOGGING_LEVEL,logging_root:D.LOGGING_ROOT,logging_rotation_enabled:D.LOGGING_ROTATION_ENABLED,logging_rotation_compress:D.LOGGING_ROTATION_COMPRESS,logging_rotation_interval:D.LOGGING_ROTATION_INTERVAL,logging_rotation_maxsize:D.LOGGING_ROTATION_MAXSIZE,logging_rotation_path:D.LOGGING_ROTATION_PATH,logging_stdstreams:D.LOGGING_STDSTREAMS,logging_auditlog:D.LOGGING_AUDITLOG,logging_auditretention:D.LOGGING_AUDITRETENTION,logging_auditauthevents_logfailed:D.LOGGING_AUDITAUTHEVENTS_LOGFAILED,logging_auditauthevents_logsuccessful:D.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL,operationsapi_authentication_operationtokentimeout:D.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operationsapi_authentication_refreshtokentimeout:D.AUTHENTICATION_REFRESHTOKENTIMEOUT,operationsapi_network_cors:D.OPERATIONSAPI_NETWORK_CORS,operationsapi_network_corsaccesslist:D.OPERATIONSAPI_NETWORK_CORSACCESSLIST,operationsapi_network_headerstimeout:D.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,operationsapi_network_https:D.OPERATIONSAPI_NETWORK_HTTPS,operationsapi_network_keepalivetimeout:D.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,operationsapi_network_port:D.OPERATIONSAPI_NETWORK_PORT,operationsapi_network_domainsocket:D.OPERATIONSAPI_NETWORK_DOMAINSOCKET,operationsapi_network_secureport:D.OPERATIONSAPI_NETWORK_SECUREPORT,operationsapi_tls:D.OPERATIONSAPI_TLS,operationsapi_tls_certificate:D.OPERATIONSAPI_TLS_CERTIFICATE,operationsapi_tls_privatekey:D.OPERATIONSAPI_TLS_PRIVATEKEY,operationsapi_tls_certificateauthority:D.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY,operationsapi_network_timeout:D.OPERATIONSAPI_NETWORK_TIMEOUT,operationsapi_root:D.ROOTPATH,databases:D.DATABASES,storage_path:D.STORAGE_PATH,storage_maxtransactionqueuetime:D.STORAGE_MAXTRANSACTIONQUEUETIME,ignorescripts:D.IGNORE_SCRIPTS,mqtt_network_port:D.MQTT_NETWORK_PORT,mqtt_websocket:D.MQTT_WEBSOCKET,mqtt_network_secureport:D.MQTT_NETWORK_SECUREPORT,mqtt_network_mtls:D.MQTT_NETWORK_MTLS,mqtt_network_mtls_certificateAuthority:D.MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY,mqtt_network_mtls_user:D.MQTT_NETWORK_MTLS_USER,mqtt_network_mtls_required:D.MQTT_NETWORK_MTLS_REQUIRED,mqtt_requireauthentication:D.MQTT_REQUIREAUTHENTICATION,analytics_aggregatePeriod:D.ANALYTICS_AGGREGATEPERIOD,authentication_authorizelocal:D.AUTHENTICATION_AUTHORIZELOCAL,authentication_cachettl:D.AUTHENTICATION_CACHETTL,authentication_enablesessions:D.AUTHENTICATION_ENABLESESSIONS,authentication_operationtokentimeout:D.AUTHENTICATION_OPERATIONTOKENTIMEOUT,authentication_refreshtokentimeout:D.AUTHENTICATION_REFRESHTOKENTIMEOUT,componentsroot:D.COMPONENTSROOT,replication:D.REPLICATION,replication_port:D.REPLICATION_PORT,replication_secureport:D.REPLICATION_SECUREPORT,replication_hostname:D.REPLICATION_HOSTNAME,replication_url:D.REPLICATION_URL,replication_routes:D.REPLICATION_ROUTES,tls:D.TLS,tls_certificate:D.TLS_CERTIFICATE,tls_privatekey:D.TLS_PRIVATEKEY,tls_certificateauthority:D.TLS_CERTIFICATEAUTHORITY,tls_ciphers:D.TLS_CIPHERS};for(let e in D){let t=D[e];tN[t.toLowerCase()]=t}var U1={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},v1={csv_file_load:"csv_file_load",csv_data_load:oe.CSV_DATA_LOAD,csv_url_load:oe.CSV_URL_LOAD,delete_files_before:"delete_files_before",delete_records_before:"delete_records_before",delete_audit_logs_before:"delete_audit_logs_before",delete_transaction_logs_before:"delete_transaction_logs_before",empty_trash:"empty_trash",export_local:"export_local",export_to_s3:"export_to_s3",import_from_s3:"import_from_s3",restart_service:"restart_service"},x1={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"},B1={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},H1={VERSION_DEFAULT:"2.2.0"},k1={DEVELOPMENT:8192,DEFAULT:512},F1={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"},G1={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"},q1={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},rN={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},V1=Symbol("metadata"),$1="__clustering__",Y1=Object.values(rN),K1=15984864e5,nN={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},W1=ZO.invert(nN),Q1={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"},z1=111,j1=`\r
2
+ `,J1={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},X1=["*","%"],Z1="unauthorized_access",eY="func_val",tY={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},rY={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},nY={SHUTDOWN:"shutdown",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",SCHEMA:"schema",USER:"user",CLUSTER_STATUS_RESPONSE:"cluster_status_response",CLUSTER_STATUS_REQUEST:"cluster_status_request",METRICS:"metrics",GET_METRICS:"get_metrics",RESTART:"restart",START_JOB:"start_job",NATS_CONSUMER_UPDATE:"nats_consumer_update"},sY={HDB_CORE:"hdb_core",CUSTOM_FUNCTIONS:"custom_functions"},iY={HTTP:"http"},oY={STOPPED:"stopped",ONLINE:"online"},aY="3.x.x",cY={SUCCESS:"success",FAILURE:"failure"},lY={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"};sN.exports={LOCAL_HARPERDB_OPERATIONS:ze,HDB_SUPPORT_ADDRESS:QO,HDB_SUPPORT_URL:jO,HDB_PRICING_URL:P$,SUPPORT_HELP_MSG:M$,LICENSE_HELP_MSG:JO,HDB_PROC_NAME:KO,HDB_PROC_DESCRIPTOR:Jp,CLUSTERING_LEAF_PROC_DESCRIPTOR:c_,CLUSTERING_HUB_PROC_DESCRIPTOR:a_,SYSTEM_SCHEMA_NAME:X$,HASH_FOLDER_NAME:Z$,HDB_HOME_DIR_NAME:e1,UPDATE_FILE_NAME:s1,LICENSE_KEY_DIR_NAME:r1,BOOT_PROPS_FILE_NAME:n1,JOB_TYPE_ENUM:v1,JOB_STATUS_ENUM:N1,SYSTEM_TABLE_NAMES:g1,SYSTEM_TABLE_HASH_ATTRIBUTES:R1,OPERATIONS_ENUM:oe,VALID_S3_FILE_TYPES:I1,S3_BUCKET_AUTH_KEYS:w1,VALID_SQL_OPS_ENUM:C1,GEO_CONVERSION_ENUM:L1,HDB_SETTINGS_NAMES:eN,HDB_SETTINGS_NAMES_REVERSE_LOOKUP:P1,SERVICE_ACTIONS_ENUM:D1,CLUSTER_MESSAGE_TYPE_ENUM:x1,CLUSTER_CONNECTION_DIRECTION_ENUM:B1,CLUSTER_EVENTS_DEFS_ENUM:F1,PERIOD_REGEX:F$,DOUBLE_PERIOD_REGEX:G$,UNICODE_PERIOD:q$,FORWARD_SLASH_REGEX:V$,UNICODE_FORWARD_SLASH:$$,ESCAPED_FORWARD_SLASH_REGEX:Y$,ESCAPED_PERIOD_REGEX:K$,ESCAPED_DOUBLE_PERIOD_REGEX:W$,REG_KEY_FILE_NAME:y1,RESTART_TIMEOUT_MS:a1,HDB_FILE_PERMISSIONS:c1,DATABASES_DIR_NAME:d1,LEGACY_DATABASES_DIR_NAME:f1,TRANSACTIONS_DIR_NAME:_1,LIMIT_COUNT_NAME:E1,ID_ATTRIBUTE_STRING:h1,INSERT_MODULE_ENUM:S1,UPGRADE_JSON_FIELD_NAMES_ENUM:T1,RESTART_CODE:i1,RESTART_CODE_NUM:o1,CLUSTER_OPERATIONS:Jl,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:b1,HDB_INTERNAL_SC_CHANNEL_PREFIX:_n,INTERNAL_SC_CHANNELS:A1,CLUSTERING_MESSAGE_TYPES:Q1,HDB_FILE_SUFFIX:t1,BLOB_FOLDER_NAME:l1,HDB_TRASH_DIR:u1,ORIGINATOR_SET_VALUE:z1,LICENSE_VALUES:H1,RAM_ALLOCATION_ENUM:k1,TIME_STAMP_NAMES_ENUM:rN,TIME_STAMP_NAMES:Y1,PERMS_UPDATE_RELEASE_TIMESTAMP:K1,SEARCH_NOT_FOUND_MESSAGE:U$,SEARCH_ATTRIBUTE_NOT_FOUND:v$,LICENSE_ROLE_DENIED_RESPONSE:x$,LICENSE_MAX_CONNS_REACHED:B$,BASIC_LICENSE_MAX_NON_CU_ROLES:zO,BASIC_LICENSE_CLUSTER_CONNECTION_LIMIT_WS_ERROR_CODE:L$,VALUE_SEARCH_COMPARATORS:nN,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:W1,LICENSE_FILE_NAME:O1,WEBSOCKET_CLOSE_CODE_DESCRIPTION_LOOKUP:G1,NEW_LINE:j1,BASIC_LICENSE_MAX_CLUSTER_USER_ROLES:k$,MOMENT_DAYS_TAG:Q$,API_TURNOVER_SEC:z$,LOOPBACK:H$,CODE_EXTENSION:o_,WILDCARD_SEARCH_VALUE:j$,NODE_ERROR_CODES:q1,JAVASCRIPT_EXTENSION:YO,PERMS_CRUD_ENUM:J1,UNAUTHORIZED_PERMISSION_NAME:Z1,SEARCH_WILDCARDS:X1,FUNC_VAL:eY,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:tY,JWT_ENUM:rY,CLUSTERING_FLAG:$1,ITC_EVENT_TYPES:nY,CUSTOM_FUNCTION_PROC_NAME:WO,CUSTOM_FUNCTION_PROC_DESCRIPTOR:i_,SERVICES:sY,THREAD_TYPES:iY,MEM_SETTING_KEY:J$,HDB_RESTART_SCRIPT:m$,PROCESS_DESCRIPTORS:A$,SERVICE_SERVERS:I$,SERVICE_SERVERS_CWD:jp,PROCESS_DESCRIPTORS_VALIDATE:O$,LAUNCH_SERVICE_SCRIPTS:w$,LOG_LEVELS:y$,PROCESS_NAME_ENV_PROP:m1,LOG_NAMES:b$,PM2_PROCESS_STATUSES:oY,CONFIG_PARAM_MAP:tN,CONFIG_PARAMS:D,HDB_CONFIG_FILE:_$,HDB_DEFAULT_CONFIG_FILE:E$,ROLE_TYPES_ENUM:C$,BOOT_PROP_PARAMS:XO,INSTALL_PROMPTS:p1,HDB_ROOT_DIR_NAME:h$,CLUSTERING_PROCESSES:N$,FOREGROUND_PID_FILE:T$,PACKAGE_ROOT:zi,PRE_4_0_0_VERSION:aY,DATABASES_PARAM_CONFIG:U1,METADATA_PROPERTY:V1,AUTH_AUDIT_STATUS:cY,AUTH_AUDIT_TYPES:lY,HDB_PID_FILE:g$,DEFAULT_DATABASE_NAME:R$,LEGACY_CONFIG_PARAMS:M1};$O()});var l_=I((nfe,aN)=>{"use strict";var iN=require("minimist");aN.exports=uY;function uY(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=oN(process.env),n=oN(iN(process.argv))):(r=process.env,n=iN(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(uY,"assignCMDENVVariables");function oN(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(oN,"objKeysToLowerCase")});var X=I((AN,bN)=>{"use strict";var fi=require("fs-extra"),{workerData:dY,threadId:fY,isMainThread:_Y}=require("worker_threads"),Ps=require("path"),dN=require("yaml"),fN=require("properties-reader"),Wt=B(),cN=l_(),EY=require("os"),{PACKAGE_ROOT:eS}=B(),{_assignPackageExport:hY}=require("../../index"),lN=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),At={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},_N={STDOUT:"stdOut",STDERR:"stdErr"},mY=Ps.join(eS,"logs"),pY=Ps.join(eS,"config/yaml/",Wt.HDB_DEFAULT_CONFIG_FILE),SY=1e4,Ls,Fn,nr,u_,Xl,d_,Ms,Zl;Zl===void 0&&EN();Object.assign(AN,{notify:TN,fatal:gN,error:f_,warn:RN,info:mN,debug:SN,trace:pN,setLogLevel:NY,log_level:nr,loggerWithTag:RY,suppressLogging:AY,initLogSettings:EN,logCustomLevel:yY,closeLogFile:tS,logsAtLevel:TY,getLogFilePath:()=>d_,OUTPUTS:_N,AuthAuditLog:CY});hY("logger",bN.exports);var Xp;function TY(e){return At[nr]<=At[e]}a(TY,"logsAtLevel");function EN(e=!1){try{if(Zl===void 0||e){tS();let t=OY(),r=cN(["ROOTPATH"]);try{Zl=fN(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!fi.pathExistsSync(Ps.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE)))throw n}if({level:nr,config_log_path:Xl,to_file:Ls,to_stream:Fn}=IY(r.ROOTPATH?Ps.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE):Zl.get("settings_path")),u_=Wt.LOG_NAMES.HDB,d_=Ps.join(Xl,u_),_Y)try{require("segfault-handler").registerHandler(Ps.join(Xl,"crash.log"))}catch{}}}catch(t){if(Zl=void 0,t.code===Wt.NODE_ERROR_CODES.ENOENT||t.code===Wt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=cN(Object.keys(Wt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Wt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Wt.CONFIG_PARAMS.LOGGING_LEVEL){nr=l;continue}if(c===Wt.CONFIG_PARAMS.LOGGING_STDSTREAMS){Fn=l;continue}c===Wt.CONFIG_PARAMS.LOGGING_FILE&&(Ls=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=wY();Ls=Ls===void 0?s:Ls,Ls=uN(Ls),Fn=Fn===void 0?i:Fn,Fn=uN(Fn),nr=nr===void 0?n:nr,Xl=mY,u_=Wt.LOG_NAMES.INSTALL,d_=Ps.join(Xl,u_);return}throw f_("Error initializing log settings"),f_(t),t}process.env.DEV_MODE&&(Fn=!0),gY()}a(EN,"initLogSettings");var ji=!0;function gY(){Ls&&(process.stdout.write=function(e){return typeof e=="string"&&Ms&&ji&&At[nr]<=At.info&&(Zp(),e=e.toString(),e[e.length-1]===`
3
+ `&&(e=e.slice(0,-1)),fi.appendFileSync(Ms,cs("info",[e]))),lN.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&Ms&&ji&&At[nr]<=At.error&&(Zp(),e[e.length-1]===`
4
+ `&&(e=e.slice(0,-1)),fi.appendFileSync(Ms,cs("error",[e]))),lN.apply(process.stderr,arguments)})}a(gY,"stdioLogging");function RY(e,t){let r={tagName:e.replace(/ /g,"-")};return{notify:n(TN,"notify"),fatal:n(gN,"fatal"),error:n(f_,"error"),warn:n(RN,"warn"),info:n(mN,"info"),debug:n(SN,"debug"),trace:n(pN,"trace")};function n(s,i){return!t||At[nr]<=At[i]?function(...o){return s(r,...o)}:null}}a(RY,"loggerWithTag");function AY(e){try{ji=!1,e()}finally{ji=!0}}a(AY,"suppressLogging");var bY=dY?.name?.replace(/ /g,"-")||"main";function cs(e,t){let r=new Date(Date.now()).toISOString(),n="",s=t.length,i=s-1,o=[e],c=0,l;for(typeof t[0]=="object"&&(t[0]?.tagName?(o.push(t[0]?.tagName),c++):t[0]?.serviceName&&(l=t[0]?.serviceName,c++)),o.unshift(l||bY+"/"+fY);c<s;c++){let d=t[c];d instanceof Error&&d.stack?n+=d.stack:typeof d=="object"?n+=JSON.stringify(d):n+=d,c<i&&(n+=" ")}return`${r} [${o.join("] [")}]: ${n}
5
+ `}a(cs,"createLogRecord");function eu(e){if(Ls){if(hN(e),Fn){ji=!1;try{process.stdout.write(e)}finally{ji=!0}}}else Fn&&process.stdout.write(e)}a(eu,"logStdOut");function __(e){if(Ls){if(hN(e),Fn){ji=!1;try{process.stderr.write(e)}finally{ji=!0}}}else Fn&&process.stderr.write(e)}a(__,"logStdErr");function hN(e){Zp(),Ms?fi.appendFileSync(Ms,e):Xp||console.log(e)}a(hN,"logToFile");function tS(){try{fi.closeSync(Ms)}catch{}Ms=null}a(tS,"closeLogFile");function Zp(){if(!Ms){try{Ms=fi.openSync(d_,"a")}catch(e){Xp||(Xp=!0,console.error(e))}setTimeout(()=>{tS()},SY).unref()}}a(Zp,"openLogFile");function mN(...e){At[nr]<=At.info&&eu(cs("info",e))}a(mN,"info");function pN(...e){At[nr]<=At.trace&&eu(cs("trace",e))}a(pN,"trace");function f_(...e){At[nr]<=At.error&&__(cs("error",e))}a(f_,"error");function SN(...e){At[nr]<=At.debug&&eu(cs("debug",e))}a(SN,"debug");function TN(...e){At[nr]<=At.notify&&eu(cs("notify",e))}a(TN,"notify");function gN(...e){At[nr]<=At.fatal&&__(cs("fatal",e))}a(gN,"fatal");function RN(...e){At[nr]<=At.warn&&__(cs("warn",e))}a(RN,"warn");function yY(e,t,...r){t===_N.STDERR?__(cs(e,r)):eu(cs(e,r))}a(yY,"logCustomLevel");function OY(){let e;try{e=EY.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=Ps.join(e,Wt.HDB_HOME_DIR_NAME,Wt.BOOT_PROPS_FILE_NAME);return fi.existsSync(t)||(t=Ps.join(eS,"utility/hdb_boot_properties.file")),t}a(OY,"getPropsFilePath");function NY(e){nr=e}a(NY,"setLogLevel");function uN(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(uN,"autoCastBoolean");function IY(e){try{if(e.includes("config/settings.js")){let o=fN(e);return{level:o.get(Wt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:Ps.dirname(o.get(Wt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=dN.parseDocument(fi.readFileSync(e,"utf8")),r=t.getIn(["logging","level"]),n=t.getIn(["logging","root"]),s=t.getIn(["logging","file"]),i=t.getIn(["logging","stdStreams"]);return{level:r,config_log_path:n,to_file:s,to_stream:i}}catch(t){if(t.code===Wt.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(IY,"getLogConfig");function wY(){try{let e=dN.parseDocument(fi.readFileSync(pY,"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(wY,"getDefaultConfig");function CY(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(CY,"AuthAuditLog")});var ON=I((ofe,yN)=>{"use strict";var DY=require("util"),LY=require("path"),PY=require("child_process"),MY=DY.promisify(PY.execFile),UY=1e3*1e3*10;yN.exports={findPs:vY};async function vY(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await MY("ps",["wwxo",`pid,${r}`],{maxBuffer:UY});for(let s of n.trim().split(`
6
+ `).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:LY.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(vY,"findPs")});var Ft=I((cfe,IN)=>{"use strict";var xY="__dbis__",BY="__txns__",HY="__environment_name__",kY="__dbi_defintion__",FY={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"},GY=["__createdtime__","__updatedtime__"],qY="\uFFFF",NN={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},VY=Object.values(NN);IN.exports={AUDIT_STORE_NAME:BY,INTERNAL_DBIS_NAME:xY,DBI_DEFINITION_NAME:kY,SEARCH_TYPES:FY,TIMESTAMP_NAMES:GY,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:HY,TRANSACTIONS_DBI_NAMES_ENUM:NN,TRANSACTIONS_DBIS:VY,OVERFLOW_MARKER:qY}});var En=I((lfe,xN)=>{"use strict";var wN=B(),CN=Ft(),DN={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},LN=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),PN={500:LN("There was an error processing your request."),400:"Invalid request"},$Y=PN[DN.INTERNAL_SERVER_ERROR],YY={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.`},KY={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},WY={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"},QY={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 ${CN.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${CN.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"},zY={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${wN.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 ${wN.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"},MN={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"},jY={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."},JY={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`},XY={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"},ZY={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},eK={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`},UN={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.`},vN={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}`},tK={FUNCTION_STATUS:"Error getting custom function status, check the log for more details",GET_FUNCTIONS:"Error getting custom functions, check the log for more details",GET_FUNCTION:"Error getting custom function, check the log for more details",SET_FUNCTION:"Error setting custom function, check the log for more details",NO_PROJECT:"Project does not exist. Create one using 'add_custom_function_project'",PROJECT_EXISTS:"Project already exists",VALIDATION_ERR:"Error validating request, check the log for more details",NO_FILE:"File does not exist",BAD_FILE_NAME:"File name can only contain alphanumeric, dash and underscore characters",BAD_PROJECT_NAME:"Project name can only contain alphanumeric, dash and underscores characters",BAD_PACKAGE:"Packaged project must be base64-encoded tar file of project directory",DROP_FUNCTION:"Error dropping custom function, check the log for more details",ADD_FUNCTION:"Error adding custom function project, check the log for more details",DROP_FUNCTION_PROJECT:"Error dropping custom function project, check the log for more details",BAD_FILE_PATH:"Filepath must be valid, and contain the name of the tarball you wish to write",NOT_ENABLED:"Custom functions is not enabled, to enable set fastifyRoutes enabled to true in hdb/harperdb-config.yaml file.",BAD_SSH_KEY_NAME:"SSH key name can only contain alphanumeric, dash and underscore characters"},rK={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},nK={...MN,...WY,...YY,...jY,...JY,...XY,...ZY,...eK,...zY,...UN,...vN,...tK,...rK,...KY};xN.exports={CHECK_LOGS_WRAPPER:LN,HDB_ERROR_MSGS:nK,DEFAULT_ERROR_MSGS:PN,DEFAULT_ERROR_RESP:$Y,HTTP_STATUS_CODES:DN,LMDB_ERRORS_ENUM:QY,AUTHENTICATION_ERROR_MSGS:MN,VALIDATION_ERROR_MSGS:UN,ITC_ERRORS:vN}});var ce=I((dfe,kN)=>{"use strict";var ic=En(),sK=X(),iK=B(),E_=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,BN),this.statusCode=n||ic.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(ic.DEFAULT_ERROR_MSGS[n]?ic.DEFAULT_ERROR_MSGS[n]:ic.DEFAULT_ERROR_MSGS[ic.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&&sK[s](i)}},rS=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}},nS=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function BN(e,t,r,n=iK.LOG_LEVELS.ERROR,s=null,i=!1){if(HN(e))return e;let o=new E_(e,t,r,n,s);return i&&delete o.stack,o}a(BN,"handleHDBError");function HN(e){return e.__proto__.constructor.name===E_.name}a(HN,"isHDBError");kN.exports={isHDBError:HN,handleHDBError:BN,ClientError:rS,ServerError:nS,hdb_errors:ic}});var sS=I(FN=>{"use strict";var oK={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
7
+ `),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
8
+ `)},aK="certificate.pem",cK="privateKey.pem",lK="caCertificate.pem",uK="natsCertificate.pem",dK="natsCaCertificate.pem",ht={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},fK={tls_certificate:ht.SERVER,tls_certificateAuthority:ht.CA,customFunctions_tls_certificate:ht.SERVER,customFunctions_tls_certificateAuthority:ht.CA,operationsApi_tls_certificate:ht["OPERATIONS-API"],operationsApi_tls_certificateAuthority:ht["OPERATIONS-CA"]},_K={[ht.SERVER]:2,[ht.DEFAULT]:1},EK={[ht["OPERATIONS-API"]]:3,[ht.SERVER]:2,[ht.DEFAULT]:1},hK={[ht["OPERATIONS-API"]]:3,[ht.SERVER]:2,[ht.DEFAULT]:1},mK={[ht["OPERATIONS-CA"]]:3,[ht.CA]:2,[ht["DEFAULT-CA"]]:1},pK={[ht["OPERATIONS-CA"]]:3,[ht.CA]:2,[ht["DEFAULT-CA"]]:1},SK={[ht.CA]:2,[ht["DEFAULT-CA"]]:1};Object.assign(FN,{CERTIFICATE_PEM_NAME:aK,PRIVATEKEY_PEM_NAME:cK,CA_PEM_NAME:lK,CERT_NAME:ht,CERT_CONFIG_NAME_MAP:fK,CERT_PREFERENCE_APP:_K,CERT_PREFERENCE_OPS:EK,CERT_PREFERENCE_REP:hK,CA_CERT_PREFERENCE_REP:mK,CA_CERT_PREFERENCE_OPS:pK,CA_CERT_PREFERENCE_APP:SK,CERTIFICATE_VALUES:oK,NATS_CERTIFICATE_PEM_NAME:uK,NATS_CA_PEM_NAME:dK})});var mt=I((Efe,GN)=>{"use strict";var qr=require("validate.js");qr.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||qr.validators.type.checks[t](e)?null:` must be a '${t}' value`};qr.validators.type.checks={Object:function(e){return qr.isObject(e)&&!qr.isArray(e)},Array:qr.isArray,Integer:qr.isInteger,Number:qr.isNumber,String:qr.isString,Date:qr.isDate,Boolean:function(e){return typeof e=="boolean"}};qr.validators.hasValidFileExt=function(e,t){return qr.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};GN.exports={validateObject:TK,validateObjectAsync:gK,validateBySchema:RK};function TK(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=qr(e,t,{format:"flat"});return r?new Error(r):null}a(TK,"validateObject");async function gK(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await qr.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(gK,"validateObjectAsync");function RK(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(RK,"validateBySchema")});var oS=I((pfe,WN)=>{"use strict";var YN=require("fs-extra"),de=require("joi"),AK=require("os"),{boolean:Ge,string:pt,number:bt,array:ru}=de.types(),{totalmem:qN}=require("os"),ko=require("path"),bK=X(),iS=te(),mfe=sS(),VN=B(),yK=mt(),$N="log",OK="components",NK="Invalid logging.rotation.maxSize unit. Available units are G, M or K",IK="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",wK="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",CK="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",DK="rootPath config parameter is undefined",Ji=de.alternatives([bt.min(0),pt]).required(),h_=de.alternatives([ru.items(pt,{host:pt.required(),port:Ji},{hostname:pt.required(),port:Ji}).empty(null),ru.items(pt)]),Us,KN=!1;WN.exports={configValidator:LK,routesValidator:BK,route_constraints:h_};function LK(e,t=!1){if(KN=t,Us=e.rootPath,iS.isEmpty(Us))throw DK;let r=Ge.optional(),n=bt.min(0).max(1e3).empty(null).default(xK),s=pt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(tu),i=pt.optional().empty(null),o=pt.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=de.string().empty(null).default(tu),l=de.custom(MK).empty(null).default(tu),d=e.clustering?.enabled,u=de.object({certificate:i,certificateAuthority:i,privateKey:i}),f;return d===!0?f=de.object({enabled:r,hubServer:de.object({cluster:de.object({name:de.required().empty(null),network:de.object({port:Ji,routes:h_}).required()}).required(),leafNodes:de.object({network:de.object({port:Ji}).required()}).required(),network:de.object({port:Ji}).required()}).required(),leafServer:de.object({network:de.object({port:Ji,routes:h_}).required(),streams:de.object({maxAge:bt.min(120).allow(null).optional(),maxBytes:bt.min(1).allow(null).optional(),maxMsgs:bt.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:de.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:Ge.optional(),databaseLevel:Ge.optional(),tls:de.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Ge.required(),verify:Ge.optional()}),user:pt.optional().empty(null)}).optional():f=de.object({enabled:r,tls:de.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Ge.optional()})}).optional(),de.object({authentication:de.object({authorizeLocal:Ge,cacheTTL:bt.required(),enableSessions:Ge}),analytics:de.object({aggregatePeriod:bt}),componentsRoot:s.optional(),clustering:f,localStudio:de.object({enabled:r}).required(),logging:de.object({auditAuthEvents:de.object({logFailed:Ge,logSuccessful:Ge}),file:Ge.required(),level:de.valid("notify","fatal","error","warn","info","debug","trace"),rotation:de.object({enabled:Ge.optional(),compress:Ge.optional(),interval:pt.custom(vK).optional().empty(null),maxSize:pt.custom(UK).optional().empty(null),path:pt.optional().empty(null).default(tu)}).required(),root:s,stdStreams:Ge.required(),auditLog:Ge.required()}).required(),operationsApi:de.object({network:de.object({cors:Ge.optional(),corsAccessList:ru.optional(),headersTimeout:bt.min(1).optional(),keepAliveTimeout:bt.min(1).optional(),port:de.alternatives([bt.min(0),pt]).optional().empty(null),domainSocket:de.optional().empty("hdb/operations-server").default(tu),securePort:de.alternatives([bt.min(0),pt]).optional().empty(null),timeout:bt.min(1).optional()}).optional(),tls:de.alternatives([de.array().items(u),u])}).required(),rootPath:pt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:de.object({network:de.object({port:Ji,securePort:Ji,mtls:de.alternatives([Ge.optional(),de.object({user:pt.optional(),certificateAuthority:i,required:Ge.optional()})])}).required(),webSocket:Ge.optional(),requireAuthentication:Ge.optional()}),http:de.object({compressionThreshold:bt.optional(),cors:Ge.optional(),corsAccessList:ru.optional(),headersTimeout:bt.min(1).optional(),port:de.alternatives([bt.min(0),pt]).optional().empty(null),securePort:de.alternatives([bt.min(0),pt]).optional().empty(null),maxHeaderSize:bt.optional(),mtls:de.alternatives([Ge.optional(),de.object({user:pt.optional(),certificateAuthority:i,required:Ge.optional()})]),threadRange:de.alternatives([ru.optional(),pt.optional()])}).required(),threads:de.alternatives(n.optional(),de.object({count:n.optional(),debug:de.alternatives(Ge.optional(),de.object({startingPort:bt.min(1).optional(),host:pt.optional(),waitForDebugger:Ge.optional()})),maxHeapMemory:bt.min(0).optional()})),storage:de.object({writeAsync:Ge.required(),overlappingSync:Ge.optional(),caching:Ge.optional(),compression:de.alternatives([Ge.optional(),de.object({dictionary:pt.optional(),threshold:bt.optional()})]),compactOnStart:Ge.optional(),compactOnStartKeepBackup:Ge.optional(),noReadAhead:Ge.optional(),path:l,prefetchWrites:Ge.optional(),maxFreeSpaceToLoad:bt.optional(),maxFreeSpaceToRetain:bt.optional()}).required(),ignoreScripts:Ge.optional(),tls:de.alternatives([de.array().items(u),u])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(LK,"configValidator");function PK(e){return KN||YN.existsSync(e)?null:`Specified path ${e} does not exist.`}a(PK,"doesPathExist");function MK(e,t){de.assert(e,pt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=PK(e);if(r)return t.message(r)}a(MK,"validatePath");function UK(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(NK);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(wK):e}a(UK,"validateRotationMaxSize");function vK(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(IK);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(CK):e}a(vK,"validateRotationInterval");function xK(e,t){let r=t.state.path.join("."),n=AK.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||qN();return i=Math.round(Math.min(i,qN())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),bK.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(xK,"setDefaultThreads");function tu(e,t){let r=t.state.path.join(".");if(!iS.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(iS.isEmpty(Us))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return ko.join(Us,OK);case"logging.root":return ko.join(Us,$N);case"clustering.leafServer.streams.path":return ko.join(Us,"clustering","leaf");case"storage.path":let n=ko.join(Us,VN.LEGACY_DATABASES_DIR_NAME);return YN.existsSync(n)?n:ko.join(Us,VN.DATABASES_DIR_NAME);case"logging.rotation.path":return ko.join(Us,$N);case"operationsApi.network.domainSocket":return r==null?null:ko.join(Us,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(tu,"setDefaultRoot");function BK(e){let t=de.object({routes:h_});return yK.validateBySchema({routes:e},t)}a(BK,"routesValidator")});var Fo={};Ze(Fo,{server:()=>st});var QN,st,Lr=Oe(()=>{QN=require("../../index"),st={};(0,QN._assignPackageExport)("server",st)});var dr=I((Tfe,sI)=>{"use strict";var Vr=B(),sr=te(),ir=X(),{configValidator:HK,routesValidator:zN}=oS(),Pr=require("fs-extra"),JN=require("yaml"),mn=require("path"),kK=require("is-number"),XN=require("properties-reader"),FK=require("lodash"),{handleHDBError:GK}=ce(),{HTTP_STATUS_CODES:qK,HDB_ERROR_MSGS:oc}=En(),{server:VK}=(Lr(),ae(Fo)),{DATABASES_PARAM_CONFIG:nu,CONFIG_PARAMS:hn,CONFIG_PARAM_MAP:ls}=Vr,$K="Unable to get config value because config is uninitialized",YK="Config successfully initialized",KK="Error backing up config file",WK="Empty parameter sent to getConfigValue",ZN=mn.join(Vr.PACKAGE_ROOT,"config","yaml",Vr.HDB_DEFAULT_CONFIG_FILE),QK=mn.join(Vr.PACKAGE_ROOT,"config","yaml","defaultNatsConfig.yaml"),zK="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",jN={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"},m_,or,p_;sI.exports={createConfigFile:jK,getDefaultConfig:JK,getConfigValue:tI,initConfig:lS,flattenConfig:ac,updateConfigValue:rI,updateConfigObject:ZK,getConfiguration:rW,setConfiguration:nW,readConfigFile:dS,getClusteringRoutes:sW,initOldConfig:nI,getConfigFromFile:iW,getConfigFilePath:Go,addConfig:oW,deleteConfigFromFile:aW,getConfigObj:cW,resolvePath:aS};function aS(e){if(e?.startsWith("~/"))return mn.join(sr.getHomeDir(),e.slice(1));let t=ie();return mn.resolve(t.getHdbBasePath(),e)}a(aS,"resolvePath");function jK(e,t=!1){let r=Xi(ZN);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=JN.parseDocument(Pr.readFileSync(QK,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}m_=ac(r.toJSON());let n;for(let c in e){let l=ls[c.toLowerCase()];if(l===hn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(d=>({[d]:e[c][d]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let d=l.split("_"),u=cS(l,e[c]);l==="rootPath"&&u?.endsWith("/")&&(u=u.slice(0,-1));try{r.setIn([...d],u)}catch(f){ir.error(f)}}}n&&eI(r,n),uS(r,t);let s=r.toJSON();or=ac(s);let i=r.getIn(["rootPath"]),o=mn.join(i,Vr.HDB_CONFIG_FILE);Pr.createFileSync(o),Pr.writeFileSync(o,String(r)),ir.trace(`Config file written to ${o}`)}a(jK,"createConfigFile");function eI(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!sr.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(nu.TABLES))for(let i in n[s][nu.TABLES])for(let o in n[s][nu.TABLES][i]){let c=n[s][nu.TABLES][i][o],l=[hn.DATABASES,s,nu.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[hn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){ir.error("Error parsing schemas CLI/env config arguments",n)}}a(eI,"setSchemasConfig");function JK(e){if(m_===void 0){let r=Xi(ZN);m_=ac(r.toJSON())}let t=ls[e.toLowerCase()];if(t!==void 0)return m_[t.toLowerCase()]}a(JK,"getDefaultConfig");function tI(e){if(e==null){ir.info(WK);return}if(or===void 0){ir.trace($K);return}let t=ls[e.toLowerCase()];if(t!==void 0)return or[t.toLowerCase()]}a(tI,"getConfigValue");function Go(e=sr.getPropsFilePath()){let t=sr.getEnvCliRootPath();if(t)return aS(mn.join(t,Vr.HDB_CONFIG_FILE));let r=XN(e);return aS(r.get(Vr.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Go,"getConfigFilePath");function lS(e=!1){if(or===void 0||e){let t;if(!sr.noBootFile()){t=sr.getPropsFilePath();try{Pr.accessSync(t,Pr.constants.F_OK|Pr.constants.R_OK)}catch(i){throw ir.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Go(t),n;if(r.includes("config/settings.js"))try{nI(r);return}catch(i){if(i.code!==Vr.NODE_ERROR_CODES.ENOENT)throw i}try{n=Xi(r)}catch(i){if(i.code===Vr.NODE_ERROR_CODES.ENOENT){ir.trace(`HarperDB config file not found at ${r}.
9
+ This can occur during early stages of install where the config file has not yet been created`);return}else throw ir.error(i),new Error(`Error reading HarperDB config file at ${r}`)}XK(n,r),uS(n);let s=n.toJSON();if(VK.config=s,or=ac(s),or.logging_rotation_rotate)for(let i in jN)or[i]&&ir.error(`Config ${jN[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);ir.trace(YK)}}a(lS,"initConfig");function XK(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],mn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],mn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n&&(ir.trace("Updating config file with missing config params"),Pr.writeFileSync(t,String(e)))}a(XK,"checkForUpdatedConfig");function uS(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw oc.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw oc.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=HK(r,t);if(n.error)throw oc.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(uS,"validateConfig");function ZK(e,t){or===void 0&&(or={});let r=ls[e.toLowerCase()];if(r===void 0){ir.trace(`Unable to update config object because config param '${e}' does not exist`);return}or[r.toLowerCase()]=t}a(ZK,"updateConfigObject");function rI(e,t,r=void 0,n=!1,s=!1,i=!1){or===void 0&&lS();let o=tI(ls.hdb_root),c=mn.join(o,Vr.HDB_CONFIG_FILE),l=Xi(c),d;if(r===void 0&&e.toLowerCase()===hn.DATABASES)d=t;else if(r===void 0){let E;if(i)E=e;else if(E=ls[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let _=E.split("_"),h=cS(E,t);l.setIn([..._],h)}else for(let E in r){let _=ls[E.toLowerCase()];if(_===hn.HTTP_SECUREPORT&&r[E]===or[hn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),_===hn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===or[hn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),_===hn.DATABASES){d=r[E];continue}if(_?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!_&&(E.endsWith("_package")||E.endsWith("_port"))&&(_=E),_!==void 0){let h=_.split("_"),p=Vr.LEGACY_CONFIG_PARAMS[E.toUpperCase()];p&&p.startsWith("customFunctions")&&l.hasIn(p.split("_"))&&(_=p,h=p.split("_"));let S=cS(_,r[E]);_==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],S)}catch(g){ir.error(g)}}}d&&eI(l,d),uS(l);let u=l.getIn(["rootPath"]),f=mn.join(u,Vr.HDB_CONFIG_FILE);n===!0&&eW(c,u),Pr.writeFileSync(f,String(l)),s&&(or=ac(l.toJSON())),ir.trace(`Config parameter: ${e} updated with value: ${t}`)}a(rI,"updateConfigValue");function eW(e,t){try{let r=mn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${Vr.HDB_CONFIG_FILE}.bak`);Pr.copySync(e,r),ir.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){ir.error(KK),ir.error(r)}}a(eW,"backupConfigFile");var tW=["databases"];function ac(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)),p_=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])&&!tW.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!hn[l.toUpperCase()]&&ls[l]&&(s[ls[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(ac,"flattenConfig");function cS(e,t){if(e===hn.CLUSTERING_NODENAME||e===hn.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(kK(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||sr.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return sr.autoCast(t)}a(cS,"castConfigValue");function rW(){let e=sr.getPropsFilePath(),t=Go(e);return Xi(t).toJSON()}a(rW,"getConfiguration");async function nW(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return rI(void 0,void 0,s,!0),zK}catch(i){throw typeof i=="string"||i instanceof String?GK(i,i,qK.BAD_REQUEST,void 0,void 0,!0):i}}a(nW,"setConfiguration");function dS(){let e=sr.getPropsFilePath();try{Pr.accessSync(e,Pr.constants.F_OK|Pr.constants.R_OK)}catch(n){if(!sr.noBootFile())throw ir.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Go(e);return Xi(t).toJSON()}a(dS,"readConfigFile");function Xi(e){return JN.parseDocument(Pr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Xi,"parseYamlDoc");function sW(){let e=dS(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=sr.isEmptyOrZeroLength(t)?[]:t;let r=zN(t);if(r)throw oc.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=sr.isEmptyOrZeroLength(n)?[]:n;let s=zN(n);if(s)throw oc.CONFIG_VALIDATION(s.message);if(!sr.isEmptyOrZeroLength(n)&&!sr.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!sr.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw oc.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(sW,"getClusteringRoutes");function nI(e){let t=XN(e);or={};for(let r in ls){let n=t.get(r.toUpperCase());if(sr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ls[r].toLowerCase();s===hn.LOGGING_ROOT?or[s]=mn.dirname(n):or[s]=n}return or}a(nI,"initOldConfig");function iW(e){let t=dS();return FK.get(t,e.replaceAll("_","."))}a(iW,"getConfigFromFile");async function oW(e,t){let r=Xi(Go());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await Pr.writeFile(Go(),String(r))}a(oW,"addConfig");function aW(e){let t=Go(sr.getPropsFilePath()),r=Xi(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=mn.join(n,Vr.HDB_CONFIG_FILE);Pr.writeFileSync(s,String(r))}a(aW,"deleteConfigFromFile");function cW(){return p_||(lS(),p_)}a(cW,"getConfigObj")});var ie=I((lI,uI)=>{"use strict";var fS=require("fs-extra"),qo=require("path"),iI=require("os"),lW=require("properties-reader"),iu=X(),su=te(),be=B(),S_=dr(),uW="Error initializing environment manager",T_="BOOT_PROPS_FILE_PATH",oI=!1,dW={[be.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[be.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[be.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},_i={};Object.assign(lI,uI.exports={BOOT_PROPS_FILE_PATH:T_,getHdbBasePath:fW,setHdbBasePath:_W,get:aI,initSync:hW,setProperty:$e,initTestEnvironment:pW,setCloneVar:mW});function fW(){return _i[be.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(fW,"getHdbBasePath");function _W(e){_i[be.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(_W,"setHdbBasePath");function aI(e){let t=S_.getConfigValue(e);return t===void 0?_i[e]:t}a(aI,"get");function $e(e,t){dW[e]&&(_i[e]=t),S_.updateConfigObject(e,t)}a($e,"setProperty");function EW(){let e;try{e=su.getPropsFilePath(),fS.accessSync(e,fS.constants.F_OK|fS.constants.R_OK),oI=!0;let t=lW(e);return _i[be.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(be.HDB_SETTINGS_NAMES.INSTALL_USER),_i[be.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(be.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),_i[T_]=e,!0}catch{return iu.trace(`Environment manager found no properties file at ${e}`),!1}}a(EW,"doesPropFileExist");function hW(e=!1){try{(oI||EW()||su.noBootFile())&&!cI&&(S_.initConfig(e),_i[be.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=S_.getConfigValue(be.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){iu.error(uW),iu.error(t),console.error(t),process.exit(1)}}a(hW,"initSync");var cI=!1;function mW(e){cI=e}a(mW,"setCloneVar");function pW(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=qo.join(__dirname,"../../","unitTests");_i[T_]=qo.join(l,"hdb_boot_properties.file"),$e(be.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,qo.join(l,"settings.test")),$e(be.HDB_SETTINGS_NAMES.INSTALL_USER,iI.userInfo()?iI.userInfo().username:void 0),$e(be.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),$e(be.HDB_SETTINGS_NAMES.LOG_PATH_KEY,qo.join(l,"envDir","log")),$e(be.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),$e(be.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),$e(be.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),$e(be.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,qo.join(l,"envDir")),$e(be.CONFIG_PARAMS.STORAGE_PATH,qo.join(l,"envDir")),s&&($e(be.CONFIG_PARAMS.HTTP_SECUREPORT,aI(be.CONFIG_PARAMS.HTTP_PORT)),$e(be.CONFIG_PARAMS.HTTP_PORT,null)),$e(be.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),$e(be.CONFIG_PARAMS.HTTP_PORT,9926),$e(be.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),$e(be.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),$e(be.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,su.isEmpty(i)?!1:i),$e(be.CONFIG_PARAMS.HTTP_CORS,su.isEmpty(i)?!1:i),$e(be.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),$e(be.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),$e(be.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),$e(be.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),$e(be.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,qo.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),$e(be.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,su.isEmpty(c)?!1:c),o&&($e("CORS_ACCESSLIST",o),$e(be.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&($e(be.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),$e(be.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&($e(be.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),$e(be.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&($e(be.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),$e(be.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${T_}. Please check your boot props and settings files`;iu.fatal(r),iu.error(t)}}a(pW,"initTestEnvironment")});var St=I((Afe,pI)=>{"use strict";var uu=B(),SW=te(),$r=ie(),du=require("path"),TW=require("minimist"),dI=require("fs-extra"),fI=require("lodash");$r.initSync();var{CONFIG_PARAMS:Zi,DATABASES_PARAM_CONFIG:ou,SYSTEM_SCHEMA_NAME:g_}=uu,au,cu,lu;function _I(){if(au!==void 0)return au;if($r.getHdbBasePath()!==void 0)return au=$r.get(Zi.STORAGE_PATH)||du.join($r.getHdbBasePath(),uu.DATABASES_DIR_NAME),au}a(_I,"getBaseSchemaPath");function EI(){if(cu!==void 0)return cu;if($r.getHdbBasePath()!==void 0)return cu=mI(g_),cu}a(EI,"getSystemSchemaPath");function hI(){if(lu!==void 0)return lu;if($r.getHdbBasePath()!==void 0)return lu=$r.get(uu.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||du.join($r.getHdbBasePath(),uu.TRANSACTIONS_DIR_NAME),lu}a(hI,"getTransactionAuditStoreBasePath");function gW(e,t){let r=$r.get(Zi.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||du.join(hI(),e.toString())}a(gW,"getTransactionAuditStorePath");function mI(e,t){e=e.toString(),t=t&&t.toString();let r=$r.get(uu.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||du.join(_I(),e)}a(mI,"getSchemaPath");function RW(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,TW(process.argv));let n=r[Zi.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!SW.isObject(n))throw o;i=n}for(let o of i){let c=o[g_];if(!c)continue;let l=$r.get(Zi.DATABASES);l=l??{};let d=c?.tables?.[t]?.[ou.PATH];if(d)return fI.set(l,[g_,ou.TABLES,t,ou.PATH],d),$r.setProperty(Zi.DATABASES,l),d;let u=c?.[ou.PATH];if(u)return fI.set(l,[g_,ou.PATH],u),$r.setProperty(Zi.DATABASES,l),u}}let s=r[Zi.STORAGE_PATH.toUpperCase()];if(s){if(!dI.pathExistsSync(s))throw new Error(s+" does not exist");let i=du.join(s,e);return dI.mkdirsSync(i),$r.setProperty(Zi.STORAGE_PATH,s),i}return EI()}a(RW,"initSystemSchemaPaths");function AW(){au=void 0,cu=void 0,lu=void 0}a(AW,"resetPaths");pI.exports={getBaseSchemaPath:_I,getSystemSchemaPath:EI,getTransactionAuditStorePath:gW,getTransactionAuditStoreBasePath:hI,getSchemaPath:mI,initSystemSchemaPaths:RW,resetPaths:AW}});var pn=I((Nfe,AI)=>{"use strict";var bW=En().LMDB_ERRORS_ENUM,yfe=require("lmdb"),yW=Ft(),Ofe=require("buffer").Buffer,{OVERFLOW_MARKER:SI,MAX_SEARCH_KEY_LENGTH:R_}=yW,TI=["number","string","symbol","boolean","bigint"];function OW(e){if(e=e?.primaryStore||e,!e)throw new Error(bW.ENV_REQUIRED)}a(OW,"validateEnv");function NW(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(NW,"stringifyData");function IW(e){return e instanceof Date?e.valueOf():e}a(IW,"convertKeyValueToWrite");function wW(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(TI.includes(typeof e))return e.length>R_?[e.slice(0,R_)+SI]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(TI.includes(typeof i))i.length>R_?r.push(i.slice(0,R_)+SI):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(wW,"getIndexedValues");var A_=0,gI=0;function RI(){gI=Date.now()-performance.now()}a(RI,"adjustStartTime");RI();var CW=6e4;setInterval(RI,CW).unref();function DW(){let e=performance.now()+gI;return e>A_?(A_=e,e):(A_+=488e-6,A_)}a(DW,"getNextMonotonicTime");AI.exports={validateEnv:OW,stringifyData:NW,convertKeyValueToWrite:IW,getNextMonotonicTime:DW,getIndexedValues:wW}});var bI,Sn,_S,cc=Oe(()=>{bI=require("events"),Sn=class extends bI.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;[Symbol.asyncIterator](){let t=new _S;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)}},_S=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 mS={};Ze(mS,{loadGQLSchema:()=>MW,start:()=>hS,startOnMainThread:()=>PW});function hS({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:d,StringValueNode:u}=await import("graphql"),f=o(new c(r.toString(),s)),E=new Map,_=[],h;for(let g of f.definitions)switch(g.kind){case l.OBJECT_TYPE_DEFINITION:let v=function($){if($.kind==="NonNullType"){let ee=v($.type);return ee.nullable=!1,ee}if($.kind==="ListType")return{type:"array",elements:v($.type)};let ne={type:$.name?.value};return Object.defineProperty(ne,"location",{value:$.loc.startToken}),ne};a(v,"getProperty");let T=g.name.value,A=[],N={table:null,database:null,properties:A};E.set(T,N);for(let $ of g.directives){if($.name.value==="table"){for(let ne of $.arguments)N[ne.name.value]=ne.value.value;N.schema&&(N.database=N.schema),N.table||(N.table=T),N.audit&&(N.audit=N.audit!=="false"),N.attributes=N.properties,_.push(N)}if($.name.value==="sealed"&&(N.sealed=!0),$.name.value==="replicate"&&(N.replicate=!0),$.name.value==="export"){N.export=!0;for(let ne of $.arguments)typeof N.export!="object"&&(N.export={}),N.export[ne.name.value]=ne.value.value}}let V=!1,J={};for(let $ of g.fields){let F=v($.type);F.name=$.name.value,A.push(F),J[F.name]=void 0;for(let ne of $.directives){let ee=ne.name.value;if(ee==="primaryKey")V?console.warn("Can not define two attributes as a primary key at",ne.loc):(F.isPrimaryKey=!0,V=!0);else if(ee==="indexed")F.indexed=!0;else if(ee==="computed"){for(let Z of ne.arguments||[])if(Z.name.value==="from"){let le=Z.value.value;F.computed={from:S(le,Z,J)},F.version==null&&(F.version=le)}else Z.name.value==="version"&&(F.version=Z.value.value);F.computed=F.computed||!0}else if(ee==="relationship"){let Z={};for(let le of ne.arguments)Z[le.name.value]=le.value.value;F.relationship=Z}else if(ee==="createdTime")F.assignCreatedTime=!0;else if(ee==="updatedTime")F.assignUpdatedTime=!0;else if(ee==="expiresAt")F.expiresAt=!0;else if(ee==="allow"){let Z=F.authorizedRoles=[];for(let le of ne.arguments)le.name.value==="role"&&Z.push(le.value.value)}else server.knownGraphQLDirectives.includes(ee)&&console.warn(`@${ee} is an unknown directive, at`,ne.loc)}}N.type=T,T==="Query"&&(h=N)}function p(g){let T=E.get(g.type);T?(Object.defineProperty(g,"properties",{value:T.properties}),Object.defineProperty(g,"definition",{value:T})):g.type==="array"?p(g.elements):LW.includes(g.type)||(0,OI.getWorkerIndex)()===0&&console.error(`The type ${g.type} is unknown at line ${g.location.line}, column ${g.location.column}, in ${s}`)}a(p,"connectPropertyType");for(let g of E.values())for(let T of g.properties)p(T);for(let g of _)g.tableClass=e(g),g.export&&(g.export.name===""?i.set((0,ES.dirname)(n),g.tableClass):i.set((0,ES.dirname)(n)+"/"+(g.export.name||g.type),g.tableClass,g.export));function S(g,T,A){return new yI.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${g}; } } } } computed;`,{filename:s,lineOffset:T.loc.startToken.line-1,columnOffset:T.loc.startToken.column}).runInThisContext()(A)}a(S,"createComputedFrom")}}var ES,yI,OI,LW,PW,MW,NI=Oe(()=>{ES=require("path"),yI=require("node:vm");Ne();OI=U(at()),LW=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(hS,"start");PW=hS,MW=hS({ensureTable:dt}).handleFile});async function b_(e){let t=(0,CI.pathToFileURL)(e).toString();return UW?(fu||(fu=vW(BW)),(await(await fu).import(t)).namespace):import(t)}async function vW(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),fu=new Compartment({console,Math,Date,fetch:xW,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,wI.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:pr,tables:Tn,databases:Ve})}};let n=await(0,II.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),fu}function xW(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 BW(){return{Resource:pr,tables:Tn}}var II,wI,CI,UW,fu,pS=Oe(()=>{us();Ne();II=require("fs/promises"),wI=require("path"),CI=require("url"),UW=!1;a(b_,"secureImport");a(vW,"getCompartment");a(xW,"secureOnlyFetch");a(BW,"getGlobalVars")});var TS={};Ze(TS,{handleFile:()=>HW});async function HW(e,t,r,n){let s=new Map,i=await b_(r);c(i.default)&&n.set((0,SS.dirname)(t),i.default),o(i,(0,SS.dirname)(t));function o(l,d){for(let u in l){let f=l[u];c(f)?n.set(d+"/"+u,f):typeof f=="object"&&o(f,d+"/"+u)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var SS,DI=Oe(()=>{pS();SS=require("path");a(HW,"handleFile")});var RS={};Ze(RS,{start:()=>kW});function kW({resources:e}){e.set("login",gS),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var gS,LI=Oe(()=>{us();a(kW,"start");gS=class extends pr{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 HI={};Ze(HI,{parse:()=>bS,streamAsJSON:()=>_u,stringify:()=>Vo});function _u(e){return new AS({value:e})}function PI(e){return console.error(e),JSON.stringify(e.toString())}function MI(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Vo(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===xI)return BI(e);if(t.resolution)return t.resolution.then(()=>Vo(e));throw t}}function BI(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+=BI(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Vo(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function bS(e){return qW.test(e)?FW.parse(e):JSON.parse(e)}var UI,vI,FW,GW,xI,AS,qW,yS=Oe(()=>{UI=require("stream"),vI=U(require("json-bigint-fixes")),FW=(0,vI.default)({useNativeBigInt:!0}),GW=1e4,xI={};BigInt.prototype.toJSON=function(){throw xI};a(_u,"streamAsJSON");AS=class extends UI.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),PI)}catch(s){yield PI(s)}else yield Vo(t)}else yield Vo(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);MI(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>GW?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 MI(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(PI,"handleError");a(MI,"when");a(Vo,"stringify");a(BI,"jsStringify");qW=/[[,:]\s*-?\d{16,}/;a(bS,"parse")});var JI=I((qfe,jI)=>{"use strict";var OS=require("recursive-iterator"),VW=require("alasql"),NS=require("clone"),kI=te(),{handleHDBError:FI,hdb_errors:$W}=ce(),{HDB_ERROR_MSGS:GI,HTTP_STATUS_CODES:qI}=$W,{getDatabases:YW}=(Ne(),ae(it)),KW=["DISTINCT_ARRAY"],VI=Symbol("validateTables"),IS=Symbol("validateTable"),Gfe=Symbol("getAllColumns"),$I=Symbol("validateAllColumns"),y_=Symbol("findColumn"),YI=Symbol("validateOrderBy"),Eu=Symbol("validateSegment"),wS=Symbol("validateColumn"),KI=Symbol("setColumnsForTable"),WI=Symbol("checkColumnsForAsterisk"),QI=Symbol("validateGroupBy"),zI=Symbol("hasColumns"),CS=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[VI](),this[WI](),this[$I]()}[VI](){if(this[zI]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[IS](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[IS](t.table)})}}[zI](){let t=!1,r=new OS(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[IS](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=YW();if(!r[t.databaseid])throw FI(new Error,GI.SCHEMA_NOT_FOUND(t.databaseid),qI.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw FI(new Error,GI.TABLE_NOT_FOUND(t.databaseid,t.tableid),qI.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=NS(s);i.table=NS(t),this.attributes.push(i)})}[y_](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)}[WI](){let t=new OS(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[KI](r.tableid)}[KI](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new VW.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[$I](){this[Eu](this.statement.columns,!1),this[Eu](this.statement.joins,!1),this[Eu](this.statement.where,!1),this[QI](this.statement.group,!1),this[Eu](this.statement.order,!0)}[Eu](t,r){if(!t)return;let n=new OS(t),s=[];for(let{node:i,path:o}of n)!kI.isEmpty(i)&&!kI.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[YI](i):s.push(this[wS](i)));return s}[QI](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&KW.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=NS(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[y_](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[y_](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`}[YI](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[wS](t)}[wS](t){let r=this[y_](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]}};jI.exports=CS});var ZI=I(($fe,XI)=>{"use strict";var DS=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")}};XI.exports=DS});var tw=I((Kfe,ew)=>{"use strict";var LS=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};ew.exports=LS});var iw={};Ze(iw,{HAS_EXPIRATION:()=>I_,HAS_RESIDENCY_ID:()=>kS,HAS_STRUCTURE_UPDATE:()=>w_,LAST_TIMESTAMP_PLACEHOLDER:()=>Su,LOCAL_TIMESTAMP:()=>WW,METADATA:()=>hu,NO_TIMESTAMP:()=>MS,PENDING_LOCAL_TIME:()=>FS,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>HS,RecordEncoder:()=>BS,TIMESTAMP_ASSIGN_LAST:()=>zW,TIMESTAMP_ASSIGN_NEW:()=>nw,TIMESTAMP_ASSIGN_PREVIOUS:()=>sw,TIMESTAMP_PLACEHOLDER:()=>O_,TIMESTAMP_RECORD_PREVIOUS:()=>US,getUpdateRecord:()=>GS,handleLocalTimeForGets:()=>C_});function JW(){return pu[0]=pu[0]^64,QW.getFloat64(0)}function C_(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),l=c?.value,d=l?.[hu];return d>=0&&(c.metadataFlags=d,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[hu]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let l=c.value,d=l[hu];return d>=0&&(c.metadataFlags=d,c.localTime=l.localTime,c.value=l.value,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,$o.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<$o.length;l++){let d=$o[l].deref();(!d||d.isDone||d.isCommitted)&&$o.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function GS(e,t,r){return function(n,s,i,o,c=-1,l,d,u="put",f,E){f||l==null?lc=i?.localTime?US|sw:MS:lc=l?i?.localTime?US|16384:nw|16384:MS;let _=d?.expiresAt;if(_>0&&(c|=I_),mu=c,vS=_,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:lc>0},p,S=0;try{let g=i?.residencyId,T=d?.residencyId;T&&(xS=T,mu|=kS,S|=Yo),g!==T&&(S|=Ko,g||(g=0)),c&I_&&(S|=gu),d?.originatingOperation&&(S|=Tu),f&&(h.ifVersion=p=i?.version??null);let A=e.put(n,s,h);if(l){let N=d?.user?.username;if(E&&(N_=e.encoder.encode(E)),e.encoder.hasStructureUpdate&&(S|=w_,e.encoder.hasStructureUpdate=!1),f&&i?.localTime){let V=i?.localTime,v=r.get(V);if(v){let J=Lt(v).previousLocalTime;return r.put(V,uc(o,t,n,J,d?.nodeId??server.replication.getThisNodeId(r)??0,N,u,N_,S,T,g,_),{ifVersion:p}),A}}r.put(Su,uc(o,t,n,i?.localTime?1:0,d?.nodeId??server.replication?.getThisNodeId(r)??0,N,u,N_,S,T,g,_,d?.originatingOperation),{append:u!=="invalidate",instructedWrite:!0,ifVersion:p})}return A}catch(g){throw g.message+=" id: "+n+" options: "+h,g}}}var rw,PS,O_,Su,HS,WW,hu,pu,QW,MS,nw,zW,sw,US,I_,kS,FS,w_,jW,N_,lc,mu,vS,xS,BS,$o,dc=Oe(()=>{rw=require("msgpackr");Ei();PS=U(X()),O_=new Uint8Array([1,1,1,1,4,64,0,0]),Su=new Uint8Array([1,1,1,1,1,0,0,0]),HS=new Uint8Array([1,1,1,1,3,64,0,0]),WW=Symbol("local-timestamp"),hu=Symbol("metadata"),pu=new Uint8Array(8),QW=new DataView(pu.buffer,0,8),MS=0,nw=0,zW=1,sw=3,US=4,I_=16,kS=32,FS=1,w_=256,lc=0,mu=-1,vS=0,xS=0,BS=class extends rw.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(lc||mu>=0){let o=0,c=lc;c&&(o+=8,lc=0);let l=mu,d=vS,u=xS;l>=0&&(o+=2,mu=-1,d&&(o+=8,vS=0),u&&(o+=4,xS=0));let f=jW=r.call(this,s,i|2048|o);N_=f.subarray((f.start||0)+o,f.end);let E=f.start||0;return c&&(O_[4]=c,O_[5]=c>>8,f.set(O_,E),E+=8),l>=0&&(f[E++]=l&31,f[E++]=l>>5,d&&((f.dataView||(f.dataView=new DataView(f.buffer,f.byteOffset,f.byteLength))).setFloat64(E,d),E+=8),u&&(f.dataView||(f.dataView=new DataView(f.buffer,f.byteOffset,f.byteLength))).setUint32(E,u)),f}else return r.call(this,s,i)};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(pu,0,c),c+=8;else for(let E=0;E<8;E++)pu[E]=t[c++];l=JW(),i=t[c]}let d,u;i<32&&(o=i|t[c+1]<<5,c+=2,o&I_&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&kS&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let f=r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c);return{localTime:l,value:f,[hu]:o,expiresAt:d,residencyId:u}}return r?.valueAsBuffer?t:super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(JW,"getTimestamp");a(C_,"handleLocalTimeForGets");$o=[];setInterval(()=>{for(let e=0;e<$o.length;e++){let t=$o[e].deref();!t||t.isDone||t.isCommitted?$o.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(PS.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):PS.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(GS,"getUpdateRecord")});var Ru=I((Jfe,aw)=>{"use strict";var ow=ie(),XW=B(),{RecordEncoder:ZW}=(dc(),ae(iw)),jfe=require("fs");ow.initSync();var eQ=ow.get(XW.CONFIG_PARAMS.STORAGE_CACHING)!==!1,qS=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=eQ&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:ZW})}};aw.exports=qS});var Au=I((Zfe,cw)=>{"use strict";var gn=ie(),Gn=B();gn.initSync();var D_=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.eventTurnBatching=!1,this.noSync=gn.get(Gn.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||gn.get(Gn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||gn.get(Gn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",gn.get(Gn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=gn.get(Gn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),gn.get(Gn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=gn.get(Gn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),gn.get(Gn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=gn.get(Gn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),gn.get(Gn.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=gn.get(Gn.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=gn.get(Gn.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};cw.exports=D_;D_.MAX_DBS=1e4});var ft=I((t_e,Sw)=>{"use strict";var $S=require("lmdb"),ds=require("fs-extra"),Rn=require("path"),L_=pn(),dw=X(),Yr=En().LMDB_ERRORS_ENUM,P_=tw(),YS=Ru(),fw=Au(),eo=Ft(),lw=B(),{table:tQ,resetDatabases:rQ}=(Ne(),ae(it)),uw=ie(),_s=eo.INTERNAL_DBIS_NAME,_w=eo.DBI_DEFINITION_NAME,nQ="data.mdb",sQ="lock.mdb",bu=".mdb",iQ="-lock",VS=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=qn(t,r),this.key_type=this.dbi[eo.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[eo.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new $S.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function M_(e,t){if(e===void 0)throw new Error(Yr.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Yr.ENV_NAME_REQUIRED)}a(M_,"pathEnvNameValidation");async function KS(e,t,r=!0){try{await ds.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Yr.INVALID_BASE_PATH):n}try{let n=Rn.join(e,t+bu);return await ds.access(n,ds.constants.R_OK|ds.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await ds.access(Rn.join(e,t,nQ),ds.constants.R_OK|ds.constants.F_OK),Rn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Yr.INVALID_ENVIRONMENT)}else throw new Error(Yr.INVALID_ENVIRONMENT);throw n}}a(KS,"validateEnvironmentPath");function U_(e,t){if(L_.validateEnv(e),t===void 0)throw new Error(Yr.DBI_NAME_REQUIRED)}a(U_,"validateEnvDBIName");async function oQ(e,t,r=!1,n=!1){M_(e,t);let s=Rn.basename(e);t=t.toString();let i=uw.get(lw.CONFIG_PARAMS.DATABASES);i||uw.setProperty(lw.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await KS(e,t,n),Ew(e,t,r)}catch(o){if(o.message===Yr.INVALID_ENVIRONMENT){let c=Rn.join(e,t);await ds.mkdirp(n?c:e);let l=new fw(n?c:c+bu,!1),d=$S.open(l);d.dbis=Object.create(null);let u=new YS(!1);d.openDB(_s,u),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let f=WS(e,t,r);return d[eo.ENVIRONMENT_NAME_KEY]=f,global.lmdb_map[f]=d,d}throw o}}a(oQ,"createEnvironment");async function aQ(e,t,r,n=!0){M_(e,t),t=t.toString();let s=Rn.join(e,t);return tQ({table:t,database:Rn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(aQ,"copyEnvironment");async function Ew(e,t,r=!1){M_(e,t),t=t.toString();let n=WS(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 KS(e,t),i=Rn.join(e,t+bu),o=s!=i,c=new fw(s,o),l=$S.open(c);l.dbis=Object.create(null);let d=mw(l);for(let u=0;u<d.length;u++)qn(l,d[u]);return l[eo.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(Ew,"openEnvironment");async function cQ(e,t,r=!1){M_(e,t),t=t.toString();let n=Rn.join(e,t+bu),s=await KS(e,t);if(global.lmdb_map!==void 0){let i=WS(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await hw(o),delete global.lmdb_map[i]}}await ds.remove(s),await ds.remove(s===n?s+iQ:Rn.join(Rn.dirname(s),sQ))}a(cQ,"deleteEnvironment");async function hw(e){L_.validateEnv(e);let t=e[eo.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(hw,"closeEnvironment");function WS(e,t,r=!1){let s=`${Rn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(WS,"getCachedEnvironmentName");function lQ(e){L_.validateEnv(e);let t=Object.create(null),r=qn(e,_s);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==_s)try{t[n]=Object.assign(new P_,s)}catch{dw.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(lQ,"listDBIDefinitions");function mw(e){L_.validateEnv(e);let t=[],r=qn(e,_s);for(let{key:n}of r.getRange({start:!1}))n!==_s&&t.push(n);return t}a(mw,"listDBIs");function uQ(e,t){let n=qn(e,_s).getEntry(t),s=new P_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{dw.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(uQ,"getDBIDefinition");function pw(e,t,r,n=!r){if(U_(e,t),t=t.toString(),t===_s)throw new Error(Yr.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return qn(e,t)}catch(s){if(s.message===Yr.DBI_DOES_NOT_EXIST){let i=new YS(r,n===!0),o=e.openDB(t,i),c=new P_(r===!0,n);return o[_w]=c,qn(e,_s).putSync(t,c),e.dbis[t]=o,o}throw s}}a(pw,"createDBI");function qn(e,t){if(U_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==_s?r=uQ(e,t):r=new P_,r===void 0)throw new Error(Yr.DBI_DOES_NOT_EXIST);let n;try{let s=new YS(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(Yr.DBI_DOES_NOT_EXIST):s}return n[_w]=r,e.dbis[t]=n,n}a(qn,"openDBI");function dQ(e,t){U_(e,t),t=t.toString();let r=qn(e,t),n=r.getStats();return r[eo.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(dQ,"statDBI");async function fQ(e,t){try{let r=Rn.join(e,t+bu);return(await ds.stat(r)).size}catch{throw new Error(Yr.INVALID_ENVIRONMENT)}}a(fQ,"environmentDataSize");function _Q(e,t){if(U_(e,t),t=t.toString(),t===_s)throw new Error(Yr.CANNOT_DROP_INTERNAL_DBIS_NAME);qn(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],qn(e,_s).removeSync(t)}a(_Q,"dropDBI");function EQ(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{qn(e,i)}catch(o){if(o.message===Yr.DBI_DOES_NOT_EXIST)pw(e,i,i!==t,i===t),n=!0;else throw o}}n&&rQ()}a(EQ,"initializeDBIs");Sw.exports={openDBI:qn,openEnvironment:Ew,createEnvironment:oQ,listDBIs:mw,listDBIDefinitions:lQ,createDBI:pw,dropDBI:_Q,statDBI:dQ,deleteEnvironment:cQ,initializeDBIs:EQ,TransactionCursor:VS,environmentDataSize:fQ,copyEnvironment:aQ,closeEnvironment:hw}});var gw=I((n_e,Tw)=>{"use strict";var QS=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};Tw.exports=QS});var Aw=I((i_e,Rw)=>{"use strict";var zS=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}};Rw.exports=zS});var yw=I((a_e,bw)=>{"use strict";var jS=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};bw.exports=jS});var fc=I((f_e,Iw)=>{"use strict";var hQ=ft(),mQ=gw(),pQ=Aw(),SQ=yw(),vs=pn(),yu=En().LMDB_ERRORS_ENUM,TQ=Ft(),hi=B(),gQ=te(),RQ=require("uuid"),l_e=require("lmdb"),{handleHDBError:AQ,hdb_errors:bQ}=ce(),{OVERFLOW_MARKER:u_e,MAX_SEARCH_KEY_LENGTH:d_e}=TQ,Ow=ie();Ow.initSync();var v_=Ow.get(hi.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),JS=hi.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Wo=hi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function yQ(e,t,r,n,s=vs.getNextMonotonicTime()){tT(e,t,r,n),XS(e,t,r);let i=new mQ,o=[],c=[];for(let l=0;l<n.length;l++){let d=n[l];Nw(d,!0,s);let u=OQ(e,t,r,d),f=d[t];o.push(u),c.push(f)}return ZS(o,c,n,i,s)}a(yQ,"insertRecords");function OQ(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 u=c([[{}]]);Array.isArray(u)&&(c=u[0][hi.FUNC_VAL],n[o]=c)}let l=vs.getIndexedValues(c),d=e.dbis[o];if(l){v_&&d.prefetch(l.map(u=>({key:u,value:s})),x_);for(let u=0,f=l.length;u<f;u++)d.put(l[u],s)}}v_&&e.dbis[t].prefetch([s],x_),e.dbis[t].put(s,n,n[Wo])})}a(OQ,"insertRecord");function NQ(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(NQ,"removeSkippedRecords");function Nw(e,t,r){let n=r>0;(n||!Number.isInteger(e[Wo]))&&(e[Wo]=r||(r=vs.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[JS]))&&(e[JS]=r||vs.getNextMonotonicTime()):delete e[JS]}a(Nw,"setTimestamps");function XS(e,t,r){r.indexOf(hi.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(hi.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(hi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(hi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),hQ.initializeDBIs(e,t,r)}a(XS,"initializeTransaction");async function IQ(e,t,r,n,s=vs.getNextMonotonicTime()){tT(e,t,r,n),XS(e,t,r);let i=new pQ,o=[],c=[],l=[];for(let d=0;d<n.length;d++){let u=n[d],f=u[t],E;try{E=eT(e,t,u,f,i,!0,s)}catch{i.skipped_hashes.push(f),o.push(d);continue}c.push(E),l.push(f)}return ZS(c,l,n,i,s,o)}a(IQ,"updateRecords");async function wQ(e,t,r,n,s=vs.getNextMonotonicTime()){try{tT(e,t,r,n)}catch(l){throw AQ(l,l.message,bQ.HTTP_STATUS_CODES.BAD_REQUEST)}XS(e,t,r);let i=new SQ,o=[],c=[];for(let l=0;l<n.length;l++){let d=n[l],u;gQ.isEmpty(d[t])?(u=RQ.v4(),d[t]=u):u=d[t];let f=eT(e,t,d,u,i,!1,s);o.push(f),c.push(u)}return ZS(o,c,n,i,s)}a(wQ,"upsertRecords");async function ZS(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||vs.getNextMonotonicTime(),NQ(r,i),n}a(ZS,"finalizeWrite");function eT(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),d=l?.value,u=d;if(!d){if(i)return!1;d={}}if(Nw(r,!u,o),Number.isInteger(r[Wo])&&d[Wo]>r[Wo])return!1;u&&s.original_records.push(d);let f,E=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 g=d[h];if(typeof p=="function"){let A=p([[d]]);Array.isArray(A)&&(p=A[0][hi.FUNC_VAL],r[h]=p)}if(p===g)continue;let T=vs.getIndexedValues(g);if(T){v_&&S.prefetch(T.map(A=>({key:A,value:n})),x_);for(let A=0,N=T.length;A<N;A++)S.remove(T[A],n)}if(T=vs.getIndexedValues(p),T){v_&&S.prefetch(T.map(A=>({key:A,value:n})),x_);for(let A=0,N=T.length;A<N;A++)S.put(T[A],n)}}let _=Object.assign({},d,r);c.put(n,_,_[Wo])},"do_put");return l?f=c.ifVersion(n,l.version,E):f=c.ifNoExists(n,E),f.then(_=>_?!0:eT(e,t,r,n,s,i,o))}a(eT,"updateUpsertRecord");function CQ(e,t,r){if(vs.validateEnv(e),t===void 0)throw new Error(yu.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(yu.WRITE_ATTRIBUTES_REQUIRED):new Error(yu.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(CQ,"validateBasic");function tT(e,t,r,n){if(CQ(e,t,r),!Array.isArray(n))throw n===void 0?new Error(yu.RECORDS_REQUIRED):new Error(yu.RECORDS_MUST_BE_ARRAY)}a(tT,"validateWrite");function x_(){}a(x_,"noop");Iw.exports={insertRecords:yQ,updateRecords:IQ,upsertRecords:wQ}});var Qo=I((E_e,DQ)=>{DQ.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var Bs=I((h_e,Dw)=>{"use strict";var Cw=te(),ww=B(),_c=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,xs=require("joi"),to={schema_format:{pattern:_c,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},LQ=xs.alternatives(xs.string().min(1).max(to.schema_length.maximum).pattern(_c).messages({"string.pattern.base":"{:#label} "+to.schema_format.message}),xs.number(),xs.array()).required(),PQ=xs.alternatives(xs.string().min(1).max(to.schema_length.maximum).pattern(_c).messages({"string.pattern.base":"{:#label} "+to.schema_format.message}),xs.number()),MQ=xs.alternatives(xs.string().min(1).max(to.schema_length.maximum).pattern(_c).messages({"string.pattern.base":"{:#label} "+to.schema_format.message}),xs.number()).required();function UQ(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>to.schema_length.maximum?`'${e}' maximum of 250 characters`:_c.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(UQ,"checkValidTable");function vQ(e,t){return Cw.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(vQ,"validateSchemaExists");function xQ(e,t){let r=t.state.ancestors[0].schema;return Cw.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(xQ,"validateTableExists");function BQ(e,t){return e.toLowerCase()===ww.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${ww.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(BQ,"validateSchemaName");Dw.exports={common_validators:to,schema_regex:_c,hdb_schema_table:LQ,validateSchemaExists:vQ,validateTableExists:xQ,validateSchemaName:BQ,checkValidTable:UQ,hdb_database:PQ,hdb_table:MQ}});var B_=I((p_e,Lw)=>{var{common_validators:Hs}=Bs(),Nu=mt(),Ou="is required",Qt={database:{presence:!1,format:Hs.schema_format,length:Hs.schema_length},schema:{presence:!1,format:Hs.schema_format,length:Hs.schema_length},table:{presence:!0,format:Hs.schema_format,length:Hs.schema_length},attribute:{presence:!0,format:Hs.schema_format,length:Hs.schema_length},hash_attribute:{presence:!0,format:Hs.schema_format,length:Hs.schema_length}};function Iu(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(Iu,"makeAttributesStrings");function HQ(e){return e=Iu(e),Qt.table.presence=!1,Qt.attribute.presence=!1,Qt.hash_attribute.presence=!1,Nu.validateObject(e,Qt)}a(HQ,"schema_object");function kQ(e){return e=Iu(e),Qt.table.presence={message:Ou},Qt.attribute.presence=!1,Qt.hash_attribute.presence=!1,Nu.validateObject(e,Qt)}a(kQ,"table_object");function FQ(e){return e=Iu(e),Qt.table.presence={message:Ou},Qt.attribute.presence=!1,Nu.validateObject(e,Qt)}a(FQ,"create_table_object");function GQ(e){return e=Iu(e),Qt.table.presence={message:Ou},Qt.attribute.presence={message:Ou},Qt.hash_attribute.presence=!1,Nu.validateObject(e,Qt)}a(GQ,"attribute_object");function qQ(e){return e=Iu(e),Qt.table.presence={message:Ou},Qt.attribute.presence=!1,Qt.hash_attribute.presence=!1,Nu.validateObject(e,Qt)}a(qQ,"describe_table");function VQ(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(VQ,"validateTableResidence");Lw.exports={schema_object:HQ,create_table_object:FQ,table_object:kQ,attribute_object:GQ,describe_table:qQ,validateTableResidence:VQ}});var Mw=I((T_e,Pw)=>{"use strict";var $Q=require("uuid"),rT=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||$Q.v4(),this.schema_table=`${this.schema}.${this.table}`}};Pw.exports=rT});var H_=I((R_e,Uw)=>{"use strict";var YQ=Mw(),nT=class extends YQ{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}};Uw.exports=nT});var xw=I((b_e,vw)=>{"use strict";vw.exports=WQ;var KQ="inserted";function WQ(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===KQ?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(WQ,"returnObject")});var k_=I((N_e,Fw)=>{"use strict";var QQ=B(),sT=ft(),zQ=fc(),{getSystemSchemaPath:jQ,getSchemaPath:JQ}=St(),O_e=Qo(),XQ=B_(),ZQ=H_(),ez=xw(),{handleHDBError:Bw,hdb_errors:kw}=ce(),Hw=te(),{HTTP_STATUS_CODES:tz}=kw,rz="inserted";Fw.exports=nz;async function nz(e){let t=XQ.attribute_object(e);if(t)throw Bw(new Error,t.message,kw.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&Hw.checkGlobalSchemaTable(e.schema,e.table);if(r)throw Bw(new Error,r,tz.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=Hw.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 ZQ(e.schema,e.table,e.attribute,e.id);try{let i=await sT.openEnvironment(JQ(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}`);sT.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await sT.openEnvironment(jQ(),QQ.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await zQ.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return ez(rz,c,{records:[s]},l)}catch(i){throw i}}a(nz,"lmdbCreateAttribute")});var oT=I((w_e,qw)=>{var{hdb_table:sz,hdb_database:Gw}=Bs(),iz=mt(),iT=require("joi"),oz={undefined:"undefined",null:"null"},az=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||oz[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"),cz=iT.object({database:Gw,schema:Gw,table:sz,records:iT.array().items(iT.object().custom(az)).required()});qw.exports=function(e){return iz.validateBySchema(e,cz)}});var wu=I((L_e,$w)=>{"use strict";var mi=te(),Vw=X(),D_e=oT(),{getDatabases:lz}=(Ne(),ae(it)),{ClientError:zo}=ce();$w.exports=uz;function uz(e){if(mi.isEmpty(e))throw new zo("invalid update parameters defined.");if(mi.isEmptyOrZeroLength(e.schema))throw new zo("invalid schema specified.");if(mi.isEmptyOrZeroLength(e.table))throw new zo("invalid table specified.");if(!Array.isArray(e.records))throw new zo("records must be an array");let t=lz()[e.schema]?.[e.table];if(mi.isEmpty(t))throw new zo(`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&&mi.isEmptyOrZeroLength(o[r]))throw Vw.error("a valid hash attribute must be provided with update record:",o),new zo("a valid hash attribute must be provided with update record, check log for more info");if(!mi.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw Vw.error(`a valid hash value must be provided with ${e.operation} record:`,o),new zo(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!mi.isEmpty(o[r])&&o[r]!==""&&n.has(mi.autoCast(o[r]))&&(o.skip=!0),n.add(mi.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(uz,"insertUpdateValidate")});var Cu=I((M_e,Yw)=>{"use strict";var dz=B().OPERATIONS_ENUM,aT=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=dz.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};Yw.exports=aT});var Du=I((x_e,Ww)=>{"use strict";var v_e=Cu(),F_=B(),cT=te(),Kw=X(),fz=require("uuid"),{handleHDBError:G_,hdb_errors:_z}=ce(),{HDB_ERROR_MSGS:q_,HTTP_STATUS_CODES:V_}=_z;Ww.exports=Ez;function Ez(e,t,r){for(let s=0;s<t.length;s++)hz(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];mz(i,r,e.operation)}}a(Ez,"processRows");function hz(e){if(Buffer.byteLength(String(e))>F_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw G_(new Error,q_.ATTR_NAME_LENGTH_ERR(e),V_.BAD_REQUEST,void 0,void 0,!0);if(cT.isEmptyOrZeroLength(e)||cT.isEmpty(e.trim()))throw G_(new Error,q_.ATTR_NAME_NULLISH_ERR,V_.BAD_REQUEST,void 0,void 0,!0)}a(hz,"validateAttribute");function mz(e,t,r){if(!e.hasOwnProperty(t)||cT.isEmptyOrZeroLength(e[t])){if(r===F_.OPERATIONS_ENUM.INSERT||r===F_.OPERATIONS_ENUM.UPSERT){e[t]=fz.v4();return}throw Kw.error("Update transaction aborted due to record with no hash value:",e),G_(new Error,q_.RECORD_MISSING_HASH_ERR,V_.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>F_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Kw.error(e),G_(new Error,q_.HASH_VAL_LENGTH_ERR,V_.BAD_REQUEST,void 0,void 0,!0)}a(mz,"validateHash")});var zw=I((H_e,Qw)=>{"use strict";var lT=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};Qw.exports=lT});var Xw=I((F_e,Jw)=>{"use strict";var uT=ft(),pz=X(),jw=En().LMDB_ERRORS_ENUM;Jw.exports=Sz;async function Sz(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 uT.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==jw.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await uT.closeEnvironment(global.lmdb_map[n]),await uT.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==jw.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){pz.error(t)}}a(Sz,"cleanLMDBMap")});var pi=I((q_e,rC)=>{"use strict";var Lu=require("crypto"),Tz=ie(),{CONFIG_PARAMS:gz}=B(),eC="aes-256-cbc",Rz=32,Az=16,dT=64,tC=32,bz=dT+tC,Zw=new Map;rC.exports={encrypt:yz,decrypt:Oz,createNatsTableStreamName:Nz};function yz(e){let t=Lu.randomBytes(Rz),r=Lu.randomBytes(Az),n=Lu.createCipheriv(eC,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(yz,"encrypt");function Oz(e){let t=e.substr(0,dT),r=e.substr(dT,tC),n=e.substr(bz,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=Lu.createDecipheriv(eC,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(Oz,"decrypt");function Nz(e,t){let r=Tz.get(gz.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=Zw.get(r);return n||(n=Lu.createHash("md5").update(r).digest("hex"),Zw.set(r,n)),n}a(Nz,"createNatsTableStreamName")});var ro=I((Y_e,sC)=>{"use strict";var $_e=An(),Pu=X(),nC=B_(),Iz=pi(),$_=te(),{handleHDBError:Y_,hdb_errors:wz}=ce(),{HDB_ERROR_MSGS:K_,HTTP_STATUS_CODES:fT}=wz,Cz=ie();Cz.initSync();var{getDatabases:_T}=(Ne(),ae(it)),Dz=require("fs-extra");sC.exports={describeAll:Lz,describeTable:W_,describeSchema:Pz};async function Lz(e){try{let t=$_.isEmptyOrZeroLength(e),r,n;t||(r=e.hdb_user.role.permission,n=r.super_user||r.cluster_user);let s=_T(),i={},o={},c=[],l=e?.exact_count;for(let u in s){i[u]=!0,!t&&!n&&(o[u]=e.hdb_user.role.permission[u].describe);let f=s[u];for(let E in f)try{let _;if(t||n)_=await W_({schema:u,table:E,exact_count:l});else if(r&&r[u].describe&&r[u].tables[E].describe){let h=r[u].tables[E].attribute_permissions;_=await W_({schema:u,table:E,exact_count:l},h)}_&&c.push(_)}catch(_){Pu.error(_)}}let d={};for(let u in c)t||n?(d[c[u].schema]==null&&(d[c[u].schema]={}),d[c[u].schema][c[u].name]=c[u],i[c[u].schema]&&delete i[c[u].schema]):o[c[u].schema]&&(d[c[u].schema]==null&&(d[c[u].schema]={}),d[c[u].schema][c[u].name]=c[u],i[c[u].schema]&&delete i[c[u].schema]);for(let u in i)t||n?d[u]={}:o[u]&&(d[u]={});return d}catch(t){return Pu.error("Got an error in describeAll"),Pu.error(t),Y_(new Error,K_.DESCRIBE_ALL_ERR)}}a(Lz,"describeAll");async function W_(e,t){$_.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=nC.describe_table(e);if(i)throw i;let c=_T()[r];if(!c)throw Y_(new Error,K_.SCHEMA_NOT_FOUND(e.schema),fT.NOT_FOUND);let l=c[n];if(!l)throw Y_(new Error,K_.TABLE_NOT_FOUND(e.schema,e.table),fT.NOT_FOUND);function d(_){u.push(Object.assign({},{attribute:_.attribute,type:_.type,elements:_.elements?.type,indexed:_.indexed,is_primary_key:_.isPrimaryKey,assigned_created_time:_.assignCreatedTime,assigned_updated_time:_.assignUpdatedTime,nullable:_.nullable,properties:_.properties?_.properties.map(h=>({type:h.type,name:h.name})):void 0}))}a(d,"pushAtt");let u=[];if(s){let _={};s.forEach(h=>{h.describe&&(_[h.attribute_name]=!0)}),l.attributes.forEach(h=>{_[h.name]&&d(h)})}else l.attributes?.forEach(_=>d(_));let f;try{f=(await Dz.stat(l.primaryStore.env.path)).size}catch(_){Pu.warn("unable to get database size",_)}let E={schema:r,name:l.tableName,hash_attribute:l.attributes.find(_=>_.isPrimaryKey||_.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:u,db_size:f};E.clustering_stream_name=Iz.createNatsTableStreamName(E.schema,E.name);try{let _=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=_.recordCount,E.estimated_record_range=_.estimatedRange;let h=l.auditStore;if(h)for(let p of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=p[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let p of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=p}catch(_){Pu.warn(`unable to stat table dbi due to ${_}`)}return E}a(W_,"descTable");async function Pz(e){$_.transformReq(e);let t=nC.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=_T()[n];if(!i)throw Y_(new Error,K_.SCHEMA_NOT_FOUND(e.schema),fT.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),$_.isEmpty(l)||l.describe){let d=await W_({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);d&&(o[d.name]=d)}}return o}a(Pz,"describeSchema")});var Si=I((z_e,lC)=>{var Mz=Qo(),{callbackify:oC,promisify:Uz}=require("util"),{getDatabases:aC}=(Ne(),ae(it));lC.exports={setSchemaDataToGlobal:iC,getTableSchema:vz,getSystemSchema:xz,setSchemaDataToGlobalAsync:Uz(iC)};var cC=ro(),W_e=oC(cC.describeAll),Q_e=oC(cC.describeTable);function iC(e){global.hdb_schema=aC(),e&&e()}a(iC,"setSchemaDataToGlobal");function vz(e,t,r){let n=aC()[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(vz,"getTableSchema");function xz(){return Mz}a(xz,"getSystemSchema")});var Vn=I((J_e,_C)=>{"use strict";var z_=oT(),Sr=te(),Bz=require("util"),j_=$n(),Hz=Si(),uC=X(),{handleHDBError:jo,hdb_errors:kz}=ce(),{HTTP_STATUS_CODES:Jo}=kz,Fz=Bz.promisify(Hz.getTableSchema),Gz="updated",dC="inserted",fC="upserted";_C.exports={insert:Vz,update:$z,upsert:Yz,validation:qz,flush:Kz};async function qz(e){if(Sr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Sr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Sr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await Fz(e.schema,e.table),r=z_(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&&Sr.isEmptyOrZeroLength(c[n]))throw uC.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(!Sr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw uC.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Sr.isEmpty(c[n])&&c[n]!==""&&s.has(Sr.autoCast(c[n]))&&(c.skip=!0),s.add(Sr.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(qz,"validation");async function Vz(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=z_(e);if(t)throw jo(new Error,t.message,Jo.BAD_REQUEST);Sr.transformReq(e);let r=Sr.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,Jo.BAD_REQUEST);let n=await j_.createRecords(e);return Q_(dC,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(Vz,"insertData");async function $z(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=z_(e);if(t)throw jo(new Error,t.message,Jo.BAD_REQUEST);Sr.transformReq(e);let r=Sr.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,Jo.BAD_REQUEST);let n=await j_.updateRecords(e);return Sr.isEmpty(n.existing_rows)?Q_(Gz,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Q_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a($z,"updateData");async function Yz(e){if(e.operation!=="upsert")throw jo(new Error,"invalid operation, must be upsert",Jo.INTERNAL_SERVER_ERROR);let t=z_(e);if(t)throw jo(new Error,t.message,Jo.BAD_REQUEST);Sr.transformReq(e);let r=Sr.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,Jo.BAD_REQUEST);let n=await j_.upsertRecords(e);return Q_(fC,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(Yz,"upsertData");function Q_(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===dC?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===fC?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Q_,"returnObject");function Kz(e){return Sr.transformReq(e),j_.flush(e.schema,e.table)}a(Kz,"flush")});var hT=I((Z_e,mC)=>{var Wz=mt(),ET=require("joi"),{hdb_table:Qz,hdb_database:EC}=Bs(),hC={schema:EC,database:EC,table:Qz},zz={date:ET.date().iso().required()},jz={timestamp:ET.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};mC.exports=function(e,t){let r=t==="timestamp"?{...hC,...jz}:{...hC,...zz},n=ET.object(r);return Wz.validateBySchema(e,n)}});var TC=I((eEe,SC)=>{var Jz=mt(),mT=require("joi"),{hdb_table:Xz,hdb_database:pC}=Bs(),Zz=mT.object({schema:pC,database:pC,table:Xz,hash_values:mT.array().required(),ids:mT.array()});SC.exports=function(e){return Jz.validateBySchema(e,Zz)}});var RC=I((tEe,gC)=>{"use strict";var pT=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}},ST=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}},TT=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};gC.exports={InsertObject:pT,NoSQLSeachObject:ST,DeleteResponseObject:TT}});var ea=I((nEe,NC)=>{"use strict";var bC=hT(),ej=TC(),Xo=te(),AC=require("moment"),yC=X(),{promisify:tj,callbackify:rj}=require("util"),Zo=B(),nj=Si(),gT=tj(nj.getTableSchema),RT=$n(),{DeleteResponseObject:sj}=RC(),{handleHDBError:no,hdb_errors:ij}=ce(),{HDB_ERROR_MSGS:J_,HTTP_STATUS_CODES:so}=ij,oj="records successfully deleted",aj=rj(OC);NC.exports={delete:aj,deleteRecord:OC,deleteFilesBefore:cj,deleteAuditLogsBefore:lj};async function cj(e){let t=bC(e,"date");if(t)throw no(t,t.message,so.BAD_REQUEST,void 0,void 0,!0);if(Xo.transformReq(e),!AC(e.date,AC.ISO_8601).isValid())throw no(new Error,J_.INVALID_DATE,so.BAD_REQUEST,Zo.LOG_LEVELS.ERROR,J_.INVALID_DATE,!0);let n=Xo.checkSchemaTableExist(e.schema,e.table);if(n)throw no(new Error,n,so.NOT_FOUND,Zo.LOG_LEVELS.ERROR,n,!0);let s=await RT.deleteRecordsBefore(e);if(await gT(e.schema,e.table),yC.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(cj,"deleteFilesBefore");async function lj(e){let t=bC(e,"timestamp");if(t)throw no(t,t.message,so.BAD_REQUEST,void 0,void 0,!0);if(Xo.transformReq(e),isNaN(e.timestamp))throw no(new Error,J_.INVALID_VALUE("Timestamp"),so.BAD_REQUEST,Zo.LOG_LEVELS.ERROR,J_.INVALID_VALUE("Timestamp"),!0);let r=Xo.checkSchemaTableExist(e.schema,e.table);if(r)throw no(new Error,r,so.NOT_FOUND,Zo.LOG_LEVELS.ERROR,r,!0);let n=await RT.deleteAuditLogsBefore(e);return await gT(e.schema,e.table),yC.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(lj,"deleteAuditLogsBefore");async function OC(e){e.ids&&(e.hash_values=e.ids);let t=ej(e);if(t)throw no(t,t.message,so.BAD_REQUEST,void 0,void 0,!0);Xo.transformReq(e);let r=Xo.checkSchemaTableExist(e.schema,e.table);if(r)throw no(new Error,r,so.NOT_FOUND,Zo.LOG_LEVELS.ERROR,r,!0);try{await gT(e.schema,e.table);let n=await RT.deleteRecords(e);return Xo.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${oj}`),n}catch(n){if(n.message===Zo.SEARCH_NOT_FOUND_MESSAGE){let s=new sj;return s.message=Zo.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(OC,"deleteRecord")});var X_=I((iEe,CC)=>{var uj=require("crypto"),IC=9;function dj(e){let t=_j(IC),r=wC(e+t);return t+r}a(dj,"createHash");function fj(e,t){let r=e?.substr(0,IC),n=r+wC(t+r);return e===n}a(fj,"validateHash");function _j(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(_j,"generateSalt");function wC(e){return uj.createHash("md5").update(e).digest("hex")}a(wC,"md5");CC.exports={hash:dj,validate:fj}});var LC=I((aEe,DC)=>{var AT=mt(),Mr={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 Ej(e){return Mr.password.presence=!0,Mr.username.presence=!0,Mr.role.presence=!0,Mr.active.presence=!0,AT.validateObject(e,Mr)}a(Ej,"addUserValidation");function hj(e){return Mr.password.presence=!1,Mr.username.presence=!0,Mr.role.presence=!1,Mr.active.presence=!1,AT.validateObject(e,Mr)}a(hj,"alterUserValidation");function mj(e){return Mr.password.presence=!1,Mr.username.presence=!0,Mr.role.presence=!1,Mr.active.presence=!1,AT.validateObject(e,Mr)}a(mj,"dropUserValidation");DC.exports={addUserValidation:Ej,alterUserValidation:hj,dropUserValidation:mj}});var Pt=I((uEe,MC)=>{"use strict";var{platform:lEe}=require("os"),pj="nats-server.zip",bT="nats-server",Sj=process.platform==="win32"?`${bT}.exe`:bT,Tj=/^[^\s.,*>]+$/,PC="__request__",gj=a(e=>`${e}.${PC}`,"REQUEST_SUBJECT"),Rj={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},Aj={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},bj={HUB:"hub.pid",LEAF:"leaf.pid"},yj={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},Oj={SUCCESS:"success",ERROR:"error"},Nj={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},Ij={TXN:"txn",MSGID:"msgid"},Ec={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},wj={[Ec.ERR]:1,[Ec.WRN]:2,[Ec.INF]:3,[Ec.DBG]:4,[Ec.TRC]:5},Cj={debug:"-D",trace:"-DVV"};MC.exports={NATS_SERVER_ZIP:pj,NATS_SERVER_NAME:bT,NATS_BINARY_NAME:Sj,PID_FILES:bj,NATS_CONFIG_FILES:Aj,SERVER_SUFFIX:yj,NATS_TERM_CONSTRAINTS_RX:Tj,REQUEST_SUFFIX:PC,UPDATE_REMOTE_RESPONSE_STATUSES:Oj,CLUSTER_STATUS_STATUSES:Nj,REQUEST_SUBJECT:gj,SUBJECT_PREFIXES:Ij,MSG_HEADERS:Rj,LOG_LEVELS:Ec,LOG_LEVEL_FLAGS:Cj,LOG_LEVEL_HIERARCHY:wj}});var vC=I((fEe,UC)=>{"use strict";var Z_=B(),eE=class{static{a(this,"BaseLicense")}constructor(t=0,r=Z_.RAM_ALLOCATION_ENUM.DEFAULT,n=Z_.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},yT=class extends eE{static{a(this,"ExtendedLicense")}constructor(t=0,r=Z_.RAM_ALLOCATION_ENUM.DEFAULT,n=Z_.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};UC.exports={BaseLicense:eE,ExtendedLicense:yT}});var ta=I((EEe,qC)=>{"use strict";var mc=require("fs-extra"),BC=X_(),HC=require("crypto"),Dj=require("moment"),Lj=require("uuid").v4,Ur=X(),NT=require("path"),Pj=te(),io=B(),{totalmem:xC}=require("os"),Mj=vC().ExtendedLicense,hc="invalid license key format",Uj="061183",vj="mofi25",xj="aes-256-cbc",Bj=16,Hj=32,kC=ie(),{resolvePath:FC}=dr();kC.initSync();var OT;qC.exports={validateLicense:GC,generateFingerPrint:Fj,licenseSearch:CT,getLicense:Vj,checkMemoryLimit:$j};function IT(){return NT.join(kC.getHdbBasePath(),io.LICENSE_KEY_DIR_NAME,io.LICENSE_FILE_NAME)}a(IT,"getLicenseDirPath");function kj(){let e=IT();return FC(NT.join(e,io.LICENSE_FILE_NAME))}a(kj,"getLicenseFilePath");function wT(){let e=IT();return FC(NT.join(e,io.REG_KEY_FILE_NAME))}a(wT,"getFingerPrintFilePath");async function Fj(){let e=wT();try{return await mc.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await Gj();throw Ur.error(`Error writing fingerprint file to ${e}`),Ur.error(t),new Error("There was an error generating the fingerprint")}}a(Fj,"generateFingerPrint");async function Gj(){let e=Lj(),t=BC.hash(e),r=wT();try{await mc.mkdirp(IT()),await mc.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Ur.error(`Error writing fingerprint file to ${r}`),Ur.error(n),new Error("There was an error generating the fingerprint")}return t}a(Gj,"writeFingerprint");function GC(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:io.RAM_ALLOCATION_ENUM.DEFAULT,version:io.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Ur.error("empty license key passed to validate."),r;let n=wT(),s=!1;try{s=mc.statSync(n)}catch(i){Ur.error(i)}if(s){let i;try{i=mc.readFileSync(n,"utf8")}catch{Ur.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(vj),c=o[1];c=Buffer.concat([Buffer.from(c)],Bj);let l=Buffer.concat([Buffer.from(i)],Hj),d=HC.createDecipheriv(xj,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let u=null;try{u=d.update(o[0],"hex","utf8"),u.trim(),u+=d.final("utf8")}catch{let _=qj(o[0],i);if(_)u=_;else throw r.valid_license=!1,r.valid_machine=!1,console.error(hc),Ur.error(hc),new Error(hc)}let f;if(isNaN(u))try{f=JSON.parse(u),r.version=f.version,r.exp_date=f.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),f.ram_allocation&&(r.ram_allocation=f.ram_allocation)}catch{throw console.error(hc),Ur.error(hc),new Error(hc)}else r.exp_date=u;r.exp_date<Dj().valueOf()&&(r.valid_date=!1),BC.validate(o[1],`${Uj}${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||Ur.error("Invalid licence"),r}a(GC,"validateLicense");function qj(e,t){try{let r=HC.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Ur.warn("Check old license failed")}}a(qj,"checkOldLicense");function CT(){let e=new Mj,t=[];try{t=mc.readFileSync(kj(),"utf-8").split(io.NEW_LINE)}catch(r){r.code==="ENOENT"?Ur.debug("no license file found"):Ur.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(Pj.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=GC(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){Ur.error("There was an error parsing the license string."),Ur.error(s),e.ram_allocation=io.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return OT=e,e}a(CT,"licenseSearch");async function Vj(){return OT||await CT(),OT}a(Vj,"getLicense");function $j(){let e=CT().ram_allocation,t=process.constrainedMemory?.()||xC();if(t=Math.round(Math.min(t,xC())/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($j,"checkMemoryLimit")});var yn=I((TEe,sD)=>{"use strict";var KC="username is required",WC="nothing to update, must supply active, role or password to update",QC="password cannot be an empty string",zC="If role is specified, it cannot be empty.",jC="active must be true or false";sD.exports={addUser:Zj,alterUser:e2,dropUser:r2,getSuperUser:o2,userInfo:n2,listUsers:rE,listUsersExternal:s2,setUsersToGlobal:Sc,findAndValidateUser:rD,getClusterUser:a2,USERNAME_REQUIRED:KC,ALTERUSER_NOTHING_TO_UPDATE:WC,EMPTY_PASSWORD:QC,EMPTY_ROLE:zC,ACTIVE_BOOLEAN:jC};var JC=Vn(),Yj=ea(),PT=X_(),XC=LC(),ZC=An(),MT=Ti(),bn=te(),eD=require("validate.js"),ke=X(),{promisify:Kj}=require("util"),UT=pi(),VC=B(),$C=Pt(),Wj=dr(),mEe=ie(),pEe=ta(),Qj=Qo(),{table:SEe}=(Ne(),ae(it)),{handleHDBError:ks,hdb_errors:zj}=ce(),{HTTP_STATUS_CODES:Fs,AUTHENTICATION_ERROR_MSGS:DT,HDB_ERROR_MSGS:pc}=zj,{UserEventMsg:vT}=Es(),LT=require("lodash"),{server:xT}=(Lr(),ae(Fo)),jj=X();xT.getUser=(e,t)=>rD(e,t,t!=null);var tD={username:!0,active:!0,role:!0,password:!0},YC=new Map,tE=ZC.searchByValue,Jj=ZC.searchByHash,Xj=Kj(Yj.delete);async function Zj(e){let t=eD.cleanAttributes(e,tD),r=XC.addUserValidation(t);if(r)throw ks(new Error,r.message,Fs.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 tE(n),s=s&&Array.from(s)}catch(l){throw ke.error("There was an error searching for a role in add user"),ke.error(l),l}if(!s||s.length<1)throw ks(new Error,pc.ROLE_NAME_NOT_FOUND(t.role),Fs.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw ks(new Error,pc.DUP_ROLES_FOUND(t.role),Fs.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=UT.encrypt(t.password)),t.password=PT.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await JC.insert(i)}catch(l){throw ke.error("There was an error searching for a user."),ke.error(l),l}ke.debug(o);try{await Sc()}catch(l){throw ke.error("Got an error setting users to global"),ke.error(l),l}if(o.skipped_hashes.length===1)throw ks(new Error,pc.USER_ALREADY_EXISTS(t.username),Fs.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],MT.signalUserChange(new vT(process.pid)),`${c.username} successfully added`}a(Zj,"addUser");async function e2(e){let t=eD.cleanAttributes(e,tD);if(bn.isEmptyOrZeroLength(t.username))throw new Error(KC);if(bn.isEmptyOrZeroLength(t.password)&&bn.isEmptyOrZeroLength(t.role)&&bn.isEmptyOrZeroLength(t.active))throw new Error(WC);if(!bn.isEmpty(t.password)&&bn.isEmptyOrZeroLength(t.password.trim()))throw new Error(QC);if(!bn.isEmpty(t.active)&&!bn.isBoolean(t.active))throw new Error(jC);let r=t2(t.username);if(!bn.isEmpty(t.password)&&!bn.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=UT.encrypt(t.password)),t.password=PT.hash(t.password)),t.role==="")throw new Error(zC);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 tE(i)||[])}catch(c){throw ke.error("Got an error searching for a role."),ke.error(c),c}if(!o||o.length===0){let c=pc.ALTER_USER_ROLE_NOT_FOUND(t.role);throw ke.error(c),ks(new Error,c,Fs.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=pc.ALTER_USER_DUP_ROLES(t.role);throw ke.error(c),ks(new Error,c,Fs.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 JC.update(n)}catch(i){throw ke.error("Error during update."),ke.error(i),i}try{await Sc()}catch(i){throw ke.error("Got an error setting users to global"),ke.error(i),i}return MT.signalUserChange(new vT(process.pid)),s}a(e2,"alterUser");function t2(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(t2,"isClusterUser");async function r2(e){try{let t=XC.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(bn.isEmpty(global.hdb_users.get(e.username)))throw ks(new Error,pc.USER_NOT_EXIST(e.username),Fs.NOT_FOUND,void 0,void 0,!0);let n;try{n=await Xj(r)}catch(s){throw ke.error("Got an error deleting a user."),ke.error(s),s}ke.debug(n);try{await Sc()}catch(s){throw ke.error("Got an error setting users to global."),ke.error(s),s}return MT.signalUserChange(new vT(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(r2,"dropUser");async function n2(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=LT.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await Jj(r)}catch(s){throw ke.error("Got an error searching for a role."),ke.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw ke.error(r),r}return t}a(n2,"userInfo");async function s2(){let e;try{e=await rE()}catch(t){throw ke.error("Got an error listing users."),ke.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(s2,"listUsersExternal");async function rE(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await tE(e)}catch(o){throw ke.error("Got an error searching for roles."),ke.error(o),o}let r={};for(let o of t)r[o.id]=LT.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 tE(n)}catch(o){throw ke.error("Got an error searching for users."),ke.error(o),o}let i=new Map;for(let o of s)o=LT.cloneDeep(o),o.role=r[o.role],i2(o.role),i.set(o.username,o);return i}catch(e){throw ke.error("got an error listing users"),ke.error(e),bn.errorizeMessage(e)}return null}a(rE,"listUsers");function i2(e){try{if(!e){ke.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(Qj)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){ke.error("Got an error trying to set system permissions."),ke.error(t)}}a(i2,"appendSystemTablesToRole");async function Sc(){try{let e=await rE();global.hdb_users=e}catch(e){throw ke.error(e),e}}a(Sc,"setUsersToGlobal");async function rD(e,t,r=!0){global.hdb_users||await Sc();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw ks(new Error,DT.GENERIC_AUTH_FAIL,Fs.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw ks(new Error,DT.USER_INACTIVE,Fs.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(YC.get(t)===n.password)return s;if(PT.validate(n.password,t))YC.set(t,n.password);else throw ks(new Error,DT.GENERIC_AUTH_FAIL,Fs.UNAUTHORIZED,void 0,void 0,!0)}return s}a(rD,"findAndValidateUser");async function o2(){global.hdb_users||await Sc();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(o2,"getSuperUser");async function a2(){let e=await rE(),t=Wj.getConfigFromFile(VC.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!bn.isEmpty(r)&&r?.role?.role===VC.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=UT.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+$C.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+$C.SERVER_SUFFIX.ADMIN,r}a(a2,"getClusterUser");var nD=[];xT.invalidateUser=function(e){for(let t of nD)try{t(e)}catch(r){jj.error("Error invalidating user",r)}};xT.onInvalidatedUser=function(e){nD.push(e)}});var Uu=I((bEe,cD)=>{"use strict";var ra=X(),On=B(),c2=Xw(),REe=Si(),AEe=ro(),l2=yn(),{validateEvent:iD}=Es(),Mu=$n(),u2=require("process"),{resetDatabases:d2}=(Ne(),ae(it)),f2={[On.ITC_EVENT_TYPES.SCHEMA]:_2,[On.ITC_EVENT_TYPES.USER]:aD};async function _2(e){let t=iD(e);if(t){ra.error(t);return}ra.trace("ITC schemaHandler received schema event:",e),await c2(e.message),await E2(e.message)}a(_2,"schemaHandler");async function E2(e){try{Mu.resetReadTxn(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Mu.resetReadTxn(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Mu.resetReadTxn(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=d2();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){ra.error(t)}}a(E2,"syncSchemaMetadata");var oD=[];async function aD(e){try{try{Mu.resetReadTxn(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Mu.resetReadTxn(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){ra.warn(r)}let t=iD(e);if(t){ra.error(t);return}ra.trace(`ITC userHandler ${On.HDB_ITC_CLIENT_PREFIX}${u2.pid} received user event:`,e),await l2.setUsersToGlobal();for(let r of oD)r()}catch(t){ra.error(t)}}a(aD,"userHandler");aD.addListener=function(e){oD.push(e)};cD.exports=f2});var Es=I((CEe,uD)=>{"use strict";var OEe=X(),BT=te(),h2=B(),{ITC_ERRORS:vu}=En(),{parentPort:NEe,threadId:m2,isMainThread:p2,workerData:IEe}=require("worker_threads"),{onMessageFromWorkers:S2,broadcast:wEe,broadcastWithAcknowledgement:T2}=at();uD.exports={sendItcEvent:g2,validateEvent:lD,SchemaEventMsg:R2,UserEventMsg:A2};var nE;S2(async(e,t)=>{nE=nE||Uu(),lD(e),nE[e.type]&&await nE[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function g2(e){return!p2&&e.message&&(e.message.originator=m2),T2(e)}a(g2,"sendItcEvent");function lD(e){if(typeof e!="object")return vu.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||BT.isEmpty(e.type))return vu.MISSING_TYPE;if(!e.hasOwnProperty("message")||BT.isEmpty(e.message))return vu.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||BT.isEmpty(e.message.originator))return vu.MISSING_ORIGIN;if(h2.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return vu.INVALID_EVENT(e.type)}a(lD,"validateEvent");function R2(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(R2,"SchemaEventMsg");function A2(e){this.originator=e}a(A2,"UserEventMsg")});var Ti=I((PEe,ED)=>{"use strict";var dD=B(),LEe=te(),sE=X(),fD=zw(),Tc,{sendItcEvent:_D}=Es();function b2(e){try{sE.info("signalSchemaChange called with message:",e),Tc=Tc||Uu();let t=new fD(dD.ITC_EVENT_TYPES.SCHEMA,e);return Tc.schema(t),_D(t)}catch(t){sE.error(t)}}a(b2,"signalSchemaChange");function y2(e){try{sE.trace("signalUserChange called with message:",e),Tc=Tc||Uu();let t=new fD(dD.ITC_EVENT_TYPES.USER,e);return Tc.user(t),_D(t)}catch(t){sE.error(t)}}a(y2,"signalUserChange");ED.exports={signalSchemaChange:b2,signalUserChange:y2}});var iE=I((UEe,mD)=>{"use strict";var hD=te(),O2=B(),N2=X(),I2=k_(),w2=H_(),C2=Ti(),{SchemaEventMsg:D2}=Es(),L2="already exists in";mD.exports=P2;async function P2(e,t,r){if(hD.isEmptyOrZeroLength(r))return r;let n=[];hD.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 M2(e,t.schema,t.name,i)})),s}a(P2,"lmdbCheckForNewAttributes");async function M2(e,t,r,n){let s=new w2(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await U2(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(L2))N2.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(M2,"createNewAttribute");async function U2(e){let t;return t=await I2(e),C2.signalSchemaChange(new D2(process.pid,O2.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(U2,"createAttribute")});var gc=I((xEe,pD)=>{"use strict";var HT=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}};pD.exports=HT});var TD=I((HEe,SD)=>{"use strict";var v2=gc(),x2=B().OPERATIONS_ENUM,kT=class extends v2{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(x2.INSERT,r,n,s,i),this.records=t}};SD.exports=kT});var RD=I((FEe,gD)=>{"use strict";var B2=gc(),H2=B().OPERATIONS_ENUM,FT=class extends B2{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(H2.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};gD.exports=FT});var bD=I((qEe,AD)=>{"use strict";var k2=gc(),F2=B().OPERATIONS_ENUM,GT=class extends k2{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(F2.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};AD.exports=GT});var OD=I(($Ee,yD)=>{"use strict";var G2=gc(),q2=B().OPERATIONS_ENUM,qT=class extends G2{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(q2.DELETE,n,s,t,i),this.original_records=r}};yD.exports=qT});var xu=I((WEe,CD)=>{"use strict";var KEe=require("path"),ND=ft(),V2=TD(),$2=RD(),Y2=bD(),K2=OD(),Rc=Ft(),ID=te(),{CONFIG_PARAMS:W2}=B(),wD=ie();wD.initSync();var oE=B().OPERATIONS_ENUM,{getTransactionAuditStorePath:Q2}=St();CD.exports=z2;async function z2(e,t){if(wD.get(W2.LOGGING_AUDITLOG)===!1)return;let r=Q2(e.schema,e.table),n=await ND.openEnvironment(r,e.table,!0),s=j2(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){ND.initializeDBIs(n,Rc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Rc.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Rc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Rc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),ID.isEmpty(s.user_name)||n.dbis[Rc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Rc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(z2,"writeTransaction");function j2(e,t){let r=ID.isEmpty(e.hdb_user)?void 0:e.hdb_user.username;if(e.operation===oE.INSERT)return new V2(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===oE.UPDATE)return new $2(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===oE.UPSERT)return new Y2(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===oE.DELETE)return new K2(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(j2,"createTransactionObject")});var VT=I((jEe,DD)=>{"use strict";var J2=wu(),zEe=Cu(),Bu=B(),X2=Du(),Z2=fc().insertRecords,e4=ft(),t4=X(),r4=iE(),{getSchemaPath:n4}=St(),s4=xu();DD.exports=i4;async function i4(e){try{let{schema_table:t,attributes:r}=J2(e);X2(e,r,t.hash_attribute),e.schema!==Bu.SYSTEM_SCHEMA_NAME&&(r.includes(Bu.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Bu.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Bu.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Bu.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await r4(e.hdb_auth_header,t,r),s=n4(e.schema,e.table),i=await e4.openEnvironment(s,e.table),o=await Z2(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await s4(e,o)}catch(c){t4.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(i4,"lmdbCreateRecords")});var MD=I((XEe,PD)=>{"use strict";var LD=B(),o4=VT(),a4=Cu(),c4=require("fs-extra"),{getSchemaPath:l4}=St();PD.exports=u4;async function u4(e){let t=[{name:e.schema,createddate:Date.now()}],r=new a4(LD.SYSTEM_SCHEMA_NAME,LD.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await o4(r),await c4.mkdirp(l4(e.schema))}a(u4,"lmdbCreateSchema")});var vD=I((ehe,UD)=>{"use strict";var $T=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}};UD.exports=$T});var kD=I((ihe,HD)=>{"use strict";var xD=ft(),YT=pn(),KT=En().LMDB_ERRORS_ENUM,d4=Ft(),BD=X(),rhe=te(),f4=require("lmdb"),_4=vD(),E4=B(),{OVERFLOW_MARKER:nhe,MAX_SEARCH_KEY_LENGTH:she}=d4,h4=E4.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function m4(e,t,r,n){if(YT.validateEnv(e),t===void 0)throw new Error(KT.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(KT.IDS_REQUIRED):new Error(KT.IDS_MUST_BE_ITERABLE);try{let s=xD.listDBIs(e);xD.initializeDBIs(e,t,s);let i=new _4,o,c=[],l=[];for(let E=0,_=r.length;E<_;E++)try{o=r[E];let h=e.dbis[t].get(o);if(!h||n&&h[h4]>n){i.skipped.push(o);continue}let p=e.dbis[t].ifVersion(o,f4.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let S=0;S<s.length;S++){let g=s[S];if(!h.hasOwnProperty(g)||g===t)continue;let T=e.dbis[g],A=h[g];if(A!=null)try{let N=YT.getIndexedValues(A);if(N)for(let V=0,v=N.length;V<v;V++)T.remove(N[V],o)}catch{BD.warn(`cannot delete from attribute: ${g}, ${A}:${o}`)}}});c.push(p),l.push(o),i.original_records.push(h)}catch(h){BD.warn(h),i.skipped.push(o)}let d=[],u=await Promise.all(c);for(let E=0,_=u.length;E<_;E++)u[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),d.push(E));let f=0;for(let E=0;E<d.length;E++){let _=d[E];i.original_records.splice(_-f,1),f++}return i.txn_time=YT.getNextMonotonicTime(),i}catch(s){throw s}}a(m4,"deleteRecords");HD.exports={deleteRecords:m4}});var Hu=I((ahe,GD)=>{"use strict";var Ac=te(),p4=kD(),S4=ft(),{getSchemaPath:T4}=St(),g4=xu(),R4=X();GD.exports=A4;async function A4(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Ac.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Ac.isEmptyOrZeroLength(e.hash_values)&&!Ac.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Ac.isEmpty(l)||e.hash_values.push(l)}}if(Ac.isEmptyOrZeroLength(e.hash_values))return FD([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Ac.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=T4(e.schema,e.table),i=await S4.openEnvironment(s,e.table),o=await p4.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await g4(e,o)}catch(c){R4.error(`unable to write transaction due to ${c.message}`)}return FD(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(A4,"lmdbDeleteRecords");function FD(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(FD,"createDeleteResponse")});var QT=I((uhe,qD)=>{"use strict";var b4=B(),lhe=pn();function WT(e,t){let r=Object.create(null);if(t.length===1&&b4.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(WT,"parseRow");function y4(e,t,r,n){let s=WT(r,e);n.push(s)}a(y4,"searchAll");function O4(e,t,r,n){let s=WT(r,e);n[t]=s}a(O4,"searchAllToMap");function N4(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(N4,"iterateDBI");function na(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(na,"pushResults");function I4(e,t,r,n,s,i){t.toString().endsWith(e)&&na(t,r,n,s,i)}a(I4,"endsWith");function w4(e,t,r,n,s,i){t.toString().includes(e)&&na(t,r,n,s,i)}a(w4,"contains");function C4(e,t,r,n,s,i){t>e&&na(t,r,n,s,i)}a(C4,"greaterThanCompare");function D4(e,t,r,n,s,i){t>=e&&na(t,r,n,s,i)}a(D4,"greaterThanEqualCompare");function L4(e,t,r,n,s,i){t<e&&na(t,r,n,s,i)}a(L4,"lessThanCompare");function P4(e,t,r,n,s,i){t<=e&&na(t,r,n,s,i)}a(P4,"lessThanEqualCompare");qD.exports={parseRow:WT,searchAll:y4,searchAllToMap:O4,iterateDBI:N4,endsWith:I4,contains:w4,greaterThanCompare:C4,greaterThanEqualCompare:D4,lessThanCompare:L4,lessThanEqualCompare:P4,pushResults:na}});var bc=I((hhe,zD)=>{"use strict";var oo=ft(),fhe=X(),Nn=pn(),aE=Ft(),Gt=En().LMDB_ERRORS_ENUM,_he=te(),M4=B(),cE=QT(),{parseRow:U4}=cE,Ehe=require("lmdb"),{OVERFLOW_MARKER:VD,MAX_SEARCH_KEY_LENGTH:v4}=aE;function $D(e,t,r,n=!1,s=void 0,i=void 0){return sa(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($D,"iterateFullIndex");function ku(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,d=!1){return sa(e,t,r,(u,f,E,_)=>{let T={transaction:u,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!d,exclusiveStart:i===!0?d:l};return _===r?(T.values=!1,f.getRange(T).map(A=>({value:A}))):f.getRange(T)})}a(ku,"iterateRangeBetween");function sa(e,t,r,n){let s=e.database||e,i=oo.openDBI(s,r);i[aE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&oo.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(sa,"setupTransaction");function YD(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(VD)){if(!s)if(r)s=oo.openDBI(e,r);else{let l=oo.listDBIs(e);for(let d=0,u=l.length;d<u&&(s=oo.openDBI(e,l[d]),!s[aE.DBI_DEFINITION_NAME].is_hash_attribute);d++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(YD,"getOverflowCheck");function x4(e,t,r,n=!1,s=void 0,i=void 0){if(Nn.validateEnv(e),t===void 0)throw new Error(Gt.HASH_ATTRIBUTE_REQUIRED);return sa(e,t,t,(o,c,l)=>(lE(r),r=Fu(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(d=>U4(d.value,r))))}a(x4,"searchAll");function B4(e,t,r,n=!1,s=void 0,i=void 0){if(Nn.validateEnv(e),t===void 0)throw new Error(Gt.HASH_ATTRIBUTE_REQUIRED);lE(r),r=Fu(e.database||e,r);let o=new Map;for(let{key:c,value:l}of $D(e,t,t,n,s,i))o.set(c,cE.parseRow(l,r));return o}a(B4,"searchAllToMap");function H4(e,t,r=!1,n=void 0,s=void 0){if(Nn.validateEnv(e),t===void 0)throw new Error(Gt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=$D(e,void 0,t,r,n,s),c=o.transaction,l=YD(c.database,c,void 0,t);for(let{key:d,value:u}of o){let f=l(d,u);i[f]===void 0&&(i[f]=[]),i[f].push(u)}return i}a(H4,"iterateDBI");function k4(e,t){if(Nn.validateEnv(e),t===void 0)throw new Error(Gt.HASH_ATTRIBUTE_REQUIRED);return oo.statDBI(e,t).entryCount}a(k4,"countAll");function F4(e,t,r,n,s=!1,i=void 0,o=void 0){return ao(e,r,n),sa(e,t,r,(c,l,d,u)=>(n=Nn.convertKeyValueToWrite(n),u===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(f=>({key:n,value:f}))))}a(F4,"equals");function G4(e,t,r){return ao(e,t,r),oo.openDBI(e,t).getValuesCount(r)}a(G4,"count");function q4(e,t,r,n,s=!1,i=void 0,o=void 0){return ao(e,r,n),sa(e,null,r,(c,l)=>{n=Nn.convertKeyValueToWrite(n);let d=!0;typeof n=="number"&&(d=!1);let u;if(s===!0){let f;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){f=E;break}return f!==void 0&&(Number.isInteger(o)?o++:i++),u=l.getRange({transaction:c,start:f,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:_}=E;if(_!==f){if(_.toString().startsWith(n))return E;if(d===!0)return u.DONE}}),u.filter(E=>E)}else return u=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(f=>{if(f.key.toString().startsWith(n))return f;if(d===!0)return u.DONE}),d?u:u.filter(f=>f)})}a(q4,"startsWith");function V4(e,t,r,n,s=!1,i=void 0,o=void 0){return KD(e,t,r,n,s,i,o,!0)}a(V4,"endsWith");function KD(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return ao(e,r,n),sa(e,null,r,(l,d,u,f)=>{let E=YD(u,l,f,r);return o=Number.isInteger(o)?o:0,d.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(_=>{let h=_.toString();return h.endsWith(VD)?d.getValues(_,{transaction:l}).map(p=>{let S=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))?d[aE.DBI_DEFINITION_NAME].is_hash_attribute?{key:_,value:_}:d.getValues(_,{transaction:l}).map(p=>({key:_,value:p})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(KD,"contains");function $4(e,t,r,n,s=!1,i=void 0,o=void 0){ao(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),ku(e,t,r,n,l,s,i,o,!0,!1)}a($4,"greaterThan");function Y4(e,t,r,n,s=!1,i=void 0,o=void 0){ao(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),ku(e,t,r,n,l,s,i,o,!1,!1)}a(Y4,"greaterThanEqual");function K4(e,t,r,n,s=!1,i=void 0,o=void 0){ao(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),ku(e,t,r,l,n,s,i,o,!1,!0)}a(K4,"lessThan");function W4(e,t,r,n,s=!1,i=void 0,o=void 0){ao(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),ku(e,t,r,l,n,s,i,o,!1,!1)}a(W4,"lessThanEqual");function Q4(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Nn.validateEnv(e),r===void 0)throw new Error(Gt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Gt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Gt.END_VALUE_REQUIRED);if(n=Nn.convertKeyValueToWrite(n),s=Nn.convertKeyValueToWrite(s),n>s)throw new Error(Gt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return ku(e,t,r,n,s,i,o,c)}a(Q4,"between");function z4(e,t,r,n){Nn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Gt.HASH_ATTRIBUTE_REQUIRED);if(lE(r),r=Fu(s,r),n===void 0)throw new Error(Gt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=cE.parseRow(c,r)),o}a(z4,"searchByHash");function j4(e,t,r){Nn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Gt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Gt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(j4,"checkHashExists");function J4(e,t,r,n,s=[]){return QD(e,t,r,n,s),WD(e,t,r,n,s).map(i=>i[1])}a(J4,"batchSearchByHash");function X4(e,t,r,n,s=[]){QD(e,t,r,n,s);let i=new Map;for(let[o,c]of WD(e,t,r,n,s))i.set(o,c);return i}a(X4,"batchSearchByHashToMap");function WD(e,t,r,n,s=[]){return sa(e,t,t,(i,o,c)=>{r=Fu(c,r);let l=r.length<3;return n.map(d=>{let u=c.dbis[t].get(d,{transaction:i,lazy:l});if(u)return[d,cE.parseRow(u,r)];s.push(d)}).filter(d=>d)})}a(WD,"batchHashSearch");function QD(e,t,r,n,s){if(Nn.validateEnv(e),t===void 0)throw new Error(Gt.HASH_ATTRIBUTE_REQUIRED);if(lE(r),n==null)throw new Error(Gt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Gt.IDS_MUST_BE_ITERABLE)}a(QD,"initializeBatchSearchByHash");function lE(e){if(!Array.isArray(e))throw e===void 0?new Error(Gt.FETCH_ATTRIBUTES_REQUIRED):new Error(Gt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(lE,"validateFetchAttributes");function ao(e,t,r){if(Nn.validateEnv(e),t===void 0)throw new Error(Gt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Gt.SEARCH_VALUE_REQUIRED);if(r?.length>v4)throw new Error(Gt.SEARCH_VALUE_TOO_LARGE)}a(ao,"validateComparisonFunctions");function Fu(e,t){return t.length===1&&M4.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=oo.listDBIs(e)),t}a(Fu,"setGetWholeRowAttributes");zD.exports={searchAll:x4,searchAllToMap:B4,count:G4,countAll:k4,equals:F4,startsWith:q4,endsWith:V4,contains:KD,searchByHash:z4,setGetWholeRowAttributes:Fu,batchSearchByHash:J4,batchSearchByHashToMap:X4,checkHashExists:j4,iterateDBI:H4,greaterThan:$4,greaterThanEqual:Y4,lessThan:K4,lessThanEqual:W4,between:Q4}});var yc=I((phe,eL)=>{var jD=require("lodash"),JD=mt(),Le=require("joi"),Z4=te(),{hdb_schema_table:Gu,checkValidTable:XD,hdb_table:ZD,hdb_database:uE}=Bs(),{handleHDBError:eJ,hdb_errors:tJ}=ce(),{getDatabases:rJ}=(Ne(),ae(it)),{HTTP_STATUS_CODES:nJ}=tJ,sJ=Le.object({database:uE,schema:uE,table:ZD,search_attribute:Gu,search_value:Le.any().required(),get_attributes:Le.array().min(1).items(Le.alternatives(Gu,Le.object())).optional(),desc:Le.bool(),limit:Le.number().integer().min(1),offset:Le.number().integer().min(0)}),iJ=Le.object({database:uE,schema:uE,table:ZD,operator:Le.string().valid("and","or").default("and").lowercase(),offset:Le.number().integer().min(0),limit:Le.number().integer().min(1),get_attributes:Le.array().min(1).items(Le.alternatives(Gu,Le.object())).optional(),sort:Le.object({attribute:Le.alternatives(Gu,Le.array().min(1)),descending:Le.bool().optional()}).optional(),conditions:Le.array().min(1).items(Le.alternatives(Le.object({operator:Le.string().valid("and","or").default("and").lowercase(),conditions:Le.array()}),Le.object({search_attribute:Le.alternatives(Gu,Le.array().min(1)),search_type:Le.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:Le.when("search_type",{switch:[{is:"equals",then:Le.any()},{is:"between",then:Le.array().items(Le.alternatives([Le.string(),Le.number()])).length(2)}],otherwise:Le.alternatives(Le.string(),Le.number())}).required()}))).required()});eL.exports=function(e,t){let r=null;switch(t){case"value":r=JD.validateBySchema(e,sJ);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(XD("database",e.schema)),i(XD("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=JD.validateBySchema(e,iJ);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=Z4.checkGlobalSchemaTable(e.schema,e.table);if(s)return eJ(new Error,s,nJ.NOT_FOUND);let o=rJ()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(u=>{for(let f=0,E=u.conditions.length;f<E;f++){let _=u.conditions[f];_.conditions?l(_):c.push(_.search_attribute)}},"addConditions");t==="conditions"&&l(e);let d=jD.filter(c,u=>u!=="*"&&u.attribute!=="*"&&!Array.isArray(u)&&!u.name&&!jD.some(o,f=>f===u||f.attribute===u||f.attribute===u.attribute));if(d&&d.length>0){let u=d.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var zT=I((The,tL)=>{"use strict";var oJ=ft(),aJ=yc(),{getSchemaPath:cJ}=St();tL.exports=lJ;function lJ(e){let t=aJ(e,"hashes");if(t)throw t;let r=cJ(e.schema,e.table);return oJ.openEnvironment(r,e.table)}a(lJ,"initialize")});var jT=I((Rhe,rL)=>{"use strict";var uJ=bc(),dJ=zT();rL.exports=fJ;async function fJ(e){let t=await dJ(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return uJ.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(fJ,"lmdbGetDataByHash")});var Oc=I((bhe,nL)=>{"use strict";var JT=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};nL.exports=JT});var iL=I((Nhe,sL)=>{"use strict";var Ohe=Oc(),_J=bc(),EJ=zT();sL.exports=hJ;async function hJ(e){let t=await EJ(e),r=global.hdb_schema[e.schema][e.table];return _J.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(hJ,"lmdbSearchByHash")});var Gs=I((whe,oL)=>{"use strict";var XT=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,d=void 0,u=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=d,this.offset=u}};oL.exports=XT});var dE=I((Dhe,fL)=>{"use strict";var vr=bc(),mJ=ft(),pJ=te(),Pe=Ft(),ia=B(),SJ=Qo(),aL=En().LMDB_ERRORS_ENUM,{getSchemaPath:TJ}=St(),gi=ia.SEARCH_WILDCARDS;async function gJ(e,t,r){let n;e.schema===ia.SYSTEM_SCHEMA_NAME?n=SJ[e.table]:n=global.hdb_schema[e.schema][e.table];let s=dL(e,n.hash_attribute,r,t);return lL(e,s,n.hash_attribute,r)}a(gJ,"prepSearch");async function lL(e,t,r,n){let s=TJ(e.schema,e.table),i=await mJ.openEnvironment(s,e.table),o=uL(i,e,t,r),c=o.transaction||i;if([Pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,Pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,Pe.SEARCH_TYPES.SEARCH_ALL,Pe.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(RJ(e,r)===!1){let u=e.search_attribute;if(u===r)return n?cL(o,()=>!0):o.map(E=>({[r]:E.key}));let f=a(E=>({[r]:E.value,[u]:E.key}),"toObject");return n?cL(o,f):o.map(f)}let d=e.search_attribute===r?o.map(u=>u.key):o.map(u=>u.value);return n===!0?vr.batchSearchByHashToMap(c,r,e.get_attributes,d):vr.batchSearchByHash(c,r,e.get_attributes,d)}a(lL,"executeSearch");function uL(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case Pe.SEARCH_TYPES.EQUALS:s=vr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case Pe.SEARCH_TYPES.CONTAINS:s=vr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case Pe.SEARCH_TYPES.ENDS_WITH:case Pe.SEARCH_TYPES._ENDS_WITH:s=vr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Pe.SEARCH_TYPES.STARTS_WITH:case Pe.SEARCH_TYPES._STARTS_WITH:s=vr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return vr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return vr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Pe.SEARCH_TYPES.SEARCH_ALL:return vr.searchAll(e,n,t.get_attributes,o,c,l);case Pe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return vr.searchAllToMap(e,n,t.get_attributes,o,c,l);case Pe.SEARCH_TYPES.BETWEEN:s=vr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case Pe.SEARCH_TYPES.GREATER_THAN:case Pe.SEARCH_TYPES._GREATER_THAN:s=vr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Pe.SEARCH_TYPES.GREATER_THAN_EQUAL:case Pe.SEARCH_TYPES._GREATER_THAN_EQUAL:s=vr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case Pe.SEARCH_TYPES.LESS_THAN:case Pe.SEARCH_TYPES._LESS_THAN:s=vr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Pe.SEARCH_TYPES.LESS_THAN_EQUAL:case Pe.SEARCH_TYPES._LESS_THAN_EQUAL:s=vr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(uL,"searchByType");function cL(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(cL,"createMapFromIterable");function RJ(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(RJ,"checkToFetchMore");function dL(e,t,r,n){if(pJ.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),gi.indexOf(s)>-1)return r===!0?Pe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Pe.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(gi[0])<0&&s.indexOf(gi[1])<0)return c===!0?r===!0?Pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:Pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:Pe.SEARCH_TYPES.EQUALS;if(gi.indexOf(i)>=0&&gi.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),Pe.SEARCH_TYPES.CONTAINS;if(gi.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Pe.SEARCH_TYPES.ENDS_WITH;if(gi.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),Pe.SEARCH_TYPES.STARTS_WITH;if(s.includes(gi[0])||s.includes(gi[1]))return Pe.SEARCH_TYPES.EQUALS;throw new Error(aL.UNKNOWN_SEARCH_TYPE)}else switch(n){case ia.VALUE_SEARCH_COMPARATORS.BETWEEN:return Pe.SEARCH_TYPES.BETWEEN;case ia.VALUE_SEARCH_COMPARATORS.GREATER:return Pe.SEARCH_TYPES.GREATER_THAN;case ia.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Pe.SEARCH_TYPES.GREATER_THAN_EQUAL;case ia.VALUE_SEARCH_COMPARATORS.LESS:return Pe.SEARCH_TYPES.LESS_THAN;case ia.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Pe.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(aL.UNKNOWN_SEARCH_TYPE)}}a(dL,"createSearchTypeFromSearchObject");fL.exports={executeSearch:lL,createSearchTypeFromSearchObject:dL,prepSearch:gJ,searchByType:uL}});var EL=I((Mhe,_L)=>{"use strict";var Phe=Gs(),AJ=yc(),bJ=te(),yJ=B(),OJ=dE();_L.exports=NJ;function NJ(e,t){if(!bJ.isEmpty(t)&&yJ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=AJ(e,"value");if(n)throw n;return OJ.prepSearch(e,t,!0)}a(NJ,"lmdbGetDataByValue")});var qu=I((xhe,hL)=>{"use strict";var vhe=Gs(),IJ=yc(),wJ=te(),CJ=B(),DJ=dE();hL.exports=LJ;async function LJ(e,t){if(!wJ.isEmpty(t)&&CJ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=IJ(e,"value");if(n)throw n;return DJ.prepSearch(e,t,!1)}a(LJ,"lmdbSearchByValue")});var pL=I((khe,mL)=>{"use strict";var Hhe=Ft(),ZT=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}},eg=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},tg=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};mL.exports={SearchByConditionsObject:ZT,SearchCondition:eg,SortAttribute:tg}});var AL=I((Vhe,RL)=>{"use strict";var Ghe=pL().SearchByConditionsObject,PJ=Gs(),MJ=yc(),rg=bc(),fE=Ft(),{Resource:qhe}=(us(),ae(ng)),gL=dE(),UJ=QT(),vJ=require("lodash"),{getSchemaPath:xJ}=St(),SL=ft(),{handleHDBError:BJ,hdb_errors:HJ}=ce(),{HTTP_STATUS_CODES:kJ}=HJ,FJ=1e8;RL.exports=GJ;async function GJ(e){let t=MJ(e,"conditions");if(t)throw BJ(t,t.message,kJ.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=xJ(e.schema,e.table),n=await SL.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let d of e.conditions)SL.openDBI(n,d.search_attribute);let i=vJ.sortBy(e.conditions,d=>{if(d.estimated_count===void 0){let u=d.search_type;u===fE.SEARCH_TYPES.EQUALS?d.estimated_count=rg.count(n,d.search_attribute,d.search_value):u===fE.SEARCH_TYPES.CONTAINS||u===fE.SEARCH_TYPES.ENDS_WITH?d.estimated_count=1/0:d.estimated_count=FJ}return d.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await TL(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let d=n.dbis[s.hash_attribute],u=i.slice(1).map(gL.filterByType),f=u.length,E=rg.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(_=>d.get(_,{transaction:o,lazy:!0})),f>0&&(l=l.filter(_=>{for(let h=0;h<f;h++)if(!u[h](_))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(_=>UJ.parseRow(_,E))}else{for(let f=1;f<i.length;f++){let E=i[f],_=await TL(o,e,E,s.hash_attribute);c=c.concat(_)}let d=new Set,u=e.offset||0;c=c.filter(f=>d.has(f)?!1:(d.add(f),!0)).slice(u,e.limit&&e.limit+u),l=rg.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(GJ,"lmdbSearchByConditions");async function TL(e,t,r,n){let s=new PJ(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===fE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,gL.searchByType(e,s,i,n).map(o=>o.value)}a(TL,"executeConditionSearch")});var Vu=I((Yhe,bL)=>{"use strict";var qJ=B().OPERATIONS_ENUM,sg=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=qJ.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};bL.exports=sg});var ig=I((Whe,LL)=>{"use strict";var IL=Gs(),wL=Vu(),CL=qu(),DL=Hu(),Kr=B(),yL=te(),OL=ft(),{getTransactionAuditStorePath:VJ,getSchemaPath:$J}=St(),NL=X();LL.exports=YJ;async function YJ(e){try{if(yL.isEmpty(global.hdb_schema[e.schema])||yL.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await KJ(e),await WJ(e);let t=$J(e.schema,e.table);try{await OL.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")NL.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=VJ(e.schema,e.table);await OL.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")NL.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(YJ,"lmdbDropTable");async function KJ(e){let t=new IL(Kr.SYSTEM_SCHEMA_NAME,Kr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Kr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Kr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await CL(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 wL(Kr.SYSTEM_SCHEMA_NAME,Kr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await DL(s)}a(KJ,"deleteAttributesFromSystem");async function WJ(e){let t=new IL(Kr.SYSTEM_SCHEMA_NAME,Kr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Kr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Kr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Kr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Kr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await CL(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 wL(Kr.SYSTEM_SCHEMA_NAME,Kr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await DL(s)}catch(i){throw i}}a(WJ,"dropTableFromSystem")});var ML=I((zhe,PL)=>{"use strict";var QJ=require("fs-extra"),zJ=Gs(),jJ=Oc(),JJ=Vu(),XJ=ig(),ZJ=Hu(),e3=jT(),t3=qu(),Ri=B(),{getSchemaPath:r3}=St(),{handleHDBError:n3,hdb_errors:s3}=ce(),{HDB_ERROR_MSGS:i3,HTTP_STATUS_CODES:o3}=s3;PL.exports=a3;async function a3(e){let t;try{t=await c3(e.schema);let r=new zJ(Ri.SYSTEM_SCHEMA_NAME,Ri.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Ri.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Ri.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await t3(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await XJ(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new JJ(Ri.SYSTEM_SCHEMA_NAME,Ri.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await ZJ(s);let i=r3(t);await QJ.remove(i)}catch(r){throw r}}a(a3,"lmdbDropSchema");async function c3(e){let t=new jJ(Ri.SYSTEM_SCHEMA_NAME,Ri.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Ri.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await e3(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw n3(new Error,i3.SCHEMA_NOT_FOUND(e),o3.NOT_FOUND,void 0,void 0,!0);return n}a(c3,"validateDropSchema")});var ag=I((Jhe,UL)=>{"use strict";var og=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};UL.exports=og});var xL=I((eme,vL)=>{"use strict";var l3=require("fs-extra"),_E=ft(),{getTransactionAuditStorePath:u3}=St(),cg=Ft(),Zhe=ag();vL.exports=d3;async function d3(e){let t;try{let r=u3(e.schema,e.table);await l3.mkdirp(r),t=await _E.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{_E.createDBI(t,cg.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),_E.createDBI(t,cg.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),_E.createDBI(t,cg.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(d3,"createTransactionsAuditEnvironment")});var kL=I((nme,HL)=>{"use strict";var lg=B(),BL=ft(),f3=fc(),{getSystemSchemaPath:_3,getSchemaPath:E3}=St(),rme=Qo(),h3=k_(),ug=H_(),m3=X(),p3=xL();HL.exports=S3;async function S3(e,t){let r=E3(t.schema,t.table),n=new ug(t.schema,t.table,lg.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new ug(t.schema,t.table,lg.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new ug(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await BL.createEnvironment(r,t.table),e!==void 0){let o=await BL.openEnvironment(_3(),lg.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await f3.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await dg(n),await dg(s),await dg(i)}await p3(t)}catch(o){throw o}}a(S3,"lmdbCreateTable");async function dg(e){try{await h3(e)}catch(t){m3.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(dg,"createAttribute")});var GL=I((ime,FL)=>{"use strict";var T3=wu(),g3=Du(),R3=iE(),$u=B(),A3=fc().updateRecords,b3=ft(),{getSchemaPath:y3}=St(),O3=xu(),N3=X();FL.exports=I3;async function I3(e){try{let{schema_table:t,attributes:r}=T3(e);g3(e,r,t.hash_attribute),e.schema!==$u.SYSTEM_SCHEMA_NAME&&(r.includes($u.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push($u.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes($u.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push($u.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await R3(e.hdb_auth_header,t,r),s=y3(e.schema,e.table),i=await b3.openEnvironment(s,e.table),o=await A3(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await O3(e,o)}catch(c){N3.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(I3,"lmdbUpdateRecords")});var VL=I((ame,qL)=>{"use strict";var w3=B().OPERATIONS_ENUM,fg=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=w3.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};qL.exports=fg});var YL=I((ume,$L)=>{"use strict";var lme=VL(),C3=wu(),D3=Du(),L3=iE(),Yu=B(),P3=fc().upsertRecords,M3=ft(),{getSchemaPath:U3}=St(),v3=xu(),x3=X(),{handleHDBError:B3,hdb_errors:H3}=ce();$L.exports=k3;async function k3(e){let t;try{t=C3(e)}catch(l){throw B3(l,l.message,H3.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;D3(e,n,r.hash_attribute),e.schema!==Yu.SYSTEM_SCHEMA_NAME&&(n.includes(Yu.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(Yu.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(Yu.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(Yu.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await L3(e.hdb_auth_header,r,n),i=U3(e.schema,e.table),o=await M3.openEnvironment(i,e.table),c=await P3(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await v3(e,c)}catch(l){x3.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(k3,"lmdbUpsertRecords")});var WL=I((fme,KL)=>{"use strict";var _g=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};KL.exports=_g});var zL=I((Eme,QL)=>{"use strict";var Eg=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}};QL.exports=Eg});var XL=I((pme,JL)=>{"use strict";var hg=ft(),{getTransactionAuditStorePath:F3}=St(),mme=WL(),Ku=Ft(),G3=te(),jL=zL(),q3=require("util").promisify,V3=q3(setTimeout),$3=1e4,Y3=100;JL.exports=K3;async function K3(e){let t=F3(e.schema,e.table),r=await hg.openEnvironment(t,e.table,!0),n=hg.listDBIs(r);hg.initializeDBIs(r,Ku.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new jL;do s=await W3(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 V3(Y3);while(s.transactions_deleted>0);return i}a(K3,"deleteAuditLogsBefore");async function W3(e,t){let r=new jL;try{let n=e.dbis[Ku.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[Ku.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];G3.isEmpty(c)||(s=e.dbis[Ku.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[Ku.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>$3)break}return await s,r}catch(n){throw n}}a(W3,"deleteTransactions")});var eP=I((Tme,ZL)=>{"use strict";var mg=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};ZL.exports=mg});var rP=I((Ame,tP)=>{"use strict";var Q3=Gs(),z3=Vu(),Rme=eP(),qs=B(),j3=te(),pg=ft(),J3=Qo(),X3=qu(),Z3=Hu(),{getSchemaPath:eX}=St();tP.exports=tX;async function tX(e,t=!0){let r;e.schema===qs.SYSTEM_SCHEMA_NAME?r=J3[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await nX(e),s=eX(e.schema,e.table),i=await pg.openEnvironment(s,e.table);return t===!0&&await rX(e,i,r.hash_attribute),pg.dropDBI(i,e.attribute),n}a(tX,"lmdbDropAttribute");async function rX(e,t,r){let n=pg.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let d={};for(let u in c)u!==i&&(d[u]=c[u]);s=t.dbis[r].put(o,d,l)}await s}a(rX,"removeAttributeFromAllObjects");async function nX(e){let t=new Q3(qs.SYSTEM_SCHEMA_NAME,qs.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,qs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[qs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,qs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await X3(t)).filter(o=>o[qs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(j3.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[qs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new z3(qs.SYSTEM_SCHEMA_NAME,qs.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Z3(i)}a(nX,"dropAttributeFromSystem")});var cP=I((Ome,aP)=>{"use strict";var Sg=ft(),Nc=Ft(),yme=pn(),Tg=B(),nP=te(),{getTransactionAuditStorePath:sX}=St(),iX=bc(),EE=gc(),oX=X();aP.exports=aX;async function aX(e){let t=sX(e.schema,e.table),r=await Sg.openEnvironment(t,e.table,!0),n=Sg.listDBIs(r);Sg.initializeDBIs(r,Nc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Tg.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return sP(r,e.search_values);case Tg.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,lX(r,e.search_values,s);case Tg.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return cX(r,e.search_values);default:return sP(r)}}a(aX,"readAuditLog");function sP(e,t=[0,Date.now()]){nP.isEmpty(t[0])&&(t[0]=0),nP.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Nc.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 EE,s))}a(sP,"searchTransactionsByTimestamp");function cX(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[Nc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,oP(e,i))}return Object.fromEntries(r)}a(cX,"searchTransactionsByUsername");function lX(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let d=t[c],u=iX.equals(e,Nc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Nc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,d);for(let{value:f}of u){let E=Number(f);n.has(E)?n.get(E).push(d.toString()):n.set(E,[d.toString()])}}let s=Array.from(n.keys()),i=oP(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],d=l.timestamp,u=n.get(d);iP(l,"records",r,u,o),iP(l,"original_records",r,u,o)}return Object.fromEntries(o)}a(lX,"searchTransactionsByHashValues");function iP(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let d=s.get(l),u=d[d.length-1];if(u.timestamp===i)u[t]=[c];else{let f=new EE(e.operation,e.user_name,i,void 0);f[t]=[c],d.push(f)}}else{let d=new EE(e.operation,e.user_name,i,void 0);d[t]=[c],s.set(l,[d])}}}a(iP,"loopRecords");function oP(e,t){let r=[];try{let n=e.dbis[Nc.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 EE,i);r.push(o)}}catch(i){oX.warn(i)}return r}catch(n){throw n}}a(oP,"batchSearchTransactions")});var uP=I((Cme,lP)=>{"use strict";var{getSchemaPath:Ime}=St(),wme=ft(),{database:uX}=(Ne(),ae(it));lP.exports={writeTransaction:dX};async function dX(e,t,r){return uX({database:e,table:t}).transaction(r)}a(dX,"writeTransaction")});var EP=I((Lme,_P)=>{"use strict";var{getSchemaPath:dP}=St(),fP=ft();_P.exports={flush:fX,resetReadTxn:_X};async function fX(e,t){return(await fP.openEnvironment(dP(e,t),t.toString())).flushed}a(fX,"flush");async function _X(e,t){try{(await fP.openEnvironment(dP(e,t),t.toString())).resetReadTxn()}catch{}}a(_X,"resetReadTxn")});var SP=I((Mme,pP)=>{"use strict";var{Readable:EX}=require("stream"),{getDatabases:hX}=(Ne(),ae(it)),{readSync:mX,openSync:pX,createReadStream:hP}=require("fs"),{open:SX}=require("lmdb"),mP=Ru(),TX=Au(),{AUDIT_STORE_OPTIONS:gX}=(Ei(),ae(TP)),{INTERNAL_DBIS_NAME:RX,AUDIT_STORE_NAME:AX}=Ft();pP.exports=yX;var gg=32768,bX=100;async function yX(e){let t=e.database||e.schema||"data",r=hX()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let d=r[s[0]];if(!d)throw new Error(`Can not find table ${s[0]}`);let u=d.dbisDB,f=SX({noSync:!0,maxDbs:TX.MAX_DBS}),E,_=f.openDB(RX,new mP(!1)),h=u.useReadTransaction(),p=0,S=a(async function(T,A){A.encoding="binary",A.encoder=void 0;let N=f.openDB(T,A),V=u.openDB(T,A);for(let{key:v,version:J,value:$}of V.getRange({start:null,transaction:h,versions:V.useVersions}))E=N.put(v,$,J),p++%bX===0&&(await new Promise(F=>setTimeout(F,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:T,value:A}of u.getRange({transaction:h,start:!1}))if(s.some(N=>T.startsWith?.(N+"/"))){_.put(T,A);let[,N]=T.split("/"),V=!N,v=new mP(!V,V);await S(T,v)}e.include_audit&&await S(AX,Object.assign({},gX)),await E;let g=hP(f.path);return g.headers=l(),g.on("close",()=>{h.done(),f.close()}),g}let o=r[Object.keys(r)[0]].primaryStore,c=pX(o.path);return o.transaction(()=>{let d=Buffer.alloc(gg);mX(c,d,0,gg),o.resetReadTxn();let u=o.useReadTransaction();u.renew();let f=hP(null,{fd:c,start:gg}),E=new EX.from(async function*(){yield d;for await(let _ of f)u.openTimer&&(u.openTimer=0),yield _;u.done()}());return E.headers=l(),E});function l(){let d=new Map;return d.set("content-type","application/octet-stream"),d.set("content-disposition",`attachment; filename="${t}"`),d.set("date",n),d}}a(yX,"getBackup")});var AP=I((vme,RP)=>{"use strict";var OX=X(),{handleHDBError:NX}=ce(),IX=ZI(),wX=k_(),CX=VT(),DX=MD(),LX=Hu(),PX=jT(),MX=iL(),UX=EL(),vX=qu(),xX=AL(),BX=ML(),HX=kL(),kX=GL(),FX=YL(),GX=XL(),qX=ig(),VX=rP(),$X=cP(),YX=uP(),gP=EP(),KX=SP(),Rg=class extends IX{static{a(this,"LMDBBridge")}async searchByConditions(t){return xX(t)}async getDataByHash(t){return await PX(t)}async searchByHash(t){return await MX(t)}async getDataByValue(t,r){return await UX(t,r)}async searchByValue(t){return await vX(t)}async createSchema(t){return await DX(t)}async dropSchema(t){return await BX(t)}async createTable(t,r){return await HX(t,r)}async dropTable(t){return await qX(t)}async createAttribute(t){return await wX(t)}async createRecords(t){return await CX(t)}async updateRecords(t){return await kX(t)}async upsertRecords(t){try{return await FX(t)}catch(r){throw NX(r,null,null,OX.ERR,r)}}async deleteRecords(t){return await LX(t)}async dropAttribute(t){return await VX(t)}async deleteAuditLogsBefore(t){return await GX(t)}async readAuditLog(t){return await $X(t)}writeTransaction(t,r,n){return YX.writeTransaction(t,r,n)}flush(t,r){return gP.flush(t,r)}resetReadTxn(t,r){return gP.resetReadTxn(t,r)}getBackup(t){return KX(t)}};RP.exports=Rg});function DP(e){bg=e}function jX(){zX=setInterval(function(){for(let e of Ag)if(e.stale){let t=e[Me]?.url;NP.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},QX).unref()}var yg,OP,NP,IP,wP,CP,bP,Ag,WX,Wu,yP,bg,oa,hE,QX,zX,mE=Oe(()=>{yg=U(pn()),OP=U(ce()),NP=U(X());us();IP=U(ie()),wP=U(B()),CP=U(te()),bP=100,Ag=new Set,WX=(0,CP.convertToMS)(IP.get(wP.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(DP,"replicationConfirmation");oa=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxnsUsed=1,this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxn.openTimer&&(this.readTxn.openTimer=0),Ag.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(Ag.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(Wu&&!this.overloadChecked&&performance.now()-yP>WX)throw new OP.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp=t.timestamp||(0,yg.getNextMonotonicTime)());let n=t.retries||0;if(this.validated<this.writes.length)try{let f=this.validated;this.validated=this.writes.length;for(let _=f;_<this.validated;_++)this.writes[_]?.validate?.(this.timestamp);let E;for(let _=f;_<this.validated;_++){let h=this.writes[_];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let _=0;_<2;_++){let h;for(let p=f;p<this.validated;p++){let S=this.writes[p];if(!S)continue;let g=S[_===0?"before":"beforeIntermediate"];if(g){let T=g();h?h.push?h.push(T):h=[h,T]:h=T}}h&&await(h.push?Promise.all(h):h)}}catch(_){throw this.abort(),_}return this.commit(t)})()}catch(f){throw this.abort(),f}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(f=>f);let c=a(f=>{f.commit(r,f.entry,n)},"doWrite"),l=a(()=>{let f=this.writes[o++];if(f)if(f.key){n>0&&(f.entry=f.store.getEntry(f.key));let E=f.store.ifVersion(f.key,f.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),d=this.lmdbDb;if(this.writes.length>0&&(d?.retryRisk&&(d.retryRisk*=.99),this.writes.length+(d?.retryRisk||0)<bP>>n?l():s=this.writes[0].store.transaction(()=>{for(let f of this.writes)f.entry=f.store.getEntry(f.key),c(f);return!0})),s)return Wu||(Wu=s,yP=performance.now(),Wu.then(()=>{Wu=null})),s.then(f=>{if(f){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let E=this.writes[0].store.rootStore.databaseName,_=this.writes[this.writes.length-1];bg&&_&&i.push(bg(E,_.store.getEntry(_.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return d&&(d.retryRisk=(d.retryRisk||0)+bP/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let u={txnTime:r};if(this.next){let f=this.next?.commit(t);if(f?.then)return f?.then(E=>({txnTime:r,next:E}));u.next=f}return u}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},hE=class extends oa{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,yg.getNextMonotonicTime)())}getReadTxn(){}},QX=3e4;a(jX,"startMonitoringTxns");jX()});function Tt(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 oa;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n[Me]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var LP,aa=Oe(()=>{LP=require("../../index");us();mE();a(Tt,"transaction");(0,LP._assignPackageExport)("transaction",Tt);Tt.commit=function(e){let t=(e[Me]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Tt.abort=function(e){let t=(e[Me]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var FP={};Ze(FP,{ResourceBridge:()=>Ig});function wg({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 MP(e,t){let r=Vs(e),n=wg(e,r);if(!r)throw new hs.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;Tt(i,()=>new Promise(d=>o=d));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let d=c[l++],u=await r.get({id:d,lazy:s,select:n},i);return u=u&&SE(u),t?{value:{key:d,value:u}}:{value:u}}else return o(),{done:!0}},return(d){return o(),{value:d,done:!0}},throw(d){return o(),{done:!0}}}}}}function Vs(e){let t=e.database||e.schema||XX,r=ct()[t];if(!r)throw(0,hs.handleHDBError)(new Error,JX.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function UP(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*vP(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:d,value:u}=o;if(s?.timestamp===d)s.hash_values.push(l),s.records.push(u);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:d,hash_values:[l],records:[u]}}}s&&(yield s)}var xP,pE,hs,BP,HP,ms,Og,Ng,kP,JX,XX,ZX,eZ,PP,Ig,GP=Oe(()=>{"use strict";xP=U(AP()),pE=U(yc()),hs=U(ce());Ne();BP=U(wu()),HP=U(Du()),ms=U(B()),Og=U(Ti()),Ng=U(Es()),kP=U(te());aa();TE();({HDB_ERROR_MSGS:JX}=hs.hdb_errors),XX="data",ZX=1e4,eZ=10,Ig=class extends xP.default{static{a(this,"ResourceBridge")}constructor(t){super(t),PP=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,pE.default)(t,"conditions");if(r)throw(0,hs.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Vs(t);if(!n)throw new hs.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:wg(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 hs.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}dt({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await Vs(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Vs(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(d=>{if(!d){let{value:u,version:f}=r.primaryStore.getEntry(o);return i(o,u,f)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(d=>setImmediate(d));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){Vs(t).dropTable()}createSchema(t){return Ic({database:t.schema,table:null}),Og.signalSchemaChange(new Ng.SchemaEventMsg(process.pid,ms.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Cg(t.schema),Og.signalSchemaChange(new Ng.SchemaEventMsg(process.pid,ms.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,PP.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,BP.default)(t);(0,HP.default)(t,n,r.primaryKey);let s,i=ct()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),Tt(o,async c=>{if(!i.schemaDefined){s=[];for(let u of n)i.attributes.find(E=>E.name==u)||s.push(u);s.length>0&&await i.addAttributes(s.map(u=>({name:u,indexed:!0})))}let l=[],d=[];for(let u of t.records){let f=await i.get(u[i.primaryKey],o);if(t.requires_existing&&!f||t.requires_no_existing&&f){d.push(u[i.primaryKey]);continue}f&&(f=SE(f));for(let E in u)if(Object.prototype.hasOwnProperty.call(u,E)){let _=u[E];if(typeof _=="function")try{let h=_([[f]]);Array.isArray(h)&&(_=h[0].func_val,u[E]=_)}catch(h){throw h.message+="Trying to set key "+E+" on object"+JSON.stringify(u),h}}if(f)for(let E in f)Object.prototype.hasOwnProperty.call(u,E)||(u[E]=f[E]);await i.put(u,o),l.push(u[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:d}})}async deleteRecords(t){let r=ct()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Tt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return UP(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=ct()[t.schema][t.table];if(!r.createdTimeProperty)throw new hs.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:ms.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],d=a(async()=>{let u=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...u.deleted_hashes),o.push(...u.skipped_hashes),await(0,kP.async_set_timeout)(eZ),l=[],s=!0},"chunkDelete");for await(let u of n)l.push(u[r.primaryKey]),c++,c%ZX===0&&await d();return l.length>0&&await d(),s?UP(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,pE.default)(t,"hashes");if(r)throw r;return MP(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of MP(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&ms.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,pE.default)(t,"value");if(n)throw n;let s=Vs(t);if(!s)throw new hs.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===ms.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:wg(t,s)})}async getDataByValue(t,r){let n=new Map,s=Vs(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){Vs({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Vs(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=Vs(t),n={};switch(t.search_type){case ms.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case ms.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of vP(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return vP(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(wg,"getSelect");a(MP,"getRecords");a(Vs,"getTable");a(UP,"createDeleteResponse");a(vP,"groupRecordsInHistory")});var $n=I((jme,qP)=>{"use strict";var{ResourceBridge:tZ}=(GP(),ae(FP)),rZ=ie();rZ.initSync();var gE;function nZ(){return gE||(gE=new tZ,gE)}a(nZ,"getBridge");qP.exports=nZ()});var KP=I((Xme,YP)=>{"use strict";var VP=require("lodash"),Qu=require("mathjs"),sZ=require("jsonata"),$P=te();YP.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?VP.uniqWith(e,VP.isEqual):e,searchJSON:iZ,mad:zu.bind(null,Qu.mad),mean:zu.bind(null,Qu.mean),mode:zu.bind(null,Qu.mode),prod:zu.bind(null,Qu.prod),median:zu.bind(null,Qu.median)};function zu(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(zu,"aggregateFunction");function iZ(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($P.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),$P.isEmpty(this.__ala__.res[r])){let n=sZ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(iZ,"searchJSON")});var QP=I((epe,WP)=>{"use strict";var zt=require("moment"),Dg="YYYY-MM-DDTHH:mm:ss.SSSZZ";zt.suppressDeprecationWarnings=!0;WP.exports={current_date:()=>zt().utc().format("YYYY-MM-DD"),current_time:()=>zt().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return zt(e).utc().format("YYYY");case"month":return zt(e).utc().format("MM");case"day":return zt(e).utc().format("DD");case"hour":return zt(e).utc().format("HH");case"minute":return zt(e).utc().format("mm");case"second":return zt(e).utc().format("ss");case"millisecond":return zt(e).utc().format("SSS");default:break}},date:e=>zt(e).utc().format(Dg),date_format:(e,t)=>zt(e).utc().format(t),date_add:(e,t,r)=>zt(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>zt(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=zt(e).utc(),s=zt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>zt().utc().valueOf(),get_server_time:()=>zt().format(Dg),offset_utc:(e,t)=>zt(e).utc().utcOffset(t).format(Dg)}});var XP=I((tpe,JP)=>{"use strict";var oZ=require("@turf/area"),aZ=require("@turf/length"),cZ=require("@turf/circle"),lZ=require("@turf/difference"),uZ=require("@turf/distance"),dZ=require("@turf/boolean-contains"),fZ=require("@turf/boolean-equal"),_Z=require("@turf/boolean-disjoint"),EZ=require("@turf/helpers"),zP=B(),Be=te(),Ai=X();JP.exports={geoArea:hZ,geoLength:mZ,geoCircle:pZ,geoDifference:SZ,geoDistance:jP,geoNear:TZ,geoContains:gZ,geoEqual:RZ,geoCrosses:AZ,geoConvert:bZ};function hZ(e){if(Be.isEmpty(e))return NaN;typeof e=="string"&&(e=Be.autoCastJSON(e));try{return oZ.default(e)}catch(t){return Ai.trace(t,e),NaN}}a(hZ,"geoArea");function mZ(e,t){if(Be.isEmpty(e))return NaN;typeof e=="string"&&(e=Be.autoCastJSON(e));try{return aZ.default(e,{units:t||"kilometers"})}catch(r){return Ai.trace(r,e),NaN}}a(mZ,"geoLength");function pZ(e,t,r){if(Be.isEmpty(e))return NaN;if(Be.isEmpty(t))return NaN;typeof e=="string"&&(e=Be.autoCastJSON(e));try{return cZ.default(e,t,{units:r||"kilometers"})}catch(n){return Ai.trace(n,e,t),NaN}}a(pZ,"geoCircle");function SZ(e,t){if(Be.isEmpty(e))return NaN;if(Be.isEmpty(t))return NaN;typeof e=="string"&&(e=Be.autoCastJSON(e)),typeof t=="string"&&(t=Be.autoCastJSON(t));try{return lZ(e,t)}catch(r){return Ai.trace(r,e,t),NaN}}a(SZ,"geoDifference");function jP(e,t,r){if(Be.isEmpty(e))return NaN;if(Be.isEmpty(t))return NaN;typeof e=="string"&&(e=Be.autoCastJSON(e)),typeof t=="string"&&(t=Be.autoCastJSON(t));try{return uZ.default(e,t,{units:r||"kilometers"})}catch(n){return Ai.trace(n,e,t),NaN}}a(jP,"geoDistance");function TZ(e,t,r,n){if(Be.isEmpty(e)||Be.isEmpty(t))return!1;if(Be.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Be.autoCastJSON(e)),typeof t=="string"&&(t=Be.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return jP(e,t,n)<=r}catch(s){return Ai.trace(s,e,t),!1}}a(TZ,"geoNear");function gZ(e,t){if(Be.isEmpty(e)||Be.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Be.autoCastJSON(e)),typeof t=="string"&&(t=Be.autoCastJSON(t));try{return dZ.default(e,t)}catch(r){return Ai.trace(r,e,t),!1}}a(gZ,"geoContains");function RZ(e,t){if(Be.isEmpty(e)||Be.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Be.autoCastJSON(e)),typeof t=="string"&&(t=Be.autoCastJSON(t));try{return fZ.default(e,t)}catch(r){return Ai.trace(r,e,t),!1}}a(RZ,"geoEqual");function AZ(e,t){if(Be.isEmpty(e)||Be.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Be.autoCastJSON(e)),typeof t=="string"&&(t=Be.autoCastJSON(t));try{return!_Z.default(e,t)}catch(r){return Ai.trace(r,e,t),!1}}a(AZ,"geoCrosses");function bZ(e,t,r){if(Be.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Be.isEmpty(t))throw new Error("geo_type is required");if(Be.isEmpty(zP.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(zP.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Be.autoCastJSON(e)),EZ[t](e,r)}a(bZ,"geoConvert")});var RE=I((npe,ZP)=>{var ca=KP(),In=QP(),$s=XP();ZP.exports=e=>{e.aggr.mad=e.aggr.MAD=ca.mad,e.aggr.mean=e.aggr.MEAN=ca.mean,e.aggr.mode=e.aggr.MODE=ca.mode,e.aggr.prod=e.aggr.PROD=ca.prod,e.aggr.median=e.aggr.MEDIAN=ca.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=ca.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=ca.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=In.current_date,e.fn.current_time=e.fn.CURRENT_TIME=In.current_time,e.fn.extract=e.fn.EXTRACT=In.extract,e.fn.date=e.fn.DATE=In.date,e.fn.date_format=e.fn.DATE_FORMAT=In.date_format,e.fn.date_add=e.fn.DATE_ADD=In.date_add,e.fn.date_sub=e.fn.DATE_SUB=In.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=In.date_diff,e.fn.now=e.fn.NOW=In.now,e.fn.offset_utc=e.fn.OFFSET_UTC=In.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=In.get_server_time,e.fn.getdate=e.fn.GETDATE=In.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=In.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=$s.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=$s.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=$s.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=$s.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=$s.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=$s.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=$s.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=$s.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=$s.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=$s.geoNear}});var nM=I((spe,rM)=>{"use strict";var ju=require("lodash"),Wr=require("alasql");Wr.options.cache=!1;var yZ=RE(),eM=require("clone"),AE=require("recursive-iterator"),we=X(),Qe=te(),wc=$n(),OZ=B(),{hdb_errors:NZ}=ce(),{getDatabases:tM}=(Ne(),ae(it)),IZ="IS NULL",ps="There was a problem performing this search. Please check the logs and try again.";yZ(Wr);var Lg=class{static{a(this,"SQLSearch")}constructor(t,r){if(Qe.isEmpty(t))throw we.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(),Qe.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Qe.isEmptyOrZeroLength(n))return we.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw we.error("Error thrown from checkEmptySQL in SQLSearch class method search."),we.error(n),new Error(ps)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw we.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),we.error(n),new Error(ps)}if(Object.keys(this.data).length===0)return we.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw we.error("Error thrown from processJoins in SQLSearch class method search."),we.error(n),new Error(ps)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw we.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),we.error(n),new Error(ps)}try{return t=await this._finalSQL(),t}catch(n){throw we.error("Error thrown from finalSQL in SQLSearch class method search."),we.error(n),new Error(ps)}}_getColumns(){let t=new AE(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(eM(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=ju.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=tM()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Qe.isEmpty(this.statement.where)){we.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new AE(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Qe.isEmpty(r)&&r.right)if(Qe.isNotEmptyAndHasValue(r.right.value)){let n=Qe.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Wr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Qe.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Wr.yy.LogicValue({value:i}):n instanceof Wr.yy.StringValue&&Qe.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Wr.yy.NumValue({value:i}))});if(t){we.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new AE(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!Qe.isEmpty(OZ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Qe.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Qe.isEmptyOrZeroLength(r.left.columnid)||Qe.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(Qe.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"=":!Qe.isEmpty(r.right.value)||!Qe.isEmpty(r.left.value)?n.add(Qe.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let d=0;d<l.length;d++)if(l[d].value)n.add(l[d].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(Qe.isEmptyOrZeroLength(this.all_table_attributes)&&Qe.isEmptyOrZeroLength(this.statement.from)&&Qe.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&&ju.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(Qe.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Qe.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(Qe.isEmptyOrZeroLength(this.all_table_attributes)&&!Qe.isEmptyOrZeroLength(this.columns.columns))return t;if(Qe.isEmptyOrZeroLength(this.all_table_attributes)&&Qe.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Wr.promise(r)}catch(r){throw we.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),we.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(eM(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(Qe.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(IZ)>-1&&this.tables.forEach(s=>{let i={columnid:tM()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=ju.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,d=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!Qe.isEmpty(this.exact_search_values[d])&&!this.exact_search_values[d].ignore&&!Qe.isEmptyOrZeroLength(this.exact_search_values[d].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[d].values);let u=await wc.getDataByHash(c);for(let f of c.hash_values)u.get(f)&&!this.data[i].__merged_data[f]&&(this.data[i].__merged_data[f]=[...n[i]],this._setMergedHashAttribute(i,f))}catch(u){throw we.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),we.error(u),new Error(ps)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[d].values).map(async u=>{let f=Object.assign({},c);f.search_value=u;let E=await wc.getDataByValue(f);for(let[_,h]of E)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,_))}))}catch(u){throw we.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),we.error(u),new Error(ps)}else if(!Qe.isEmpty(this.comparator_search_values[d])&&!this.comparator_search_values[d].ignore&&!Qe.isEmptyOrZeroLength(this.comparator_search_values[d].comparators))try{let u=this.comparator_search_values[d].comparators;for(let f=0,E=u.length;f<E;f++){let _=u[f];c.search_attribute=_.attribute,c.search_value=_.search_value;let h=await wc.getDataByValue(c,_.operation);if(l)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(u){throw we.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),we.error(u),new Error(ps)}else try{c.search_attribute=s.attribute,c.search_value="*";let u=await wc.getDataByValue(c);if(l)for(let[f]of u)this.data[i].__merged_data[f]||(this.data[i].__merged_data[f]=[...n[i]],this._setMergedHashAttribute(i,f));else for(let[f,E]of u)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,E[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,f))}catch(u){throw we.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),we.error(u),new Error(ps)}}}_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 Wr.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 Wr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Wr.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 Wr.yy.FuncValue:new Wr.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(_=>{_.joinmode&&_.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(_.table);let h=_.joinmode+" JOIN ? AS "+(_.as?_.as:_.table.tableid);_.on&&(h+=" ON "+_.on.toString()),i.push(h),t.push(Object.values(this.data[`${_.table.databaseid_orig}_${_.table.as?_.table.as_orig:_.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(_=>{let h=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__hash_name,p=_.as?_.as_orig:_.tableid_orig;o.push({key:`'${p}.${h}'`,schema:_.databaseid_orig,table:_.as?_.as_orig:_.tableid_orig,keys:new Set}),r.push(`${_.as?_.as:_.tableid}.\`${h}\` AS "${p}.${h}"`),c[_.as?_.as_orig:_.tableid_orig]=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let d="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(d="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(_=>{_.is_func?r.push(_.initial_select_column.toString()):_.initial_select_column.tableid?r.push(`${_.initial_select_column.tableid}.${_.initial_select_column.columnid} AS ${_.expression.columnid}`):r.push(`${_.initial_select_column.columnid} AS ${_.expression.columnid}`)}));let u="",f="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(u=this.statement.limit?"LIMIT "+this.statement.limit:"",f=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let _=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${d} ${u} ${f}`,h=this._convertColumnsToIndexes(_,s);E=await Wr.promise(h,t),t=null}catch(_){throw we.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),we.error(_),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let _=0,h=E.length;_<h;_++){let p=E[_];o.forEach(S=>{p[S.key]!==null&&p[S.key]!==void 0&&S.keys.add(p[S.key])})}o.forEach(_=>{let h=Object.keys(this.data[`${_.schema}_${_.table}`].__merged_data),p=ju.difference(h,[..._.keys].map(S=>S.toString()));for(let S=0,g=p.length;S<g;S++){let T=p[S];delete this.data[`${_.schema}_${_.table}`].__merged_data[T]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new AE(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=ju.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 we.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),we.error(i),new Error(ps)}}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 u in i)o.push(i[u][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await wc.getDataByHash(c),d=s.columns.length;for(let u=0,f=o.length;u<f;u++){let E=o[u],_=l.get(E);for(let h=0;h<d;h++){let p=s.columns[h],S=_[p]===void 0?null:_[p];this.data[n].__merged_data[E].push(S)}}}}catch(r){throw we.error("Error thrown from getDataByHash function in SQLSearch class method getData."),we.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();we.trace(`Final SQL: ${s}`),n=await Wr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),we.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw we.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),we.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 we.error(NZ.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),we.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],d=new RegExp(`${l}.\`${o}\``,"g"),u=`${l}.[${c}]`;n=n.replace(d,u)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),d=`[${c}]`;n=n.replace(l,d)});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 wc.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]=Object.assign({},r[s])),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw we.error("There was an error when processing this SQL operation. Check your logs"),we.error(o),new Error(ps)}}return Object.values(Object.values(this.data)[0].__merged_data)}};rM.exports=Lg});var An=I((ope,sM)=>{"use strict";var wZ=JI();sM.exports={searchByConditions:DZ,searchByHash:LZ,searchByValue:PZ,search:MZ};var Pg=$n(),{transformReq:Mg}=te(),CZ=nM();async function DZ(e){return Mg(e),Pg.searchByConditions(e)}a(DZ,"searchByConditions");async function LZ(e){Mg(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of Pg.searchByHash(e))r&&t.push(r);return t}a(LZ,"searchByHash");async function PZ(e){Mg(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of Pg.searchByValue(e))t.push(r);return t}a(PZ,"searchByValue");function MZ(e,t){try{let r=new wZ(e);r.validate(),new CZ(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(MZ,"search")});var bE=I((cpe,iM)=>{"use strict";var UZ=$n();iM.exports={writeTransaction:vZ};function vZ(e,t,r){return UZ.writeTransaction(e,t,r)}a(vZ,"writeTransaction")});var lM=I((dpe,cM)=>{"use strict";var xZ=An(),BZ=Si(),oM=X(),HZ=Vn(),upe=bE(),kZ=require("clone"),vg=require("alasql"),FZ=RE(),aM=require("util"),GZ=aM.promisify(BZ.getTableSchema),qZ=aM.promisify(xZ.search),VZ=B(),Ug=te();FZ(vg);cM.exports={update:YZ};var $Z="There was a problem performing this update. Please check the logs and try again.";async function YZ({statement:e,hdb_user:t}){let r=await GZ(e.table.databaseid,e.table.tableid),n=KZ(e.columns);Ug.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=kZ(s),c=Ug.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,d=vg.parse(l).statements[0],u=await qZ(d),f=WZ(n,u);return QZ(o,f,t)}a(YZ,"update");function KZ(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=vg.compile(`SELECT ${r.expression.toString()} AS [${VZ.FUNC_VAL}] FROM ?`)}),t}catch(t){throw oM.error(t),new Error($Z)}}a(KZ,"createUpdateRecord");function WZ(e,t){return Ug.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(WZ,"buildUpdateRecords");async function QZ(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await HZ.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){oM.error(`Error delete new_attributes from update response: ${i}`)}return s}a(QZ,"updateRecords")});var dM=I((hpe,uM)=>{var zZ=require("alasql"),jZ=An(),JZ=X(),XZ=$n(),Bg=require("util"),xg=te(),ZZ=B(),e5=Si(),_pe=bE(),Epe=Vn(),t5="record",r5="successfully deleted",n5=Bg.callbackify(a5),s5=Bg.promisify(jZ.search),i5=Bg.promisify(e5.getTableSchema);uM.exports={convertDelete:n5};function o5(e){return`${e.deleted_hashes.length} ${t5}${e.deleted_hashes.length===1?"":"s"} ${r5}`}a(o5,"generateReturnMessage");async function a5({statement:e,hdb_user:t}){let r=await i5(e.table.databaseid,e.table.tableid);xg.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=xg.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=zZ.parse(o).statements[0],l={operation:ZZ.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await s5(c);let d=await XZ.deleteRecords(l);return xg.isEmptyOrZeroLength(d.message)&&(d.message=o5(d)),delete d.txn_time,d}catch(d){throw JZ.error(d),d.hdb_code?d.message:d}}a(a5,"convertDelete")});var mM=I((ppe,hM)=>{"use strict";var c5=ro(),{hdb_errors:fM}=ce(),{getDatabases:_M}=(Ne(),ae(it));hM.exports={checkSchemaExists:EM,checkSchemaTableExists:l5,schema_describe:c5};async function EM(e){if(!_M()[e])return fM.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(EM,"checkSchemaExists");async function l5(e,t){let r=await EM(e);if(r)return r;if(!_M()[e][t])return fM.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(l5,"checkSchemaTableExists")});var Ju=I((Tpe,u5)=>{u5.exports={name:"harperdb",version:"4.4.0-alpha.1",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive",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:replication && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc --no-clean --reporter=lcovonly npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:replication && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","test:security":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/security/**/*.js' --config '../unitTests/.mocharc.json'","test:replication":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/replication/**/*.js' --config '../unitTests/.mocharc.json'","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test"},dependencies:{"@aws-sdk/client-s3":"3.635.0","@aws-sdk/lib-storage":"3.635.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.10.0","@fastify/compress":"~6.5.0","@fastify/cors":"~9.0.1","@fastify/static":"~7.0.4","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.6.0",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.28.1","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.9.0","gunzip-maybe":"1.4.2","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.0.14",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",moment:"2.30.1","mqtt-packet":"~9.0.0",msgpackr:"1.11.0",nats:"2.19.0",needle:"3.3.1","node-forge":"^1.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.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.4.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.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.23.5","tar-fs":"3.0.6",ulidx:"0.5.0",uuid:"10.0.0","validate.js":"0.13.1",ws:"8.18.0",yaml:"2.5.0"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"20.14.8","@typescript-eslint/eslint-plugin":"^5.55.0","@typescript-eslint/parser":"^5.55.0",axios:"1.7.5",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.20.2",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",mkcert:"1.5.1",mocha:"^10.3.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"6.1.3","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"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.4.2","why-is-node-still-running":"^1.0.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","segfault-handler":"^1.3.0","utf-8-validate":"^5.0.10"}}});var rd={};Ze(rd,{addAnalyticsListener:()=>td,recordAction:()=>Qr,recordActionBinary:()=>wn,setAnalyticsEnabled:()=>d5});function d5(e){OM=e}function Qr(e,t,r,n,s){if(!OM)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=NE.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let d=c;o.values=c=new Float32Array(l*2),c.set(d),c.index=l+1}c[l]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},NE.set(i,o)}yE||f5()}function wn(e,t,r,n,s){Qr(!!e,t,r,n,s)}function td(e){wM.push(e)}function f5(){yE=performance.now(),setTimeout(async()=>{let e=performance.now()-yE;yE=0;let t=[],r={time:Date.now(),period:e,threadId:la.threadId,metrics:t};for(let[s,i]of NE){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,d=[],u;for(let f of CM){let E=Math.floor(c*f),_=o[E-1];if(E>l){let h=E-l;if(_===u){let p=d[d.length-1];typeof p=="number"?d[d.length-1]={value:p,count:1+h}:p.count+=h}else d.push(h>1?{value:_,count:h}:_),u=_;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:d,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 DM()}let n=process.memoryUsage();t.push({metric:"memory",threadId:la.threadId,byThread:!0,...n});for(let s of wM)s(t);NE=new Map,la.parentPort?la.parentPort.postMessage({type:IM,report:r}):MM({report:r})},NM).unref()}async function _5(e,t=6e4){let r=Fg(),n=LM(),s=new Promise(p=>{let S=performance.now();setImmediate(()=>{let g=performance.now();g-S>5e3&&(0,Xu.warn)("Unusually high event queue latency on the main thread of "+Math.round(g-S)+"ms"),S=performance.now()}),n.primaryStore.prefetch([1],()=>{let g=performance.now();g-S>5e3&&(0,Xu.warn)("Unusually high task queue latency on the main thread of "+Math.round(g-S)+"ms"),p(g-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,l=new Map,d=[],u;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;u=p;let{metrics:g,threadId:T}=S;for(let A of g||[]){let{path:N,method:V,type:v,metric:J,count:$,total:F,distribution:ne,threads:ee,...Z}=A;$||($=1);let le=J+(N?"-"+N:"");V!==void 0&&(le+="-"+V),v!==void 0&&(le+="-"+v);let fe=c.get(le);if(fe){if(fe.threads){let ye=fe.threads[T];if(ye)fe=ye;else{fe.threads[T]=Object.assign({},Z);continue}}fe.count||(fe.count=1);let je=fe.count;for(let ye in Z){let Ht=Z[ye];typeof Ht=="number"&&(fe[ye]=(fe[ye]*je+Ht*$)/(je+$))}fe.count+=$,F>=0&&(fe.total+=F,fe.ratio=fe.total/fe.count)}else fe=Object.assign({period:t},A),delete fe.distribution,c.set(le,fe),fe.byThread&&(fe.threads=[],fe.threads[T]=Object.assign({},Z),d.push(fe));if(ne){ne=ne.map(ye=>typeof ye=="number"?{value:ye,count:1}:ye);let je=l.get(le);je?je.push(...ne):l.set(le,ne)}}await DM()}for(let p of d){let{path:S,method:g,type:T,metric:A,count:N,total:V,distribution:v,threads:J,...$}=p;J=J.filter(F=>F);for(let F in $){if(typeof p[F]!="number")continue;let ne=0;for(let ee of J){let Z=ee[F];typeof Z=="number"&&(ne+=Z)}p[F]=ne}p.count=J.length,delete p.threads,delete p.byThread}for(let[p,S]of l){let g=c.get(p);S.sort((ye,Ht)=>ye.value>Ht.value?1:-1);let T=g.count-1,A=[],N=0,V=0,v;for(let ye of CM){let Ht=T*ye;for(;N<Ht;)v=S[V++],N+=v.count,V===1&&N--;let Bo=S[V>1?V-2:0];v||(v=S[0]),A.push(v.value-(v.value-Bo.value)*(N-Ht)/v.count)}let[J,$,F,ne,ee,Z,le,fe,je]=A;Object.assign(g,{p1:J,p10:$,p25:F,median:ne,p75:ee,p90:Z,p95:le,p99:fe,p999:je})}let f;for(let[p,S]of c)S.id=(0,OE.getNextMonotonicTime)(),S.time=u,n.primaryStore.put(S.id,S,{append:!0}).then(g=>{g||n.primaryStore.put(S.id,S)}),f=!0;let E=Date.now(),{idle:_,active:h}=performance.eventLoopUtilization();if(f||h*10>_){let p=(0,OE.getNextMonotonicTime)(),S={id:p,metric:"main-thread-utilization",idle:_-pM,active:h-SM,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(p,S,{append:!0}).then(g=>{g||n.primaryStore.put(p,S)})}pM=_,SM=h}async function TM(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function Fg(){return gM||(gM=dt({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function LM(){return RM||(RM=dt({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function m5(){PM=!0;let e=(0,ed.get)(kg.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await _5(NM,e),await TM(Fg(),E5),await TM(LM(),h5)},Math.min(e/2,2147483647)).unref()}function MM(e,t){let r=e.report;r.threadId=t?.threadId||la.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(AM+=n.mean*n.count);r.totalBytesProcessed=AM,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(bM.get(t))}),bM.set(t,t.performance.eventLoopUtilization())),r.id=(0,OE.getNextMonotonicTime)(),Fg().primaryStore.put(r.id,r),PM||m5(),p5&&(UM=T5(r))}async function T5(e){if(await UM,!co){let r=(0,Zu.dirname)((0,Xu.getLogFilePath)());try{co=await(0,Hg.open)((0,Zu.join)(r,"analytics.log"),"r+")}catch{co=await(0,Hg.open)((0,Zu.join)(r,"analytics.log"),"w+")}}let t=(await co.stat()).size;if(t>S5){let r=Buffer.alloc(t);await co.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await co.write(r,{position:0}),await co.truncate(r.length),t=r.length}await co.write(JSON.stringify(e)+`
10
+ `,t)}var la,yM,Xu,Zu,Hg,OE,ed,kg,NE,OM,yE,NM,IM,wM,CM,pM,SM,DM,E5,h5,gM,RM,PM,AM,bM,p5,UM,co,S5,bi=Oe(()=>{la=require("worker_threads"),yM=U(at());Ne();Xu=U(X()),Zu=require("path"),Hg=require("fs/promises"),OE=U(pn()),ed=U(ie()),kg=U(B());Lr();(0,ed.initSync)();NE=new Map,OM=(0,ed.get)(kg.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(d5,"setAnalyticsEnabled");a(Qr,"recordAction");st.recordAnalytics=Qr;a(wn,"recordActionBinary");yE=0,NM=1e3,IM="analytics-report",wM=[];a(td,"addAnalyticsListener");CM=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(f5,"sendAnalytics");a(_5,"aggregation");pM=0,SM=0,DM=a(()=>new Promise(setImmediate),"rest");a(TM,"cleanup");E5=36e5,h5=31536e6;a(Fg,"getRawAnalyticsTable");a(LM,"getAnalyticsTable");(0,yM.setChildListenerByType)(IM,MM);a(m5,"startScheduledTasks");AM=0,bM=new Map,p5=!1;a(MM,"recordAnalytics");S5=1e6;a(T5,"logAnalytics")});var Yg=I((Ppe,YM)=>{"use strict";var{decode:g5}=require("msgpackr"),{isMainThread:Cpe,parentPort:Dpe,threadId:Lpe}=require("worker_threads"),CE=jt(),Cc=Pt(),Vg=B(),xr=X(),qg=ie(),R5=B(),{onMessageByType:A5}=at(),BM=pi(),{recordAction:b5,recordActionBinary:y5}=(bi(),ae(rd)),{publishToStream:O5}=CE,{ConsumerEvents:vM}=require("nats"),N5=An(),{promisify:I5}=require("util"),HM=I5(setTimeout),DE=1e4,LE,wE,w5,C5,kM,nd=new Map,Dc=new Map;YM.exports={initialize:FM,ingestConsumer:$g,setSubscription:D5,setIgnoreOrigin:M5,getDatabaseSubscriptions:P5,updateConsumer:GM};async function FM(){A5(Vg.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await GM(n)}),kM=!0,xr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await CE.getNATSReferences();LE=e,wE=e.info.server_name,w5=t,C5=r}a(FM,"initialize");async function GM(e){if(e.status==="start"){let{js:t,jsm:r}=await qM(e.node_domain_name);$g(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=nd.get(e.stream_name+e.node_domain_name);t&&(xr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),nd.set(e.stream_name+e.node_domain_name,"close")),Dc.get(e.node_domain_name)==="failed"&&Dc.set(e.node_domain_name,"close")}}a(GM,"updateConsumer");var PE=new Map;function D5(e,t,r){let n=PE.get(e);n||PE.set(e,n=new Map),n.set(t,r),kM||FM().then(L5)}a(D5,"setSubscription");async function L5(){let e=await N5.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Cc.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions)if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await qM(r),!n))break;let{schema:o,table:c}=i,l=BM.createNatsTableStreamName(o,c);$g(l,n,s,r)}}}a(L5,"accessConsumers");async function qM(e){let t,r,n=1;for(;!r;)try{t=await LE.jetstream({domain:e}),r=await LE.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Dc.get(e)==="close")break;Dc.set(e,"failed"),n%10===1&&xr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<DE?n++*100:DE;await HM(i)}return{js:t,jsm:r}}a(qM,"connectToRemoteJS");function P5(){return PE}a(P5,"getDatabaseSubscriptions");var VM;function M5(e){VM=e}a(M5,"setIgnoreOrigin");var $M=100,xM=new Array($M),IE=0;async function $g(e,t,r,n){let{connection:s}=await CE.getNATSReferences();LE=s,wE=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,wE),xr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(d){if(Dc.get(n)==="close")break;o%10===1&&xr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",d.message),d.code==="404"&&(xr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await CE.createConsumer(r,e,wE,new Date(Date.now()).toISOString()));let u=o++*100<DE?o++*100:DE;await HM(u)}let c=!1,l;for(;!c;){if(nd.get(e+n)==="close"||Dc.get(n)==="close"){nd.delete(e+n),c=!0;continue}l=await i.consume({max_messages:qg.get(Vg.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),nd.set(e+n,l);let d=!1;(async()=>{for await(let u of await l.status())if(u.type===vM.ConsumerDeleted&&(await l.close(),c=!0),u.type===vM.HeartbeatsMissed){let f=u.data;xr.trace(`${f} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),f===100&&(xr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),d=!0)}})();try{for await(let u of l)await xM[IE],xM[IE]=U5(u).catch(f=>{xr.error(f)}),++IE>=$M&&(IE=0)}catch(u){u.message==="consumer deleted"?(xr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):xr.error("Error consuming clustering ingest, restarting consumer",u)}}}a($g,"ingestConsumer");async function U5(e){let t=g5(e.data);b5(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),xr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=qg.get(Vg.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Cc.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Cc.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Cc.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!VM),y5(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Cc.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:d,records:u,hash_values:f,__origin:E,expiresAt:_}=t;xr.trace("processing message:",o,c,d,(u?"records: "+u.map(N=>N?.id):"")+(f?"ids: "+f:""),"with sequence:",e.seq),xr.trace(`messageProcessor nats msg id: ${e.headers.get(Cc.MSG_HEADERS.NATS_MSG_ID)}`);let h;u||(u=f);let p=new Promise(N=>h=N),{timestamp:S,user:g,node_name:T}=E||{},A=PE.get(c)?.get(d);if(!A)throw new Error("Missing table for replication message",d);if(o==="define_schema")t.type=o,t.onCommit=h,A.send(t);else if(u.length===1&&!l)A.send({type:Gg(o),value:u[0],id:f?.[0],expiresAt:_,timestamp:S,table:d,onCommit:h,user:g,nodeName:T});else{let N=u.map((V,v)=>({type:Gg(o),value:V,expiresAt:_,id:f?.[v],table:d}));for(;l;)N.push({type:Gg(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;A.send({type:"transaction",writes:N,table:d,timestamp:S,onCommit:h,user:g,nodeName:T})}qg.get(R5.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&O5(e.subject.split(".").slice(0,-1).join("."),BM.createNatsTableStreamName(c,d),e.headers,e.data),await p}catch(o){xr.error(o)}e.ack()}a(U5,"messageProcessor");function Gg(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(Gg,"convertOperation")});var jt=I((kpe,cU)=>{"use strict";var fr=ie();fr.initSync();var v5=require("fs-extra"),x5=require("semver"),od=require("path"),{monotonicFactory:B5}=require("ulidx"),WM=B5(),H5=require("util"),QM=require("child_process"),k5=H5.promisify(QM.exec),F5=QM.spawn,Tr=Pt(),Ye=B(),ME=te(),Ss=X(),UE=pi(),G5=bE(),sd=dr(),{broadcast:q5,onMessageByType:V5,getWorkerIndex:$5}=at(),{isMainThread:zM}=require("worker_threads"),{Encoder:Y5,decode:zg}=require("msgpackr"),jM=new Y5,{isEmpty:_a}=ME,JM=yn(),Upe=48*36e11;zM&&V5(Ye.ITC_EVENT_TYPES.RESTART,()=>{zr=void 0,fa=void 0});var{connect:K5,StorageType:W5,RetentionPolicy:Q5,AckPolicy:jg,DeliverPolicy:Jg,DiscardPolicy:z5,NatsConnection:vpe,JetStreamManager:xpe,JetStreamClient:Bpe,StringCodec:Hpe,JSONCodec:j5,createInbox:Xg,headers:J5,ErrorCode:KM}=require("nats"),{PACKAGE_ROOT:X5}=B(),Z5=Ju(),{recordAction:e8}=(bi(),ae(rd)),XM=j5(),t8="clustering",r8=Z5.engines[Tr.NATS_SERVER_NAME],n8=od.join(X5,"dependencies"),Qg=od.join(n8,`${process.platform}-${process.arch}`,Tr.NATS_BINARY_NAME),Kg,Wg,id,ua,da;cU.exports={runCommand:ZM,checkNATSServerInstalled:s8,createConnection:Zg,getConnection:ad,getJetStreamManager:cd,getJetStream:tU,getNATSReferences:Ys,getServerList:o8,createLocalStream:eR,listStreams:rU,deleteLocalStream:a8,getServerConfig:Lc,listRemoteStreams:c8,viewStream:l8,viewStreamIterator:u8,publishToStream:d8,request:E8,reloadNATS:tR,reloadNATSHub:h8,reloadNATSLeaf:m8,extractServerName:_8,requestErrorHandler:p8,createLocalTableStream:oU,createTableStreams:g8,purgeTableStream:aU,purgeSchemaTableStreams:R8,getStreamInfo:A8,updateLocalStreams:y8,closeConnection:i8,getJsmServerName:vE,addNatsMsgHeader:nU,clearClientCache:eU,updateRemoteConsumer:S8,createConsumer:sU,updateConsumerIterator:T8};async function ZM(e,t=void 0){let{stdout:r,stderr:n}=await k5(e,{cwd:t});if(n)throw new Error(n.replace(`
9
11
  `,""));return r.replace(`
10
- `,"")}a(rL,"runCommand");async function K3(){try{await O3.access(yS)}catch{return!1}let e=await rL(`${yS} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return b3.eq(t,$3)}a(K3,"checkNATSServerInstalled");async function DS(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await eL.getClusterUser();if(co(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}vn.trace("create nats connection called");let i=await U3({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),vn.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&vn.error("Error with Nats client connection, connection closed",o),nL()}),i}a(DS,"createConnection");function nL(){Tr=void 0,io=void 0,oo=void 0,ao=void 0}a(nL,"clearClientCache");async function W3(){Tr&&(await Tr.drain(),Tr=void 0,io=void 0,oo=void 0,ao=void 0)}a(W3,"closeConnection");var Tr,ao;async function gl(){return ao||(ao=DS(Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Tr=await ao),Tr||ao}a(gl,"getConnection");async function Rl(){if(io)return io;co(Tr)&&await gl();let{domain:e}=la(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(co(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return io=await Tr.jetstreamManager({domain:e,timeout:6e4}),io}a(Rl,"getJetStreamManager");async function sL(){if(oo)return oo;co(Tr)&&await gl();let{domain:e}=la(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(co(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return oo=Tr.jetstream({domain:e,timeout:6e4}),oo}a(sL,"getJetStream");async function ss(){let e=Tr||await gl(),t=io||await Rl(),r=oo||await sL();return{connection:e,jsm:t,js:r}}a(ss,"getNATSReferences");async function Q3(e){let t=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await eL.getClusterUser(),s=await DS(t,r,n),i=CS(),o=s.subscribe(i),c=[],l,_=(async()=>{for await(let u of o){let d=tL.decode(u.data);d.response_time=Date.now()-l,c.push(d)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Id.async_set_timeout(e),await o.drain(),await s.close(),await _,c}a(Q3,"getServerList");async function LS(e,t){let{jsm:r}=await ss(),n=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:v3.File,retention:B3.Limits,subjects:t,discard:H3.Old,max_msgs:s,max_bytes:i,max_age:n})}a(LS,"createLocalStream");async function iL(){let{jsm:e}=await ss(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(iL,"listStreams");async function z3(e){let{jsm:t}=await ss();await t.streams.delete(e)}a(z3,"deleteLocalStream");async function J3(e){let{connection:t}=await ss(),r=[],n=CS(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(tL.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(J3,"listRemoteStreams");async function j3(e,t=void 0,r=void 0){let{jsm:n,js:s}=await ss(),i=JD(),o={durable_name:i,ack_policy:IS.Explicit};t&&(o.deliver_policy=wS.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let _=[];for await(let u of l){let d=NS(u.data),E={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:d};if(u.headers&&(E.origin=u.headers.get(Kt.MSG_HEADERS.ORIGIN)),_.push(E),u.ack(),u.info.pending===0)break}return await c.delete(),_}a(j3,"viewStream");async function*X3(e,t=void 0,r=void 0){let{jsm:n,js:s}=await ss(),i=JD(),o={durable_name:i,ack_policy:IS.Explicit};t&&(o.deliver_policy=wS.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let _ of l){let u=NS(_.data);u[0]||(u=[u]);for(let d of u){let E={nats_timestamp:_.info.timestampNanos,nats_sequence:_.info.streamSequence,entry:d};_.headers&&(E.origin=_.headers.get(Kt.MSG_HEADERS.ORIGIN)),yield E}if(_.ack(),_.info.pending===0)break}await c.delete()}a(X3,"viewStreamIterator");async function Z3(e,t,r,n){vn.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=oL(n,r);let{js:s}=await ss(),i=await Cd(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:ZD.encode(n);try{vn.trace(`publishToStream publishing to subject: ${o}`),k3(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return cL(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){vn.trace(`publishToStream creating stream: ${t}`);let u=o.split(".");u[2]="*",await LS(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(Z3,"publishToStream");function oL(e,t){t===void 0&&(t=G3());let r=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Kt.MSG_HEADERS.ORIGIN)&&r&&t.append(Kt.MSG_HEADERS.ORIGIN,r),t}a(oL,"addNatsMsgHeader");function la(e){e=e.toLowerCase();let t=Tl.join(Ht.get(Ie.CONFIG_PARAMS.ROOTPATH),V3);if(e===Ie.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return co(bS)&&(bS={port:pl.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:pl.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+Kt.SERVER_SUFFIX.HUB,config_file:Kt.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:Tl.join(t,Kt.PID_FILES.HUB),hdb_nats_path:t}),bS;if(e===Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return co(OS)&&(OS={port:pl.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:pl.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+Kt.SERVER_SUFFIX.LEAF,config_file:Kt.NATS_CONFIG_FILES.LEAF_SERVER,domain:pl.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+Kt.SERVER_SUFFIX.LEAF,pid_file_path:Tl.join(t,Kt.PID_FILES.LEAF),hdb_nats_path:t}),OS;vn.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(la,"getServerConfig");async function aL(e,t,r,n){try{await e.consumers.add(t,{ack_policy:IS.Explicit,durable_name:r,deliver_policy:wS.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(aL,"createConsumer");async function ej(e,t,r){await e.consumers.delete(t,r)}a(ej,"removeConsumer");function tj(e){return e.split(".")[1]}a(tj,"extractServerName");async function rj(e,t,r=6e4,n=CS()){if(!Id.isObject(t))throw new Error("data param must be an object");let s=ZD.encode(t),{connection:i}=await ss(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return NS(c.data)}a(rj,"request");function MS(e){return new Promise(async(t,r)=>{let n=w3(yS,["--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(MS,"reloadNATS");async function nj(){let{pid_file_path:e}=la(Ie.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await MS(e)}a(nj,"reloadNATSHub");async function sj(){let{pid_file_path:e}=la(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await MS(e)}a(sj,"reloadNATSLeaf");function ij(e,t,r){let n;switch(e.code){case zD.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case zD.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(ij,"requestErrorHandler");async function oj(e,t){let r=t+Kt.SERVER_SUFFIX.LEAF,{connection:n}=await ss(),{jsm:s}=await Ej(r),{schema:i,table:o}=e,c=wd.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await cL(async()=>{if(e.subscribe===!0)await aL(s,c,n.info.server_name,l);else try{await ej(s,c,n.info.server_name)}catch(_){vn.trace(_)}})}a(oj,"updateRemoteConsumer");async function aj(e,t,r,n){let s=wd.createNatsTableStreamName(e,t),i=r+Kt.SERVER_SUFFIX.LEAF,o={type:Ie.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!XD&&M3()<Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=AS();await c(o)}await D3(o),n==="stop"&&await Id.async_set_timeout(1e3)}a(aj,"updateConsumerIterator");function cL(e){return C3.writeTransaction(Ie.SYSTEM_SCHEMA_NAME,Ie.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(cL,"exclusiveLock");async function lL(e,t){let r=wd.createNatsTableStreamName(e,t),n=await Cd(),s=_j(e,t,n);await LS(r,[s])}a(lL,"createLocalTableStream");async function cj(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await lL(n,s)}}a(cj,"createTableStreams");async function uL(e,t,r=void 0){if(Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=wd.createNatsTableStreamName(e,t),{domain:s}=la(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await gl()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")vn.warn(n);else throw n}}a(uL,"purgeTableStream");async function lj(e,t){if(Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await uL(e,t[r])}a(lj,"purgeSchemaTableStreams");async function uj(e){return(await Rl()).streams.info(e)}a(uj,"getStreamInfo");function _j(e,t,r){return`${Kt.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(_j,"createSubjectName");async function Cd(){if(Sl)return Sl;if(Sl=(await Rl())?.nc?.info?.server_name,Sl===void 0)throw new Error("Unable to get jetstream manager server name");return Sl}a(Cd,"getJsmServerName");async function dj(){let e=await Rl(),t=await Cd(),r=await iL();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=fj(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let _=i.split(".");_[_.length-1]=t;let u=_.join(".");vn.trace(`Updating stream subject name from: ${i} to: ${u}`),s.subjects[0]=u,await e.streams.update(s.name,s)}}a(dj,"updateLocalStreams");function fj(e){let{config:t}=e,r=!1,n=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Ht.get(Ie.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(fj,"updateStreamLimits");async function Ej(e){let t,r;try{t=await Tr.jetstream({domain:e}),r=await Tr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw vn.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(Ej,"connectToRemoteJS")});var Pd=g((Nde,hL)=>{"use strict";var ua=M_(),_a=TD(),hj=Y(),mj=require("uuid").v4,yde=require("clone"),Ld=bs(),da=U(),pj=require("util"),_i=Dn(),{handleHDBError:gr,hdb_errors:Sj}=ne(),{HDB_ERROR_MSGS:Dd,HTTP_STATUS_CODES:Rr}=Sj,{SchemaEventMsg:Md}=Ln(),dL=Rt(),{getDatabases:Tj}=(Ae(),ie(ke)),{transformReq:fa}=z();hL.exports={createSchema:gj,createSchemaStructure:fL,createTable:Rj,createTableStructure:EL,createAttribute:Nj,dropSchema:Aj,dropTable:Oj,dropAttribute:bj,getBackup:Ij};async function gj(e){let t=await fL(e);return Ld.signalSchemaChange(new Md(process.pid,e.operation,e.schema)),t}a(gj,"createSchema");async function fL(e){let t=ua.schema_object(e);if(t)throw gr(t,t.message,Rr.BAD_REQUEST,void 0,void 0,!0);if(fa(e),!await _a.checkSchemaExists(e.schema))throw gr(new Error,Dd.SCHEMA_EXISTS_ERR(e.schema),Rr.BAD_REQUEST,da.LOG_LEVELS.ERROR,Dd.SCHEMA_EXISTS_ERR(e.schema),!0);return await _i.createSchema(e),`database '${e.schema}' successfully created`}a(fL,"createSchemaStructure");async function Rj(e){return fa(e),e.hash_attribute=e.primary_key??e.hash_attribute,await EL(e)}a(Rj,"createTable");async function EL(e){let t=ua.create_table_object(e);if(t)throw gr(t,t.message,Rr.BAD_REQUEST,void 0,void 0,!0);if(ua.validateTableResidence(e.residence),!await _a.checkSchemaTableExists(e.schema,e.table))throw gr(new Error,Dd.TABLE_EXISTS_ERR(e.schema,e.table),Rr.BAD_REQUEST,da.LOG_LEVELS.ERROR,Dd.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:mj(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await _i.createTable(n,e);else throw gr(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Rr.BAD_REQUEST);else await _i.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(EL,"createTableStructure");async function Aj(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=ua.schema_object(e),n=t??r;if(n)throw gr(n,n.message,Rr.BAD_REQUEST,void 0,void 0,!0);fa(e);let s=await _a.checkSchemaExists(e.schema);if(s)throw gr(new Error,s,Rr.NOT_FOUND,da.LOG_LEVELS.ERROR,s,!0);let i=await _a.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);return await _i.dropSchema(e),Ld.signalSchemaChange(new Md(process.pid,e.operation,e.schema)),await dL.purgeSchemaTableStreams(e.schema,o),`successfully deleted '${e.schema}'`}a(Aj,"dropSchema");async function Oj(e){let t=ua.table_object(e);if(t)throw gr(t,t.message,Rr.BAD_REQUEST,void 0,void 0,!0);fa(e);let r=await _a.checkSchemaTableExists(e.schema,e.table);if(r)throw gr(new Error,r,Rr.NOT_FOUND,da.LOG_LEVELS.ERROR,r,!0);return await _i.dropTable(e),await dL.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(Oj,"dropTable");async function bj(e){let t=ua.attribute_object(e);if(t)throw gr(t,t.message,Rr.BAD_REQUEST,void 0,void 0,!0);fa(e);let r=await _a.checkSchemaTableExists(e.schema,e.table);if(r)throw gr(new Error,r,Rr.NOT_FOUND,da.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw gr(new Error,"You cannot drop a hash attribute",Rr.BAD_REQUEST,void 0,void 0,!0);if(da.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw gr(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Rr.BAD_REQUEST,void 0,void 0,!0);try{return await _i.dropAttribute(e),yj(e),Ld.signalSchemaChange(new Md(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw hj.error(`Got an error deleting attribute ${pj.inspect(e)}.`),n}}a(bj,"dropAttribute");function yj(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(yj,"dropAttributeFromGlobal");async function Nj(e){fa(e);let t=Tj()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw gr(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Rr.BAD_REQUEST,void 0,void 0,!0);return await _i.createAttribute(e),Ld.signalSchemaChange(new Md(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(Nj,"createAttribute");function Ij(e){return _i.getBackup(e)}a(Ij,"getBackup")});var pL=g((wde,mL)=>{"use strict";var{OPERATIONS_ENUM:wj}=U(),PS=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=wj.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};mL.exports=PS});var US=g((Lde,AL)=>{"use strict";var Cj=Dn(),Dde=pL(),Ud=z(),vd=U(),Dj=te(),{handleHDBError:SL,hdb_errors:Lj}=ne(),{HDB_ERROR_MSGS:TL,HTTP_STATUS_CODES:gL}=Lj,Mj=Object.values(vd.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),RL="To use this operation audit log must be enabled in harperdb-config.yaml";AL.exports=Pj;async function Pj(e){if(Ud.isEmpty(e.schema))throw new Error(TL.SCHEMA_REQUIRED_ERR);if(Ud.isEmpty(e.table))throw new Error(TL.TABLE_REQUIRED_ERR);if(!Dj.get(vd.CONFIG_PARAMS.LOGGING_AUDITLOG))throw SL(new Error,RL,gL.BAD_REQUEST,vd.LOG_LEVELS.ERROR,RL,!0);let t=Ud.checkSchemaTableExist(e.schema,e.table);if(t)throw SL(new Error,t,gL.NOT_FOUND,vd.LOG_LEVELS.ERROR,t,!0);if(!Ud.isEmpty(e.search_type)&&Mj.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await Cj.readAuditLog(e)}a(Pj,"readAuditLog")});var bL=g((Pde,OL)=>{"use strict";var{OPERATIONS_ENUM:Uj}=U(),vS=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Uj.GET_BACKUP,this.schema=t,this.table=r}};OL.exports=vS});var IL=g((Hde,NL)=>{"use strict";var vj=Dn(),vde=bL(),BS=z(),Bj=U(),Bde=te(),{handleHDBError:Hj,hdb_errors:xj}=ne(),{HDB_ERROR_MSGS:yL,HTTP_STATUS_CODES:Gj}=xj;NL.exports=Fj;async function Fj(e){if(BS.isEmpty(e.schema))throw new Error(yL.SCHEMA_REQUIRED_ERR);if(BS.isEmpty(e.table))throw new Error(yL.TABLE_REQUIRED_ERR);let t=BS.checkSchemaTableExist(e.schema,e.table);if(t)throw Hj(new Error,t,Gj.NOT_FOUND,Bj.LOG_LEVELS.ERROR,t,!0);return await vj.getBackup(read_audit_log_object)}a(Fj,"getBackup")});var PL=g((Gde,ML)=>{var di=require("validate.js"),CL=st(),Ea=U(),{handleHDBError:qj,hdb_errors:kj}=ne(),{HDB_ERROR_MSGS:ht,HTTP_STATUS_CODES:Vj}=kj,HS=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),$j={STRUCTURE_USER:"structure_user"},wL=Object.values(Ea.ROLE_TYPES_ENUM),Yj="attribute_permissions",Kj="attribute_name",{PERMS_CRUD_ENUM:ha}=Ea,Wj=[Yj,...Object.values(ha)],DL=[ha.READ,ha.INSERT,ha.UPDATE],Qj=[Kj,...DL];function zj(e){let t=HS();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,LL(e,t)}a(zj,"addRoleValidation");function Jj(e){let t=HS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,LL(e,t)}a(Jj,"alterRoleValidation");function jj(e){let t=HS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,CL.validateObject(e,t)}a(jj,"dropRoleValidation");var Xj=["operation","role","id","permission","hdb_user","hdb_auth_header"];function LL(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)Xj.includes(n[o])||s.push(n[o]);s.length>0&&At(ht.INVALID_ROLE_JSON_KEYS(s),r);let i=CL.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{At(o,r)}),e.permission){let o=Zj(e);o&&At(o,r),wL.forEach(c=>{e.permission[c]&&!di.isBoolean(e.permission[c])&&At(ht.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(wL.indexOf(o)<0){if(o===$j.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let _=0,u=l.length;_<u;_++){let d=l[_];global.hdb_schema[d]||At(ht.SCHEMA_NOT_FOUND(d),r)}continue}At(ht.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){At(ht.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let _=c.tables[l];if(!l||!global.hdb_schema[o][l]){At(ht.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(_).forEach(u=>{Wj.includes(u)||At(ht.INVALID_PERM_KEY(u),r,o,l)}),Object.values(ha).forEach(u=>{di.isDefined(_[u])?di.isBoolean(_[u])||At(ht.TABLE_PERM_NOT_BOOLEAN(u),r,o,l):At(ht.TABLE_PERM_MISSING(u),r,o,l)}),di.isDefined(_.attribute_permissions)){if(!di.isArray(_.attribute_permissions)){At(ht.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}}else{At(ht.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}if(_.attribute_permissions){let u=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),d={read:!1,insert:!1,update:!1};for(let E in _.attribute_permissions){let f=_.attribute_permissions[E];if(Object.keys(f).forEach(p=>{!Qj.includes(p)&&p!==ha.DELETE&&At(ht.INVALID_ATTR_PERM_KEY(p),r,o,l)}),!di.isDefined(f.attribute_name)){At(ht.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=f.attribute_name;if(!u.includes(h)){At(ht.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}DL.forEach(p=>{di.isDefined(f[p])?di.isBoolean(f[p])||At(ht.ATTR_PERM_NOT_BOOLEAN(p,h),r,o,l):At(ht.ATTR_PERM_MISSING(p,h),r,o,l)}),!d.read&&f.read===!0&&(d.read=!0),!d.insert&&f.insert===!0&&(d.insert=!0),!d.update&&f.update===!0&&(d.update=!0)}if(_.read===!1&&d.read===!0||_.insert===!1&&d.insert===!0||_.update===!1&&d.update===!0){let E=`${o}.${l}`;At(ht.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return eX(r)}a(LL,"customValidate");ML.exports={addRoleValidation:zj,alterRoleValidation:Jj,dropRoleValidation:jj};function Zj(e){let{operation:t,permission:r}=e;if(t===Ea.OPERATIONS_ENUM.ADD_ROLE||t===Ea.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 ht.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Ea.ROLE_TYPES_ENUM.SUPER_USER:Ea.ROLE_TYPES_ENUM.CLUSTER_USER;return ht.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(Zj,"validateNoSUPerms");function eX(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:ht.ROLE_PERMS_ERROR,...e};return qj(new Error,n,Vj.BAD_REQUEST)}else return null}a(eX,"generateRolePermResponse");function At(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(At,"addPermError")});var VS=g((qde,HL)=>{"use strict";var UL=un(),vL=qr(),tX=zi(),GS=PL(),FS=bs(),rX=require("uuid").v4,nX=require("util"),Bd=U(),sX=z(),qS=vL.searchByValue,iX=vL.searchByHash,oX=nX.promisify(tX.delete),aX=es(),cX=na(),{hdb_errors:lX,handleHDBError:lo}=ne(),{HDB_ERROR_MSGS:BL,HTTP_STATUS_CODES:Al}=lX,{UserEventMsg:kS}=Ln();HL.exports={addRole:uX,alterRole:_X,dropRole:dX,listRoles:fX};function xS(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(xS,"scrubRoleDetails");async function uX(e){let t=GS.addRoleValidation(e);if(t)throw t;e=xS(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 qS(r)||[])}catch(i){throw lo(i)}if(n&&n.length>0)throw lo(new Error,BL.ROLE_ALREADY_EXISTS(e.role),Al.CONFLICT,void 0,void 0,!0);e.id||(e.id=rX());let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await UL.insert(s),FS.signalUserChange(new kS(process.pid)),e=xS(e),e}a(uX,"addRole");async function _X(e){let t=GS.alterRoleValidation(e);if(t)throw t;e=xS(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await UL.update(r)}catch(s){throw lo(s)}if(n&&n?.message==="updated 0 of 1 records")throw lo(new Error,"Invalid role id",Al.BAD_REQUEST,void 0,void 0,!0);return await FS.signalUserChange(new kS(process.pid)),e}a(_X,"alterRole");async function dX(e){let t=GS.dropRoleValidation(e);if(t)throw lo(new Error,t,Al.BAD_REQUEST,void 0,void 0,!0);let r=new cX(Bd.SYSTEM_SCHEMA_NAME,Bd.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await iX(r));if(n.length===0)throw lo(new Error,BL.ROLE_NOT_FOUND,Al.NOT_FOUND,void 0,void 0,!0);let s=new aX(Bd.SYSTEM_SCHEMA_NAME,Bd.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await qS(s)),o=!1;if(sX.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw lo(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,Al.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await oX(c),FS.signalUserChange(new kS(process.pid)),`${n[0].role} successfully deleted`}a(dX,"dropRole");async function fX(){return qS({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(fX,"listRoles")});var qL=g((Vde,FL)=>{"use strict";var EX=te(),fi=require("joi"),hX=st(),xL=require("moment"),mX=require("fs-extra"),$S=require("path"),pX=require("lodash"),Ol=U(),{LOG_LEVELS:uo}=U(),SX="YYYY-MM-DD hh:mm:ss",TX=$S.resolve(__dirname,"../logs");FL.exports=function(e){return hX.validateBySchema(e,gX)};var gX=fi.object({from:fi.custom(GL),until:fi.custom(GL),level:fi.valid(uo.NOTIFY,uo.FATAL,uo.ERROR,uo.WARN,uo.INFO,uo.DEBUG,uo.TRACE),order:fi.valid("asc","desc"),limit:fi.number().min(1),start:fi.number().min(0),log_name:fi.custom(RX)});function GL(e,t){if(xL(e,xL.ISO_8601).format(SX)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(GL,"validateDatetime");function RX(e,t){if(pX.invert(Ol.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=EX.get(Ol.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Ol.LOG_NAMES.HDB:e,i=s===Ol.LOG_NAMES.INSTALL?$S.join(TX,Ol.LOG_NAMES.INSTALL):$S.join(n,s);return mX.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(RX,"validateReadLogPath")});var KS=g((Yde,VL)=>{"use strict";var Hd=U(),AX=Y(),OX=te(),bX=qL(),YS=require("path"),kL=require("fs-extra"),{once:yX}=require("events"),{handleHDBError:NX,hdb_errors:IX}=ne(),{PACKAGE_ROOT:wX}=U(),CX=YS.join(wX,"logs"),DX=1e3,LX=200;VL.exports=MX;async function MX(e){let t=bX(e);if(t)throw NX(t,t.message,IX.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=OX.get(Hd.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?Hd.LOG_NAMES.HDB:e.log_name,s=n===Hd.LOG_NAMES.INSTALL?YS.join(CX,Hd.LOG_NAMES.INSTALL):YS.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,_=e.until!==void 0,u=_?new Date(e.until):void 0,d=e.limit===void 0?DX:e.limit,E=e.order===void 0?void 0:e.order,f=e.start===void 0?0:e.start,h=f+d,p=0;E==="desc"&&!l&&!u&&(p=Math.max(kL.statSync(s).size-(h+5)*LX,0));let S=kL.createReadStream(s,{start:p});S.on("error",v=>{AX.error(v)});let T=0,R=[],b="",C;S.on("data",v=>{let q=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;v=b+v;let M=0,Q;for(;(Q=q.exec(v))&&!S.destroyed;){C&&(C.message=v.slice(M,Q.index),H(C));let[J,j,ae]=Q,ce=ae.split("] ["),ge=ce[0],Ge=ce[1];ce.splice(0,2),C={timestamp:j,thread:ge,level:Ge,tags:ce,message:""},M=Q.index+J.length}b=v.slice(M)}),S.on("end",v=>{S.destroyed||C&&(C.message=b.trim(),H(C))}),S.resume();function H(v){let q,M,Q;switch(!0){case(i&&c&&_):q=new Date(v.timestamp),M=new Date(l),Q=new Date(u),v.level===o&&q>=M&&q<=Q&&T<f?T++:v.level===o&&q>=M&&q<=Q&&(Ei(v,E,R),T++,T===h&&S.destroy());break;case(i&&c):q=new Date(v.timestamp),M=new Date(l),v.level===o&&q>=M&&T<f?T++:v.level===o&&q>=M&&(Ei(v,E,R),T++,T===h&&S.destroy());break;case(i&&_):q=new Date(v.timestamp),Q=new Date(u),v.level===o&&q<=Q&&T<f?T++:v.level===o&&q<=Q&&(Ei(v,E,R),T++,T===h&&S.destroy());break;case(c&&_):q=new Date(v.timestamp),M=new Date(l),Q=new Date(u),q>=M&&q<=Q&&T<f?T++:q>=M&&q<=Q&&(Ei(v,E,R),T++,T===h&&S.destroy());break;case i:v.level===o&&T<f?T++:v.level===o&&(Ei(v,E,R),T++,T===h&&S.destroy());break;case c:q=new Date(v.timestamp),M=new Date(l),q>=M&&T<f?T++:q>=M&&T>=f&&(Ei(v,E,R),T++,T===h&&S.destroy());break;case _:q=new Date(v.timestamp),Q=new Date(u),q<=Q&&T<f?T++:q<=Q&&T>=f&&(Ei(v,E,R),T++,T===h&&S.destroy());break;default:T<f?T++:(Ei(v,E,R),T++,T===h&&S.destroy())}}return a(H,"onLogMessage"),await yX(S,"close"),R}a(MX,"readLog");function Ei(e,t,r){t==="desc"?PX(e,r):t==="asc"?UX(e,r):r.push(e)}a(Ei,"pushLineToResult");function PX(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(PX,"insertDescending");function UX(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(UX,"insertAscending")});var xd=g((Jde,WL)=>{"use strict";var WS=require("joi"),{string:bl,boolean:$L,date:vX}=WS.types(),BX=st(),{validateSchemaExists:Wde,validateTableExists:Qde,validateSchemaName:zde}=Jn(),HX=U(),xX=ct(),YL=te();YL.initSync();var GX=bl.invalid(YL.get(HX.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(xX.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(),KL={operation:bl.valid("add_node","update_node","set_node_replication"),node_name:GX,subscriptions:WS.array().items({table:bl.optional(),schema:bl.optional(),database:bl.optional(),subscribe:$L.required(),publish:$L.required().custom(qX),start_time:vX.iso()}).min(1).required()};function FX(e){return BX.validateBySchema(e,WS.object(KL))}a(FX,"addUpdateNodeValidator");function qX(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(qX,"checkForFalsy");WL.exports={addUpdateNodeValidator:FX,validation_schema:KL}});var zL=g((Xde,QL)=>{var kX=st(),VX={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};QL.exports=function(e){return kX.validateObject(e,VX)}});var zS=g((Zde,JL)=>{"use strict";var $X=U().OPERATIONS_ENUM,QS=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=$X.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};JL.exports=QS});var XL=g((tfe,jL)=>{"use strict";var YX={OPERATION:"operation",REFRESH:"refresh"},JS=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},jS=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};jL.exports={JWTTokens:JS,TOKEN_TYPE_ENUM:YX,JWTRSAKeys:jS}});var Il=g((nfe,rM)=>{"use strict";var Nl=require("jsonwebtoken"),XS=require("fs-extra"),ZS=z(),_n=U(),{handleHDBError:Ar,hdb_errors:KX}=ne(),{HTTP_STATUS_CODES:Or,AUTHENTICATION_ERROR_MSGS:br}=KX,yl=Y(),ZL=W_(),rT=Vr(),WX=un().update,QX=zS(),zX=bs(),{UserEventMsg:JX}=Ln(),hi=te();hi.initSync();var eT=require("path"),{JWTTokens:jX,JWTRSAKeys:XX,TOKEN_TYPE_ENUM:Gd}=XL(),ZX=hi.get(_n.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?hi.get(_n.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",eZ=hi.get(_n.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?hi.get(_n.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",Fd="RS256",tT;rM.exports={createTokens:tZ,validateOperationToken:nZ,refreshOperationToken:rZ,validateRefreshToken:tM};async function tZ(e){if(ZS.isEmpty(e)||typeof e!="object")throw Ar(new Error,br.INVALID_AUTH_OBJECT,Or.BAD_REQUEST,void 0,void 0,!0);if(ZS.isEmpty(e.username))throw Ar(new Error,br.USERNAME_REQUIRED,Or.BAD_REQUEST,void 0,void 0,!0);if(ZS.isEmpty(e.password))throw Ar(new Error,br.PASSWORD_REQUIRED,Or.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await rT.findAndValidateUser(e.username,e.password),!t)throw Ar(new Error,br.INVALID_CREDENTIALS,Or.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw yl.error(E),Ar(new Error,br.INVALID_CREDENTIALS,Or.UNAUTHORIZED,void 0,void 0,!0)}let r=await qd(),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 eM(i,r.private_key,r.passphrase),c=await Nl.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:eZ,algorithm:Fd,subject:Gd.REFRESH}),l=ZL.hash(c),_=new QX(_n.SYSTEM_SCHEMA_NAME,_n.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),u,d;try{u=await WX(_)}catch(E){yl.error(E),d=E}if(d!==void 0||u.skipped_hashes.length>0)throw Ar(new Error,br.REFRESH_TOKEN_SAVE_FAILED,Or.INTERNAL_SERVER_ERROR);return zX.signalUserChange(new JX(process.pid)),new jX(o,c)}a(tZ,"createTokens");async function eM(e,t,r){return await Nl.sign(e,{key:t,passphrase:r},{expiresIn:ZX,algorithm:Fd,subject:Gd.OPERATION})}a(eM,"signOperationToken");async function qd(){if(tT===void 0)try{let e=eT.join(hi.getHdbBasePath(),_n.LICENSE_KEY_DIR_NAME,_n.JWT_ENUM.JWT_PASSPHRASE_NAME),t=eT.join(hi.getHdbBasePath(),_n.LICENSE_KEY_DIR_NAME,_n.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=eT.join(hi.getHdbBasePath(),_n.LICENSE_KEY_DIR_NAME,_n.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await XS.readFile(e)).toString(),s=(await XS.readFile(t)).toString(),i=(await XS.readFile(r)).toString();tT=new XX(i,s,n)}catch(e){throw yl.error(e),Ar(new Error,br.NO_ENCRYPTION_KEYS,Or.INTERNAL_SERVER_ERROR)}return tT}a(qd,"getJWTRSAKeys");async function rZ(e){if(!e)throw Ar(new Error,br.INVALID_BODY,Or.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw Ar(new Error,br.REFRESH_TOKEN_REQUIRED,Or.BAD_REQUEST,void 0,void 0,!0);await tM(e.refresh_token);let t=await qd(),r=await Nl.decode(e.refresh_token);return{operation_token:await eM({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(rZ,"refreshOperationToken");async function nZ(e){try{let t=await qd(),r=await Nl.verify(e,t.public_key,{algorithms:Fd,subject:Gd.OPERATION});return await rT.findAndValidateUser(r.username,void 0,!1)}catch(t){throw yl.warn(t),t.name&&t.name==="TokenExpiredError"?Ar(new Error,br.TOKEN_EXPIRED,Or.FORBIDDEN):Ar(new Error,br.INVALID_TOKEN,Or.UNAUTHORIZED)}}a(nZ,"validateOperationToken");async function tM(e){let t;try{let r=await qd(),n=await Nl.verify(e,r.public_key,{algorithms:Fd,subject:Gd.REFRESH});t=await rT.findAndValidateUser(n.username,void 0,!1)}catch(r){throw yl.warn(r),r.name&&r.name==="TokenExpiredError"?Ar(new Error,br.TOKEN_EXPIRED,Or.FORBIDDEN):Ar(new Error,br.INVALID_TOKEN,Or.UNAUTHORIZED)}if(!ZL.validate(t.refresh_token,e))throw Ar(new Error,br.INVALID_TOKEN,Or.UNAUTHORIZED);return t}a(tM,"validateRefreshToken")});var nT=g((ofe,iM)=>{"use strict";var sZ=zL(),ma=require("passport"),iZ=require("passport-local").Strategy,oZ=require("passport-http").BasicStrategy,aZ=require("util"),cZ=Vr(),sM=aZ.callbackify(cZ.findAndValidateUser),ife=Ur(),lZ=U(),nM=Il();ma.use(new iZ(function(e,t,r){sM(e,t,r)}));ma.use(new oZ(function(e,t,r){sM(e,t,r)}));ma.serializeUser(function(e,t){t(null,e)});ma.deserializeUser(function(e,t){t(null,e)});function uZ(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":ma.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===lZ.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?nM.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):nM.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:ma.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(uZ,"authorize");function _Z(e,t){let r=sZ(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(_Z,"checkPermissions");iM.exports={authorize:uZ,checkPermissions:_Z}});var pa=g((cfe,oM)=>{"use strict";var sT=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},iT=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};oM.exports={Node:sT,NodeSubscription:iT}});var cM=g((ufe,aM)=>{"use strict";var dZ=U().OPERATIONS_ENUM,oT=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=dZ.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};aM.exports=oT});var wl=g((dfe,lM)=>{"use strict";var aT=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},cT=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)}};lM.exports={RemotePayloadObject:aT,RemotePayloadSubscription:cT}});var _M=g((Efe,uM)=>{"use strict";var lT=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}};uM.exports=lT});var EM=g((Tfe,fM)=>{"use strict";var fZ=_M(),mfe=dt(),dM=Ke(),EZ=Y(),{getSchemaPath:pfe,getTransactionAuditStorePath:Sfe}=ze(),{getDatabases:hZ}=(Ae(),ie(ke));fM.exports=mZ;async function mZ(e){let t=new fZ;try{let r=hZ()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats(),i=await dM.environmentDataSize(schema_path,e.name),o=await dM.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){EZ.warn(`unable to stat table dbi due to ${r}`)}return t}a(mZ,"lmdbGetTableSize")});var mM=g((Rfe,hM)=>{"use strict";var uT=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}};hM.exports=uT});var Sa=g((Ife,gM)=>{"use strict";var pZ=require("fs-extra"),SZ=require("path"),sr=require("systeminformation"),mi=Y(),pM=Rt(),Ofe=ct(),Vd=U(),TZ=EM(),gZ=si(),{getThreadInfo:SM}=ot(),RT=te();RT.initSync();var RZ=mM(),{openEnvironment:bfe}=Ke(),{getSchemaPath:yfe}=ze(),{database:Nfe,databases:_T}=(Ae(),ie(ke)),kd;gM.exports={getHDBProcessInfo:hT,getNetworkInfo:pT,getDiskInfo:mT,getMemoryInfo:ET,getCPUInfo:fT,getTimeInfo:dT,getSystemInformation:ST,systemInformation:AZ,getTableSize:TT,getMetrics:gT};function dT(){return sr.time()}a(dT,"getTimeInfo");async function fT(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:_,...u}=await sr.cpu();u.cpu_speed=await sr.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:E,raw_currentload_irq:f,raw_currentload_nice:h,raw_currentload_system:p,raw_currentload_user:S,cpus:T,...R}=await sr.currentLoad();return R.cpus=[],T.forEach(b=>{let{raw_load:C,raw_load_idle:H,raw_load_irq:v,raw_load_nice:q,raw_load_system:M,raw_load_user:Q,...J}=b;R.cpus.push(J)}),u.current_load=R,u}catch(e){return mi.error(`error in getCPUInfo: ${e}`),{}}}a(fT,"getCPUInfo");async function ET(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await sr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return mi.error(`error in getMemoryInfo: ${e}`),{}}}a(ET,"getMemoryInfo");async function hT(){let e={core:[],clustering:[]};try{let t=await sr.processes(),r;try{r=Number.parseInt(await pZ.readFile(SZ.join(RT.get(Vd.CONFIG_PARAMS.ROOTPATH),Vd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Vd.NODE_ERROR_CODES.ENOENT)mi.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return mi.error(`error in getHDBProcessInfo: ${t}`),e}}a(hT,"getHDBProcessInfo");async function mT(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await sr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,..._}=await sr.fsStats();return e.read_write=_,e.size=await sr.fsSize(),e}catch(t){return mi.error(`error in getDiskInfo: ${t}`),e}}a(mT,"getDiskInfo");async function pT(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await sr.networkInterfaceDefault(),e.latency=await sr.inetChecksite("google.com"),(await sr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:_,ieee8021xState:u,carrier_changes:d,...E}=n;e.interfaces.push(E)}),(await sr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)}),e}catch(t){return mi.error(`error in getNetworkInfo: ${t}`),e}}a(pT,"getNetworkInfo");async function ST(){if(kd!==void 0)return kd;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await sr.osInfo();e=c;let l=await sr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,kd=e,kd}catch(t){return mi.error(`error in getSystemInformation: ${t}`),e}}a(ST,"getSystemInformation");async function TT(){let e=[],t=await gZ.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await TZ(n));return e}a(TT,"getTableSize");async function gT(){let e={};for(let t in _T){let r=e[t]={},n=r.tables={};for(let s in _T[t])try{let i=_T[t][s];r.readers||(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[_,u,d]=l.trim().split(" ");return{pid:_,thread:u,txnid:d}}),i.primaryStore.auditStore&&(r.audit=i.auditStore.getStats()));let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){mi.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(gT,"getMetrics");async function TM(){if(RT.get(Vd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await pM.getNATSReferences(),t=await pM.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(TM,"getNatsStreamInfo");async function AZ(e){let t=new RZ;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await ST(),t.time=dT(),t.cpu=await fT(),t.memory=await ET(),t.disk=await mT(),t.network=await pT(),t.harperdb_processes=await hT(),t.table_size=await TT(),t.metrics=await gT(),t.threads=await SM(),t.replication=await TM(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await ST();break;case"time":t.time=dT();break;case"cpu":t.cpu=await fT();break;case"memory":t.memory=await ET();break;case"disk":t.disk=await mT();break;case"network":t.network=await pT();break;case"harperdb_processes":t.harperdb_processes=await hT();break;case"table_size":t.table_size=await TT();break;case"database_metrics":case"metrics":t.metrics=await gT();break;case"threads":t.threads=await SM();break;case"replication":t.replication=await TM();break;default:break}return t}a(AZ,"systemInformation")});var Yd=g((Cfe,RM)=>{"use strict";RM.exports={version:OZ,printVersion:bZ};var $d=ul();function OZ(){if($d)return $d.version}a(OZ,"version");function bZ(){$d&&console.log(`HarperDB Version ${$d.version}`)}a(bZ,"printVersion")});var Cs=g((Pfe,yM)=>{"use strict";var yZ=un(),AT=z(),NZ=require("util"),_o=U(),AM=te();AM.initSync();var IZ=nT(),OM=qr(),{Node:Lfe,NodeSubscription:Mfe}=pa(),wZ=na(),CZ=cM(),{RemotePayloadObject:DZ,RemotePayloadSubscription:LZ}=wl(),{handleHDBError:MZ,hdb_errors:PZ}=ne(),{HTTP_STATUS_CODES:UZ,HDB_ERROR_MSGS:vZ}=PZ,BZ=es(),HZ=Sa(),xZ=Yd(),{getDatabases:GZ}=(Ae(),ie(ke)),FZ=NZ.promisify(IZ.authorize),qZ=OM.searchByHash,kZ=OM.searchByValue;yM.exports={authHeaderToUser:VZ,isEmpty:$Z,getNodeRecord:YZ,upsertNodeRecord:KZ,buildNodePayloads:WZ,checkClusteringEnabled:QZ,getAllNodeRecords:zZ,getSystemInfo:JZ,reverseSubscription:bM};async function VZ(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await FZ(t,null),e}a(VZ,"authHeaderToUser");function $Z(e){return e==null}a($Z,"isEmpty");async function YZ(e){let t=new wZ(_o.SYSTEM_SCHEMA_NAME,_o.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return qZ(t)}a(YZ,"getNodeRecord");async function KZ(e){let t=new CZ(_o.SYSTEM_SCHEMA_NAME,_o.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return yZ.upsert(t)}a(KZ,"upsertNodeRecord");function bM(e){if(AT.isEmpty(e.subscribe)||AT.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(bM,"reverseSubscription");function WZ(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:_}=c,u=AT.getTableHashAttribute(l,_),{subscribe:d,publish:E}=bM(c),f=GZ()[l]?.[_],h=new LZ(l,_,u,E,d,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new DZ(r,t,s,n)}a(WZ,"buildNodePayloads");function QZ(){if(!AM.get(_o.CONFIG_PARAMS.CLUSTERING_ENABLED))throw MZ(new Error,vZ.CLUSTERING_NOT_ENABLED,UZ.BAD_REQUEST,void 0,void 0,!0)}a(QZ,"checkClusteringEnabled");async function zZ(){let e=new BZ(_o.SYSTEM_SCHEMA_NAME,_o.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await kZ(e))}a(zZ,"getAllNodeRecords");async function JZ(){let e=await HZ.getSystemInformation();return{hdb_version:xZ.version(),node_version:e.node_version,platform:e.platform}}a(JZ,"getSystemInfo")});var OT=g((vfe,PM)=>{"use strict";var Kd=Rt(),NM=z(),IM=ct(),wM=U(),Wd=Y(),CM=Pd(),jZ=Hp(),{RemotePayloadObject:XZ}=wl(),{handleHDBError:DM,hdb_errors:ZZ}=ne(),{HTTP_STATUS_CODES:LM}=ZZ,{NodeSubscription:MM}=pa();PM.exports=e5;async function e5(e,t){let r;try{r=await Kd.request(`${t}.${IM.REQUEST_SUFFIX}`,new XZ(wM.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),Wd.trace("Response from remote describe all request:",r)}catch(o){Wd.error(`addNode received error from describe all request to remote node: ${o}`);let c=Kd.requestErrorHandler(o,"add_node",t);throw DM(new Error,c,LM.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===IM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw DM(new Error,o,LM.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,l=o.database??o.schema??"data";if(l===wM.SYSTEM_SCHEMA_NAME){await Kd.createLocalTableStream(l,c);let h=new MM(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let _=NM.doesSchemaExist(l),u=n[l]!==void 0,d=c?NM.doesTableExist(l,c):!0,E=c?n?.[l]?.[c]!==void 0:!0;if(!_&&!u||!d&&!E){s.push(o);continue}if(!_&&u&&(Wd.trace(`addNode creating schema: ${l}`),await CM.createSchema({operation:"create_schema",schema:l})),!d&&E){Wd.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new jZ(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await CM.createTable(h)}await Kd.createLocalTableStream(l,c);let f=new MM(l,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(e5,"reviewSubscriptions")});var jd=g((Hfe,BM)=>{"use strict";var{handleHDBError:Qd,hdb_errors:t5}=ne(),{HTTP_STATUS_CODES:zd}=t5,{addUpdateNodeValidator:r5}=xd(),Jd=Y(),vM=U(),UM=ct(),n5=z(),Cl=Rt(),Dl=Cs(),s5=te(),i5=OT(),{Node:o5,NodeSubscription:a5}=pa(),{broadcast:c5}=ot(),l5="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",u5="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",_5=s5.get(vM.CONFIG_PARAMS.CLUSTERING_NODENAME);BM.exports=d5;async function d5(e,t=!1){Jd.trace("addNode called with:",e),Dl.checkClusteringEnabled();let r=r5(e);if(r)throw Qd(r,r.message,zd.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await Dl.getNodeRecord(n);if(!n5.isEmptyOrZeroLength(d))throw Qd(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,zd.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await i5(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=l5,o;let c=Dl.buildNodePayloads(s,_5,vM.OPERATIONS_ENUM.ADD_NODE,await Dl.getSystemInfo()),l=[];for(let d=0,E=s.length;d<E;d++){let f=s[d];s[d].start_time===void 0&&delete s[d].start_time,l.push(new a5(f.schema,f.table,f.publish,f.subscribe))}Jd.trace("addNode sending remote payload:",c);let _;try{_=await Cl.request(`${n}.${UM.REQUEST_SUFFIX}`,c)}catch(d){Jd.error(`addNode received error from request: ${d}`);for(let f=0,h=s.length;f<h;f++){let p=s[f];p.publish=!1,p.subscribe=!1,await Cl.updateRemoteConsumer(p,n)}let E=Cl.requestErrorHandler(d,"add_node",n);throw Qd(new Error,E,zd.INTERNAL_SERVER_ERROR,"error",E)}if(_.status===UM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${_.message}`;throw Qd(new Error,d,zd.INTERNAL_SERVER_ERROR,"error",d)}Jd.trace(_);for(let d=0,E=s.length;d<E;d++){let f=s[d];await Cl.updateRemoteConsumer(f,n),f.subscribe===!0&&await Cl.updateConsumerIterator(f.schema,f.table,n,"start")}let u=new o5(n,l,_.system_info);return await Dl.upsertNodeRecord(u),c5({type:"nats_update"}),i.length>0?o.message=u5:o.message=`Successfully added '${n}' to manifest`,o}a(d5,"addNode")});var NT=g((Ffe,GM)=>{"use strict";var{handleHDBError:bT,hdb_errors:f5}=ne(),{HTTP_STATUS_CODES:yT}=f5,{addUpdateNodeValidator:E5}=xd(),Ll=Y(),xM=U(),HM=ct(),Gfe=z(),Ml=Rt(),Pl=Cs(),h5=te(),{cloneDeep:m5}=require("lodash"),p5=OT(),{Node:S5,NodeSubscription:T5}=pa(),{broadcast:g5}=ot(),R5="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",A5="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",O5=h5.get(xM.CONFIG_PARAMS.CLUSTERING_NODENAME);GM.exports=b5;async function b5(e){Ll.trace("updateNode called with:",e),Pl.checkClusteringEnabled();let t=E5(e);if(t)throw bT(t,t.message,yT.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Pl.getNodeRecord(r);s.length>0&&(n=m5(s));let{added:i,skipped:o}=await p5(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=R5,c;let l=Pl.buildNodePayloads(i,O5,xM.OPERATIONS_ENUM.UPDATE_NODE,await Pl.getSystemInfo());for(let u=0,d=i.length;u<d;u++){let E=i[u];Ll.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[u].start_time===void 0&&delete i[u].start_time}Ll.trace("updateNode sending remote payload:",l);let _;try{_=await Ml.request(`${r}.${HM.REQUEST_SUFFIX}`,l)}catch(u){Ll.error(`updateNode received error from request: ${u}`);let d=Ml.requestErrorHandler(u,"update_node",r);throw bT(new Error,d,yT.INTERNAL_SERVER_ERROR,"error",d)}if(_.status===HM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let u=`Error returned from remote node ${r}: ${_.message}`;throw bT(new Error,u,yT.INTERNAL_SERVER_ERROR,"error",u)}Ll.trace(_);for(let u=0,d=i.length;u<d;u++){let E=i[u];await Ml.updateRemoteConsumer(E,r),E.subscribe===!0?await Ml.updateConsumerIterator(E.schema,E.table,r,"start"):await Ml.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new S5(r,[],_.system_info)]),await y5(n[0],i,_.system_info),o.length>0?c.message=A5:c.message=`Successfully updated '${r}'`,c}a(b5,"updateNode");async function y5(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,_=e.subscriptions.length;l<_;l++){let u=n.subscriptions[l];if(u.schema===o.schema&&u.table===o.table){u.publish=o.publish,u.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new T5(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Pl.upsertNodeRecord(n),g5({type:"nats_update"})}a(y5,"updateNodeTable")});var $M=g((kfe,VM)=>{"use strict";var kM=require("joi"),{string:FM}=kM.types(),N5=st(),qM=U(),I5=te(),w5=ct();VM.exports=C5;function C5(e){let t=FM.invalid(I5.get(qM.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(w5.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=kM.object({operation:FM.valid(qM.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return N5.validateBySchema(e,r)}a(C5,"removeNodeValidator")});var Zd=g(($fe,zM)=>{"use strict";var{handleHDBError:YM,hdb_errors:D5}=ne(),{HTTP_STATUS_CODES:KM}=D5,L5=$M(),Ul=Y(),WM=Cs(),M5=z(),Xd=U(),QM=ct(),IT=Rt(),P5=te(),{RemotePayloadObject:U5}=wl(),{NodeSubscription:v5}=pa(),B5=rl(),H5=zi(),{broadcast:x5}=ot(),G5=P5.get(Xd.CONFIG_PARAMS.CLUSTERING_NODENAME);zM.exports=F5;async function F5(e){Ul.trace("removeNode called with:",e),WM.checkClusteringEnabled();let t=L5(e);if(t)throw YM(t,t.message,KM.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await WM.getNodeRecord(r);if(M5.isEmptyOrZeroLength(n))throw YM(new Error,`Node '${r}' was not found.`,KM.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new U5(Xd.OPERATIONS_ENUM.REMOVE_NODE,G5,[]),i,o=!1;for(let l=0,_=n.subscriptions.length;l<_;l++){let u=n.subscriptions[l];u.subscribe===!0&&await IT.updateConsumerIterator(u.schema,u.table,r,"stop");try{await IT.updateRemoteConsumer(new v5(u.schema,u.table,!1,!1),r)}catch(d){Ul.error(d)}}try{i=await IT.request(`${r}.${QM.REQUEST_SUFFIX}`,s),Ul.trace("Remove node reply from remote node:",r,i)}catch(l){Ul.error("removeNode received error from request:",l),o=!0}let c=new B5(Xd.SYSTEM_SCHEMA_NAME,Xd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await H5.deleteRecord(c),x5({type:"nats_update"}),i?.status===QM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(Ul.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(F5,"removeNode")});var XM=g((Kfe,jM)=>{"use strict";var JM=require("joi"),{string:q5,array:k5}=JM.types(),V5=st(),$5=xd();jM.exports=Y5;function Y5(e){let t=JM.object({operation:q5.valid("configure_cluster").required(),connections:k5.items($5.validation_schema).required()});return V5.validateBySchema(e,t)}a(Y5,"configureClusterValidator")});var wT=g((Qfe,nP)=>{"use strict";var K5=U(),ef=Y(),W5=z(),Q5=Zd(),z5=jd(),ZM=Cs(),J5=XM(),{handleHDBError:eP,hdb_errors:j5}=ne(),{HTTP_STATUS_CODES:tP}=j5,X5="Configure cluster complete.",Z5="Failed to configure the cluster. Check the logs for more details.",e8="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";nP.exports=t8;async function t8(e){ef.trace("configure cluster called with:",e),ZM.checkClusteringEnabled();let t=J5(e);if(t)throw eP(t,t.message,tP.BAD_REQUEST,void 0,void 0,!0);let r=await ZM.getAllNodeRecords(),n=[];for(let u=0,d=r.length;u<d;u++){let E=await rP(Q5,{operation:K5.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[u].name},r[u].name);n.push(E)}ef.trace("All results from configure_cluster remove node:",n);let s=[],i=e.connections.length;for(let u=0;u<i;u++){let d=e.connections[u],E=await rP(z5,d,d.node_name);s.push(E)}ef.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,_=n.concat(s);for(let u=0,d=_.length;u<d;u++){let E=_[u];E.status==="rejected"&&(ef.error(E),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(l=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,subscriptions:E?.result})}if(W5.isEmptyOrZeroLength(o))return{message:X5,connections:c};if(l)return{message:e8,failed_nodes:o,connections:c};throw eP(new Error,Z5,tP.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(t8,"configureCluster");async function rP(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(rP,"functionWrapper")});var aP=g((Jfe,oP)=>{"use strict";var vl=require("joi"),r8=st(),{validateSchemaExists:sP,validateTableExists:n8,validateSchemaName:iP}=Jn(),s8=vl.object({operation:vl.string().valid("purge_stream"),schema:vl.string().custom(sP).custom(iP).optional(),database:vl.string().custom(sP).custom(iP).optional(),table:vl.string().custom(n8).required()});function i8(e){return r8.validateBySchema(e,s8)}a(i8,"purgeStreamValidator");oP.exports=i8});var CT=g((Xfe,cP)=>{"use strict";var{handleHDBError:o8,hdb_errors:a8}=ne(),{HTTP_STATUS_CODES:c8}=a8,l8=aP(),u8=Rt(),_8=Cs();cP.exports=d8;async function d8(e){e.schema=e.schema??e.database;let t=l8(e);if(t)throw o8(t,t.message,c8.BAD_REQUEST,void 0,void 0,!0);_8.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await u8.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(d8,"purgeStream")});var MT=g((eEe,EP)=>{"use strict";var LT=Cs(),f8=Rt(),_P=te(),tf=U(),fo=ct(),E8=z(),DT=Y(),{RemotePayloadObject:h8}=wl(),{ErrorCode:lP}=require("nats"),uP=_P.get(tf.CONFIG_PARAMS.CLUSTERING_ENABLED),dP=_P.get(tf.CONFIG_PARAMS.CLUSTERING_NODENAME);EP.exports={clusterStatus:m8,buildNodeStatus:fP};async function m8(){let e={node_name:dP,is_enabled:uP,connections:[]};if(!uP)return e;let t=await LT.getAllNodeRecords();if(E8.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(fP(t[n],e.connections));return await Promise.allSettled(r),e}a(m8,"clusterStatus");async function fP(e,t){let r=e.name,n=new h8(tf.OPERATIONS_ENUM.CLUSTER_STATUS,dP,void 0,await LT.getSystemInfo()),s,i,o=fo.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await f8.request(fo.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===fo.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=fo.CLUSTER_STATUS_STATUSES.CLOSED,DT.error(`Error getting node status from ${r} `,s))}catch(l){DT.warn(`Error getting node status from ${r}`,l),l.code===lP.NoResponders?o=fo.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===lP.Timeout?o=fo.CLUSTER_STATUS_STATUSES.TIMEOUT:o=fo.CLUSTER_STATUS_STATUSES.CLOSED}let c=new p8(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==tf.PRE_4_0_0_VERSION&&await LT.upsertNodeRecord(l)}catch(l){DT.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(fP,"buildNodeStatus");function p8(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(p8,"NodeStatusObject")});var UT=g((rEe,hP)=>{"use strict";var{handleHDBError:S8,hdb_errors:T8}=ne(),{HTTP_STATUS_CODES:g8}=T8,R8=Rt(),A8=Cs(),PT=z(),rf=require("joi"),O8=st(),b8=2e3,y8=rf.object({timeout:rf.number().min(1),connected_nodes:rf.boolean(),routes:rf.boolean()});hP.exports=N8;async function N8(e){A8.checkClusteringEnabled();let t=O8.validateBySchema(e,y8);if(t)throw S8(t,t.message,g8.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||PT.autoCastBoolean(n),o=s===void 0||PT.autoCastBoolean(s),c={nodes:[]},l=await R8.getServerList(r??b8),_={};if(i)for(let u=0,d=l.length;u<d;u++){let E=l[u].statsz;E&&(_[l[u].server.name]=E.routes)}for(let u=0,d=l.length;u<d;u++){if(l[u].statsz)continue;let E=l[u].server,f=l[u].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:l[u].response_time};i&&(h.connected_nodes=[],_[E.name]&&_[E.name].forEach(p=>{h.connected_nodes.includes(p.name.slice(0,-4))||h.connected_nodes.push(p.name.slice(0,-4))})),o&&(h.routes=f.cluster?.urls?f.cluster?.urls.map(p=>({host:p.split(":")[0],port:PT.autoCast(p.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(N8,"clusterNetwork")});var TP=g((sEe,SP)=>{"use strict";var vT=require("joi"),mP=st(),{route_constraints:pP}=Hh();SP.exports={setRoutesValidator:I8,deleteRoutesValidator:w8};function I8(e){let t=vT.object({server:vT.valid("hub","leaf").required(),routes:pP.required()});return mP.validateBySchema(e,t)}a(I8,"setRoutesValidator");function w8(e){let t=vT.object({routes:pP.required()});return mP.validateBySchema(e,t)}a(w8,"deleteRoutesValidator")});var HT=g((oEe,OP)=>{"use strict";var Eo=dr(),BT=z(),nf=U(),gP=TP(),{handleHDBError:RP,hdb_errors:C8}=ne(),{HTTP_STATUS_CODES:AP}=C8,D8="cluster routes successfully set",L8="cluster routes successfully deleted";OP.exports={setRoutes:M8,getRoutes:P8,deleteRoutes:U8};function M8(e){let t=gP.setRoutesValidator(e);if(t)throw RP(t,t.message,AP.BAD_REQUEST,void 0,void 0,!0);let r=Eo.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,l=e.routes.length;c<l;c++){let _=e.routes[c];_.port=BT.autoCast(_.port);let u=n.some(E=>E.host===_.host&&E.port===_.port),d=s.some(E=>E.host===_.host&&E.port===_.port);u||d?i.push(_):(n.push(_),o.push(_))}return e.server==="hub"?Eo.updateConfigValue(nf.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n):Eo.updateConfigValue(nf.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n),{message:D8,set:o,skipped:i}}a(M8,"setRoutes");function P8(){let e=Eo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}a(P8,"getRoutes");function U8(e){let t=gP.deleteRoutesValidator(e);if(t)throw RP(t,t.message,AP.BAD_REQUEST,void 0,void 0,!0);let r=Eo.getClusteringRoutes(),n=r.hub_routes,s=r.leaf_routes,i=[],o=[],c=!1,l=!1;for(let _=0,u=e.routes.length;_<u;_++){let d=e.routes[_],E=!1;for(let f=0,h=n.length;f<h;f++){let p=n[f];if(d.host===p.host&&d.port===p.port){n.splice(f,1),E=!0,c=!0,i.push(d);break}}if(!E){let f=!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),l=!0,f=!1,i.push(d);break}}f&&o.push(d)}}return c&&(n=BT.isEmptyOrZeroLength(n)?null:n,Eo.updateConfigValue(nf.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n)),l&&(s=BT.isEmptyOrZeroLength(s)?null:s,Eo.updateConfigValue(nf.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,s)),{message:L8,deleted:i,skipped:o}}a(U8,"deleteRoutes")});var yP=g((cEe,bP)=>{"use strict";var Bl=require("alasql"),ho=require("recursive-iterator"),Bn=Y(),v8=z(),Hl=U(),xT=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,H8(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=>Hl.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=>!Hl.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][Hl.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=B8(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(_=>({attribute_name:_.attribute}));let l=this.affected_attributes.get(i).get(o).filter(_=>!Hl.SEARCH_WILDCARDS.includes(_));c.forEach(({attribute_name:_})=>{let u=new Bl.yy.Column({columnid:_});s.tableid&&(u.tableid=s.tableid),this.ast.columns.push(u),l.includes(_)||l.push(_)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function B8(e){return e.filter(t=>t[Hl.PERMS_CRUD_ENUM.READ])}a(B8,"filterReadRestrictedAttrs");function H8(e,t,r,n,s){x8(e,t,r,n,s)}a(H8,"interpretAST");function xl(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(xl,"addSchemaTableToMap");function x8(e,t,r,n,s){if(!e){Bn.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Bl.yy.Insert?k8(e,t,r):e instanceof Bl.yy.Select?G8(e,t,r,n,s):e instanceof Bl.yy.Update?F8(e,t,r):e instanceof Bl.yy.Delete?q8(e,t,r):Bn.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(x8,"getRecordAttributesAST");function G8(e,t,r,n,s){if(!e){Bn.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(v8.isEmptyOrZeroLength(i)){Bn.error("No schema specified");return}e.from.forEach(c=>{xl(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),xl(c.table,t,r,n,s)});let o=new ho(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,_=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(_).has(l))if(r.has(l))l=r.get(l);else{Bn.info(`table specified as ${l} not found.`);return}t.get(_).get(l).indexOf(c.columnid)<0&&t.get(_).get(l).push(c.columnid)}if(e.where){let c=new ho(e.where),l=e.from[0].tableid;for(let{node:_}of c)if(_&&_.columnid){let u=_.tableid?_.tableid:l;if(!t.get(i).has(u))if(r.has(u))u=r.get(u);else{Bn.info(`table specified as ${u} not found.`);continue}t.get(i).get(u).indexOf(_.columnid)<0&&t.get(i).get(u).push(_.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new ho(c.on);for(let{node:_}of l)if(_&&_.columnid){let u=_.tableid,d=s.get(u);if(!t.get(d).has(u))if(r.has(u))u=r.get(u);else{Bn.info(`table specified as ${u} not found.`);continue}t.get(d).get(u).indexOf(_.columnid)<0&&t.get(d).get(u).push(_.columnid)}}),e.order){let c=new ho(e.order);for(let{node:l}of c)if(l&&l.columnid){let _=l.tableid,u=n.has(_)?n.get(_):i;if(_||(_=e.from[0].tableid),!t.get(u).has(_))if(r.has(_))_=r.get(_);else{Bn.info(`table specified as ${_} not found.`);return}t.get(u).get(_).indexOf(l.columnid)<0&&t.get(u).get(_).push(l.columnid)}}}a(G8,"getSelectAttributes");function F8(e,t,r){if(!e){Bn.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new ho(e.columns),s=e.table.databaseid;xl(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&GT(e.table.tableid,s,i.columnid,t,r)}a(F8,"getUpdateAttributes");function q8(e,t,r){if(!e){Bn.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new ho(e.where),s=e.table.databaseid;xl(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&GT(e.table.tableid,s,i.columnid,t,r)}a(q8,"getDeleteAttributes");function k8(e,t,r){if(!e){Bn.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new ho(e.columns),s=e.into.databaseid;xl(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&GT(e.into.tableid,s,i.columnid,t,r)}a(k8,"getInsertAttributes");function GT(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(GT,"pushAttribute");bP.exports=xT});var kT=g((uEe,CP)=>{var sf=Ji(),NP=require("chalk"),Qr=Y(),IP=require("prompt"),{promisify:V8}=require("util"),FT=U(),$8=require("fs-extra"),Y8=require("path"),K8=z(),W8=Yd(),wP=te();wP.initSync();var Q8=require("moment"),z8=V8(IP.get),J8=Y8.join(wP.getHdbBasePath(),FT.LICENSE_KEY_DIR_NAME,FT.LICENSE_FILE_NAME,FT.LICENSE_FILE_NAME);CP.exports={getFingerprint:X8,setLicense:j8,parseLicense:qT,register:Z8,getRegistrationInfo:t6};async function j8(e){if(e&&e.key&&e.company){try{Qr.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await qT(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Qr.error(r),Qr.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(j8,"setLicense");async function X8(){let e={};try{e=await sf.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Qr.error(r),Qr.error(t),new Error(r)}return e}a(X8,"getFingerprint");async function qT(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Qr.info("Validating license input...");let r=sf.validateLicense(e,t);if(Qr.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Qr.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Qr.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Qr.info("writing license to disk"),await $8.writeFile(J8,JSON.stringify({license_key:e,company:t}))}catch(n){throw Qr.error("Failed to write License"),n}return"Registration successful."}a(qT,"parseLicense");async function Z8(){let e=await e6();return qT(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(Z8,"register");async function e6(){let e=await sf.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:NP.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:NP.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{IP.start()}catch(n){Qr.error(n)}let r;try{r=await z8(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(e6,"promptForRegistration");async function t6(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await sf.getLicense()}catch(r){throw Qr.error(`There was an error when searching licenses due to: ${r.message}`),r}if(K8.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=W8.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=Q8.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(t6,"getRegistrationInfo")});var LP=g((dEe,DP)=>{"use strict";var r6=ct(),VT=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,_,u,d,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+r6.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:_,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:u,port:d,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};DP.exports=VT});var UP=g((EEe,PP)=>{"use strict";var MP=ct(),$T=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,_,u,d){this.port=t,d===null&&(d=void 0),this.server_name=r+MP.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+MP.SERVER_SUFFIX.LEAF},this.tls={cert_file:_,key_file:u,ca_file:d,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:d,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:d,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};PP.exports=$T});var BP=g((mEe,vP)=>{"use strict";var YT=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};vP.exports=YT});var xP=g((SEe,HP)=>{"use strict";var n6=ct(),KT=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+n6.SERVER_SUFFIX.ADMIN,this.password=r}};HP.exports=KT});var zT=g((gEe,qP)=>{"use strict";var Ta=require("path"),cf=require("fs-extra"),s6=LP(),i6=UP(),o6=BP(),a6=xP(),WT=Vr(),Ra=z(),yr=dr(),af=U(),Gl=ct(),{CONFIG_PARAMS:mt}=af,Aa=Y(),Fl=te(),GP=As(),QT=Rt(),ga="clustering",c6=1e4,FP=50;qP.exports={generateNatsConfig:u6,removeNatsConfig:_6,getHubConfigPath:l6};function l6(){let e=Fl.get(mt.ROOTPATH);return Ta.join(e,ga,Gl.NATS_CONFIG_FILES.HUB_SERVER)}a(l6,"getHubConfigPath");async function u6(e=!1,t=void 0){Fl.initSync();let r=Fl.get(mt.ROOTPATH),n=Ta.join(r,ga,Gl.PID_FILES.HUB),s=Ta.join(r,ga,Gl.PID_FILES.LEAF),i=yr.getConfigFromFile(mt.CLUSTERING_LEAFSERVER_STREAMS_PATH),o=Ta.join(r,ga,Gl.NATS_CONFIG_FILES.HUB_SERVER),c=Ta.join(r,ga,Gl.NATS_CONFIG_FILES.LEAF_SERVER),l=yr.getConfigFromFile(mt.CLUSTERING_TLS_CERTIFICATE),_=yr.getConfigFromFile(mt.CLUSTERING_TLS_PRIVATEKEY),u=yr.getConfigFromFile(mt.CLUSTERING_TLS_CERT_AUTH),d=yr.getConfigFromFile(mt.CLUSTERING_TLS_INSECURE),E=yr.getConfigFromFile(mt.CLUSTERING_TLS_VERIFY),f=yr.getConfigFromFile(mt.CLUSTERING_NODENAME),h=yr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await QT.checkNATSServerInstalled()||lf("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let p=await WT.listUsers(),S=yr.getConfigFromFile(mt.CLUSTERING_USER),T=await WT.getClusterUser();(Ra.isEmpty(T)||T.active!==!0)&&lf(`Invalid cluster user '${S}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await of(mt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await of(mt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await of(mt.CLUSTERING_HUBSERVER_NETWORK_PORT),await of(mt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let R=[],b=[];for(let[J,j]of p.entries())j.role.role===af.ROLE_TYPES_ENUM.CLUSTER_USER&&j.active&&(R.push(new a6(j.username,GP.decrypt(j.hash))),b.push(new o6(j.username,GP.decrypt(j.hash))));let C=[],{hub_routes:H}=yr.getClusteringRoutes();if(!Ra.isEmptyOrZeroLength(H))for(let J of H)C.push(`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@${J.host}:${J.port}`);let v=new s6(yr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,n,l,_,u,d,E,h,yr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_CLUSTER_NAME),yr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),C,R,b);u==null&&(delete v.tls.ca_file,delete v.leafnodes.tls.ca_file),t=Ra.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===af.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await cf.writeJson(o,v),Aa.trace(`Hub server config written to ${o}`));let q=`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,M=`tls://${T.uri_encoded_name}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,Q=new i6(yr.getConfigFromFile(mt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,s,i,[q],[M],R,b,l,_,u,d);u==null&&delete Q.tls.ca_file,(t===void 0||t===af.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await cf.writeJson(c,Q),Aa.trace(`Leaf server config written to ${c}`))}a(u6,"generateNatsConfig");async function of(e){let t=Fl.get(e);return Ra.isEmpty(t)&&lf(`port undefined for '${e}'`),await Ra.isPortTaken(t)&&lf(`'${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(of,"isPortAvailable");function lf(e){let t=`Error generating clustering config: ${e}`;Aa.error(t),console.error(t),process.exit(1)}a(lf,"generateNatsConfigError");async function _6(e){let{port:t,config_file:r}=QT.getServerConfig(e),{username:n,decrypt_hash:s}=await WT.getClusterUser(),i=0,o=2e3;for(;i<FP;){try{let u=await QT.createConnection(t,n,s,!1);if(u.protocol.connected===!0){u.close();break}}catch(u){Aa.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${u}`)}if(i++,i>=FP)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let _=o*(i*2);_>3e4&&Aa.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Ra.async_set_timeout(_)}let c="0".repeat(c6),l=Ta.join(Fl.get(mt.ROOTPATH),ga,r);await cf.writeFile(l,c),await cf.remove(l),Aa.notify(e,"started.")}a(_6,"removeNatsConfig")});var WP=g((AEe,KP)=>{"use strict";var zr=te(),d6=Ji(),he=U(),ql=ct(),Ds=require("path"),{PACKAGE_ROOT:_f}=U(),kP=te(),uf=z(),Oa="/dev/null",f6=Ds.join(_f,"launchServiceScripts"),VP=Ds.join(_f,"utility/scripts"),E6=Ds.join(VP,he.HDB_RESTART_SCRIPT),$P=Ds.resolve(_f,"dependencies",`${process.platform}-${process.arch}`,ql.NATS_BINARY_NAME);function YP(){let t=d6.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 uf.noBootFile()&&(n[he.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=uf.getEnvCliRootPath()),{name:he.PROCESS_DESCRIPTORS.HDB,script:he.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:_f}}a(YP,"generateMainServerConfig");var h6=9930;function m6(){zr.initSync(!0);let e=zr.get(he.CONFIG_PARAMS.ROOTPATH),t=Ds.join(e,"clustering",ql.NATS_CONFIG_FILES.HUB_SERVER),r=Ds.join(zr.get(he.HDB_SETTINGS_NAMES.LOG_PATH_KEY),he.LOG_NAMES.HDB),n=kP.get(he.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=ql.LOG_LEVEL_FLAGS[zr.get(he.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:he.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==h6?"-"+n:""),script:$P,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 zr.get(he.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Oa,i.error_file=Oa),i}a(m6,"generateNatsHubServerConfig");var p6=9940;function S6(){zr.initSync(!0);let e=zr.get(he.CONFIG_PARAMS.ROOTPATH),t=Ds.join(e,"clustering",ql.NATS_CONFIG_FILES.LEAF_SERVER),r=Ds.join(zr.get(he.HDB_SETTINGS_NAMES.LOG_PATH_KEY),he.LOG_NAMES.HDB),n=kP.get(he.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=ql.LOG_LEVEL_FLAGS[zr.get(he.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:he.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==p6?"-"+n:""),script:$P,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 zr.get(he.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Oa,i.error_file=Oa),i}a(S6,"generateNatsLeafServerConfig");function T6(){zr.initSync();let e=Ds.join(zr.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:f6,autorestart:!1};return zr.get(he.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Oa,t.error_file=Oa),t}a(T6,"generateClusteringUpgradeV4ServiceConfig");function g6(){let e={[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.RESTART_HDB};return uf.noBootFile()&&(e[he.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=uf.getEnvCliRootPath()),{...{name:he.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:VP},script:E6}}a(g6,"generateRestart");function R6(){return{apps:[YP()]}}a(R6,"generateAllServiceConfigs");KP.exports={generateAllServiceConfigs:R6,generateMainServerConfig:YP,generateRestart:g6,generateNatsHubServerConfig:m6,generateNatsLeafServerConfig:S6,generateClusteringUpgradeV4ServiceConfig:T6}});var aU=g((yEe,oU)=>{"use strict";var Ue=U(),A6=z(),Ms=zT(),df=Rt(),Ls=ct(),pi=WP(),ff=te(),Si=Y(),O6=Cs(),{startWorker:QP,onMessageFromWorkers:b6}=ot(),y6=Sa(),bEe=require("util"),N6=require("child_process"),I6=require("fs"),{execFile:w6}=N6,we;oU.exports={enterPM2Mode:C6,start:Ti,stop:JT,reload:JP,restart:jP,list:jT,describe:ZP,connect:Ps,kill:U6,startAllServices:v6,startService:XT,getUniqueServicesList:eU,restartAllServices:B6,isServiceRegistered:tU,reloadStopStart:rU,restartHdb:XP,deleteProcess:M6,startClusteringProcesses:sU,startClusteringThreads:iU,isHdbRestartRunning:P6,isClusteringRunning:x6,stopClustering:H6,reloadClustering:G6};var kl=!1;b6(e=>{e.type==="restart"&&ff.initSync(!0)});function C6(){kl=!0}a(C6,"enterPM2Mode");function Ps(){return we||(we=require("pm2")),new Promise((e,t)=>{we.connect((r,n)=>{Si.setupConsoleLogging(),r&&t(r),e(n)})})}a(Ps,"connect");var Nr,D6=10,zP;function Ti(e,t=!1){if(kl)return L6(e);let r=w6(e.script,e.args.split(" "),e);r.name=e.name,r.on("exit",async i=>{let o=Nr.indexOf(r);o>-1&&Nr.splice(o,1),!zP&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<D6&&(I6.existsSync(Ms.getHubConfigPath())?Ti(e):(await Ms.generateNatsConfig(!0),Ti(e),await new Promise(c=>setTimeout(c,3e3)),await Ms.removeNatsConfig(Ue.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Ms.removeNatsConfig(Ue.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=ff.get(Ue.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,_=0,u;for(;l=c.exec(i);){if(l.index&&Ls.LOG_LEVEL_HIERARCHY[o]>=Ls.LOG_LEVEL_HIERARCHY[u||"info"]){let f=u===Ls.LOG_LEVELS.ERR||u===Ls.LOG_LEVELS.WRN?Si.OUTPUTS.STDERR:Si.OUTPUTS.STDOUT;Si.logCustomLevel(u||"info",f,n,i.slice(_,l.index).trim())}let[d,E]=l;_=l.index+d.length,u=Ls.LOG_LEVELS[E]}if(Ls.LOG_LEVEL_HIERARCHY[o]>=Ls.LOG_LEVEL_HIERARCHY[u||"info"]){let d=u===Ls.LOG_LEVELS.ERR||u===Ls.LOG_LEVELS.WRN?Si.OUTPUTS.STDERR:Si.OUTPUTS.STDOUT;Si.logCustomLevel(u||"info",d,n,i.slice(_).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),Nr=[],!Nr&&!t){let i=a(()=>{zP=!0,Nr&&(Nr.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)}Nr.push(r)}a(Ti,"start");function L6(e){return new Promise(async(t,r)=>{try{await Ps()}catch(n){r(n)}we.start(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(L6,"startWithPM2");function JT(e){if(!kl){for(let t of Nr||[])t.name===e&&(Nr.splice(Nr.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Ps()}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(JT,"stop");function JP(e){return new Promise(async(t,r)=>{try{await Ps()}catch(n){r(n)}we.reload(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(JP,"reload");function jP(e){if(!kl)for(let t of Nr||[])t.name===e&&t.kill();return new Promise(async(t,r)=>{try{await Ps()}catch(n){r(n)}we.restart(e,(n,s)=>{we.disconnect(),t(s)})})}a(jP,"restart");function M6(e){return new Promise(async(t,r)=>{try{await Ps()}catch(n){r(n)}we.delete(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(M6,"deleteProcess");async function XP(){await Ti(pi.generateRestart())}a(XP,"restartHdb");async function P6(){let e=await jT();for(let t in e)if(e[t].name===Ue.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(P6,"isHdbRestartRunning");function jT(){return new Promise(async(e,t)=>{try{await Ps()}catch(r){t(r)}we.list((r,n)=>{r&&(we.disconnect(),t(r)),we.disconnect(),e(n)})})}a(jT,"list");function ZP(e){return new Promise(async(t,r)=>{try{await Ps()}catch(n){r(n)}we.describe(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(ZP,"describe");function U6(){if(!kl){for(let e of Nr||[])e.kill();Nr=[];return}return new Promise(async(e,t)=>{try{await Ps()}catch(r){t(r)}we.killDaemon((r,n)=>{r&&(we.disconnect(),t(r)),we.disconnect(),e(n)})})}a(U6,"kill");async function v6(){try{await sU(),await iU(),await Ti(pi.generateAllServiceConfigs())}catch(e){throw we?.disconnect(),e}}a(v6,"startAllServices");async function XT(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case Ue.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=pi.generateMainServerConfig();break;case Ue.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=pi.generateNatsIngestServiceConfig();break;case Ue.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=pi.generateNatsReplyServiceConfig();break;case Ue.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=pi.generateNatsHubServerConfig(),await Ti(r,t),await Ms.removeNatsConfig(e);return;case Ue.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=pi.generateNatsLeafServerConfig(),await Ti(r,t),await Ms.removeNatsConfig(e);return;case Ue.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=pi.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Ti(r)}catch(r){throw we?.disconnect(),r}}a(XT,"startService");async function eU(){try{let e=await jT(),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(eU,"getUniqueServicesList");async function B6(e=[]){try{let t=!1,r=await eU();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===Ue.PROCESS_DESCRIPTORS.HDB?t=!0:await jP(o))}t&&await rU(Ue.PROCESS_DESCRIPTORS.HDB)}catch(t){throw we?.disconnect(),t}}a(B6,"restartAllServices");async function tU(e){if(Nr?.find(r=>r.name===e))return!0;let t=await y6.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(tU,"isServiceRegistered");async function rU(e){let t=ff.get(Ue.CONFIG_PARAMS.THREADS_COUNT)??ff.get(Ue.CONFIG_PARAMS.THREADS),r=await ZP(e),n=A6.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await JT(e),await XT(e)):e===Ue.PROCESS_DESCRIPTORS.HDB?await XP():await JP(e)}a(rU,"reloadStopStart");var nU;async function sU(e=!1){for(let t in Ue.CLUSTERING_PROCESSES){let r=Ue.CLUSTERING_PROCESSES[t];await XT(r,e)}}a(sU,"startClusteringProcesses");async function iU(){nU=QP(Ue.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:Ue.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await df.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await df.updateLocalStreams();let e=await O6.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===Ue.PRE_4_0_0_VERSION){Si.info("Starting clustering upgrade 4.0.0 process"),QP(Ue.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(iU,"startClusteringThreads");async function H6(){for(let e in Ue.CLUSTERING_PROCESSES)if(e!==Ue.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===Ue.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await nU.terminate();else{let t=Ue.CLUSTERING_PROCESSES[e];await JT(t)}}a(H6,"stopClustering");async function x6(){for(let e in Ue.CLUSTERING_PROCESSES){let t=Ue.CLUSTERING_PROCESSES[e];if(await tU(t)===!1)return!1}return!0}a(x6,"isClusteringRunning");async function G6(){await Ms.generateNatsConfig(!0),await df.reloadNATSHub(),await df.reloadNATSLeaf(),await Ms.removeNatsConfig(Ue.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await Ms.removeNatsConfig(Ue.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(G6,"reloadClustering")});var EU={};qe(EU,{compactOnStart:()=>F6,copyDb:()=>fU});async function F6(){$l.notify("Running compact on start"),console.log("Running compact on start");let e=(0,ZT.get)(gi.CONFIG_PARAMS.ROOTPATH),t=new Map,r=mr();try{for(let n in r){if(n==="system")continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,Ef.join)(e,"backup",n+".mdb"),o=(0,Ef.join)(e,gi.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await cU(n);console.log("Database",n,"before compact has a total record count of",c),t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await fU(n,o),console.log("Backing up",n,"to",i),await(0,mo.move)(s,i,{overwrite:!0})}Vl();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,mo.move)(i,s,{overwrite:!0}),await(0,mo.remove)((0,Ef.join)(e,gi.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));Vl()}catch(n){$l.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,eg.updateConfigValue)(gi.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,mo.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Vl(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await cU(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
12
+ `,"")}a(ZM,"runCommand");async function s8(){try{await v5.access(Qg)}catch{return!1}let e=await ZM(`${Qg} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return x5.eq(t,r8)}a(s8,"checkNATSServerInstalled");async function Zg(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await JM.getClusterUser();if(_a(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}Ss.trace("create nats connection called");let i=await K5({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:fr.get(Ye.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:fr.get(Ye.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:fr.get(Ye.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),Ss.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&Ss.error("Error with Nats client connection, connection closed",o),eU()}),i}a(Zg,"createConnection");function eU(){zr=void 0,ua=void 0,da=void 0,fa=void 0}a(eU,"clearClientCache");async function i8(){zr&&(await zr.drain(),zr=void 0,ua=void 0,da=void 0,fa=void 0)}a(i8,"closeConnection");var zr,fa;async function ad(){return fa||(fa=Zg(fr.get(Ye.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),zr=await fa),zr||fa}a(ad,"getConnection");async function cd(){if(ua)return ua;_a(zr)&&await ad();let{domain:e}=Lc(Ye.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(_a(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ua=await zr.jetstreamManager({domain:e,timeout:6e4}),ua}a(cd,"getJetStreamManager");async function tU(){if(da)return da;_a(zr)&&await ad();let{domain:e}=Lc(Ye.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(_a(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return da=zr.jetstream({domain:e,timeout:6e4}),da}a(tU,"getJetStream");async function Ys(){let e=zr||await ad(),t=ua||await cd(),r=da||await tU();return{connection:e,jsm:t,js:r}}a(Ys,"getNATSReferences");async function o8(e){let t=fr.get(Ye.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await JM.getClusterUser(),s=await Zg(t,r,n),i=Xg(),o=s.subscribe(i),c=[],l,d=(async()=>{for await(let u of o){let f=XM.decode(u.data);f.response_time=Date.now()-l,c.push(f)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await ME.async_set_timeout(e),await o.drain(),await s.close(),await d,c}a(o8,"getServerList");async function eR(e,t){let{jsm:r}=await Ys(),n=fr.get(Ye.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=fr.get(Ye.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=fr.get(Ye.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:W5.File,retention:Q5.Limits,subjects:t,discard:z5.Old,max_msgs:s,max_bytes:i,max_age:n})}a(eR,"createLocalStream");async function rU(){let{jsm:e}=await Ys(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(rU,"listStreams");async function a8(e){let{jsm:t}=await Ys();await t.streams.delete(e)}a(a8,"deleteLocalStream");async function c8(e){let{connection:t}=await Ys(),r=[],n=Xg(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(XM.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(c8,"listRemoteStreams");async function l8(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ys(),i=WM(),o={durable_name:i,ack_policy:jg.Explicit};t&&(o.deliver_policy=Jg.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let d=[];for await(let u of l){let f=zg(u.data),E={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:f};if(u.headers&&(E.origin=u.headers.get(Tr.MSG_HEADERS.ORIGIN)),d.push(E),u.ack(),u.info.pending===0)break}return await c.delete(),d}a(l8,"viewStream");async function*u8(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ys(),i=WM(),o={durable_name:i,ack_policy:jg.Explicit};t&&(o.deliver_policy=Jg.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let d of l){let u=zg(d.data);u[0]||(u=[u]);for(let f of u){let E={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:f};d.headers&&(E.origin=d.headers.get(Tr.MSG_HEADERS.ORIGIN)),yield E}if(d.ack(),d.info.pending===0)break}await c.delete()}a(u8,"viewStreamIterator");async function d8(e,t,r,n){Ss.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=nU(n,r);let{js:s}=await Ys(),i=await vE(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:jM.encode(n);try{Ss.trace(`publishToStream publishing to subject: ${o}`),e8(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return iU(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){Ss.trace(`publishToStream creating stream: ${t}`);let u=o.split(".");u[2]="*",await eR(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(d8,"publishToStream");function nU(e,t){t===void 0&&(t=J5());let r=fr.get(Ye.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Tr.MSG_HEADERS.ORIGIN)&&r&&t.append(Tr.MSG_HEADERS.ORIGIN,r),t}a(nU,"addNatsMsgHeader");function Lc(e){e=e.toLowerCase();let t=od.join(fr.get(Ye.CONFIG_PARAMS.ROOTPATH),t8);if(e===Ye.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return _a(Wg)&&(Wg={port:sd.getConfigFromFile(Ye.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:sd.getConfigFromFile(Ye.CONFIG_PARAMS.CLUSTERING_NODENAME)+Tr.SERVER_SUFFIX.HUB,config_file:Tr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:od.join(t,Tr.PID_FILES.HUB),hdb_nats_path:t}),Wg;if(e===Ye.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return _a(Kg)&&(Kg={port:sd.getConfigFromFile(Ye.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:sd.getConfigFromFile(Ye.CONFIG_PARAMS.CLUSTERING_NODENAME)+Tr.SERVER_SUFFIX.LEAF,config_file:Tr.NATS_CONFIG_FILES.LEAF_SERVER,domain:sd.getConfigFromFile(Ye.CONFIG_PARAMS.CLUSTERING_NODENAME)+Tr.SERVER_SUFFIX.LEAF,pid_file_path:od.join(t,Tr.PID_FILES.LEAF),hdb_nats_path:t}),Kg;Ss.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Lc,"getServerConfig");async function sU(e,t,r,n){try{await e.consumers.add(t,{ack_policy:jg.Explicit,durable_name:r,deliver_policy:Jg.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(sU,"createConsumer");async function f8(e,t,r){await e.consumers.delete(t,r)}a(f8,"removeConsumer");function _8(e){return e.split(".")[1]}a(_8,"extractServerName");async function E8(e,t,r=6e4,n=Xg()){if(!ME.isObject(t))throw new Error("data param must be an object");let s=jM.encode(t),{connection:i}=await Ys(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return zg(c.data)}a(E8,"request");function tR(e){return new Promise(async(t,r)=>{let n=F5(Qg,["--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(tR,"reloadNATS");async function h8(){let{pid_file_path:e}=Lc(Ye.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await tR(e)}a(h8,"reloadNATSHub");async function m8(){let{pid_file_path:e}=Lc(Ye.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await tR(e)}a(m8,"reloadNATSLeaf");function p8(e,t,r){let n;switch(e.code){case KM.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case KM.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(p8,"requestErrorHandler");async function S8(e,t){let r=t+Tr.SERVER_SUFFIX.LEAF,{connection:n}=await Ys(),{jsm:s}=await N8(r),{schema:i,table:o}=e,c=UE.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await iU(async()=>{if(e.subscribe===!0)await sU(s,c,n.info.server_name,l);else try{await f8(s,c,n.info.server_name)}catch(d){Ss.trace(d)}})}a(S8,"updateRemoteConsumer");async function T8(e,t,r,n){let s=UE.createNatsTableStreamName(e,t),i=r+Tr.SERVER_SUFFIX.LEAF,o={type:Ye.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!zM&&$5()<fr.get(Ye.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=Yg();await c(o)}await q5(o),n==="stop"&&await ME.async_set_timeout(1e3)}a(T8,"updateConsumerIterator");function iU(e){return G5.writeTransaction(Ye.SYSTEM_SCHEMA_NAME,Ye.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(iU,"exclusiveLock");async function oU(e,t){let r=UE.createNatsTableStreamName(e,t),n=await vE(),s=b8(e,t,n);await eR(r,[s])}a(oU,"createLocalTableStream");async function g8(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await oU(n,s)}}a(g8,"createTableStreams");async function aU(e,t,r=void 0){if(fr.get(Ye.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=UE.createNatsTableStreamName(e,t),{domain:s}=Lc(Ye.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await ad()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")Ss.warn(n);else throw n}}a(aU,"purgeTableStream");async function R8(e,t){if(fr.get(Ye.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await aU(e,t[r])}a(R8,"purgeSchemaTableStreams");async function A8(e){return(await cd()).streams.info(e)}a(A8,"getStreamInfo");function b8(e,t,r){return`${Tr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(b8,"createSubjectName");async function vE(){if(id)return id;if(id=(await cd())?.nc?.info?.server_name,id===void 0)throw new Error("Unable to get jetstream manager server name");return id}a(vE,"getJsmServerName");async function y8(){let e=await cd(),t=await vE(),r=await rU();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=O8(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let d=i.split(".");d[d.length-1]=t;let u=d.join(".");Ss.trace(`Updating stream subject name from: ${i} to: ${u}`),s.subjects[0]=u,await e.streams.update(s.name,s)}}a(y8,"updateLocalStreams");function O8(e){let{config:t}=e,r=!1,n=fr.get(Ye.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=fr.get(Ye.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=fr.get(Ye.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(O8,"updateStreamLimits");async function N8(e){let t,r;try{t=await zr.jetstream({domain:e}),r=await zr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw Ss.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(N8,"connectToRemoteJS")});var kE=I((qpe,fU)=>{"use strict";var Pc=B_(),Mc=mM(),I8=X(),w8=require("uuid").v4,Gpe=require("clone"),BE=Ti(),Uc=B(),C8=require("util"),lo=$n(),{handleHDBError:jr,hdb_errors:D8}=ce(),{HDB_ERROR_MSGS:xE,HTTP_STATUS_CODES:Jr}=D8,{SchemaEventMsg:HE}=Es(),lU=jt(),{getDatabases:L8}=(Ne(),ae(it)),{transformReq:vc}=te();fU.exports={createSchema:P8,createSchemaStructure:uU,createTable:M8,createTableStructure:dU,createAttribute:H8,dropSchema:U8,dropTable:v8,dropAttribute:x8,getBackup:k8};async function P8(e){let t=await uU(e);return BE.signalSchemaChange(new HE(process.pid,e.operation,e.schema)),t}a(P8,"createSchema");async function uU(e){let t=Pc.schema_object(e);if(t)throw jr(t,t.message,Jr.BAD_REQUEST,void 0,void 0,!0);if(vc(e),!await Mc.checkSchemaExists(e.schema))throw jr(new Error,xE.SCHEMA_EXISTS_ERR(e.schema),Jr.BAD_REQUEST,Uc.LOG_LEVELS.ERROR,xE.SCHEMA_EXISTS_ERR(e.schema),!0);return await lo.createSchema(e),`database '${e.schema}' successfully created`}a(uU,"createSchemaStructure");async function M8(e){return vc(e),e.hash_attribute=e.primary_key??e.hash_attribute,await dU(e)}a(M8,"createTable");async function dU(e){let t=Pc.create_table_object(e);if(t)throw jr(t,t.message,Jr.BAD_REQUEST,void 0,void 0,!0);if(Pc.validateTableResidence(e.residence),!await Mc.checkSchemaTableExists(e.schema,e.table))throw jr(new Error,xE.TABLE_EXISTS_ERR(e.schema,e.table),Jr.BAD_REQUEST,Uc.LOG_LEVELS.ERROR,xE.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:w8(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await lo.createTable(n,e);else throw jr(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Jr.BAD_REQUEST);else await lo.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(dU,"createTableStructure");async function U8(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=Pc.schema_object(e),n=t??r;if(n)throw jr(n,n.message,Jr.BAD_REQUEST,void 0,void 0,!0);vc(e);let s=await Mc.checkSchemaExists(e.schema);if(s)throw jr(new Error,s,Jr.NOT_FOUND,Uc.LOG_LEVELS.ERROR,s,!0);let i=await Mc.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);return await lo.dropSchema(e),BE.signalSchemaChange(new HE(process.pid,e.operation,e.schema)),await lU.purgeSchemaTableStreams(e.schema,o),`successfully deleted '${e.schema}'`}a(U8,"dropSchema");async function v8(e){let t=Pc.table_object(e);if(t)throw jr(t,t.message,Jr.BAD_REQUEST,void 0,void 0,!0);vc(e);let r=await Mc.checkSchemaTableExists(e.schema,e.table);if(r)throw jr(new Error,r,Jr.NOT_FOUND,Uc.LOG_LEVELS.ERROR,r,!0);return await lo.dropTable(e),await lU.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(v8,"dropTable");async function x8(e){let t=Pc.attribute_object(e);if(t)throw jr(t,t.message,Jr.BAD_REQUEST,void 0,void 0,!0);vc(e);let r=await Mc.checkSchemaTableExists(e.schema,e.table);if(r)throw jr(new Error,r,Jr.NOT_FOUND,Uc.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw jr(new Error,"You cannot drop a hash attribute",Jr.BAD_REQUEST,void 0,void 0,!0);if(Uc.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw jr(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Jr.BAD_REQUEST,void 0,void 0,!0);try{return await lo.dropAttribute(e),B8(e),BE.signalSchemaChange(new HE(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw I8.error(`Got an error deleting attribute ${C8.inspect(e)}.`),n}}a(x8,"dropAttribute");function B8(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(B8,"dropAttributeFromGlobal");async function H8(e){vc(e);let t=L8()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw jr(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Jr.BAD_REQUEST,void 0,void 0,!0);return await lo.createAttribute(e),BE.signalSchemaChange(new HE(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(H8,"createAttribute");function k8(e){return lo.getBackup(e)}a(k8,"getBackup")});var EU=I(($pe,_U)=>{"use strict";var{OPERATIONS_ENUM:F8}=B(),rR=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=F8.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};_U.exports=rR});var nR=I((Wpe,TU)=>{"use strict";var G8=$n(),Kpe=EU(),FE=te(),GE=B(),q8=ie(),{handleHDBError:hU,hdb_errors:V8}=ce(),{HDB_ERROR_MSGS:mU,HTTP_STATUS_CODES:pU}=V8,$8=Object.values(GE.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),SU="To use this operation audit log must be enabled in harperdb-config.yaml";TU.exports=Y8;async function Y8(e){if(FE.isEmpty(e.schema))throw new Error(mU.SCHEMA_REQUIRED_ERR);if(FE.isEmpty(e.table))throw new Error(mU.TABLE_REQUIRED_ERR);if(!q8.get(GE.CONFIG_PARAMS.LOGGING_AUDITLOG))throw hU(new Error,SU,pU.BAD_REQUEST,GE.LOG_LEVELS.ERROR,SU,!0);let t=FE.checkSchemaTableExist(e.schema,e.table);if(t)throw hU(new Error,t,pU.NOT_FOUND,GE.LOG_LEVELS.ERROR,t,!0);if(!FE.isEmpty(e.search_type)&&$8.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await G8.readAuditLog(e)}a(Y8,"readAuditLog")});var RU=I((zpe,gU)=>{"use strict";var{OPERATIONS_ENUM:K8}=B(),sR=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=K8.GET_BACKUP,this.schema=t,this.table=r}};gU.exports=sR});var yU=I((Zpe,bU)=>{"use strict";var W8=$n(),Jpe=RU(),iR=te(),Q8=B(),Xpe=ie(),{handleHDBError:z8,hdb_errors:j8}=ce(),{HDB_ERROR_MSGS:AU,HTTP_STATUS_CODES:J8}=j8;bU.exports=X8;async function X8(e){if(iR.isEmpty(e.schema))throw new Error(AU.SCHEMA_REQUIRED_ERR);if(iR.isEmpty(e.table))throw new Error(AU.TABLE_REQUIRED_ERR);let t=iR.checkSchemaTableExist(e.schema,e.table);if(t)throw z8(new Error,t,J8.NOT_FOUND,Q8.LOG_LEVELS.ERROR,t,!0);return await W8.getBackup(read_audit_log_object)}a(X8,"getBackup")});var DU=I((tSe,CU)=>{var uo=require("validate.js"),NU=mt(),xc=B(),{handleHDBError:Z8,hdb_errors:e6}=ce(),{HDB_ERROR_MSGS:qt,HTTP_STATUS_CODES:t6}=e6,oR=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),r6={STRUCTURE_USER:"structure_user"},OU=Object.values(xc.ROLE_TYPES_ENUM),n6="attribute_permissions",s6="attribute_name",{PERMS_CRUD_ENUM:Bc}=xc,i6=[n6,...Object.values(Bc)],IU=[Bc.READ,Bc.INSERT,Bc.UPDATE],o6=[s6,...IU];function a6(e){let t=oR();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,wU(e,t)}a(a6,"addRoleValidation");function c6(e){let t=oR();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,wU(e,t)}a(c6,"alterRoleValidation");function l6(e){let t=oR();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,NU.validateObject(e,t)}a(l6,"dropRoleValidation");var u6=["operation","role","id","permission","hdb_user","hdb_auth_header"];function wU(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)u6.includes(n[o])||s.push(n[o]);s.length>0&&Jt(qt.INVALID_ROLE_JSON_KEYS(s),r);let i=NU.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{Jt(o,r)}),e.permission){let o=d6(e);o&&Jt(o,r),OU.forEach(c=>{e.permission[c]&&!uo.isBoolean(e.permission[c])&&Jt(qt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(OU.indexOf(o)<0){if(o===r6.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let d=0,u=l.length;d<u;d++){let f=l[d];global.hdb_schema[f]||Jt(qt.SCHEMA_NOT_FOUND(f),r)}continue}Jt(qt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){Jt(qt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let d=c.tables[l];if(!l||!global.hdb_schema[o][l]){Jt(qt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(d).forEach(u=>{i6.includes(u)||Jt(qt.INVALID_PERM_KEY(u),r,o,l)}),Object.values(Bc).forEach(u=>{uo.isDefined(d[u])?uo.isBoolean(d[u])||Jt(qt.TABLE_PERM_NOT_BOOLEAN(u),r,o,l):Jt(qt.TABLE_PERM_MISSING(u),r,o,l)}),uo.isDefined(d.attribute_permissions)){if(!uo.isArray(d.attribute_permissions)){Jt(qt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}}else{Jt(qt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}if(d.attribute_permissions){let u=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),f={read:!1,insert:!1,update:!1};for(let E in d.attribute_permissions){let _=d.attribute_permissions[E];if(Object.keys(_).forEach(p=>{!o6.includes(p)&&p!==Bc.DELETE&&Jt(qt.INVALID_ATTR_PERM_KEY(p),r,o,l)}),!uo.isDefined(_.attribute_name)){Jt(qt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=_.attribute_name;if(!u.includes(h)){Jt(qt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}IU.forEach(p=>{uo.isDefined(_[p])?uo.isBoolean(_[p])||Jt(qt.ATTR_PERM_NOT_BOOLEAN(p,h),r,o,l):Jt(qt.ATTR_PERM_MISSING(p,h),r,o,l)}),!f.read&&_.read===!0&&(f.read=!0),!f.insert&&_.insert===!0&&(f.insert=!0),!f.update&&_.update===!0&&(f.update=!0)}if(d.read===!1&&f.read===!0||d.insert===!1&&f.insert===!0||d.update===!1&&f.update===!0){let E=`${o}.${l}`;Jt(qt.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return f6(r)}a(wU,"customValidate");CU.exports={addRoleValidation:a6,alterRoleValidation:c6,dropRoleValidation:l6};function d6(e){let{operation:t,permission:r}=e;if(t===xc.OPERATIONS_ENUM.ADD_ROLE||t===xc.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return qt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?xc.ROLE_TYPES_ENUM.SUPER_USER:xc.ROLE_TYPES_ENUM.CLUSTER_USER;return qt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(d6,"validateNoSUPerms");function f6(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:qt.ROLE_PERMS_ERROR,...e};return Z8(new Error,n,t6.BAD_REQUEST)}else return null}a(f6,"generateRolePermResponse");function Jt(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(Jt,"addPermError")});var fR=I((sSe,UU)=>{"use strict";var LU=Vn(),PU=An(),_6=ea(),cR=DU(),lR=Ti(),nSe=require("uuid").v4,E6=require("util"),qE=B(),h6=te(),uR=PU.searchByValue,m6=PU.searchByHash,p6=E6.promisify(_6.delete),S6=Gs(),T6=Oc(),{hdb_errors:g6,handleHDBError:Ea}=ce(),{HDB_ERROR_MSGS:MU,HTTP_STATUS_CODES:ld}=g6,{UserEventMsg:dR}=Es();UU.exports={addRole:R6,alterRole:A6,dropRole:b6,listRoles:y6};function aR(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(aR,"scrubRoleDetails");async function R6(e){let t=cR.addRoleValidation(e);if(t)throw t;e=aR(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 uR(r)||[])}catch(i){throw Ea(i)}if(n&&n.length>0)throw Ea(new Error,MU.ROLE_ALREADY_EXISTS(e.role),ld.CONFLICT,void 0,void 0,!0);e.id||(e.id=e.role);let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await LU.insert(s),lR.signalUserChange(new dR(process.pid)),e=aR(e),e}a(R6,"addRole");async function A6(e){let t=cR.alterRoleValidation(e);if(t)throw t;e=aR(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await LU.update(r)}catch(s){throw Ea(s)}if(n&&n?.message==="updated 0 of 1 records")throw Ea(new Error,"Invalid role id",ld.BAD_REQUEST,void 0,void 0,!0);return await lR.signalUserChange(new dR(process.pid)),e}a(A6,"alterRole");async function b6(e){let t=cR.dropRoleValidation(e);if(t)throw Ea(new Error,t,ld.BAD_REQUEST,void 0,void 0,!0);let r=new T6(qE.SYSTEM_SCHEMA_NAME,qE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await m6(r));if(n.length===0)throw Ea(new Error,MU.ROLE_NOT_FOUND,ld.NOT_FOUND,void 0,void 0,!0);let s=new S6(qE.SYSTEM_SCHEMA_NAME,qE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await uR(s)),o=!1;if(h6.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Ea(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,ld.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await p6(c),lR.signalUserChange(new dR(process.pid)),`${n[0].role} successfully deleted`}a(b6,"dropRole");async function y6(){return uR({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(y6,"listRoles")});var HU=I((oSe,BU)=>{"use strict";var O6=ie(),fo=require("joi"),N6=mt(),vU=require("moment"),I6=require("fs-extra"),_R=require("path"),w6=require("lodash"),ud=B(),{LOG_LEVELS:ha}=B(),C6="YYYY-MM-DD hh:mm:ss",D6=_R.resolve(__dirname,"../logs");BU.exports=function(e){return N6.validateBySchema(e,L6)};var L6=fo.object({from:fo.custom(xU),until:fo.custom(xU),level:fo.valid(ha.NOTIFY,ha.FATAL,ha.ERROR,ha.WARN,ha.INFO,ha.DEBUG,ha.TRACE),order:fo.valid("asc","desc"),limit:fo.number().min(1),start:fo.number().min(0),log_name:fo.custom(P6)});function xU(e,t){if(vU(e,vU.ISO_8601).format(C6)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(xU,"validateDatetime");function P6(e,t){if(w6.invert(ud.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=O6.get(ud.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?ud.LOG_NAMES.HDB:e,i=s===ud.LOG_NAMES.INSTALL?_R.join(D6,ud.LOG_NAMES.INSTALL):_R.join(n,s);return I6.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(P6,"validateReadLogPath")});var hR=I((cSe,FU)=>{"use strict";var VE=B(),M6=X(),U6=ie(),v6=HU(),ER=require("path"),kU=require("fs-extra"),{once:x6}=require("events"),{handleHDBError:B6,hdb_errors:H6}=ce(),{PACKAGE_ROOT:k6}=B(),F6=ER.join(k6,"logs"),G6=1e3,q6=200;FU.exports=V6;async function V6(e){let t=v6(e);if(t)throw B6(t,t.message,H6.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=U6.get(VE.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?VE.LOG_NAMES.HDB:e.log_name,s=n===VE.LOG_NAMES.INSTALL?ER.join(F6,VE.LOG_NAMES.INSTALL):ER.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,d=e.until!==void 0,u=d?new Date(e.until):void 0,f=e.limit===void 0?G6:e.limit,E=e.order===void 0?void 0:e.order,_=e.start===void 0?0:e.start,h=_+f,p=0;E==="desc"&&!l&&!u&&(p=Math.max(kU.statSync(s).size-(h+5)*q6,0));let S=kU.createReadStream(s,{start:p});S.on("error",v=>{M6.error(v)});let g=0,T=[],A="",N;S.on("data",v=>{let J=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;v=A+v;let $=0,F;for(;(F=J.exec(v))&&!S.destroyed;){N&&(N.message=v.slice($,F.index),V(N));let[ne,ee,Z]=F,le=Z.split("] ["),fe=le[0],je=le[1];le.splice(0,2),N={timestamp:ee,thread:fe,level:je,tags:le,message:""},$=F.index+ne.length}A=v.slice($)}),S.on("end",v=>{S.destroyed||N&&(N.message=A.trim(),V(N))}),S.resume();function V(v){let J,$,F;switch(!0){case(i&&c&&d):J=new Date(v.timestamp),$=new Date(l),F=new Date(u),v.level===o&&J>=$&&J<=F&&g<_?g++:v.level===o&&J>=$&&J<=F&&(_o(v,E,T),g++,g===h&&S.destroy());break;case(i&&c):J=new Date(v.timestamp),$=new Date(l),v.level===o&&J>=$&&g<_?g++:v.level===o&&J>=$&&(_o(v,E,T),g++,g===h&&S.destroy());break;case(i&&d):J=new Date(v.timestamp),F=new Date(u),v.level===o&&J<=F&&g<_?g++:v.level===o&&J<=F&&(_o(v,E,T),g++,g===h&&S.destroy());break;case(c&&d):J=new Date(v.timestamp),$=new Date(l),F=new Date(u),J>=$&&J<=F&&g<_?g++:J>=$&&J<=F&&(_o(v,E,T),g++,g===h&&S.destroy());break;case i:v.level===o&&g<_?g++:v.level===o&&(_o(v,E,T),g++,g===h&&S.destroy());break;case c:J=new Date(v.timestamp),$=new Date(l),J>=$&&g<_?g++:J>=$&&g>=_&&(_o(v,E,T),g++,g===h&&S.destroy());break;case d:J=new Date(v.timestamp),F=new Date(u),J<=F&&g<_?g++:J<=F&&g>=_&&(_o(v,E,T),g++,g===h&&S.destroy());break;default:g<_?g++:(_o(v,E,T),g++,g===h&&S.destroy())}}return a(V,"onLogMessage"),await x6(S,"close"),T}a(V6,"readLog");function _o(e,t,r){t==="desc"?$6(e,r):t==="asc"?Y6(e,r):r.push(e)}a(_o,"pushLineToResult");function $6(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($6,"insertDescending");function Y6(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(Y6,"insertAscending")});var $E=I((ESe,$U)=>{"use strict";var mR=require("joi"),{string:Hc,boolean:GU,date:K6}=mR.types(),W6=mt(),{validateSchemaExists:uSe,validateTableExists:dSe,validateSchemaName:fSe}=Bs(),Q6=B(),z6=Pt(),qU=ie();qU.initSync();var _Se=Hc.invalid(qU.get(Q6.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(z6.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),VU={operation:Hc.valid("add_node","update_node","set_node_replication"),node_name:Hc.optional(),subscriptions:mR.array().items({table:Hc.optional(),schema:Hc.optional(),database:Hc.optional(),subscribe:GU.required(),publish:GU.required().custom(J6),start_time:K6.iso()})};function j6(e){return W6.validateBySchema(e,mR.object(VU))}a(j6,"addUpdateNodeValidator");function J6(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(J6,"checkForFalsy");$U.exports={addUpdateNodeValidator:j6,validation_schema:VU}});var KU=I((mSe,YU)=>{var X6=mt(),Z6={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};YU.exports=function(e){return X6.validateObject(e,Z6)}});var SR=I((pSe,WU)=>{"use strict";var e9=B().OPERATIONS_ENUM,pR=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=e9.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};WU.exports=pR});var zU=I((TSe,QU)=>{"use strict";var t9={OPERATION:"operation",REFRESH:"refresh"},TR=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},gR=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};QU.exports={JWTTokens:TR,TOKEN_TYPE_ENUM:t9,JWTRSAKeys:gR}});var _d=I((RSe,ZU)=>{"use strict";var fd=require("jsonwebtoken"),RR=require("fs-extra"),AR=te(),Yn=B(),{handleHDBError:Xr,hdb_errors:r9}=ce(),{HTTP_STATUS_CODES:Zr,AUTHENTICATION_ERROR_MSGS:en}=r9,dd=X(),jU=X_(),OR=yn(),n9=Vn().update,s9=SR(),i9=Ti(),{UserEventMsg:o9}=Es(),Eo=ie();Eo.initSync();var bR=require("path"),{JWTTokens:a9,JWTRSAKeys:c9,TOKEN_TYPE_ENUM:YE}=zU(),l9=Eo.get(Yn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?Eo.get(Yn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",u9=Eo.get(Yn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?Eo.get(Yn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",KE="RS256",yR;ZU.exports={createTokens:d9,validateOperationToken:_9,refreshOperationToken:f9,validateRefreshToken:XU};async function d9(e){if(AR.isEmpty(e)||typeof e!="object")throw Xr(new Error,en.INVALID_AUTH_OBJECT,Zr.BAD_REQUEST,void 0,void 0,!0);if(AR.isEmpty(e.username))throw Xr(new Error,en.USERNAME_REQUIRED,Zr.BAD_REQUEST,void 0,void 0,!0);if(AR.isEmpty(e.password))throw Xr(new Error,en.PASSWORD_REQUIRED,Zr.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await OR.findAndValidateUser(e.username,e.password),!t)throw Xr(new Error,en.INVALID_CREDENTIALS,Zr.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw dd.error(E),Xr(new Error,en.INVALID_CREDENTIALS,Zr.UNAUTHORIZED,void 0,void 0,!0)}let r=await WE(),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 JU(i,r.private_key,r.passphrase),c=await fd.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:u9,algorithm:KE,subject:YE.REFRESH}),l=jU.hash(c),d=new s9(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),u,f;try{u=await n9(d)}catch(E){dd.error(E),f=E}if(f!==void 0||u.skipped_hashes.length>0)throw Xr(new Error,en.REFRESH_TOKEN_SAVE_FAILED,Zr.INTERNAL_SERVER_ERROR);return i9.signalUserChange(new o9(process.pid)),new a9(o,c)}a(d9,"createTokens");async function JU(e,t,r){return await fd.sign(e,{key:t,passphrase:r},{expiresIn:l9,algorithm:KE,subject:YE.OPERATION})}a(JU,"signOperationToken");async function WE(){if(yR===void 0)try{let e=bR.join(Eo.getHdbBasePath(),Yn.LICENSE_KEY_DIR_NAME,Yn.JWT_ENUM.JWT_PASSPHRASE_NAME),t=bR.join(Eo.getHdbBasePath(),Yn.LICENSE_KEY_DIR_NAME,Yn.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=bR.join(Eo.getHdbBasePath(),Yn.LICENSE_KEY_DIR_NAME,Yn.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await RR.readFile(e)).toString(),s=(await RR.readFile(t)).toString(),i=(await RR.readFile(r)).toString();yR=new c9(i,s,n)}catch(e){throw dd.error(e),Xr(new Error,en.NO_ENCRYPTION_KEYS,Zr.INTERNAL_SERVER_ERROR)}return yR}a(WE,"getJWTRSAKeys");async function f9(e){if(!e)throw Xr(new Error,en.INVALID_BODY,Zr.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw Xr(new Error,en.REFRESH_TOKEN_REQUIRED,Zr.BAD_REQUEST,void 0,void 0,!0);await XU(e.refresh_token);let t=await WE(),r=await fd.decode(e.refresh_token);return{operation_token:await JU({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(f9,"refreshOperationToken");async function _9(e){try{let t=await WE(),r=await fd.verify(e,t.public_key,{algorithms:KE,subject:YE.OPERATION});return await OR.findAndValidateUser(r.username,void 0,!1)}catch(t){throw dd.warn(t),t.name&&t.name==="TokenExpiredError"?Xr(new Error,en.TOKEN_EXPIRED,Zr.FORBIDDEN):Xr(new Error,en.INVALID_TOKEN,Zr.UNAUTHORIZED)}}a(_9,"validateOperationToken");async function XU(e){let t;try{let r=await WE(),n=await fd.verify(e,r.public_key,{algorithms:KE,subject:YE.REFRESH});t=await OR.findAndValidateUser(n.username,void 0,!1)}catch(r){throw dd.warn(r),r.name&&r.name==="TokenExpiredError"?Xr(new Error,en.TOKEN_EXPIRED,Zr.FORBIDDEN):Xr(new Error,en.INVALID_TOKEN,Zr.UNAUTHORIZED)}if(!jU.validate(t.refresh_token,e))throw Xr(new Error,en.INVALID_TOKEN,Zr.UNAUTHORIZED);return t}a(XU,"validateRefreshToken")});var NR=I((ySe,rv)=>{"use strict";var E9=KU(),kc=require("passport"),h9=require("passport-local").Strategy,m9=require("passport-http").BasicStrategy,p9=require("util"),S9=yn(),tv=p9.callbackify(S9.findAndValidateUser),bSe=En(),T9=B(),ev=_d();kc.use(new h9(function(e,t,r){tv(e,t,r)}));kc.use(new m9(function(e,t,r){tv(e,t,r)}));kc.serializeUser(function(e,t){t(null,e)});kc.deserializeUser(function(e,t){t(null,e)});function g9(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":kc.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===T9.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?ev.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):ev.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:kc.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(g9,"authorize");function R9(e,t){let r=E9(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(R9,"checkPermissions");rv.exports={authorize:g9,checkPermissions:R9}});var Fc=I((NSe,nv)=>{"use strict";var IR=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},wR=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};nv.exports={Node:IR,NodeSubscription:wR}});var iv=I((wSe,sv)=>{"use strict";var A9=B().OPERATIONS_ENUM,CR=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=A9.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};sv.exports=CR});var Ed=I((DSe,ov)=>{"use strict";var DR=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},LR=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)}};ov.exports={RemotePayloadObject:DR,RemotePayloadSubscription:LR}});var cv=I((PSe,av)=>{"use strict";var PR=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}};av.exports=PR});var uv=I((HSe,lv)=>{"use strict";var b9=cv(),USe=Ft(),vSe=ft(),y9=X(),{getSchemaPath:xSe,getTransactionAuditStorePath:BSe}=St(),{getDatabases:O9}=(Ne(),ae(it));lv.exports=N9;async function N9(e){let t=new b9;try{let r=O9()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats();t.schema=e.schema,t.table=e.name,t.record_count=n.entryCount,t.transaction_log_record_count=s.entryCount}catch(r){y9.warn(`unable to stat table dbi due to ${r}`)}return t}a(N9,"lmdbGetTableSize")});var fv=I((FSe,dv)=>{"use strict";var MR=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}};dv.exports=MR});var Gc=I((KSe,mv)=>{"use strict";var I9=require("fs-extra"),w9=require("path"),Br=require("systeminformation"),ho=X(),_v=jt(),qSe=Pt(),zE=B(),C9=uv(),D9=ro(),{getThreadInfo:Ev}=at(),$R=ie();$R.initSync();var L9=fv(),{openEnvironment:VSe}=ft(),{getSchemaPath:$Se}=St(),{database:YSe,databases:UR}=(Ne(),ae(it)),QE;mv.exports={getHDBProcessInfo:HR,getNetworkInfo:FR,getDiskInfo:kR,getMemoryInfo:BR,getCPUInfo:xR,getTimeInfo:vR,getSystemInformation:GR,systemInformation:P9,getTableSize:qR,getMetrics:VR};function vR(){return Br.time()}a(vR,"getTimeInfo");async function xR(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:d,...u}=await Br.cpu();u.cpu_speed=await Br.cpuCurrentSpeed();let{raw_currentload:f,raw_currentload_idle:E,raw_currentload_irq:_,raw_currentload_nice:h,raw_currentload_system:p,raw_currentload_user:S,cpus:g,...T}=await Br.currentLoad();return T.cpus=[],g.forEach(A=>{let{raw_load:N,raw_load_idle:V,raw_load_irq:v,raw_load_nice:J,raw_load_system:$,raw_load_user:F,...ne}=A;T.cpus.push(ne)}),u.current_load=T,u}catch(e){return ho.error(`error in getCPUInfo: ${e}`),{}}}a(xR,"getCPUInfo");async function BR(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Br.mem();return Object.assign(s,process.memoryUsage())}catch(e){return ho.error(`error in getMemoryInfo: ${e}`),{}}}a(BR,"getMemoryInfo");async function HR(){let e={core:[],clustering:[]};try{let t=await Br.processes(),r;try{r=Number.parseInt(await I9.readFile(w9.join($R.get(zE.CONFIG_PARAMS.ROOTPATH),zE.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===zE.NODE_ERROR_CODES.ENOENT)ho.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return ho.error(`error in getHDBProcessInfo: ${t}`),e}}a(HR,"getHDBProcessInfo");async function kR(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Br.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...d}=await Br.fsStats();return e.read_write=d,e.size=await Br.fsSize(),e}catch(t){return ho.error(`error in getDiskInfo: ${t}`),e}}a(kR,"getDiskInfo");async function FR(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await Br.networkInterfaceDefault(),e.latency=await Br.inetChecksite("google.com"),(await Br.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:d,ieee8021xState:u,carrier_changes:f,...E}=n;e.interfaces.push(E)}),(await Br.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)}),e}catch(t){return ho.error(`error in getNetworkInfo: ${t}`),e}}a(FR,"getNetworkInfo");async function GR(){if(QE!==void 0)return QE;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Br.osInfo();e=c;let l=await Br.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,QE=e,QE}catch(t){return ho.error(`error in getSystemInformation: ${t}`),e}}a(GR,"getSystemInformation");async function qR(){let e=[],t=await D9.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await C9(n));return e}a(qR,"getTableSize");async function VR(){let e={};for(let t in UR){let r=e[t]={},n=r.tables={};for(let s in UR[t])try{let i=UR[t][s];r.readers||(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[d,u,f]=l.trim().split(" ");return{pid:d,thread:u,txnid:f}}),i.primaryStore.auditStore&&(r.audit=i.auditStore.getStats()));let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){ho.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(VR,"getMetrics");async function hv(){if($R.get(zE.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await _v.getNATSReferences(),t=await _v.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(hv,"getNatsStreamInfo");async function P9(e){let t=new L9;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await GR(),t.time=vR(),t.cpu=await xR(),t.memory=await BR(),t.disk=await kR(),t.network=await FR(),t.harperdb_processes=await HR(),t.table_size=await qR(),t.metrics=await VR(),t.threads=await Ev(),t.replication=await hv(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await GR();break;case"time":t.time=vR();break;case"cpu":t.cpu=await xR();break;case"memory":t.memory=await BR();break;case"disk":t.disk=await kR();break;case"network":t.network=await FR();break;case"harperdb_processes":t.harperdb_processes=await HR();break;case"table_size":t.table_size=await qR();break;case"database_metrics":case"metrics":t.metrics=await VR();break;case"threads":t.threads=await Ev();break;case"replication":t.replication=await hv();break;default:break}return t}a(P9,"systemInformation")});var JE=I((QSe,pv)=>{"use strict";pv.exports={version:M9,printVersion:U9};var jE=Ju();function M9(){if(jE)return jE.version}a(M9,"version");function U9(){jE&&console.log(`HarperDB Version ${jE.version}`)}a(U9,"printVersion")});var yi=I((XSe,Rv)=>{"use strict";var v9=Vn(),YR=te(),x9=require("util"),ma=B(),Sv=ie();Sv.initSync();var B9=NR(),Tv=An(),{Node:jSe,NodeSubscription:JSe}=Fc(),H9=Oc(),k9=iv(),{RemotePayloadObject:F9,RemotePayloadSubscription:G9}=Ed(),{handleHDBError:q9,hdb_errors:V9}=ce(),{HTTP_STATUS_CODES:$9,HDB_ERROR_MSGS:Y9}=V9,K9=Gs(),W9=Gc(),Q9=JE(),{getDatabases:z9}=(Ne(),ae(it)),j9=x9.promisify(B9.authorize),J9=Tv.searchByHash,X9=Tv.searchByValue;Rv.exports={authHeaderToUser:Z9,isEmpty:e7,getNodeRecord:t7,upsertNodeRecord:r7,buildNodePayloads:n7,checkClusteringEnabled:s7,getAllNodeRecords:i7,getSystemInfo:o7,reverseSubscription:gv};async function Z9(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await j9(t,null),e}a(Z9,"authHeaderToUser");function e7(e){return e==null}a(e7,"isEmpty");async function t7(e){let t=new H9(ma.SYSTEM_SCHEMA_NAME,ma.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return J9(t)}a(t7,"getNodeRecord");async function r7(e){let t=new k9(ma.SYSTEM_SCHEMA_NAME,ma.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return v9.upsert(t)}a(r7,"upsertNodeRecord");function gv(e){if(YR.isEmpty(e.subscribe)||YR.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(gv,"reverseSubscription");function n7(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:d}=c,u=YR.getTableHashAttribute(l,d),{subscribe:f,publish:E}=gv(c),_=z9()[l]?.[d],h=new G9(l,d,u,E,f,c.start_time,_.schemaDefined?_.attributes:void 0);s.push(h)}return new F9(r,t,s,n)}a(n7,"buildNodePayloads");function s7(){if(!Sv.get(ma.CONFIG_PARAMS.CLUSTERING_ENABLED))throw q9(new Error,Y9.CLUSTERING_NOT_ENABLED,$9.BAD_REQUEST,void 0,void 0,!0)}a(s7,"checkClusteringEnabled");async function i7(){let e=new K9(ma.SYSTEM_SCHEMA_NAME,ma.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await X9(e))}a(i7,"getAllNodeRecords");async function o7(){let e=await W9.getSystemInformation();return{hdb_version:Q9.version(),node_version:e.node_version,platform:e.platform}}a(o7,"getSystemInfo")});var KR=I((eTe,Cv)=>{"use strict";var XE=jt(),Av=te(),bv=Pt(),yv=B(),ZE=X(),Ov=kE(),a7=ag(),{RemotePayloadObject:c7}=Ed(),{handleHDBError:Nv,hdb_errors:l7}=ce(),{HTTP_STATUS_CODES:Iv}=l7,{NodeSubscription:wv}=Fc();Cv.exports=u7;async function u7(e,t){let r;try{r=await XE.request(`${t}.${bv.REQUEST_SUFFIX}`,new c7(yv.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),ZE.trace("Response from remote describe all request:",r)}catch(o){ZE.error(`addNode received error from describe all request to remote node: ${o}`);let c=XE.requestErrorHandler(o,"add_node",t);throw Nv(new Error,c,Iv.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===bv.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw Nv(new Error,o,Iv.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,l=o.database??o.schema??"data";if(l===yv.SYSTEM_SCHEMA_NAME){await XE.createLocalTableStream(l,c);let h=new wv(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let d=Av.doesSchemaExist(l),u=n[l]!==void 0,f=c?Av.doesTableExist(l,c):!0,E=c?n?.[l]?.[c]!==void 0:!0;if(!d&&!u||!f&&!E){s.push(o);continue}if(!d&&u&&(ZE.trace(`addNode creating schema: ${l}`),await Ov.createSchema({operation:"create_schema",schema:l})),!f&&E){ZE.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new a7(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await Ov.createTable(h)}await XE.createLocalTableStream(l,c);let _=new wv(l,c,o.publish,o.subscribe);_.start_time=o.start_time,i.push(_)}return{added:i,skipped:s}}a(u7,"reviewSubscriptions")});var hd=I(th=>{var eh=X();for(let e of["trace","debug","info","warn","error","fatal","notify"])eh.logsAtLevel(e)&&(th[e]=eh[e]);th.loggerWithTag=e=>eh.loggerWithTag(e,!0);th.setLogLevel=eh.setLogLevel});function WR(e){let t=e.idMapping;if(!t){let r=e.get(Symbol.for("remote-ids"));e.idMapping=t=r?(0,qc.unpack)(r):null}return t||(t={nodeName:ot(),remoteNameToId:{[ot()]:0}},e.putSync(Symbol.for("remote-ids"),(0,qc.pack)(t))),t}function md(e){return WR(e).remoteNameToId}function Lv(e,t,r){let n=WR(r),s=n.remoteNameToId,i=new Map,o=!1;t[e]=0;for(let c in t){let l=t[c],d=s[c];if(d==null){let u=0;for(let f in s){let E=s[f];E>u&&(u=E)}d=u+1,s[c]=d,o=!0}i.set(l,d)}return o&&r.putSync(Symbol.for("remote-ids"),(0,qc.pack)(n)),i}function QR(e,t){let r=WR(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(Symbol.for("remote-ids"),(0,qc.pack)(r))}return Dv.info?.("The remote node name map",e,n,s),s}var Dv,qc,zR=Oe(()=>{Dv=U(hd());Oi();qc=require("msgpackr");a(WR,"getIdMappingRecord");a(md,"exportIdMapping");a(Lv,"remoteToLocalNodeId");a(QR,"getIdOfRemoteNode")});var Pv={};Ze(Pv,{Resources:()=>rh,keyArrayToString:()=>Vc,resetResources:()=>d7,resources:()=>mo});function d7(){return mo=new rh}function Vc(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var rh,mo,pd=Oe(()=>{aa();rh=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s)throw new Error(`Conflicting paths for ${t}`);super.set(t,i);for(let[c,l]of this){let d=2;for(;(d=c.indexOf("/",d))>-1;){let u=this.get(c.slice(0,d));u&&(u.hasSubPaths=!0),d+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),l=this.get(c);if(l&&(!r||l.exportTypes?.[r]!==!1)){if(l.relativeURL=t.slice(n),!l.hasSubPaths)return l;s=l}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),s&&(!r||s.exportTypes?.[r]!==!1)?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(!r||s.exportTypes?.[r]!==!1)&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Tt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(d7,"resetResources");a(Vc,"keyArrayToString")});function XR(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=Uv,f7(e.primaryStore,e.auditStore)):(c=Mv,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{vv(Mv[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let d=l[o];d||(d=l[o]=new Map,d.envs=l,d.tableId=o,d.store=e.primaryStore),t=Vc(t);let u=new JR(r);u.startTime=n;let f=d.get(t);return f?f.push(u):(d.set(t,f=[u]),f.tables=d,f.key=t),u.subscriptions=f,u}function vv(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),xv(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Lt(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=Vc(c),d=0;do{let u=o.get(l);if(u){for(let E of u)if(!(d>0&&!(E.includeDescendants&&!(E.onlyChildren&&d>1)))){if(E.startTime>=n){(0,jR.info)("omitting",c,E.startTime,n);continue}try{let _;E.supportsTransactions&&E.txnInProgress!==i.version&&(_=!0,E.txnInProgress||(r?r.push(E):r=[E]),E.txnInProgress=i.version),E.listener(c,i,n,_)}catch(_){console.error(_),(0,jR.info)(_)}}}if(l==null)break;let f=l.lastIndexOf?.("/",l.length-2);f>-1?l=l.slice(0,f):l=null,d++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function f7(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let l=Uv[s];if(!l)return;let d=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{vv(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",d)&&d()})}}function xv(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function Bv(e){return e.nextTransaction||(XR({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),xv(e)),e.nextTransaction}var jR,Mv,Uv,JR,ZR=Oe(()=>{jR=U(X());cc();pd();Ei();Mv=Object.create(null),Uv=Object.create(null);a(XR,"addSubscription");JR=class extends Sn{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(vv,"notifyFromTransactionData");a(f7,"listenToCommits");a(xv,"nextTransaction");a(Bv,"whenNextTransaction")});function Hr(){return Hv||(Hv=dt({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"replicates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function Td(e){Hr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;server.nodes=server.nodes.filter(s=>s!==n),r.type==="put"&&n!==ot()&&server.nodes.push(n),(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function nh(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&Hr().primaryStore.get(ot())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function _7(){Td(e=>{po({},(t,r)=>{let n=e.name,s=kv.get(n);if(s||kv.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=new Float64Array(i.getUserSharedBuffer(["replicated",r,n],new ArrayBuffer(8),{callback:()=>{let c=o[0],l=o.lastTime;for(let{txnTime:d,onConfirm:u}of Sd.get(r)||[])d>l&&d<=c&&u();o.lastTime=c}}));o.lastTime=0,s.set(r,o)}})})}function*sh(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=$c.default.get(Yc.CONFIG_PARAMS.REPLICATION_SECUREPORT)??(!$c.default.get(Yc.CONFIG_PARAMS.REPLICATION_PORT)&&$c.default.get(Yc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||$c.default.get(Yc.CONFIG_PARAMS.REPLICATION_PORT)||$c.default.get(Yc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){Fv.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{url:r,subscription:t.subscriptions,routes:t.routes}}}var Fv,$c,Yc,Hv,kv,Sd,gd=Oe(()=>{Ne();Oi();mE();Fv=require("worker_threads"),$c=U(ie()),Yc=U(B());server.nodes=[];a(Hr,"getHDBNodeTable");a(Td,"subscribeToNodeUpdates");a(nh,"shouldReplicateToNode");kv=new Map;DP((e,t,r)=>{Sd||(Sd=new Map,_7());let n=Sd.get(e);return n||Sd.set(e,n=[]),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:()=>{++i===r&&s()}})})});a(_7,"startSubscriptionToReplications");a(sh,"iterateRoutes")});var qv={};Ze(qv,{connectedToNode:()=>Sa,disconnectedFromNode:()=>Wc,ensureNode:()=>Ii,requestClusterStatus:()=>Gv,startOnMainThread:()=>tA});async function tA(e){let t=[],r,n=0;Ks.whenThreadsStarted.then(async()=>{let o=[];for await(let c of ct().system.hdb_nodes.search([]))o.push(c);for(let c of sh(e))try{let l=!c.subscriptions;if(l){let u=ot();Hr().primaryStore.get(u)===void 0&&await Ii(u,{name:u,url:e.url??So(),replicates:!0})}let d=c.trusted!==!1;if(l&&c.replicates==null&&(c.replicates=!0),o.find(u=>u.url===c.url))continue;i(c)}catch(l){console.error(l)}Td(i)});let s;function i(o,c=o?.name){let l=ot()&&c===ot()||So()&&o?.url===So();if(l){let E=!!o?.replicates;if(s!==void 0&&s!==E)for(let _ of Hr().search([]))_.replicates&&_.name!==c&&i(_,_.name);s=E}if(gr.trace("Setting up node replication for",o),!o){for(let[E,_]of Ni){let h;for(let[p,{worker:S,nodes:g}]of _){let T=g[0];if(T&&T.name==c){h=!0;for(let[A,{worker:N}]of _)_.delete(A),N?.postMessage({type:"unsubscribe-from-node",node:c,database:A,url:E});break}}if(h){Ni.get(E).iterator.remove(),Ni.delete(E);return}}return}if(l)return;if(!o.url){gr.info(`Node ${o.name} is missing url`);return}let d=Ni.get(o.url);if(d&&d.iterator.remove(),!(o.replicates===!0||o.replicates?.sends)&&!o.subscriptions?.length&&!d)return;if(gr.info(`Added node ${o.name} at ${o.url} for process ${ot()}`),o.name){for(let[E,_]of pa)if(o.url===_.url){pa.delete(E);break}pa.set(o.name,o)}let u=ct();if(d||(d=new Map,Ni.set(o.url,d)),d.iterator=po(e,(E,_,h)=>{h?f(_,!0):f(_,!1)}),o.subscriptions)for(let E of o.subscriptions){let _=E.database||E.schema;u[_]||(gr.warn(`Database ${_} not found for node ${o.name}, making a subscription anyway`),f(_,!1))}function f(E,_){gr.trace("Setting up replication for database",E,"on node",o.name);let h=d.get(E),p,S=[Object.assign({replicateByDefault:_},o)],g=nh(o,E),T=Ks.workers.filter(A=>A.name==="http");if(h?(p=h.worker,h.nodes=S):g&&(n=n%T.length,p=T[n++],d.set(E,{worker:p,nodes:S,url:o.url}),p?.on("exit",()=>{d.get(E)?.worker===p&&(d.delete(E),f(E,_))})),g)setTimeout(()=>{let A={type:"subscribe-to-node",database:E,nodes:S};p?p.postMessage(A):Kc(A)},E7);else{Hr().primaryStore.get(ot())?.replicates||(s=!1);let A={type:"unsubscribe-from-node",database:E,url:o.url};p?p.postMessage(A):oh(A)}}a(f,"onDatabase")}a(i,"onNodeUpdate"),Wc=a(function(o){let c=Array.from(pa.keys()).sort(),l=c.indexOf(o.name||Ws(o.url));if(l===-1){gr.warn("Disconnected node not found in node map",o.name,pa.keys());return}let d=Ni.get(o.url),u=d?.get(o.database);if(!u){gr.warn("Disconnected node not found in replication map",o.database,d);return}if(u.connected=!1,o.finished)return;let f=u.nodes[0];if(!(f.replicates===!0||f.replicates?.sends||f.subscriptions?.length))return;let E=(l+1)%c.length;for(;l!==E;){let _=c[E],h=pa.get(_);d=Ni.get(h.url);let p=d?.get(o.database);if(!p){E=(E+1)%c.length;continue}let{worker:S,nodes:g}=p,T=!1;for(let A of u.nodes){if(g.some(N=>N.name===A.name)){gr.info(`Disconnected node is already failing over to ${_} for ${o.database}`);continue}g.push(A),T=!0}if(!T)return;u.redirectingTo=p,gr.info(`Failing over ${o.database} from ${o.name} to ${_}`),S?S.postMessage({type:"subscribe-to-node",database:o.database,nodes:g}):Kc({database:o.database,nodes:g});break}},"disconnectedFromNode"),Sa=a(function(o){let c=Ni.get(o.url),l=c?.get(o.database);if(!l){gr.warn("Connected node not found in replication map, this may be because the node is being removed",o.database,c);return}if(l.connected=!0,l.latency=o.latency,l.redirectingTo){let{worker:d,nodes:u}=l.redirectingTo,f=u.find(E=>E.name===o.name);l.redirectingTo=null,f&&(u.splice(u.indexOf(f),1),d?d.postMessage({type:"subscribe-to-node",database:o.database,nodes:u}):Kc({database:o.database,nodes:u}))}},"connectedToNode"),(0,Ks.onMessageByType)("disconnected-from-node",Wc),(0,Ks.onMessageByType)("connected-to-node",Sa),(0,Ks.onMessageByType)("request-cluster-status",Gv)}function Gv(e,t){let r=[];for(let[,n]of pa)try{let s=Ni.get(n.url),i=[];if(s){for(let[c,{worker:l,connected:d,nodes:u,latency:f}]of s)i.push({database:c,connected:d,latency:f,threadId:l?.threadId,nodes:u.map(E=>E.name)});let o=(0,eA.cloneDeep)(n);o.database_sockets=i,delete o.ca,delete o.node_name,delete o.__updatedtime__,delete o.__createdtime__,r.push(o)}}catch(s){gr.warn("Error getting cluster status for",n?.url,s)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Ii(e,t){let r=Hr();e=e??Ws(t.url),t.name=e;let n=r.primaryStore.get(e);if(gr.info(`Ensuring node ${e} at ${t.url}, existing record:`,n),!n)await r.put(t);else{t.replicates&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,eA.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let d of o)if((c.database??c.schema)===(d.database??d.schema)&&c.table===d.table){d.publish=c.publish,d.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}gr.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Ks,ih,gr,eA,E7,Ni,Wc,Sa,pa,Rd=Oe(()=>{Ne();Ks=U(at());Oi();ih=require("worker_threads");gd();gr=U(X()),eA=require("lodash"),E7=200,Ni=new Map,pa=new Map;a(tA,"startOnMainThread");a(Gv,"requestClusterStatus");ih.parentPort&&(Wc=a(e=>{ih.parentPort.postMessage(Object.assign({type:"disconnected-from-node"},e))},"disconnectedFromNode"),Sa=a(e=>{ih.parentPort.postMessage(Object.assign({type:"connected-to-node"},e))},"connectedToNode"),(0,Ks.onMessageByType)("subscribe-to-node",e=>{Kc(e)}),(0,Ks.onMessageByType)("unsubscribe-from-node",e=>{oh(e)}));a(Ii,"ensureNode")});async function aA(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=ot(),i;if(e.includes("wss://")){if(!nA){let l=(0,n0.createTLSSelector)("operations-api"),d={secureContexts:null};await l.initialize(d),nA=d.secureContexts}if(i=nA.get(s),i&&_e.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let o={};r&&(o.Authorization=r);let c={headers:o,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,i0.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,ALPNProtocols:["http/1.1","harperdb-replication"],rejectUnauthorized:n!==!1,secureContext:void 0};return n!==!1&&i&&(c.secureContext=s0.createSecureContext(Object.assign({},i.options,{ca:Array.from(ga)}))),new t0.WebSocket(e,"harperdb-replication-v1",c)}function fh(e,t,r){let n=t.port||t.securePort,s=oA.pid%1e3+"-"+r0.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),d=t.database,u=t.databaseSubscriptions||Ta,f,E,_=!1,h=t.subscription;h?.then&&h.then(re=>h=re);let p=t.tables||d&&ct()[d];if(!r){_e.error?.("No authorization provided"),dn(1008,"Unauthorized");return}let S=new Map,g=[],T=r.name;T&&t.connection&&(t.connection.nodeName=T);let A,N,V=e0.default.get("replication_url"),v,J,$,F;if(t.url){let re=a(()=>{$?e.terminate():($=performance.now(),e.ping())},"send_ping");v=setInterval(re,Zv).unref(),re()}else ne();function ne(){clearTimeout(J),J=setTimeout(()=>{_e.warn?.(`Timeout waiting for ping from ${T}, terminating connection and reconnecting`),e.terminate()},Zv*2).unref()}a(ne,"resetPingTimer"),d&&ve(d);let ee,Z,le=[],fe=[],je,ye=[],Ht=[],Bo=[],rc=150,Gr=0,Kl=0,$i,Yi,Cs,Ds,Ct;e.on("message",re=>{try{let me=re.dataView=new zc(re.buffer,re.byteOffset,re.byteLength);if(re[0]>127){let Fe=(0,et.decode)(re),[tt,Ee,Dt]=Fe;switch(tt){case $v:{if(Ee){if(T){if(T!==Ee){_e.error?.(s,`Node name mismatch, expecting to connect to ${T}, but peer reported name as ${Ee}, disconnecting`),e.send((0,et.encode)([Qc])),dn(1008,"Node name mismatch");return}}else if(T=Ee,t.connection?.tentativeNode){let x=t.connection.tentativeNode;x.name=T,t.connection.tentativeNode=null,Ii(T,x)}if(t.connection&&(t.connection.nodeName=T),_e.info?.(s,"received node id",T,d),!d)try{ve(d=Fe[2]),d==="system"&&(ee=po(t,(x,k)=>{Wl(k)&&Ki(k)}),e.on("close",()=>{ee?.remove()}))}catch(x){_e.warn?.(s,"Error setting database",x),e.send((0,et.encode)([Qc])),dn(1008,x.message);return}_e.info?.(s,"setDatabase",d,p&&Object.keys(p)),r_()}break}case Jv:{_e.info?.(s,"Received table definitions for",Ee.map(x=>x.table));for(let x of Ee){let k=Fe[2];x.database=k;let se;Wl(k)&&(k==="system"?Ve[k]?.[x.table]||(se=sA(x,Ve[k]?.[x.table])):se=sA(x,Ve[k]?.[x.table]),f||(f=se.auditStore),p||(p=ct()?.[k]))}break}case Qc:dn();break;case Qv:try{let x=r?.replicates||r?.subscribers||r?.name;server.operation(Ee,{user:r},!x).then(k=>{k.requestId=Ee.requestId,e.send((0,et.encode)([ch,k]))},k=>{e.send((0,et.encode)([ch,{requestId:Ee.requestId,error:k instanceof Error?k.toString():k}]))})}catch(x){e.send((0,et.encode)([ch,{requestId:Ee.requestId,error:x instanceof Error?x.toString():x}]))}break;case ch:let{resolve:q,reject:m}=S.get(Ee.requestId);Ee.error?m(new Error(Ee.error)):q(Ee),S.delete(Ee.requestId);break;case rA:let R=Fe[3];p||(d?_e.error?.(s,"No tables found for",d):_e.error?.(s,"Database name never received"));let w=p[R];w=sA({table:R,database:d,attributes:Ee.attributes,schemaDefined:Ee.schemaDefined},w),le[Dt]={name:R,decoder:new et.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:Ee.typedStructs,structures:Ee.structures}),getEntry(x){return w.primaryStore.getEntry(x)},rootStore:w.primaryStore.rootStore};break;case Yv:Ct=f?Lv(T,Ee,f):new Map,je=Fe[2],_e.info?.(s,`Acknowledged subscription request, receiving messages for nodes: ${je}`);break;case Kv:let b=Dt;Bo[b]=Ee;break;case jv:let y=["replicated",d,T];E||(E=new Float64Array(f.getUserSharedBuffer(y,new ArrayBuffer(8)))),E[0]=Ee,_e.info?.(s,"received and broadcasting committed update",Ee),E.buffer.notify();break;case zv:A=Ee,h.send({type:"end_txn",localTime:A,remoteNodeIds:g});break;case Wv:{let x=Ee,k;try{let se=Fe[3],ue=fe[Dt]||(fe[Dt]=p[Fe[4]]);if(!ue)return _e.warn?.("Unknown table id trying to handle record request",Dt);let pe=ue.primaryStore.getBinaryFast(Symbol.for("structures")),rt=pe.length;if(rt!==Kl){Kl=rt;let He=(0,et.decode)(pe);e.send((0,et.encode)([rA,{typedStructs:He.typed,structures:He.named},Dt,ue.tableName]))}let xe=ue.primaryStore.getBinaryFast(se);if(xe){let He=ue.primaryStore.decoder.decode(xe,{valueAsBuffer:!0});k=(0,et.encode)([ah,x,{value:He.value,expiresAt:He.expiresAt,version:He.version,residencyId:He.residencyId,nodeId:He.nodeId,user:He.user}])}else k=(0,et.encode)([ah,x])}catch(se){k=(0,et.encode)([ah,x,{error:se.message}])}e.send(k);break}case ah:{let{resolve:x,reject:k,tableId:se,key:ue}=S.get(Fe[1]),pe=Fe[2];if(pe?.error)k(new Error(pe.error));else if(pe){let rt=le[se].decoder.decode(pe.value);pe.value=rt,pe.key=ue,x(pe)}else x();S.delete(Fe[1]);break}case Vv:Ds=Ee;let C,O,P=!1;if(h){if(d!==h.databaseName&&!h.then){_e.error?.("Subscription request for wrong database",d,h.databaseName);return}}else h=u.get(d);if(_e.info?.(s,"received subscription request for",d,"at",Ds),!h){let x;h=new Promise(k=>{_e.info?.("Waiting for subscription to database "+d),x=k}),h.ready=x,Ta.set(d,h)}if(r.name)O=Hr().subscribe(r.name),O.then(async x=>{C=x;for await(let k of C){let se=k.value;if(!(se?.replicates===!0||se?.replicates?.receives||se?.subscriptions?.some(ue=>(ue.database||ue.schema)===d&&ue.publish!==!1))){P=!0,e.send((0,et.encode)([Qc])),dn(1008,`Unauthorized database subscription to ${d}`);return}}},x=>{_e.error?.(s,"Error subscribing to HDB nodes",x)});else if(!(r?.permissions?.super_user||r.replicates)){e.send((0,et.encode)([Qc])),dn(1008,`Unauthorized database subscription to ${d}`);return}if(Cs&&(_e.info?.(s,"stopping previous subscription",d),Cs.emit("close")),Ds.length===0)return;let M,L=Ds[0],H=a(x=>{if(x&&(L.replicateByDefault?!L.tables.includes(x.tableName):L.tables.includes(x.tableName)))return M=x,{table:x}},"tableToTableEntry"),Y={txnTime:0},K,Te,j=1/0,Ie,he=a((x,k)=>{if(j=k,x.type==="end_txn"){Y.txnTime&&(o[i]!==66&&_e.error?.("Invalid encoding of message"),ui(9),ui(dh),Dr(Ie=k),De()),i=c,Y.txnTime=0;return}let se=x.nodeId,ue=x.tableId,pe=Te[ue];if(!pe&&(pe=Te[ue]=H(h.tableById[ue]),!pe))return _e.trace?.("Not subscribed to table",ue);let rt=pe.table,xe=rt.primaryStore,He=xe.encoder;if(x.extendedType&w_||!He.typedStructs){let Wi=x.getValue(xe,!0);JSON.stringify(Wi)}if(K[se]>=k)return Ad&&_e.info?.(s,"skipping replication update",x.recordId,"to:",T,"from:",se,"subscribed:",K),di();Ad&&_e.info?.(s,"sending replication update",x.recordId,"to:",T,"from:",se,"subscribed:",K);let nt=x.version;Y.txnTime!==nt&&(Y.txnTime&&(Ad&&_e.info?.(s,"new txn time, sending queued txn",Y.txnTime),o[i]!==66&&_e.error?.("Invalid encoding of message"),De()),Y.txnTime=nt,i=c,Dr(nt));let rr=x.residencyId,kt=n_(rr,rt),fn;if(kt&&!kt.includes(T)){let Wi=n_(x.previousResidencyId,rt);if(Wi&&!Wi.includes(T)&&(x.type==="put"||x.type==="patch")||rt.getResidencyById)return di();let Ql=x.recordId;_e.info?.(s,"sending invalidation",Ql,T,"from",se);let Yp=0;rr&&(Yp|=Yo),x.previousResidencyId&&(Yp|=Ko);let Kp,s_=null;for(let FO in rt.indices){if(!s_){if(Kp=x.getValue(xe,!0),!Kp)break;s_={}}s_[FO]=Kp[FO]}fn=uc(x.version,ue,Ql,null,se,x.user,x.type==="put"||x.type==="patch"?"invalidate":x.type,He.encode(s_),Yp,rr,x.previousResidencyId,x.expiresAt)}function di(){F||(F=setTimeout(()=>{F=null,(Ie||0)+Xv/2<j&&(Ad&&_e.info?.(s,"sending skipped sequence update",j),e.send((0,et.encode)([zv,j])))},Xv).unref())}a(di,"skipAuditRecord");let Vp=He.typedStructs,$p=He.structures;if((Vp?.length!=pe.typed_length||$p?.length!=pe.structure_length)&&(pe.typed_length=Vp?.length,pe.structure_length=$p.length,_e.info?.(s,"send table struct",pe.typed_length,pe.structure_length),pe.sentName||(pe.sentName=!0),e.send((0,et.encode)([rA,{typedStructs:Vp,structures:$p,attributes:rt.attributes,schemaDefined:rt.schemaDefined},ue,pe.table.tableName]))),rr&&!Ht[rr]&&(e.send((0,et.encode)([Kv,kt,rr])),Ht[rr]=!0),fn)ui(fn.length),sc(fn);else{let Wi=x.encoded,Ql=Wi[0]===66?8:0;ui(Wi.length-Ql),sc(Wi,Ql)}},"sendAuditRecord"),De=a(()=>{e.send(o.subarray(i,c))},"sendQueuedData");Cs=new iA.EventEmitter,Cs.once("close",()=>{P=!0,C?.end()});for(let{startTime:x}of Ds)x<j&&(j=x);(O||Promise.resolve()).then(async()=>{h=await h,f=h.auditStore,Te=h.tableById.map(H),K=[];for(let{name:k,startTime:se}of Ds){let ue=QR(k,f);_e.info?.("subscription to",k,"using local id",ue,"starting",se),K[ue]=se}Ki(d),ee||(ee=Ra(k=>{k.databaseName===d&&Ki(d)}),Z=bd(k=>{k===d&&(e.send((0,et.encode)([Qc])),dn())}),e.on("close",()=>{ee?.remove(),Z?.remove()})),e.send((0,et.encode)([Yv,md(h.auditStore),Ds.map(({name:k})=>k)]));let x=!0;do{isFinite(j)||(_e.warn?.("Invalid sequence id "+j),dn(1008,"Invalid sequence id"+j));let k;if(x&&!P&&(x=!1,cA(f)>j&&server.nodes[0]===T)){let pe=j,rt=_h(f);for(let xe in p){let He=p[xe];for(let nt of He.primaryStore.getRange({snapshot:!1})){if(P)return;nt.localTime>=j&&(_e.info?.(s,"Copying record from",d,xe,nt.key,nt.localTime),pe=Math.max(nt.localTime,pe),k=!0,he({recordId:nt.key,tableId:He.tableId,type:"put",getValue(){return nt.value},encoded:He.primaryStore.getBinary(nt.key),version:nt.version,residencyId:nt.residencyId,nodeId:rt},nt.localTime))}}j=pe}for(let{key:ue,value:pe}of f.getRange({start:(j||1)+1/4096,snapshot:!1})){if(P)return;let rt=Lt(pe);he(rt,ue),e._socket.writableNeedDrain&&await new Promise(xe=>e._socket.once("drain",xe)),Cs.startTime=ue,k=!0}k&&he({type:"end_txn"},j);let se=lh.get(M);se||lh.set(M,se=[]),se.push(ue=>{}),await Bv(f)}while(!P)}).catch(x=>{_e.error?.(s,"Error handling subscription to node",x),dn(1008,"Error handling subscription to node")});break}return}me.position=8;let Je=!0,Ae;do{let Fe=me.readInt();if(Fe===9&&me.getUint8(me.position)==dh){me.position++,A=Ae=me.readFloat64(),_e.info?.("received remote sequence update",A,d);break}let tt=me.position,Ee=Lt(re.subarray(tt,tt+Fe)),Dt=le[Ee.tableId];Dt||_e.error?.(`No table found with an id of ${Ee.tableId}`);let q;Ee.residencyId&&(q=Bo[Ee.residencyId],_e.info?.(s,"received residency list",q,Ee.type,Ee.recordId));let m={table:Dt.name,id:Ee.recordId,type:Ee.type,nodeId:Ct.get(Ee.nodeId),residencyList:q,timestamp:Ee.version,value:Ee.getValue(Dt),user:Ee.user,beginTxn:Je,expiresAt:Ee.expiresAt};Je=!1,Ad&&_e.info?.(s,"received replication message",Ee.type,"id",m.id,"version",Ee.version,"nodeId",m.nodeId,"name",m.value?.name),h.send(m),me.position=tt+Fe}while(me.position<re.byteLength);Gr++,Gr>rc&&!$i&&($i=!0,e.pause()),h.send({type:"end_txn",localTime:A,remoteNodeIds:g,onCommit(){Gr--,$i&&($i=!1,e.resume()),!N&&Ae&&(_e.info?.(s,"queuing confirmation of a commit at",Ae),setTimeout(()=>{e.send((0,et.encode)([jv,N])),_e.info?.(s,"sent confirmation of a commit at",N),N=null},h7)),N=Ae}})}catch(me){_e.error?.(s,"Error handling incoming replication message",me)}}),e.on("ping",ne),e.on("pong",()=>{t.connection&&Sa({name:T,database:d,url:t.url,latency:performance.now()-$}),$=null}),e.on("close",(re,me)=>{clearInterval(v),clearTimeout(J),Cs&&Cs.emit("close"),Yi&&Yi.end();for(let[Je,{reject:Ae}]of S)Ae(new Error("Connection closed"));_e.info?.(s,"closed",re,me?.toString())});function Gp(){}a(Gp,"recordRemoteNodeSequence");function dn(re,me){e.isFinished=!0,e.close(re,me)}a(dn,"close");function r_(){if(_||(_=!0,t.connection?.on("subscriptions-updated",r_)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let re=new Map;try{for(let Ae of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let Fe of Ae.value.nodes||[])Fe.seqId>(re.get(Fe.id)??0)&&re.set(Fe.id,Fe.seqId)}catch(Ae){if(!Ae.message.includes("Can not re"))throw Ae}let me=t.connection?.nodeSubscriptions?.[0];g=[];let Je=t.connection?.nodeSubscriptions.map((Ae,Fe)=>{let tt=[],{replicateByDefault:Ee}=Ae;if(Ae.subscriptions){for(let R of Ae.subscriptions)if(R.subscribe&&(R.schema||R.database)===d){let w=R.table;p?.[w]?.replicate!==!1&&tt.push(w)}Ee=!1}else for(let R in p)(Ee?p[R].replicate===!1:p[R].replicate)&&tt.push(R);let Dt=f&&QR(Ae.name,f),q=h?.dbisDB?.get([Symbol.for("seq"),Dt])??1,m=q?.seqId??(typeof Ae.start_time=="string"?new Date(Ae.start_time).getTime():Ae.start_time)??1;if(me!==Ae){m>5e3&&(m-=5e3);for(let R of q?.nodes||[])R.name===Ae.name&&(m=R.seqId)}return g.push(Dt),re.get(Dt)>m&&(m=re.get(Dt)),{name:Ae.name,replicateByDefault:Ee,tables:tt,startTime:m}});_e.info?.(s,"sending subscription request",Je,h?.dbisDB?.path),Je&&(Je.length>0?e.send((0,et.encode)([Vv,Je])):dn(1008,"No nodes to subscribe to"))}a(r_,"sendSubscriptionRequestUpdate");function n_(re,me){if(!re)return;let Je=ye[re];return Je||(Je=me.getResidencyRecord(re),ye[re]=Je),Je}a(n_,"getResidence");function Wl(re){return!(To&&To!="*"&&!To[re]&&!To.includes?.(re)&&!To.some?.(me=>me.name===re))}a(Wl,"checkDatabaseAccess");function ve(re){if(h=h||u.get(re),!Wl(re))throw new Error(`Access to database "${re}" is not permitted`);h||_e.warn?.(`No database named "${re}" was declared and registered`),f=h?.auditStore,f||_e.warn?.("No audit store found in "+re+" creating it"),p||(p=ct()?.[re]);let me=ot();if(me===T)throw me?new Error("Should not connect to self",me):new Error("Node name not defined");return qp(me,re),!0}a(ve,"setDatabase");function qp(re,me){let Je=ct()?.[me],Ae=[];for(let Fe in Je){let tt=Je[Fe];Ae.push({table:Fe,schemaDefined:tt.schemaDefined,attributes:tt.attributes.map(Ee=>({name:Ee.name,type:Ee.type,isPrimaryKey:Ee.isPrimaryKey}))})}_e.trace?.("Sending database info for node",re,"database name",me),e.send((0,et.encode)([$v,re,me,Ae]))}a(qp,"sendNodeDBName");function Ki(re){let me=ct()?.[re],Je=[];for(let Ae in me){if(Ds&&!Ds.some(tt=>tt.replicateByDefault?!tt.tables.includes(Ae):tt.tables.includes(Ae)))continue;let Fe=me[Ae];Je.push({table:Ae,schemaDefined:Fe.schemaDefined,attributes:Fe.attributes.map(tt=>({name:tt.name,type:tt.type,isPrimaryKey:tt.isPrimaryKey}))})}e.send((0,et.encode)([Jv,Je,re]))}a(Ki,"sendDBSchema");let li=1,nc=[];return{end(){Yi&&Yi.end(),Cs&&Cs.emit("close")},getRecord(re){let me=li++;return new Promise((Je,Ae)=>{let Fe=[Wv,me,re.table.tableId,re.id];nc[re.table.tableId]||(Fe.push(re.table.tableName),nc[re.table.tableId]=!0),e.send((0,et.encode)(Fe)),S.set(me,{tableId:re.table.tableId,key:re.id,resolve(tt){let{table:Ee,entry:Dt}=re;Je(tt),tt&&Ee._recordRelocate(Dt,tt)},reject:Ae})})},sendOperation(re){let me=li++;return re.requestId=me,e.send((0,et.encode)([Qv,re])),new Promise((Je,Ae)=>{S.set(me,{resolve:Je,reject:Ae})})}};function ui(re){Ho(5),re<128?o[c++]=re:re<16384?(l.setUint16(c,re|32768),c+=2):re<1056964608?(l.setUint32(c,re|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,re),c+=5)}function sc(re,me=0,Je=re.length){let Ae=Je-me;Ho(Ae),re.copy(o,c,me,Je),c+=Ae}function Dr(re){Ho(8),l.setFloat64(c,re),c+=8}function Ho(re){if(re+16>o.length-c){let me=Buffer.allocUnsafeSlow(c+re-i+65536>>10<<11);o.copy(me,0,i,c),c=c-i,i=0,o=me,l=new DataView(o.buffer,0,o.length)}}}function sA(e,t){t||(t={});let r=!1,n=e.schemaDefined,s=t.attributes||[];for(let i=0;i<e.attributes?.length;i++){let o=e.attributes[i],c=s[i];(!c||c.name!==o.name||c.type!==o.type)&&(r=!0,n||(o.indexed=!0),s[i]=o)}return r?(_e.info?.("(Re)creating",e),dt({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:s,...t})):t}var e0,et,t0,r0,_e,iA,n0,s0,oA,i0,Vv,$v,Yv,Qc,Kv,rA,Wv,ah,Qv,ch,zv,jv,Jv,lh,Ta,Ad,Xv,h7,Zv,nA,uh,o0=Oe(()=>{Ne();Ei();zR();ZR();Oi();e0=U(ie());dc();et=require("msgpackr"),t0=require("ws"),r0=require("worker_threads"),_e=U(hd());Rd();iA=require("events"),n0=U(go()),s0=U(require("node:tls"));gd();oA=U(require("node:process")),i0=require("node:net"),Vv=129,$v=140,Yv=141,Qc=142,Kv=130,rA=132,Wv=133,ah=134,Qv=136,ch=137,zv=143,jv=144,Jv=145,lh=new Map,Ta=new Map,Ad=!0,Xv=300,h7=2,Zv=3e5;a(aA,"createWebSocket");uh=class extends iA.EventEmitter{constructor(r,n,s){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=Ws(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=2e3;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];replicateTablesByDefault;session;sessionResolve;sessionReject;nodeName;async connect(){this.session||this.resetSession();let r=[];this.socket=await aA(this.url,{serverName:this.nodeName});let n;_e.info?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${oA.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),_e.info?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=2e3,Sa({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=fh(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(_e.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?_e.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):_e.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(Wc({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();_e.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(fh,"replicateOverWS");a(sA,"ensureTableIfChanged")});var Od={};Ze(Od,{clearThisNodeName:()=>R7,disableReplication:()=>S7,enabled_databases:()=>To,forEachReplicatedDatabase:()=>po,getThisNodeId:()=>_h,getThisNodeName:()=>ot,getThisNodeUrl:()=>So,hostnameToUrl:()=>Sh,replication_certificate_authorities:()=>ga,sendOperationToNode:()=>ph,servers:()=>f0,setReplicator:()=>E0,start:()=>p7,startOnMainThread:()=>tA,subscribeToNode:()=>Kc,unsubscribeFromNode:()=>oh,urlToNodeName:()=>Ws});function p7(e){if(e.port||(e.port=Qs.default.get(yd.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=Qs.default.get(yd.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),!ot())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of sh(e))t.set(Ws(n.url),n);T7(e),e=Object.assign({subProtocol:"harperdb-replication-v1",mtls:!0,isOperationsServer:!0},e);let r=st.ws(async(n,s,i)=>{await i,n._socket.unref(),fh(n,e,s?.user),n.on("error",o=>{o.code!=="ECONNREFUSED"&&Rr.error("Error in connection to "+this.url,o.message)})},e);e.runFirst=!0,st.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&Rr.error(`Incoming client connection from ${n.ip} did not have valid certificate `,n._nodeRequest.socket.authorizationError);let i=Hr().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));c?n.user=c:Rr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:Rr.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(f0.push(n),n.secureContexts){let s=0,i=a(()=>{let o=new Set(n.secureContexts.values());n.defaultContext&&o.add(n.defaultContext);for(let c of o)try{let l=Array.from(ga);c.options.ca&&l.push(...c.options.ca);let d=Object.assign({},c.options,{ca:l});c.replicationContext=mh.createSecureContext(d)}catch(l){Rr.error("Error creating replication TLS config",l)}},"updateContexts");n.secureContextsListeners.push(i),Td(o=>{o?.ca&&(ga.add(o.ca),ga.size!==s&&(s=ga.size,i()))})}}function S7(e=!0){d0=e}function T7(e){d0||(ct(),To=e.databases,po(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||Ta;for(let[s,i]of hh){let o=i.get(r);o&&(o.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];E0(r,s,e),lh.get(s)?.forEach(i=>i(s))}}))}function E0(e,t,r){if(!t)return console.error(`Attempt to replicate non-existent table ${t.name} from database ${e}`);if(t.replicate===!1||t.sources?.some(s=>s.isReplicator))return;let n;t.sourcedFrom(class _0 extends pr{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||Ta,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(Rr.trace("Setting up replicator subscription to database",e,o&&Object.keys(o)),!o?.auditStore)return this.subscription=o=new Sn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l;for(let d of c)try{let u=Hr().primaryStore.get(d);if(u){let f=h0(u.url,_0.subscription,e),E={requestId:m7++,table:t,entry:i,id:i.key};return await f.getRecord(E)}}catch(u){Rr.warn("Error in load from node",d,u),l||(l=u)}if(l)throw l}}}static isReplicator=!0},{intermediateSource:!0})}function h0(e,t,r){let n=hh.get(e);n||hh.set(e,n=new Map);let s=n.get(r);if(s)return s;if(t)return n.set(r,s=new uh(e,t,r)),s.connect(),s.once("finished",()=>n.delete(r)),s}async function ph(e,t,r){r||(r={}),r.serverName=e.name;let n=await aA(e.url,r),s=fh(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{Rr.error("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function Kc(e){try{u0.isMainThread&&Rr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=Ta.get(e.database);if(!t){let n;t=new Promise(s=>{Rr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,Ta.set(e.database,t)}let r=h0(e.nodes[0].url,t,e.database);e.nodes[0].name===void 0&&(r.tentativeNode=e.nodes[0]),r.subscribe(e.nodes.filter(n=>nh(n,e.database)),e.replicateByDefault)}catch(t){Rr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function oh({url:e,database:t}){let r=hh.get(e);if(r){let n=r.get(t);n&&(n.unsubscribe(),r.delete(t))}}function g7(){if(lA!==void 0)return lA;let e=Qs.default.get(yd.CONFIG_PARAMS.OPERATIONSAPI_TLS_CERTIFICATE)||Qs.default.get(yd.CONFIG_PARAMS.TLS_CERTIFICATE);if(e)return lA=new c0.X509Certificate((0,l0.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function ot(){return uA||(uA=Qs.default.get("replication_hostname")??Ws(Qs.default.get("replication_url"))??g7()??a0("operationsapi_network_secureport")??a0("operationsapi_network_port")??"127.0.0.1")}function R7(){uA=void 0}function a0(e){let t=Qs.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function Eh(e){let t=Qs.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function _h(e){return md(e)?.[ot()]}function So(){let e=Qs.default.get("replication_url");return e||Sh(ot())}function Sh(e){let t=Eh("replication_port");if(t)return`ws://${e}:${t}`;if(t=Eh("replication_secureport"),t)return`wss://${e}:${t}`;if(t=Eh("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=Eh("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function Ws(e){if(e)return new URL(e).hostname}function po(e,t){for(let n of Object.getOwnPropertyNames(Ve))r(n);return bd(n=>{r(n)}),Ra((n,s)=>{r(n.databaseName)});function r(n){let s=Ve[n];Rr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):A7(n)&&t(s,n,!1)}a(r,"forDatabase")}function A7(e){let t=Ve[e];for(let r in t)if(t[r].replicate)return!0}var Qs,Rr,c0,l0,yd,mh,u0,d0,m7,f0,ga,To,hh,lA,uA,Oi=Oe(()=>{Ne();us();cc();o0();Lr();Qs=U(ie()),Rr=U(X()),c0=require("crypto"),l0=require("fs");Rd();gd();yd=U(B());zR();mh=U(require("node:tls")),u0=require("worker_threads"),m7=1,f0=[],ga=new Set(mh.rootCertificates);a(p7,"start");a(S7,"disableReplication");a(T7,"assignReplicationSource");a(E0,"setReplicator");hh=new Map;a(h0,"getConnection");a(ph,"sendOperationToNode");a(Kc,"subscribeToNode");a(oh,"unsubscribeFromNode");a(g7,"getCommonNameFromCert");a(ot,"getThisNodeName");a(R7,"clearThisNodeName");Object.defineProperty(st,"hostname",{get(){return ot()}});a(a0,"getHostFromListeningPort");a(Eh,"getPortFromListeningPort");a(_h,"getThisNodeId");st.replication={getThisNodeId:_h,exportIdMapping:md};a(So,"getThisNodeUrl");a(Sh,"hostnameToUrl");a(Ws,"urlToNodeName");a(po,"forEachReplicatedDatabase");a(A7,"hasExplicitlyReplicatedTable")});var go=I(H0=>{"use strict";var _r=require("path"),Kn=require("fs-extra"),Jc=require("node-forge"),R0=require("net"),{generateKeyPair:fA,X509Certificate:Ro,createPrivateKey:A0}=require("crypto"),b7=require("util");fA=b7.promisify(fA);var yt=Jc.pki,wi=require("joi"),{v4:y7}=require("uuid"),{validateBySchema:b0}=mt(),_t=X(),Ts=ie(),gs=B(),{CONFIG_PARAMS:Xc}=gs,zs=sS(),{ClientError:Nd}=ce(),ba=require("node:tls"),{relative:O7,join:N7}=require("node:path"),{CERT_PREFERENCE_APP:zTe,CERTIFICATE_VALUES:I7}=zs,w7=l_(),_A=dr(),m0=parseInt(process.version.slice(1))<20,{table:C7,getDatabases:D7,databases:dA}=(Ne(),ae(it));Object.assign(H0,{generateKeys:D0,updateConfigCert:M0,createCsr:H7,signCertificate:k7,setCertTable:Zc,loadCertificates:w0,reviewSelfSignedCert:P0,createTLSSelector:x0,listCertificates:B0,addCertificate:$7,removeCertificate:K7,createNatsCerts:q7,generateCertsKeys:G7,getReplicationCert:wd,getReplicationCertAuth:B7});var{urlToNodeName:y0,getThisNodeUrl:L7,getThisNodeName:gh,clearThisNodeName:P7}=(Oi(),ae(Od)),{readFileSync:M7,watchFile:U7,statSync:O0}=require("node:fs"),jTe=ie(),{getTicketKeys:v7,onMessageFromWorkers:x7}=at(),Aa=X(),{isMainThread:N0}=require("worker_threads"),{TLSSocket:I0,createSecureContext:JTe}=require("node:tls"),hA=3650,Id=["127.0.0.1","localhost","::1"],mA=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];x7(async e=>{e.type===gs.ITC_EVENT_TYPES.RESTART&&(Ts.initSync(!0),await P0())});var tn;function Oa(){return tn||(tn=D7().system.hdb_certificate,tn||(tn=C7({table:"hdb_certificate",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]}))),tn}a(Oa,"getCertTable");async function wd(){let e=x0("operations-api"),t={secureContexts:null,setSecureContext:s=>{}};await e.initialize(t);let r=t.secureContexts.get(gh());if(!r)return;let n=new Ro(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(wd,"getReplicationCert");async function B7(){Oa();let e=(await wd()).options.cert,r=new Ro(e).issuer.match(/CN=(.*)/)?.[1];return tn.get(r)}a(B7,"getReplicationCertAuth");var p0,ya=new Map;function w0(){if(p0)return;p0=!0;let e=[{configKey:Xc.TLS},{configKey:Xc.OPERATIONSAPI_TLS}];Oa();let t=_r.dirname(_A.getConfigFilePath()),r;for(let{configKey:n}of e){let s=_A.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&O7(N7(t,"keys"),o);c&&S0(o,l=>{ya.set(c,l)},"private key");for(let l of[!1,!0]){let d=i[l?"certificateAuthority":"certificate"];if(d&&N0){let u;S0(d,f=>{if(I7.cert===f)return;let E=i.hostname??i.hostnames??i.host??i.hosts;E&&!Array.isArray(E)&&(E=[E]);let _=U0(d),h=new Ro(_),p;try{p=SA(h)}catch(A){_t.error("error extracting common name from certificate",A);return}if(p==null){_t.error("error extracting common name from certificate");return}let S=tn.primaryStore.get(p),g=O0(d).mtimeMs,T=!S||S.is_self_signed?1:S.file_timestamp??S.__updatedtime__;if(S&&g<=T){g<T&&_t.info(`Certificate ${p} at ${d} is older (${new Date(g)}) than the certificate in the database (${T>1?new Date(T):"only self signed certificate available"})`);return}r=tn.put({name:p,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:_,private_key_name:c,is_authority:l,hostnames:E,file_timestamp:g,details:{issuer:h.issuer.replace(/\n/g," "),subject:h.subject.replace(/\n/g," "),subject_alt_name:h.subjectAltName,serial_number:h.serialNumber,valid_from:h.validFrom,valid_to:h.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(w0,"loadCertificates");function S0(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&N0&&_t.warn(`Reloading ${r}:`,e),n=c,t(U0(e)))}catch(c){_t.error(`Error loading ${r}:`,e,c)}},"loadFile");Kn.existsSync(e)?s(O0(e)):_t.error(`${r} file not found:`,e),U7(e,{persistent:!1},s)}a(S0,"loadAndWatch");function T0(){let e=L7();if(e==null){let t=Id[0];return _t.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return y0(e)}a(T0,"getHost");function Th(){let e=gh();if(e==null){let t=Id[0];return _t.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(Th,"getCommonName");async function H7(){let e=await wd(),t=yt.certificateFromPem(e.options.cert),r=yt.privateKeyFromPem(e.options.key);_t.info("Creating CSR with cert named:",e.name);let n=yt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:Th()},...mA];_t.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:C0()}];return _t.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),Jc.pki.certificationRequestToPem(n)}a(H7,"createCsr");function C0(){let e=Id.includes(Th())?Id:[...Id,Th()];return e.includes(T0())||e.push(T0()),[{name:"basicConstraints",cA:!1,critical:!0},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0,critical:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"nsCertType",client:!0,server:!0},{name:"subjectAltName",altNames:e.map(t=>R0.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(C0,"certExtensions");async function k7(e){let t={},r=_r.join(Ts.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;Oa();for await(let u of tn.search([]))if(u.is_authority&&!u.details.issuer.includes("HarperDB-Certificate-Authority")){if(ya.has(u.private_key_name)){n=ya.get(u.private_key_name),s=u;break}else if(u.private_key_name&&await Kn.exists(_r.join(r,u.private_key_name))){n=Kn.readFile(_r.join(r,u.private_key_name)),s=u;break}}if(!n){let u=await EA();s=u.ca,n=u.private_key}n=yt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=yt.certificateFromPem(s.certificate);_t.info("Signing CSR with cert named",s.name);let o=yt.certificationRequestFromPem(e.csr);try{o.verify()}catch(u){return _t.error(u),new Error("Error verifying CSR: "+u.message)}let c=Jc.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+hA),_t.info("sign cert setting validity:",c.validity),_t.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),_t.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let d=o.getAttribute({name:"extensionRequest"}).extensions;_t.info("sign cert adding extensions from CSR:",d),c.setExtensions(d),c.publicKey=o.publicKey,c.sign(n,Jc.md.sha256.create()),t.certificate=yt.certificateToPem(c)}else _t.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(k7,"signCertificate");async function F7(e,t){await Zc({name:gh(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await Zc({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:yt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(F7,"createCertificateTable");async function Zc(e){let t=new Ro(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},Oa(),await tn.patch(e)}a(Zc,"setCertTable");async function D0(){let e=await fA("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:yt.publicKeyFromPem(e.publicKey),private_key:yt.privateKeyFromPem(e.privateKey)}}a(D0,"generateKeys");async function pA(e,t,r){let n=yt.createCertificate();if(!t){let o=await wd();t=yt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+hA);let i=[{name:"commonName",value:Th()},...mA];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(C0()),n.sign(e,Jc.md.sha256.create()),yt.certificateToPem(n)}a(pA,"generateCertificates");async function EA(){let e=await B0(),t;for(let r of e){if(!r.is_authority)continue;let n=ya.get(r.private_key_name);if(r.private_key_name&&n){let s=new Ro(r.certificate).checkPrivateKey(A0(n));if(_t.trace(`CA named: ${r.name} found with matching private key`),s){t={ca:r,private_key:n};break}}}if(t)return t;_t.trace("No CA found with matching private key")}a(EA,"getCertAuthority");async function L0(e,t){let r=yt.createCertificate();r.publicKey=t,r.serialNumber=Math.random().toString().slice(2,10),r.validity.notBefore=new Date;let n=new Date;r.validity.notAfter=n,r.validity.notAfter.setDate(n.getDate()+hA);let s=[{name:"commonName",value:`HarperDB-Certificate-Authority-${Ts.get(Xc.REPLICATION_HOSTNAME)??y0(Ts.get(Xc.REPLICATION_URL))??y7().split("-")[0]}`},...mA];r.setSubject(s),r.setIssuer(s),r.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),r.sign(e,Jc.md.sha256.create());let i=_r.join(Ts.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME),o=_r.join(i,zs.PRIVATEKEY_PEM_NAME);return await Kn.writeFile(o,yt.privateKeyToPem(e)),r}a(L0,"generateCertAuthority");async function G7(){let{private_key:e,public_key:t}=await D0(),r=await L0(e,t),n=await pA(e,t,r);await F7(n,r),M0()}a(G7,"generateCertsKeys");async function q7(){let e=await pA(yt.privateKeyFromPem(zs.CERTIFICATE_VALUES.key),void 0,yt.certificateFromPem(zs.CERTIFICATE_VALUES.cert)),t=_r.join(Ts.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME),r=_r.join(t,zs.NATS_CERTIFICATE_PEM_NAME);await Kn.exists(r)||await Kn.writeFile(r,e);let n=_r.join(t,zs.NATS_CA_PEM_NAME);await Kn.exists(n)||await Kn.writeFile(n,zs.CERTIFICATE_VALUES.cert)}a(q7,"createNatsCerts");async function P0(){P7(),await w0(),Oa();let e,t=Ts.get(Xc.TLS_PRIVATEKEY),r=a(async()=>e||(e=yt.privateKeyFromPem(await Kn.readFile(t)),e),"getPrivateKey"),n,s=await EA();if(!s){n=!0,_t.info("No self signed Cert Authority found, generating new self signed CA"),await r();let o=await L0(e,yt.setRsaPublicKey(e.n,e.e));await Zc({name:o.subject.getField("CN").value,uses:["https","wss"],certificate:yt.certificateToPem(o),private_key_name:_r.basename(t),is_authority:!0,is_self_signed:!0})}if(!await wd()||n){let o=gh();_t.info(`A suitable replication certificate was not found, creating new self singed cert named: ${o}`),s=s??await EA();let c=yt.certificateFromPem(s.ca.certificate),l=c.publicKey,d=await pA(yt.privateKeyFromPem(s.private_key),l,c);await Zc({name:o,uses:["https","operations","wss"],certificate:d,is_authority:!1,private_key_name:s.ca.private_key_name})}}a(P0,"reviewSelfSignedCert");function M0(){let e=w7(Object.keys(gs.CONFIG_PARAM_MAP),!0),t=_r.join(Ts.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME),r=_r.join(t,zs.PRIVATEKEY_PEM_NAME),n=_r.join(t,zs.NATS_CERTIFICATE_PEM_NAME),s=_r.join(t,zs.NATS_CA_PEM_NAME),i=gs.CONFIG_PARAMS,o={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(o[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(o[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,o[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,o[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),_A.updateConfigValue(void 0,void 0,o,!1,!0)}a(M0,"updateConfigCert");function U0(e){return e.startsWith("-----BEGIN")?e:M7(e,"utf8")}a(U0,"readPEM");var g0=ba.createSecureContext;ba.createSecureContext=function(e){if(!e.cert||!e.key)return g0(e);let t={...e};delete t.key,delete t.cert;let r=g0(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var v0=ba.Server;ba.Server=function(e,t){return e.ALPNCallback&&(e.ALPNProtocols=null),v0.call(this,e,t)};ba.Server.prototype=v0.prototype;var V7=I0.prototype._init;I0.prototype._init=function(e,t){V7.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o.context||o,this.certCbDone()})}};var jc=new Map;function x0(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function d(){try{r.clear(),jc.clear();let u=0;for await(let f of dA.system.hdb_certificate.search([])){if(e!=="operations-api"&&f.uses?.includes?.("operations"))continue;let E=f.certificate,_=new Ro(E);f.is_authority&&(_.asString=E,jc.set(_.subject,E))}for await(let f of dA.system.hdb_certificate.search([]))try{if(f.is_authority||!(e==="operations-api")&&f.uses?.includes?.("operations"))continue;let _=f.is_self_signed?1:2,h=ya.get(f.private_key_name);!h&&f.private_key_name&&(h=await Kn.readFile(_r.join(Ts.get(Xc.ROOTPATH),gs.LICENSE_KEY_DIR_NAME,f.private_key_name)));let p=f.certificate,S=new Ro(p);if(jc.has(S.issuer)&&(p+=`
13
+ `+jc.get(S.issuer)),!h||!p)throw new Error("Missing private key or certificate for secure server");let g={ciphers:f.ciphers,ticketKeys:v7(),ca:t&&Array.from(jc.values()),cert:p,key:h,key_file:f.private_key_name,is_self_signed:f.is_self_signed};o&&(g.sessionIdContext=o.sessionIdContext);let T=ba.createSecureContext(g);T.name=f.name,T.options=g,T.quality=_,T.certificateAuthorities=Array.from(jc),T.certStart=p.toString().slice(0,100);let A=f.hostnames??(S.subjectAltName?S.subjectAltName.split(",").map(V=>{let v=V.indexOf(":");return V.slice(v+1)}):[SA(S)]);Array.isArray(A)||(A=[A]);let N;for(let V of A)if(V){V[0]==="*"&&(s=!0,V=V.slice(1)),R0.isIP(V)&&(N=!0);let v=r.get(V)?.quality??0;_>v&&r.set(V,T)}else Aa.error("No hostname found for certificate at",ba.certificate);_>u&&(i.defaultContext=n=T,u=_,o&&(o.defaultContext=T,Aa.trace("Applying default TLS",T.name,"for",o.ports,"cert named",f.name)))}catch(E){Aa.error("Error applying TLS for",f.name,E)}o?.secureContextsListeners.forEach(f=>f()),c(n)}catch(u){l(u)}}a(d,"updateTLS"),dA.system.hdb_certificate.subscribe({listener:d,omitCurrent:!0}),d()})),i;function i(o,c){Aa.info("TLS requested for",o,this.isReplicationConnection);let l=o;for(;;){let u=r.get(l);if(u)return Aa.debug("Found certificate for",o,u.certStart),u.replicationContext&&(this.isReplicationConnection||m0)&&(u=u.replicationContext),c(null,u);if(s&&l){let f=l.indexOf(".",1);f<0?l="":l=l.slice(f)}else break}o?Aa.debug("No certificate found to match",o,"using the default certificate"):Aa.debug("No SNI, using the default certificate");let d=n;d.replicationContext&&(this.isReplicationConnection||m0)&&(d=d.replicationContext),c(null,d)}a(i,"SNICallback")}a(x0,"createTLSSelector");async function B0(){Oa();let e=[];for await(let t of tn.search([]))e.push(t);return e}a(B0,"listCertificates");async function $7(e){let t=b0(e,wi.object({name:wi.string().required(),certificate:wi.string().required(),is_authority:wi.boolean().required(),private_key:wi.string(),hosts:wi.array(),uses:wi.array()}));if(t)throw new Nd(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new Ro(n),c=!1,l=!1,d;for(let[_,h]of ya)!s&&!c&&o.checkPrivateKey(A0(h))&&(c=!0,d=_),s&&s===h&&(l=!0,d=_);if(!i&&!s&&!c)throw new Nd("A suitable private key was not found for this certificate");let u;if(!r){try{u=SA(o)}catch(_){_t.error(_)}if(u==null)throw new Nd("Error extracting certificate common name, please provide a name parameter")}let f=Y7(r??u);s&&!c&&!l&&(await Kn.writeFile(_r.join(Ts.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME,f+".pem"),s),ya.set(f,s));let E={name:r??u,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&d||i&&s)&&(E.private_key_name=d??f+".pem"),await Zc(E),"Successfully added certificate: "+f}a($7,"addCertificate");function Y7(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(Y7,"sanitizeName");async function K7(e){let t=b0(e,wi.object({name:wi.string().required()}));if(t)throw new Nd(t.message);let{name:r}=e;Oa();let n=await tn.get(r);if(!n)throw new Nd(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await tn.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(_t.info("Removing private key named",s),await Kn.remove(_r.join(Ts.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME,s)))}return await tn.delete(r),"Successfully removed "+r}a(K7,"removeCertificate");function SA(e){return e.subject.match(/CN=(.*)/)?.[1]}a(SA,"extractCommonName")});var Na={};Ze(Na,{addNodeBack:()=>J7,removeNodeBack:()=>X7,setNode:()=>j7});async function j7(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=Ws(t)):t=Sh(r);let n=(0,F0.validateBySchema)(e,z7);if(n)throw(0,js.handleHDBError)(n,n.message,Q7.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new js.ClientError("url or hostname is required for remove_node operation");let f=r,E=Hr(),_=await E.get(f);if(!_)throw new js.ClientError(f+" does not exist");try{await ph({url:_.url},{operation:Cd.OPERATIONS_ENUM.REMOVE_NODE_BACK,name:_?.subscriptions?.length>0?ot():f},void 0)}catch(h){Wn.warn(`Error removing node from target node ${f}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,h)}return await E.delete(f),`Successfully removed '${f}' from cluster`}if(!t)throw new js.ClientError("url required for this operation");let s=So();if(s==null)throw new js.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){if(e.operation==="add_node"&&!e.authorization)throw new js.ClientError("authorization parameter is required");i=await(0,Qn.getReplicationCert)();let f=await(0,Qn.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,Qn.createCsr)(),Wn.info("Sending CSR to target node:",t)):(c=f?.certificate,Wn.info("Sending CA named",f?.name,"to target node",t))}let l={operation:Cd.OPERATIONS_ENUM.ADD_NODE_BACK,hostname:(0,G0.get)(Cd.CONFIG_PARAMS.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c};if(e.subscriptions&&(l.subscriptions=e.subscriptions.map(k0)),e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let f=k0(e);l.subscribe=f.subscribe,l.publish=f.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let d;try{d=await ph({url:t},l,e)}catch(f){throw f.message=`Error returned from ${t}: `+f.message,f}if(o&&(!d?.certificate||!d?.certificate?.includes?.("BEGIN CERTIFICATE")))throw new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(d)}`);o&&(Wn.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,Qn.setCertTable)({name:W7.certificateFromPem(d.signingCA).issuer.getField("CN").value,certificate:d.signingCA,is_authority:!0}),d.certificate&&await(0,Qn.setCertTable)({name:ot(),uses:["https","operations","wss"],certificate:d.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=d.signingCA);let u={url:t,ca:d.usingCA};if(e.hostname&&(u.name=e.hostname),e.subscriptions?u.subscriptions=e.subscriptions:u.replicates=!0,e.start_time&&(u.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),u.replicates){let f={url:s,ca:c,replicates:!0};e.start_time&&(f.start_time=e.start_time),await Ii(ot(),f)}return await Ii(d.nodeName,u),e.operation==="update_node"?`Successfully updated '${t}'`:`Successfully added '${t}' to cluster`}async function J7(e){Wn.trace("addNodeBack received request:",e);let t=await(0,Qn.signCertificate)(e),r;e.csr?(r=t.signingCA,Wn.info("addNodeBack received CSR from node:",e.url,"this node will use and respond with CA that was used to issue CSR")):(r=e?.cert_auth,Wn.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:n.replicates=!0,e.start_time&&(n.start_time=e.start_time);let s=await(0,Qn.getReplicationCertAuth)();if(n.replicates){let i={url:So(),ca:s?.certificate,replicates:!0};e.start_time&&(i.start_time=e.start_time),await Ii(ot(),i)}return await Ii(e.hostname,n),t.nodeName=ot(),t.usingCA=s?.certificate,Wn.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function X7(e){Wn.trace("removeNodeBack received request:",e),await Hr().delete(e.name)}function k0(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var Qn,F0,el,G0,Cd,Wn,js,W7,Q7,z7,Ia=Oe(()=>{Qn=U(go()),F0=U(mt()),el=U(require("joi")),G0=U(ie()),Cd=U(B());Rd();gd();Oi();Wn=U(X()),js=U(ce()),{pki:W7}=require("node-forge"),{HTTP_STATUS_CODES:Q7}=js.hdb_errors,z7=el.default.object({hostname:el.default.string(),verify_tls:el.default.boolean(),replicates:el.default.boolean(),subscriptions:el.default.array()});a(j7,"setNode");a(J7,"addNodeBack");a(X7,"removeNodeBack");a(k0,"reverseSubscription")});var Oh=I((oge,V0)=>{"use strict";var{handleHDBError:Rh,hdb_errors:Z7}=ce(),{HTTP_STATUS_CODES:Ah}=Z7,{addUpdateNodeValidator:eee}=$E(),bh=X(),yh=B(),q0=Pt(),tee=te(),Dd=jt(),Ld=yi(),TA=ie(),ree=KR(),{Node:nee,NodeSubscription:see}=Fc(),{broadcast:iee}=at(),{setNode:oee}=(Ia(),ae(Na)),sge=ie(),ige=B(),aee="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",cee="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",lee=TA.get(yh.CONFIG_PARAMS.CLUSTERING_NODENAME);V0.exports=uee;async function uee(e,t=!1){if(bh.trace("addNode called with:",e),TA.get(yh.CONFIG_PARAMS.REPLICATION_URL)||TA.get(yh.CONFIG_PARAMS.REPLICATION_HOSTNAME))return oee(e);Ld.checkClusteringEnabled();let r=eee(e);if(r)throw Rh(r,r.message,Ah.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let f=await Ld.getNodeRecord(n);if(!tee.isEmptyOrZeroLength(f))throw Rh(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,Ah.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await ree(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=aee,o;let c=Ld.buildNodePayloads(s,lee,yh.OPERATIONS_ENUM.ADD_NODE,await Ld.getSystemInfo()),l=[];for(let f=0,E=s.length;f<E;f++){let _=s[f];s[f].start_time===void 0&&delete s[f].start_time,l.push(new see(_.schema,_.table,_.publish,_.subscribe))}bh.trace("addNode sending remote payload:",c);let d;try{d=await Dd.request(`${n}.${q0.REQUEST_SUFFIX}`,c)}catch(f){bh.error(`addNode received error from request: ${f}`);for(let _=0,h=s.length;_<h;_++){let p=s[_];p.publish=!1,p.subscribe=!1,await Dd.updateRemoteConsumer(p,n)}let E=Dd.requestErrorHandler(f,"add_node",n);throw Rh(new Error,E,Ah.INTERNAL_SERVER_ERROR,"error",E)}if(d.status===q0.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let f=`Error returned from remote node ${n}: ${d.message}`;throw Rh(new Error,f,Ah.INTERNAL_SERVER_ERROR,"error",f)}bh.trace(d);for(let f=0,E=s.length;f<E;f++){let _=s[f];await Dd.updateRemoteConsumer(_,n),_.subscribe===!0&&await Dd.updateConsumerIterator(_.schema,_.table,n,"start")}let u=new nee(n,l,d.system_info);return await Ld.upsertNodeRecord(u),iee({type:"nats_update"}),i.length>0?o.message=cee:o.message=`Successfully added '${n}' to manifest`,o}a(uee,"addNode")});var bA=I((lge,Y0)=>{"use strict";var{handleHDBError:gA,hdb_errors:dee}=ce(),{HTTP_STATUS_CODES:RA}=dee,{addUpdateNodeValidator:fee}=$E(),Pd=X(),Nh=B(),$0=Pt(),cge=te(),Md=jt(),Ud=yi(),AA=ie(),{cloneDeep:_ee}=require("lodash"),Eee=KR(),{Node:hee,NodeSubscription:mee}=Fc(),{broadcast:pee}=at(),{setNode:See}=(Ia(),ae(Na)),Tee="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",gee="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Ree=AA.get(Nh.CONFIG_PARAMS.CLUSTERING_NODENAME);Y0.exports=Aee;async function Aee(e){if(Pd.trace("updateNode called with:",e),AA.get(Nh.CONFIG_PARAMS.REPLICATION_URL)??AA.get(Nh.CONFIG_PARAMS.REPLICATION_HOSTNAME))return See(e);Ud.checkClusteringEnabled();let t=fee(e);if(t)throw gA(t,t.message,RA.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Ud.getNodeRecord(r);s.length>0&&(n=_ee(s));let{added:i,skipped:o}=await Eee(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=Tee,c;let l=Ud.buildNodePayloads(i,Ree,Nh.OPERATIONS_ENUM.UPDATE_NODE,await Ud.getSystemInfo());for(let u=0,f=i.length;u<f;u++){let E=i[u];Pd.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[u].start_time===void 0&&delete i[u].start_time}Pd.trace("updateNode sending remote payload:",l);let d;try{d=await Md.request(`${r}.${$0.REQUEST_SUFFIX}`,l)}catch(u){Pd.error(`updateNode received error from request: ${u}`);let f=Md.requestErrorHandler(u,"update_node",r);throw gA(new Error,f,RA.INTERNAL_SERVER_ERROR,"error",f)}if(d.status===$0.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let u=`Error returned from remote node ${r}: ${d.message}`;throw gA(new Error,u,RA.INTERNAL_SERVER_ERROR,"error",u)}Pd.trace(d);for(let u=0,f=i.length;u<f;u++){let E=i[u];await Md.updateRemoteConsumer(E,r),E.subscribe===!0?await Md.updateConsumerIterator(E.schema,E.table,r,"start"):await Md.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new hee(r,[],d.system_info)]),await bee(n[0],i,d.system_info),o.length>0?c.message=gee:c.message=`Successfully updated '${r}'`,c}a(Aee,"updateNode");async function bee(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,d=e.subscriptions.length;l<d;l++){let u=n.subscriptions[l];if(u.schema===o.schema&&u.table===o.table){u.publish=o.publish,u.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new mee(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Ud.upsertNodeRecord(n),pee({type:"nats_update"})}a(bee,"updateNodeTable")});var j0=I((dge,z0)=>{"use strict";var Q0=require("joi"),{string:K0}=Q0.types(),yee=mt(),W0=B(),Oee=ie(),Nee=Pt();z0.exports=Iee;function Iee(e){let t=K0.invalid(Oee.get(W0.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Nee.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=Q0.object({operation:K0.valid(W0.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return yee.validateBySchema(e,r)}a(Iee,"removeNodeValidator")});var Ih=I((_ge,tx)=>{"use strict";var{handleHDBError:J0,hdb_errors:wee}=ce(),{HTTP_STATUS_CODES:X0}=wee,Cee=j0(),vd=X(),Z0=yi(),Dee=te(),tl=B(),ex=Pt(),yA=jt(),OA=ie(),{RemotePayloadObject:Lee}=Ed(),{NodeSubscription:Pee}=Fc(),Mee=Vu(),Uee=ea(),{broadcast:vee}=at(),{setNode:xee}=(Ia(),ae(Na)),Bee=OA.get(tl.CONFIG_PARAMS.CLUSTERING_NODENAME);tx.exports=Hee;async function Hee(e){if(vd.trace("removeNode called with:",e),OA.get(tl.CONFIG_PARAMS.REPLICATION_URL)??OA.get(tl.CONFIG_PARAMS.REPLICATION_HOSTNAME))return xee(e);Z0.checkClusteringEnabled();let t=Cee(e);if(t)throw J0(t,t.message,X0.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await Z0.getNodeRecord(r);if(Dee.isEmptyOrZeroLength(n))throw J0(new Error,`Node '${r}' was not found.`,X0.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Lee(tl.OPERATIONS_ENUM.REMOVE_NODE,Bee,[]),i,o=!1;for(let l=0,d=n.subscriptions.length;l<d;l++){let u=n.subscriptions[l];u.subscribe===!0&&await yA.updateConsumerIterator(u.schema,u.table,r,"stop");try{await yA.updateRemoteConsumer(new Pee(u.schema,u.table,!1,!1),r)}catch(f){vd.error(f)}}try{i=await yA.request(`${r}.${ex.REQUEST_SUFFIX}`,s),vd.trace("Remove node reply from remote node:",r,i)}catch(l){vd.error("removeNode received error from request:",l),o=!0}let c=new Mee(tl.SYSTEM_SCHEMA_NAME,tl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Uee.deleteRecord(c),vee({type:"nats_update"}),i?.status===ex.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(vd.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(Hee,"removeNode")});var sx=I((hge,nx)=>{"use strict";var rx=require("joi"),{string:kee,array:Fee}=rx.types(),Gee=mt(),qee=$E();nx.exports=Vee;function Vee(e){let t=rx.object({operation:kee.valid("configure_cluster").required(),connections:Fee.items(qee.validation_schema).required()});return Gee.validateBySchema(e,t)}a(Vee,"configureClusterValidator")});var NA=I((pge,lx)=>{"use strict";var ix=B(),wh=X(),$ee=te(),Yee=ie(),Kee=Ih(),Wee=Oh(),Qee=yi(),zee=sx(),{handleHDBError:ox,hdb_errors:jee}=ce(),{HTTP_STATUS_CODES:ax}=jee,Jee="Configure cluster complete.",Xee="Failed to configure the cluster. Check the logs for more details.",Zee="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";lx.exports=ete;async function ete(e){wh.trace("configure cluster called with:",e);let t=zee(e);if(t)throw ox(t,t.message,ax.BAD_REQUEST,void 0,void 0,!0);let r=await Qee.getAllNodeRecords(),n=[];if(Yee.get(ix.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let u=0,f=r.length;u<f;u++){let E=await cx(Kee,{operation:ix.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[u].name},r[u].name);n.push(E)}wh.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let u=0;u<i;u++){let f=e.connections[u],E=await cx(Wee,f,f.node_name);s.push(E)}wh.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,d=n.concat(s);for(let u=0,f=d.length;u<f;u++){let E=d[u];E.status==="rejected"&&(wh.error(E.node_name,E?.error?.message,E?.error?.stack),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(l=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,response:E?.result})}if($ee.isEmptyOrZeroLength(o))return{message:Jee,connections:c};if(l)return{message:Zee,failed_nodes:o,connections:c};throw ox(new Error,Xee,ax.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(ete,"configureCluster");async function cx(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(cx,"functionWrapper")});var _x=I((Tge,fx)=>{"use strict";var xd=require("joi"),tte=mt(),{validateSchemaExists:ux,validateTableExists:rte,validateSchemaName:dx}=Bs(),nte=xd.object({operation:xd.string().valid("purge_stream"),schema:xd.string().custom(ux).custom(dx).optional(),database:xd.string().custom(ux).custom(dx).optional(),table:xd.string().custom(rte).required()});function ste(e){return tte.validateBySchema(e,nte)}a(ste,"purgeStreamValidator");fx.exports=ste});var IA=I((Rge,Ex)=>{"use strict";var{handleHDBError:ite,hdb_errors:ote}=ce(),{HTTP_STATUS_CODES:ate}=ote,cte=_x(),lte=jt(),ute=yi();Ex.exports=dte;async function dte(e){e.schema=e.schema??e.database;let t=cte(e);if(t)throw ite(t,t.message,ate.BAD_REQUEST,void 0,void 0,!0);ute.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await lte.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(dte,"purgeStream")});var DA=I((bge,Rx)=>{"use strict";var CA=yi(),fte=jt(),Ch=ie(),rl=B(),wa=Pt(),_te=te(),wA=X(),{RemotePayloadObject:Ete}=Ed(),{ErrorCode:hx}=require("nats"),{parentPort:mx}=require("worker_threads"),{onMessageByType:hte}=at(),{getThisNodeName:mte}=(Oi(),ae(Od)),{requestClusterStatus:pte}=(Rd(),ae(qv)),px=Ch.get(rl.CONFIG_PARAMS.CLUSTERING_ENABLED),Sx=Ch.get(rl.CONFIG_PARAMS.CLUSTERING_NODENAME);Rx.exports={clusterStatus:Ste,buildNodeStatus:gx};var Tx;hte("cluster-status",async e=>{Tx(e)});async function Ste(){if(Ch.get(rl.CONFIG_PARAMS.REPLICATION_URL)||Ch.get(rl.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;return mx?(mx.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{Tx=s})):n=await pte(),n.node_name=mte(),n.is_enabled=!0,n}let e={node_name:Sx,is_enabled:px,connections:[]};if(!px)return e;let t=await CA.getAllNodeRecords();if(_te.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(gx(t[n],e.connections));return await Promise.allSettled(r),e}a(Ste,"clusterStatus");async function gx(e,t){let r=e.name,n=new Ete(rl.OPERATIONS_ENUM.CLUSTER_STATUS,Sx,void 0,await CA.getSystemInfo()),s,i,o=wa.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await fte.request(wa.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===wa.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=wa.CLUSTER_STATUS_STATUSES.CLOSED,wA.error(`Error getting node status from ${r} `,s))}catch(l){wA.warn(`Error getting node status from ${r}`,l),l.code===hx.NoResponders?o=wa.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===hx.Timeout?o=wa.CLUSTER_STATUS_STATUSES.TIMEOUT:o=wa.CLUSTER_STATUS_STATUSES.CLOSED}let c=new Tte(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==rl.PRE_4_0_0_VERSION&&await CA.upsertNodeRecord(l)}catch(l){wA.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(gx,"buildNodeStatus");function Tte(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(Tte,"NodeStatusObject")});var PA=I((Oge,Ax)=>{"use strict";var{handleHDBError:gte,hdb_errors:Rte}=ce(),{HTTP_STATUS_CODES:Ate}=Rte,bte=jt(),yte=yi(),LA=te(),Dh=require("joi"),Ote=mt(),Nte=2e3,Ite=Dh.object({timeout:Dh.number().min(1),connected_nodes:Dh.boolean(),routes:Dh.boolean()});Ax.exports=wte;async function wte(e){yte.checkClusteringEnabled();let t=Ote.validateBySchema(e,Ite);if(t)throw gte(t,t.message,Ate.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||LA.autoCastBoolean(n),o=s===void 0||LA.autoCastBoolean(s),c={nodes:[]},l=await bte.getServerList(r??Nte),d={};if(i)for(let u=0,f=l.length;u<f;u++){let E=l[u].statsz;E&&(d[l[u].server.name]=E.routes)}for(let u=0,f=l.length;u<f;u++){if(l[u].statsz)continue;let E=l[u].server,_=l[u].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:l[u].response_time};i&&(h.connected_nodes=[],d[E.name]&&d[E.name].forEach(p=>{h.connected_nodes.includes(p.name.slice(0,-4))||h.connected_nodes.push(p.name.slice(0,-4))})),o&&(h.routes=_.cluster?.urls?_.cluster?.urls.map(p=>({host:p.split(":")[0],port:LA.autoCast(p.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(wte,"clusterNetwork")});var Nx=I((Ige,Ox)=>{"use strict";var MA=require("joi"),bx=mt(),{route_constraints:yx}=oS();Ox.exports={setRoutesValidator:Cte,deleteRoutesValidator:Dte};function Cte(e){let t=MA.object({server:MA.valid("hub","leaf"),routes:yx.required()});return bx.validateBySchema(e,t)}a(Cte,"setRoutesValidator");function Dte(e){let t=MA.object({routes:yx.required()});return bx.validateBySchema(e,t)}a(Dte,"deleteRoutesValidator")});var vA=I((Cge,Mx)=>{"use strict";var Ci=dr(),UA=te(),zn=B(),nl=ie(),Ix=Nx(),{handleHDBError:wx,hdb_errors:Lte}=ce(),{HTTP_STATUS_CODES:Cx}=Lte,Dx="cluster routes successfully set",Lx="cluster routes successfully deleted";Mx.exports={setRoutes:Mte,getRoutes:Ute,deleteRoutes:vte};function Pte(e){let t=Ci.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=UA.autoCast(l.port);let d=r.some(f=>f.host===l.host&&f.port===l.port),u=n.some(f=>f.host===l.host&&f.port===l.port);d||u?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?Ci.updateConfigValue(zn.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):Ci.updateConfigValue(zn.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:Dx,set:i,skipped:s}}a(Pte,"setRoutesNats");function Mte(e){let t=Ix.setRoutesValidator(e);if(t)throw wx(t,t.message,Cx.BAD_REQUEST,void 0,void 0,!0);if(nl.get(zn.CONFIG_PARAMS.CLUSTERING_ENABLED))return Pte(e);let r=[],n=[],s=nl.get(zn.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Px(s,i)?n.push(i):(s.push(i),r.push(i))}),Ci.updateConfigValue(zn.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:Dx,set:r,skipped:n}}a(Mte,"setRoutes");function Px(e,t){return typeof t=="string"?e.includes(t):typeof t=="object"&&t!==null?e.some(r=>(r.host===t.host||r.hostname===t.hostname)&&r.port===t.port):!1}a(Px,"existsInArray");function Ute(){if(nl.get(zn.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=Ci.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return nl.get(zn.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Ute,"getRoutes");function vte(e){let t=Ix.deleteRoutesValidator(e);if(t)throw wx(t,t.message,Cx.BAD_REQUEST,void 0,void 0,!0);if(nl.get(zn.CONFIG_PARAMS.CLUSTERING_ENABLED))return xte(e);let r=[],n=[],s=nl.get(zn.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Px(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),Ci.updateConfigValue(zn.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Lx,deleted:r,skipped:n}}a(vte,"deleteRoutes");function xte(e){let t=Ci.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,d=e.routes.length;l<d;l++){let u=e.routes[l],f=!1;for(let E=0,_=r.length;E<_;E++){let h=r[E];if(u.host===h.host&&u.port===h.port){r.splice(E,1),f=!0,o=!0,s.push(u);break}}if(!f){let E=!0;for(let _=0,h=n.length;_<h;_++){let p=n[_];if(u.host===p.host&&u.port===p.port){n.splice(_,1),c=!0,E=!1,s.push(u);break}}E&&i.push(u)}}return o&&(r=UA.isEmptyOrZeroLength(r)?null:r,Ci.updateConfigValue(zn.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=UA.isEmptyOrZeroLength(n)?null:n,Ci.updateConfigValue(zn.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Lx,deleted:s,skipped:i}}a(xte,"deleteRoutesNats")});var vx=I((Lge,Ux)=>{"use strict";var Bd=require("alasql"),Ca=require("recursive-iterator"),Rs=X(),Bte=te(),Hd=B(),xA=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,kte(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=>Hd.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=>!Hd.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][Hd.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=Hte(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(d=>({attribute_name:d.attribute}));let l=this.affected_attributes.get(i).get(o).filter(d=>!Hd.SEARCH_WILDCARDS.includes(d));c.forEach(({attribute_name:d})=>{let u=new Bd.yy.Column({columnid:d});s.tableid&&(u.tableid=s.tableid),this.ast.columns.push(u),l.includes(d)||l.push(d)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function Hte(e){return e.filter(t=>t[Hd.PERMS_CRUD_ENUM.READ])}a(Hte,"filterReadRestrictedAttrs");function kte(e,t,r,n,s){Fte(e,t,r,n,s)}a(kte,"interpretAST");function kd(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(kd,"addSchemaTableToMap");function Fte(e,t,r,n,s){if(!e){Rs.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Bd.yy.Insert?$te(e,t,r):e instanceof Bd.yy.Select?Gte(e,t,r,n,s):e instanceof Bd.yy.Update?qte(e,t,r):e instanceof Bd.yy.Delete?Vte(e,t,r):Rs.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(Fte,"getRecordAttributesAST");function Gte(e,t,r,n,s){if(!e){Rs.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Bte.isEmptyOrZeroLength(i)){Rs.error("No schema specified");return}e.from.forEach(c=>{kd(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),kd(c.table,t,r,n,s)});let o=new Ca(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,d=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(d).has(l))if(r.has(l))l=r.get(l);else{Rs.info(`table specified as ${l} not found.`);return}t.get(d).get(l).indexOf(c.columnid)<0&&t.get(d).get(l).push(c.columnid)}if(e.where){let c=new Ca(e.where),l=e.from[0].tableid;for(let{node:d}of c)if(d&&d.columnid){let u=d.tableid?d.tableid:l;if(!t.get(i).has(u))if(r.has(u))u=r.get(u);else{Rs.info(`table specified as ${u} not found.`);continue}t.get(i).get(u).indexOf(d.columnid)<0&&t.get(i).get(u).push(d.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Ca(c.on);for(let{node:d}of l)if(d&&d.columnid){let u=d.tableid,f=s.get(u);if(!t.get(f).has(u))if(r.has(u))u=r.get(u);else{Rs.info(`table specified as ${u} not found.`);continue}t.get(f).get(u).indexOf(d.columnid)<0&&t.get(f).get(u).push(d.columnid)}}),e.order){let c=new Ca(e.order);for(let{node:l}of c)if(l&&l.columnid){let d=l.tableid,u=n.has(d)?n.get(d):i;if(d||(d=e.from[0].tableid),!t.get(u).has(d))if(r.has(d))d=r.get(d);else{Rs.info(`table specified as ${d} not found.`);return}t.get(u).get(d).indexOf(l.columnid)<0&&t.get(u).get(d).push(l.columnid)}}}a(Gte,"getSelectAttributes");function qte(e,t,r){if(!e){Rs.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Ca(e.columns),s=e.table.databaseid;kd(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&BA(e.table.tableid,s,i.columnid,t,r)}a(qte,"getUpdateAttributes");function Vte(e,t,r){if(!e){Rs.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Ca(e.where),s=e.table.databaseid;kd(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&BA(e.table.tableid,s,i.columnid,t,r)}a(Vte,"getDeleteAttributes");function $te(e,t,r){if(!e){Rs.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Ca(e.columns),s=e.into.databaseid;kd(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&BA(e.into.tableid,s,i.columnid,t,r)}a($te,"getInsertAttributes");function BA(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(BA,"pushAttribute");Ux.exports=xA});var FA=I((Mge,kx)=>{var Lh=ta(),xx=require("chalk"),Cn=X(),Bx=require("prompt"),{promisify:Yte}=require("util"),HA=B(),Kte=require("fs-extra"),Wte=require("path"),Qte=te(),zte=JE(),Hx=ie();Hx.initSync();var jte=require("moment"),Jte=Yte(Bx.get),Xte=Wte.join(Hx.getHdbBasePath(),HA.LICENSE_KEY_DIR_NAME,HA.LICENSE_FILE_NAME,HA.LICENSE_FILE_NAME);kx.exports={getFingerprint:ere,setLicense:Zte,parseLicense:kA,register:tre,getRegistrationInfo:nre};async function Zte(e){if(e&&e.key&&e.company){try{Cn.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await kA(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Cn.error(r),Cn.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(Zte,"setLicense");async function ere(){let e={};try{e=await Lh.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Cn.error(r),Cn.error(t),new Error(r)}return e}a(ere,"getFingerprint");async function kA(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Cn.info("Validating license input...");let r=Lh.validateLicense(e,t);if(Cn.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Cn.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Cn.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Cn.info("writing license to disk"),await Kte.writeFile(Xte,JSON.stringify({license_key:e,company:t}))}catch(n){throw Cn.error("Failed to write License"),n}return"Registration successful."}a(kA,"parseLicense");async function tre(){let e=await rre();return kA(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(tre,"register");async function rre(){let e=await Lh.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:xx.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:xx.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{Bx.start()}catch(n){Cn.error(n)}let r;try{r=await Jte(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(rre,"promptForRegistration");async function nre(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await Lh.getLicense()}catch(r){throw Cn.error(`There was an error when searching licenses due to: ${r.message}`),r}if(Qte.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=zte.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=jte.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(nre,"getRegistrationInfo")});var Gx=I((vge,Fx)=>{"use strict";var sre=Pt(),GA=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,d,u,f,E,_,h){this.port=t,o===null&&(o=void 0),this.server_name=r+sre.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:d,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:u,port:f,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:_},HDB:{users:h}},this.system_account="SYS"}};Fx.exports=GA});var $x=I((Bge,Vx)=>{"use strict";var qx=Pt(),qA=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,d,u,f){this.port=t,f===null&&(f=void 0),this.server_name=r+qx.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+qx.SERVER_SUFFIX.LEAF},this.tls={cert_file:d,key_file:u,ca_file:f,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:f,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:f,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};Vx.exports=qA});var Kx=I((kge,Yx)=>{"use strict";var VA=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};Yx.exports=VA});var Qx=I((Gge,Wx)=>{"use strict";var ire=Pt(),$A=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+ire.SERVER_SUFFIX.ADMIN,this.password=r}};Wx.exports=$A});var WA=I((Vge,Jx)=>{"use strict";var sl=require("path"),il=require("fs-extra"),ore=Gx(),are=$x(),cre=Kx(),lre=Qx(),YA=yn(),al=te(),rn=dr(),Mh=B(),Fd=Pt(),{CONFIG_PARAMS:Vt}=Mh,cl=X(),Gd=ie(),zx=pi(),KA=jt(),ure=go(),ol="clustering",dre=1e4,jx=50;Jx.exports={generateNatsConfig:_re,removeNatsConfig:Ere,getHubConfigPath:fre};function fre(){let e=Gd.get(Vt.ROOTPATH);return sl.join(e,ol,Fd.NATS_CONFIG_FILES.HUB_SERVER)}a(fre,"getHubConfigPath");async function _re(e=!1,t=void 0){Gd.initSync();let r=rn.getConfigFromFile(Vt.CLUSTERING_TLS_CERT_AUTH),n=rn.getConfigFromFile(Vt.CLUSTERING_TLS_PRIVATEKEY),s=rn.getConfigFromFile(Vt.CLUSTERING_TLS_CERTIFICATE);!await il.exists(s)&&!await il.exists(!r)&&await ure.createNatsCerts();let i=Gd.get(Vt.ROOTPATH),o=sl.join(i,ol,Fd.PID_FILES.HUB),c=sl.join(i,ol,Fd.PID_FILES.LEAF),l=rn.getConfigFromFile(Vt.CLUSTERING_LEAFSERVER_STREAMS_PATH),d=sl.join(i,ol,Fd.NATS_CONFIG_FILES.HUB_SERVER),u=sl.join(i,ol,Fd.NATS_CONFIG_FILES.LEAF_SERVER),f=rn.getConfigFromFile(Vt.CLUSTERING_TLS_INSECURE),E=rn.getConfigFromFile(Vt.CLUSTERING_TLS_VERIFY),_=rn.getConfigFromFile(Vt.CLUSTERING_NODENAME),h=rn.getConfigFromFile(Vt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await KA.checkNATSServerInstalled()||Uh("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let p=await YA.listUsers(),S=rn.getConfigFromFile(Vt.CLUSTERING_USER),g=await YA.getClusterUser();(al.isEmpty(g)||g.active!==!0)&&Uh(`Invalid cluster user '${S}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Ph(Vt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Ph(Vt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Ph(Vt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Ph(Vt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let T=[],A=[];for(let[ne,ee]of p.entries())ee.role.role===Mh.ROLE_TYPES_ENUM.CLUSTER_USER&&ee.active&&(T.push(new lre(ee.username,zx.decrypt(ee.hash))),A.push(new cre(ee.username,zx.decrypt(ee.hash))));let N=[],{hub_routes:V}=rn.getClusteringRoutes();if(!al.isEmptyOrZeroLength(V))for(let ne of V)N.push(`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@${ne.host}:${ne.port}`);let v=new ore(rn.getConfigFromFile(Vt.CLUSTERING_HUBSERVER_NETWORK_PORT),_,o,s,n,r,f,E,h,rn.getConfigFromFile(Vt.CLUSTERING_HUBSERVER_CLUSTER_NAME),rn.getConfigFromFile(Vt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),N,T,A);r==null&&(delete v.tls.ca_file,delete v.leafnodes.tls.ca_file),t=al.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===Mh.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await il.writeJson(d,v),cl.trace(`Hub server config written to ${d}`));let J=`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,$=`tls://${g.uri_encoded_name}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,F=new are(rn.getConfigFromFile(Vt.CLUSTERING_LEAFSERVER_NETWORK_PORT),_,c,l,[J],[$],T,A,s,n,r,f);r==null&&delete F.tls.ca_file,(t===void 0||t===Mh.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await il.writeJson(u,F),cl.trace(`Leaf server config written to ${u}`))}a(_re,"generateNatsConfig");async function Ph(e){let t=Gd.get(e);return al.isEmpty(t)&&Uh(`port undefined for '${e}'`),await al.isPortTaken(t)&&Uh(`'${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(Ph,"isPortAvailable");function Uh(e){let t=`Error generating clustering config: ${e}`;cl.error(t),console.error(t),process.exit(1)}a(Uh,"generateNatsConfigError");async function Ere(e){let{port:t,config_file:r}=KA.getServerConfig(e),{username:n,decrypt_hash:s}=await YA.getClusterUser(),i=0,o=2e3;for(;i<jx;){try{let u=await KA.createConnection(t,n,s,!1);if(u.protocol.connected===!0){u.close();break}}catch(u){cl.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${u}`)}if(i++,i>=jx)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let d=o*(i*2);d>3e4&&cl.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await al.async_set_timeout(d)}let c="0".repeat(dre),l=sl.join(Gd.get(Vt.ROOTPATH),ol,r);await il.writeFile(l,c),await il.remove(l),cl.notify(e,"started.")}a(Ere,"removeNatsConfig")});var nB=I((Yge,rB)=>{"use strict";var Dn=ie(),hre=ta(),Ue=B(),qd=Pt(),Di=require("path"),{PACKAGE_ROOT:xh}=B(),Xx=ie(),vh=te(),ll="/dev/null",mre=Di.join(xh,"launchServiceScripts"),Zx=Di.join(xh,"utility/scripts"),pre=Di.join(Zx,Ue.HDB_RESTART_SCRIPT),eB=Di.resolve(xh,"dependencies",`${process.platform}-${process.arch}`,qd.NATS_BINARY_NAME);function tB(){let t=hre.licenseSearch().ram_allocation||Ue.RAM_ALLOCATION_ENUM.DEFAULT,r=Ue.MEM_SETTING_KEY+t,n={[Ue.PROCESS_NAME_ENV_PROP]:Ue.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return vh.noBootFile()&&(n[Ue.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=vh.getEnvCliRootPath()),{name:Ue.PROCESS_DESCRIPTORS.HDB,script:Ue.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:xh}}a(tB,"generateMainServerConfig");var Sre=9930;function Tre(){Dn.initSync(!0);let e=Dn.get(Ue.CONFIG_PARAMS.ROOTPATH),t=Di.join(e,"clustering",qd.NATS_CONFIG_FILES.HUB_SERVER),r=Di.join(Dn.get(Ue.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ue.LOG_NAMES.HDB),n=Xx.get(Ue.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=qd.LOG_LEVEL_FLAGS[Dn.get(Ue.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ue.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Sre?"-"+n:""),script:eB,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ue.PROCESS_NAME_ENV_PROP]:Ue.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Dn.get(Ue.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=ll,i.error_file=ll),i}a(Tre,"generateNatsHubServerConfig");var gre=9940;function Rre(){Dn.initSync(!0);let e=Dn.get(Ue.CONFIG_PARAMS.ROOTPATH),t=Di.join(e,"clustering",qd.NATS_CONFIG_FILES.LEAF_SERVER),r=Di.join(Dn.get(Ue.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ue.LOG_NAMES.HDB),n=Xx.get(Ue.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=qd.LOG_LEVEL_FLAGS[Dn.get(Ue.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ue.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==gre?"-"+n:""),script:eB,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ue.PROCESS_NAME_ENV_PROP]:Ue.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Dn.get(Ue.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=ll,i.error_file=ll),i}a(Rre,"generateNatsLeafServerConfig");function Are(){Dn.initSync();let e=Di.join(Dn.get(Ue.CONFIG_PARAMS.LOGGING_ROOT),Ue.LOG_NAMES.HDB),t={name:Ue.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Ue.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Ue.PROCESS_NAME_ENV_PROP]:Ue.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:mre,autorestart:!1};return Dn.get(Ue.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=ll,t.error_file=ll),t}a(Are,"generateClusteringUpgradeV4ServiceConfig");function bre(){let e={[Ue.PROCESS_NAME_ENV_PROP]:Ue.PROCESS_DESCRIPTORS.RESTART_HDB};return vh.noBootFile()&&(e[Ue.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=vh.getEnvCliRootPath()),{...{name:Ue.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:Zx},script:pre}}a(bre,"generateRestart");function yre(){return{apps:[tB()]}}a(yre,"generateAllServiceConfigs");rB.exports={generateAllServiceConfigs:yre,generateMainServerConfig:tB,generateRestart:bre,generateNatsHubServerConfig:Tre,generateNatsLeafServerConfig:Rre,generateClusteringUpgradeV4ServiceConfig:Are}});var pB=I((Qge,mB)=>{"use strict";var Xe=B(),Ore=te(),Pi=WA(),Bh=jt(),Li=Pt(),Ao=nB(),Hh=ie(),Da=X(),Nre=yi(),{startWorker:sB,onMessageFromWorkers:Ire}=at(),wre=Gc(),Wge=require("util"),Cre=require("child_process"),Dre=require("fs"),{execFile:Lre}=Cre,Ke;mB.exports={enterPM2Mode:Pre,start:bo,stop:QA,reload:oB,restart:aB,list:zA,describe:lB,connect:Mi,kill:Bre,startAllServices:Hre,startService:jA,getUniqueServicesList:uB,restartAllServices:kre,isServiceRegistered:dB,reloadStopStart:fB,restartHdb:cB,deleteProcess:vre,startClusteringProcesses:EB,startClusteringThreads:hB,isHdbRestartRunning:xre,isClusteringRunning:Gre,stopClustering:Fre,reloadClustering:qre};var Vd=!1;Ire(e=>{e.type==="restart"&&Hh.initSync(!0)});function Pre(){Vd=!0}a(Pre,"enterPM2Mode");function Mi(){return Ke||(Ke=require("pm2")),new Promise((e,t)=>{Ke.connect((r,n)=>{r&&t(r),e(n)})})}a(Mi,"connect");var nn,Mre=10,iB;function bo(e,t=!1){if(Vd)return Ure(e);let r=Lre(e.script,e.args.split(" "),e);r.name=e.name,r.on("exit",async i=>{let o=nn.indexOf(r);o>-1&&nn.splice(o,1),!iB&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Mre&&(Dre.existsSync(Pi.getHubConfigPath())?bo(e):(await Pi.generateNatsConfig(!0),bo(e),await new Promise(c=>setTimeout(c,3e3)),await Pi.removeNatsConfig(Xe.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Pi.removeNatsConfig(Xe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Hh.get(Xe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,d=0,u;for(;l=c.exec(i);){if(l.index&&Li.LOG_LEVEL_HIERARCHY[o]>=Li.LOG_LEVEL_HIERARCHY[u||"info"]){let _=u===Li.LOG_LEVELS.ERR||u===Li.LOG_LEVELS.WRN?Da.OUTPUTS.STDERR:Da.OUTPUTS.STDOUT;Da.logCustomLevel(u||"info",_,n,i.slice(d,l.index).trim())}let[f,E]=l;d=l.index+f.length,u=Li.LOG_LEVELS[E]}if(Li.LOG_LEVEL_HIERARCHY[o]>=Li.LOG_LEVEL_HIERARCHY[u||"info"]){let f=u===Li.LOG_LEVELS.ERR||u===Li.LOG_LEVELS.WRN?Da.OUTPUTS.STDERR:Da.OUTPUTS.STDOUT;Da.logCustomLevel(u||"info",f,n,i.slice(d).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),nn=[],!nn&&!t){let i=a(()=>{iB=!0,nn&&(nn.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)}nn.push(r)}a(bo,"start");function Ure(e){return new Promise(async(t,r)=>{try{await Mi()}catch(n){r(n)}Ke.start(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(Ure,"startWithPM2");function QA(e){if(!Vd){for(let t of nn||[])t.name===e&&(nn.splice(nn.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Mi()}catch(n){r(n)}Ke.stop(e,async(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.delete(e,(i,o)=>{i&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(o)})})})}a(QA,"stop");function oB(e){return new Promise(async(t,r)=>{try{await Mi()}catch(n){r(n)}Ke.reload(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(oB,"reload");function aB(e){if(!Vd)for(let t of nn||[])t.name===e&&t.kill();return new Promise(async(t,r)=>{try{await Mi()}catch(n){r(n)}Ke.restart(e,(n,s)=>{Ke.disconnect(),t(s)})})}a(aB,"restart");function vre(e){return new Promise(async(t,r)=>{try{await Mi()}catch(n){r(n)}Ke.delete(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(vre,"deleteProcess");async function cB(){await bo(Ao.generateRestart())}a(cB,"restartHdb");async function xre(){let e=await zA();for(let t in e)if(e[t].name===Xe.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(xre,"isHdbRestartRunning");function zA(){return new Promise(async(e,t)=>{try{await Mi()}catch(r){t(r)}Ke.list((r,n)=>{r&&(Ke.disconnect(),t(r)),Ke.disconnect(),e(n)})})}a(zA,"list");function lB(e){return new Promise(async(t,r)=>{try{await Mi()}catch(n){r(n)}Ke.describe(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(lB,"describe");function Bre(){if(!Vd){for(let e of nn||[])e.kill();nn=[];return}return new Promise(async(e,t)=>{try{await Mi()}catch(r){t(r)}Ke.killDaemon((r,n)=>{r&&(Ke.disconnect(),t(r)),Ke.disconnect(),e(n)})})}a(Bre,"kill");async function Hre(){try{await EB(),await hB(),await bo(Ao.generateAllServiceConfigs())}catch(e){throw Ke?.disconnect(),e}}a(Hre,"startAllServices");async function jA(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case Xe.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ao.generateMainServerConfig();break;case Xe.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ao.generateNatsIngestServiceConfig();break;case Xe.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ao.generateNatsReplyServiceConfig();break;case Xe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ao.generateNatsHubServerConfig(),await bo(r,t),await Pi.removeNatsConfig(e);return;case Xe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ao.generateNatsLeafServerConfig(),await bo(r,t),await Pi.removeNatsConfig(e);return;case Xe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ao.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await bo(r)}catch(r){throw Ke?.disconnect(),r}}a(jA,"startService");async function uB(){try{let e=await zA(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Ke?.disconnect(),e}}a(uB,"getUniqueServicesList");async function kre(e=[]){try{let t=!1,r=await uB();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===Xe.PROCESS_DESCRIPTORS.HDB?t=!0:await aB(o))}t&&await fB(Xe.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ke?.disconnect(),t}}a(kre,"restartAllServices");async function dB(e){if(nn?.find(r=>r.name===e))return!0;let t=await wre.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(dB,"isServiceRegistered");async function fB(e){let t=Hh.get(Xe.CONFIG_PARAMS.THREADS_COUNT)??Hh.get(Xe.CONFIG_PARAMS.THREADS),r=await lB(e),n=Ore.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await QA(e),await jA(e)):e===Xe.PROCESS_DESCRIPTORS.HDB?await cB():await oB(e)}a(fB,"reloadStopStart");var _B;async function EB(e=!1){for(let t in Xe.CLUSTERING_PROCESSES){let r=Xe.CLUSTERING_PROCESSES[t];await jA(r,e)}}a(EB,"startClusteringProcesses");async function hB(){_B=sB(Xe.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:Xe.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await Bh.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await Bh.updateLocalStreams();let e=await Nre.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===Xe.PRE_4_0_0_VERSION){Da.info("Starting clustering upgrade 4.0.0 process"),sB(Xe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(hB,"startClusteringThreads");async function Fre(){for(let e in Xe.CLUSTERING_PROCESSES)if(e!==Xe.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===Xe.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await _B.terminate();else{let t=Xe.CLUSTERING_PROCESSES[e];await QA(t)}}a(Fre,"stopClustering");async function Gre(){for(let e in Xe.CLUSTERING_PROCESSES){let t=Xe.CLUSTERING_PROCESSES[e];if(await dB(t)===!1)return!1}return!0}a(Gre,"isClusteringRunning");async function qre(){await Pi.generateNatsConfig(!0),await Bh.reloadNATSHub(),await Bh.reloadNATSLeaf(),await Pi.removeNatsConfig(Xe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await Pi.removeNatsConfig(Xe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(qre,"reloadClustering")});var yB={};Ze(yB,{compactOnStart:()=>Vre,copyDb:()=>bB});async function Vre(){Yd.notify("Running compact on start"),console.log("Running compact on start");let e=(0,JA.get)(yo.CONFIG_PARAMS.ROOTPATH),t=new Map,r=ct();try{for(let n in r){if(n==="system")continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,kh.join)(e,"backup",n+".mdb"),o=(0,kh.join)(e,yo.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await SB(n);console.log("Database",n,"before compact has a total record count of",c),t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await bB(n,o),console.log("Backing up",n,"to",i),await(0,La.move)(s,i,{overwrite:!0})}$d();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,La.move)(i,s,{overwrite:!0}),await(0,La.remove)((0,kh.join)(e,yo.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));$d()}catch(n){Yd.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,XA.updateConfigValue)(yo.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,La.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw $d(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await SB(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
11
14
  Total record count before compaction: ${i}, total after: ${c}.
12
- Database backup has not been removed and can be found here: ${s}`;$l.error(l),console.error(l)}(0,ZT.get)(gi.CONFIG_PARAMS.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,mo.remove)(s))}(0,eg.updateConfigValue)(gi.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1)}async function cU(e){let t=await(0,dU.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function fU(e,t){console.log("copyDb start");let r=mr()[e],n;for(let d in r){n=r[d].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,lU.open)(new uU.default(t)),c=o.openDB(hf.INTERNAL_DBIS_NAME),l,_=0,u=s.useReadTransaction();try{for(let{key:f,value:h}of s.getRange({transaction:u})){let p=h.is_hash_attribute||h.isPrimaryKey,S,T;if(p&&(S=h.compression,T=pf(),T?h.compression=T:delete h.compression,S?.dictionary?.toString()===T?.dictionary?.toString()&&(S=null,T=null)),c.put(f,h),!(p||h.indexed))continue;let R=new _U.default(!p,p);R.encoding="binary",R.compression=S;let b=n.openDB(f,R);b.decoder=null,R.compression=T;let C=o.openDB(f,R);C.encoder=null,console.log("copying",f,"from",e,"to",t),await E(b,C,p,u)}let d=n.openDB(hf.AUDIT_STORE_NAME,mf);console.log("copying audit log"),E(i,d,!1,u);async function E(f,h,p,S){let T=0,R=0;for(let{key:b,value:C,version:H}of f.getRange({start:null,versions:p,transaction:S}))l=h.put(b,C,H),T++,S.openTimer&&(S.openTimer=0),R+=(b?.length||10)+C.length,_++>5e3&&(await l,console.log("copied",T,"entries",R,"bytes"),_=0);console.log("finish copying, copied",T,"entries",R,"bytes")}a(E,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{u.done(),o.close()}}var lU,Ef,mo,ZT,uU,_U,hf,gi,dU,eg,$l,hU=Re(()=>{Ae();lU=require("lmdb"),Ef=require("path"),mo=require("fs-extra"),ZT=B(te()),uU=B(vc()),_U=B(Uc()),hf=B(dt()),gi=B(U());ti();dU=B(si()),eg=B(dr()),$l=B(Y());a(F6,"compactOnStart");a(cU,"getTotalDBRecordCount");a(fU,"copyDb")});var Ql=g((MEe,RU)=>{"use strict";var q6=require("minimist"),{isMainThread:ng,parentPort:tg,threadId:DEe}=require("worker_threads"),et=U(),{PROCESS_DESCRIPTORS_VALIDATE:Yl}=et,is=Y(),sg=z(),Tf=zT(),Sf=Rt(),LEe=ct(),SU=dr(),os=aU(),mU=Sa(),{compactOnStart:k6}=(hU(),ie(EU)),V6=Ih(),{restartWorkers:gf,onMessageByType:$6}=ot(),{handleHDBError:Y6,hdb_errors:K6}=ne(),{HTTP_STATUS_CODES:W6}=K6,Wl=te();Wl.initSync();var Kl=`Restarting HarperDB. This may take up to ${et.RESTART_TIMEOUT_MS/1e3} seconds.`,Q6="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",pU="Clustering is not enabled so cannot be restarted",z6="Invalid service",ba,dn;RU.exports={restart:TU,restartService:ig};ng&&$6(et.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await ig({service:e.workerType}):TU({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function TU(e){dn=Object.keys(e).length===0,ba=await os.isServiceRegistered(et.HDB_PROC_DESCRIPTOR);let t=q6(process.argv);if(t.service){await ig(t);return}if(dn&&!ba){console.error(Q6);return}if(dn&&console.log(Kl),ba){os.enterPM2Mode(),is.notify(Kl);let r=V6(Object.keys(et.CONFIG_PARAM_MAP),!0);return sg.isEmptyOrZeroLength(Object.keys(r))||SU.updateConfigValue(void 0,void 0,r,!0,!0),J6(),Kl}return ng?(is.notify(Kl),Wl.get(et.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await k6(),setTimeout(()=>{gf()},50)):tg.postMessage({type:et.ITC_EVENT_TYPES.RESTART}),Kl}a(TU,"restart");async function ig(e){let{service:t}=e;if(et.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw Y6(new Error,z6,W6.BAD_REQUEST,void 0,void 0,!0);if(ba=await os.isServiceRegistered(et.HDB_PROC_DESCRIPTOR),!ng)return tg.postMessage({type:et.ITC_EVENT_TYPES.RESTART,workerType:t}),new Promise(n=>{tg.on("message",s=>{s.type==="restart-complete"&&n()})});let r;switch(t){case Yl.clustering:if(!Wl.get(et.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=pU;break}dn&&console.log("Restarting clustering"),is.notify("Restarting clustering"),await gU();break;case Yl.clustering_config:case Yl["clustering config"]:if(!Wl.get(et.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=pU;break}dn&&console.log("Restarting clustering_config"),is.notify("Restarting clustering_config"),await os.reloadClustering();break;case"custom_functions":case"custom functions":case Yl.harperdb:case Yl.http_workers:if(dn&&!ba){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}dn&&console.log("Restarting http_workers"),is.notify("Restarting http_workers"),dn?await os.restart(et.HDB_PROC_DESCRIPTOR):await gf("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(is.error(r),dn&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(ig,"restartService");async function J6(){await gU(),await os.restart(et.HDB_PROC_DESCRIPTOR),await sg.async_set_timeout(2e3),Wl.get(et.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await rg(),dn&&(await Sf.closeConnection(),process.exit(0))}a(J6,"restartPM2Mode");async function gU(){if(!SU.getConfigFromFile(et.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await mU.getHDBProcessInfo()).clustering.length===0)is.trace("Clustering not running, restart will start clustering services"),await Tf.generateNatsConfig(!0),await os.startClusteringProcesses(),await os.startClusteringThreads(),await rg(),dn&&await Sf.closeConnection();else{await Tf.generateNatsConfig(!0),ba?(is.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await os.restart(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await os.restart(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await mU.getHDBProcessInfo()).clustering.forEach(s=>{is.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await sg.async_set_timeout(3e3),await rg(),await Sf.updateLocalStreams(),dn&&await Sf.closeConnection(),is.trace("Restart clustering restarting ingest and reply service threads");let t=gf(et.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=gf(et.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(gU,"restartClustering");async function rg(){await Tf.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Tf.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(rg,"removeNatsConfig")});var MU=g((vEe,LU)=>{"use strict";var UEe=require("lodash"),Ir=U(),{handleHDBError:AU,hdb_errors:j6}=ne(),{HDB_ERROR_MSGS:X6,HTTP_STATUS_CODES:Z6}=j6,og=Y();LU.exports={getRolePermissions:t9};var po=Object.create(null),e9=a(e=>({key:e,perms:{}}),"perms_template_obj"),NU=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),IU=a((e=!1,t=!1,r=!1,n=!1)=>({[Ir.PERMS_CRUD_ENUM.READ]:e,[Ir.PERMS_CRUD_ENUM.INSERT]:t,[Ir.PERMS_CRUD_ENUM.UPDATE]:r,[Ir.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),ag=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...IU(t,r,n,s)}),"table_perms_template"),OU=a((e,t=IU())=>({attribute_name:e,describe:DU(t),[zl]:t[zl],[cg]:t[cg],[lg]:t[lg]}),"attr_perms_template"),bU=a((e,t=!1)=>({attribute_name:e,describe:t,[zl]:t}),"timestamp_attr_perms_template"),{READ:zl,INSERT:cg,UPDATE:lg}=Ir.PERMS_CRUD_ENUM,wU=Object.values(Ir.PERMS_CRUD_ENUM),CU=[zl,cg,lg];function t9(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[Ir.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(po[t]&&po[t].key===n)return po[t].perms;let s=r9(e,r);return po[t]?po[t].key=n:po[t]=e9(n),po[t].perms=s,s}catch(r){if(!e[Ir.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Ir.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Ir.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 og.error(n),og.debug(r),AU(new Error,X6.OUTDATED_PERMS_TRANSLATION_ERROR,Z6.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
13
- ${r.stack}`;throw og.error(n),AU(new Error)}}}a(t9,"getRolePermissions");function r9(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[Ir.SYSTEM_SCHEMA_NAME]=n[Ir.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]=n9(t[i]);return}r[i]=NU(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],_=s9(c,l);r[i].describe||wU.forEach(u=>{_[u]&&(r[i].describe=!0)}),r[i].tables[o]=_}else r[i].tables[o]=ag()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=ag()})}),r}a(r9,"translateRolePermissions");function n9(e){let t=NU(!0);return Object.keys(e).forEach(r=>{t.tables[r]=ag(!0,!0,!0,!0,!0)}),t}a(n9,"createStructureUserPermissions");function s9(e,t){let{attribute_permissions:r}=e;if(r.length>0){let s=Object.assign({},e);s.attribute_permissions=[];let i=r.reduce((_,u)=>{let{attribute_name:d}=u,E=u;return Ir.TIME_STAMP_NAMES.includes(d)&&(E=bU(d,u[zl])),_[d]=E,_},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=OU(o);return t.attributes.forEach(({attribute:_})=>{if(i[_]){let u=i[_];u.describe=DU(u),s.attribute_permissions.push(u),c||i9(u,l)}else if(_!==o){let u;Ir.TIME_STAMP_NAMES.includes(_)?u=bU(_):u=OU(_),s.attribute_permissions.push(u)}}),c||s.attribute_permissions.push(l),s.describe=yU(s),s}else return e.describe=yU(e),e}a(s9,"getTableAttrPerms");function yU(e){return wU.filter(t=>e[t]).length>0}a(yU,"getSchemaTableDescribePerm");function DU(e){return CU.filter(t=>e[t]).length>0}a(DU,"getAttributeDescribePerm");function i9(e,t){CU.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(i9,"checkForHashPerms")});var PU={};qe(PU,{Resources:()=>Rf,keyArrayToString:()=>ya,resetResources:()=>o9,resources:()=>Ri});function o9(){return Ri=new Rf}function ya(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var Rf,Ri,Jl=Re(()=>{ro();Rf=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,l]of this){let _=2;for(;(_=c.indexOf("/",_))>-1;){let u=this.get(c.slice(0,_));u&&(u.hasSubPaths=!0),_+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),l=this.get(c);if(l){if(l.relativeURL=t.slice(n),!l.hasSubPaths)return l;s=l}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),s?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(o9,"resetResources");a(ya,"keyArrayToString")});var UU={};qe(UU,{Headers:()=>Ai,appendHeader:()=>ug});function ug(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 Ai,jl=Re(()=>{Ai=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(ug,"appendHeader")});var Xl={};qe(Xl,{authentication:()=>kU,bypassAuth:()=>f9,login:()=>h9,logout:()=>m9,start:()=>E9});function f9(){qU=!0}async function kU(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let f=e.isOperationsServer?u9?l9:[]:c9?a9:[];if(f.includes(i)||f.includes("*")){if(e.method==="OPTIONS"){let h=new Ai([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Af&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Af&&o.push("Access-Control-Allow-Credentials","true")}}let l,_;if(Af){i||(i=r.host);let f=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let p of h)if(p.startsWith(f)){let S=p.indexOf(";");l=p.slice(f.length,S===-1?p.length:S),_=await BU.get(l);break}e.session=_||(_={})}let u=a((f,h,p)=>{let S=new Na.AuthAuditLog(f,h,xt.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);S.auth_strategy=p,l&&(S.session_id=l),r.referer&&(S.referer=r.referer),r.origin&&(S.origin=r.origin),h===xt.AUTH_AUDIT_STATUS.SUCCESS?vU.notify(S):vU.error(S)},"authAuditLog");if(e.mtlsConfig&&e.authorized){let f=e.mtlsConfig.user;f!==null?((f===void 0||f==="Common Name"||f==="CN")&&(f=e.peerCertificate.subject.CN),e.user=await it.getUser(f,null,null),u(f,xt.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,Na.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=So.get(n),!d){let f=n.indexOf(" "),h=n.slice(0,f),p=n.slice(f+1),S,T;try{switch(h){case"Basic":let R=atob(p),b=R.indexOf(":");S=R.slice(0,b),T=R.slice(b+1),d=S||T?await it.getUser(S,T,e):null;break;case"Bearer":try{d=await(0,Of.validateOperationToken)(p)}catch(C){if(C.message==="invalid token")try{return await(0,Of.validateRefreshToken)(p),c({status:-1})}catch{throw C}}break}}catch(R){return d9&&(So.get(p)||(So.set(p,p),u(S,xt.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:To({error:R.message},e)})}So.set(n,d),_9&&u(d.username,xt.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=d}else _?.user?e.user=await it.getUser(_.user,null,e):(qU&&(e.ip?.includes("127.0.0.1")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,xU.getSuperUser)());Af&&(e.session.update=function(f){if(!l){l=(0,GU.v4)();let p=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",p):E?.headers?.set&&E.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")):E?.headers?.set&&(i&&E.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),E.headers.set("X-Hdb-Session","Secure"))),f.id=l,BU.put(f)},e.login=async function(f,h){e.user=await it.getUser(f,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 E=await t(e);return E&&(E.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Ri.loginPath?(E.status=302,E.headers.set("Location",Ri.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(l){throw c(l)}function c(l){let _=o.length;if(_>0){let u=l.headers;u||(l.headers=u=new Ai);for(let d=0;d<_;){let E=o[d++];u.set(E,o[d++])}}return o=null,l}a(c,"applyResponseHeaders")}function E9({server:e,port:t}){e.http(kU,{port:t||"all"}),HU||(HU=!0,setInterval(()=>{So=new Map},fn.get(xt.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),FU.user.addListener(()=>{So=new Map}))}async function h9(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 m9(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var xU,Of,GU,fn,xt,Na,FU,vU,a9,c9,l9,u9,BU,Af,qU,_9,d9,So,HU,bf=Re(()=>{xU=B(Vr());ur();Jl();Of=B(Il());Ae();GU=require("uuid"),fn=B(te()),xt=B(U()),Na=B(Y()),FU=B(Wc());jl();Ia();vU=(0,Na.loggerWithTag)("auth-event");fn.initSync();a9=fn.get(xt.CONFIG_PARAMS.HTTP_CORSACCESSLIST),c9=fn.get(xt.CONFIG_PARAMS.HTTP_CORS),l9=fn.get(xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),u9=fn.get(xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),BU=ft({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Af=fn.get(xt.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,qU=fn.get(xt.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,_9=fn.get(xt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,d9=fn.get(xt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,So=new Map;it.onInvalidatedUser(()=>{So=new Map});a(f9,"bypassAuth");a(kU,"authentication");a(E9,"start");a(h9,"login");a(m9,"logout")});var zU=g((KEe,QU)=>{"use strict";var Ce=require("joi"),VU=require("fs-extra"),$U=require("path"),vs=st(),YU=te(),KU=U(),WU=Y(),{hdb_errors:p9}=ne(),{HDB_ERROR_MSGS:ir}=p9,Us=/^[a-zA-Z0-9-_]+$/;QU.exports={getDropCustomFunctionValidator:T9,setCustomFunctionValidator:g9,addComponentValidator:b9,dropCustomFunctionProjectValidator:y9,packageComponentValidator:N9,deployComponentValidator:I9,setComponentFileValidator:R9,getComponentFileValidator:O9,dropComponentFileValidator:A9};function yf(e,t,r){try{let n=YU.get(KU.CONFIG_PARAMS.COMPONENTSROOT),s=$U.join(n,t);return VU.existsSync(s)?e?t:r.message(ir.PROJECT_EXISTS):e?r.message(ir.NO_PROJECT):t}catch(n){return WU.error(n),r.message(ir.VALIDATION_ERR)}}a(yf,"checkProjectExists");function Zl(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(Zl,"checkFilePath");function S9(e,t,r,n){try{let s=YU.get(KU.CONFIG_PARAMS.COMPONENTSROOT),i=$U.join(s,e,t,r+".js");return VU.existsSync(i)?r:n.message(ir.NO_FILE)}catch(s){return WU.error(s),n.message(ir.VALIDATION_ERR)}}a(S9,"checkFileExists");function T9(e){let t=Ce.object({project:Ce.string().pattern(Us).custom(yf.bind(null,!0)).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME}),type:Ce.string().valid("helpers","routes").required(),file:Ce.string().pattern(Us).custom(S9.bind(null,e.project,e.type)).custom(Zl).required().messages({"string.pattern.base":ir.BAD_FILE_NAME})});return vs.validateBySchema(e,t)}a(T9,"getDropCustomFunctionValidator");function g9(e){let t=Ce.object({project:Ce.string().pattern(Us).custom(yf.bind(null,!0)).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME}),type:Ce.string().valid("helpers","routes").required(),file:Ce.string().custom(Zl).required(),function_content:Ce.string().required()});return vs.validateBySchema(e,t)}a(g9,"setCustomFunctionValidator");function R9(e){let t=Ce.object({project:Ce.string().pattern(Us).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME}),file:Ce.string().custom(Zl).required(),payload:Ce.string().allow("").optional(),encoding:Ce.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return vs.validateBySchema(e,t)}a(R9,"setComponentFileValidator");function A9(e){let t=Ce.object({project:Ce.string().pattern(Us).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME}),file:Ce.string().custom(Zl).optional()});return vs.validateBySchema(e,t)}a(A9,"dropComponentFileValidator");function O9(e){let t=Ce.object({project:Ce.string().required(),file:Ce.string().custom(Zl).required(),encoding:Ce.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return vs.validateBySchema(e,t)}a(O9,"getComponentFileValidator");function b9(e){let t=Ce.object({project:Ce.string().pattern(Us).custom(yf.bind(null,!1)).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME})});return vs.validateBySchema(e,t)}a(b9,"addComponentValidator");function y9(e){let t=Ce.object({project:Ce.string().pattern(Us).custom(yf.bind(null,!0)).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME})});return vs.validateBySchema(e,t)}a(y9,"dropCustomFunctionProjectValidator");function N9(e){let t=Ce.object({project:Ce.string().pattern(Us).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME}),skip_node_modules:Ce.boolean()});return vs.validateBySchema(e,t)}a(N9,"packageComponentValidator");function I9(e){let t=Ce.object({project:Ce.string().pattern(Us).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME}),payload:Ce.string().optional().messages({"string.pattern.base":ir.BAD_PACKAGE}),package:Ce.string().optional()});return vs.validateBySchema(e,t)}a(I9,"deployComponentValidator")});var Cf=g((QEe,rv)=>{"use strict";var Nf=require("joi"),If=require("path"),JU=require("fs-extra"),{exec:w9}=require("child_process"),C9=require("util"),jU=C9.promisify(w9),eu=U(),{handleHDBError:wa,hdb_errors:D9}=ne(),{HTTP_STATUS_CODES:Ca}=D9,tu=te(),L9=st(),Da=Y();tu.initSync();var _g=tu.get(eu.CONFIG_PARAMS.COMPONENTSROOT),XU="npm install --omit=dev --json",M9=`${XU} --dry-run`;rv.exports={installModules:B9,auditModules:H9,installAllRootModules:P9,uninstallRootModule:U9,linkHarperdb:v9};async function P9(e=!1){await wf(),await ru(e?"npm install --ignore-scripts":"npm install",tu.get(eu.CONFIG_PARAMS.ROOTPATH))}a(P9,"installAllRootModules");async function U9(e){await ru(`npm uninstall ${e}`,tu.get(eu.CONFIG_PARAMS.ROOTPATH))}a(U9,"uninstallRootModule");async function v9(){await wf(),await ru(`npm link ${eu.PACKAGE_ROOT}`,tu.get(eu.CONFIG_PARAMS.ROOTPATH))}a(v9,"linkHarperdb");async function ru(e,t=void 0){let r,n;try{({stdout:r,stderr:n}=await jU(e,{cwd:t}))}catch(s){throw new Error(s.stderr.replace(`
14
- `,""))}return n&&!n.includes("Debugger listening")&&Da.error("Error running NPM command:",e,n),Da.trace(r,n),r?.replace(`
15
- `,"")}a(ru,"runCommand");async function B9(e){Da.info(`starting installModules for request: ${e}`);let t=tv(e);if(t)throw wa(t,t.message,Ca.BAD_REQUEST);let{projects:r,dry_run:n}=e,s=n===!0?M9:XU;await wf(),await ev(r);let i={};for(let o=0,c=r.length;o<c;o++){let l=r[o];i[l]={npm_output:null,npm_error:null};let _=If.join(_g,l),u,d=null;try{let{stdout:E,stderr:f}=await jU(s,{cwd:_});u=E?E.replace(`
16
- `,""):null,d=f?f.replace(`
17
- `,""):null}catch(E){E.stderr?i[l].npm_error=ZU(E.stderr):i[l].npm_error=E.message;continue}try{i[l].npm_output=JSON.parse(u)}catch{i[l].npm_output=u}try{i[l].npm_error=JSON.parse(d)}catch{i[l].npm_error=d}}return Da.info(`finished installModules with response ${i}`),i}a(B9,"installModules");function ZU(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
18
- `);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(ZU,"parseNPMStdErr");async function H9(e){Da.info(`starting auditModules for request: ${e}`);let t=tv(e);if(t)throw wa(t,t.message,Ca.BAD_REQUEST);let{projects:r}=e;await wf(),await ev(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=If.join(_g,o);n[o]={npm_output:null,npm_error:null};try{let l=await ru("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=ZU(l.stderr)}}return Da.info(`finished auditModules with response ${n}`),n}a(H9,"auditModules");async function wf(){try{return await ru("npm -v"),!0}catch{throw wa(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",Ca.BAD_REQUEST,void 0,void 0,!0)}}a(wf,"checkNPMInstalled");async function ev(e){if(!Array.isArray(e)||e.length===0)throw wa(new Error,"projects argument must be an array with at least 1 element",Ca.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=If.join(_g,i.toString());if(!await JU.pathExists(o)){t.push(i);continue}let l=If.join(o,"package.json");await JU.pathExists(l)||r.push(i)}if(t.length>0)throw wa(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Ca.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw wa(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Ca.BAD_REQUEST,void 0,void 0,!0)}a(ev,"checkProjectPaths");function tv(e){let t=Nf.object({projects:Nf.array().min(1).items(Nf.string()).required(),dry_run:Nf.boolean().default(!1)});return L9.validateBySchema(e,t)}a(tv,"modulesValidator")});var fg=g((JEe,av)=>{"use strict";var La=require("fs-extra"),dg=require("path"),Df=Y(),nv=z(),Lf=U(),ov=te(),x9=dr();av.exports=G9;async function G9(){let e=F9(),t=ov.get(Lf.CONFIG_PARAMS.ROOTPATH),r=dg.join(t,"package.json"),n={dependencies:{harperdb:"file:"+Lf.PACKAGE_ROOT}},s=dg.join(t,"node_modules");await La.ensureDir(s);let i,o=!0,c=!1;try{i=await La.readJson(r)}catch(l){if(nv.isEmptyOrZeroLength(e))return;if(l.code!==Lf.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!nv.isEmptyOrZeroLength(e)){for(let{name:l,package:_}of e){let u=await sv(_);n.dependencies[l]=u+_}if(!o){Df.notify("Installing components"),await iv(r,n,null);return}for(let{name:l,package:_}of e){let u=i.dependencies[l],d=await sv(_);if(u===void 0||u!==d+_){c=!0;break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(Df.notify("Removing component",l),c=!0);c&&(Df.notify("Updating components."),await iv(r,n,i))}a(G9,"installComponents");function F9(){let e=x9.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(F9,"getComponentsConfig");async function sv(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":dg.extname(e)||await La.pathExists(e)?"file:":"github:"}a(sv,"getPkgPrefix");async function iv(e,t,r){Df.trace("npm installing components package.json",t),await La.writeFile(e,JSON.stringify(t,null," "));try{await Cf().installAllRootModules(ov.get(Lf.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?await La.writeFile(e,JSON.stringify(r,null," ")):await La.unlink(e),n}}a(iv,"installPackages")});var mg=g((ZEe,_v)=>{"use strict";var Ve=require("fs-extra"),Eg=require("fast-glob"),Te=require("path"),lv=require("tar-fs"),XEe=require("uuid").v4,hg=require("normalize-path"),as=zU(),Ct=Y(),We=U(),Ot=te(),nu=dr(),q9=z(),{PACKAGE_ROOT:k9}=U(),{handleHDBError:Gt,hdb_errors:V9}=ne(),{basename:$9}=require("path"),Y9=fg(),uv=te(),K9=U(),{Readable:W9}=require("stream"),{isMainThread:Q9}=require("worker_threads"),{HDB_ERROR_MSGS:go,HTTP_STATUS_CODES:Ft}=V9,z9=Te.join(k9,"application-template"),cv=Te.join(Ot.get(We.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp");function J9(){Ct.trace("getting custom api status");let e={};try{e={port:Ot.get(We.CONFIG_PARAMS.HTTP_PORT),directory:Ot.get(We.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Gt(new Error,go.FUNCTION_STATUS,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,t)}return e}a(J9,"customFunctionsStatus");function j9(){Ct.trace("getting custom api endpoints");let e={},t=Ot.get(We.CONFIG_PARAMS.COMPONENTSROOT);try{Eg.sync(hg(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:Eg.sync(hg(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:Eg.sync(hg(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Gt(new Error,go.GET_FUNCTIONS,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,r)}return e}a(j9,"getCustomFunctions");function X9(e){e.project&&(e.project=Te.parse(e.project).name),e.file&&(e.file=Te.parse(e.file).name);let t=as.getDropCustomFunctionValidator(e);if(t)throw Gt(t,t.message,Ft.BAD_REQUEST);Ct.trace("getting custom api endpoint file content");let r=Ot.get(We.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=Te.join(r,n,s,i+".js");try{return Ve.readFileSync(o,{encoding:"utf8"})}catch(c){throw Gt(new Error,go.GET_FUNCTION,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,c)}}a(X9,"getCustomFunction");function Z9(e){e.project&&(e.project=Te.parse(e.project).name),e.file&&(e.file=Te.parse(e.file).name);let t=as.setCustomFunctionValidator(e);if(t)throw Gt(t,t.message,Ft.BAD_REQUEST);Ct.trace("setting custom function file content");let r=Ot.get(We.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{return Ve.outputFileSync(Te.join(r,n,s,i+".js"),o),`Successfully updated custom function: ${i}.js`}catch(c){throw Gt(new Error,go.SET_FUNCTION,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,c)}}a(Z9,"setCustomFunction");function e7(e){e.project&&(e.project=Te.parse(e.project).name),e.file&&(e.file=Te.parse(e.file).name);let t=as.getDropCustomFunctionValidator(e);if(t)throw Gt(t,t.message,Ft.BAD_REQUEST);Ct.trace("dropping custom function file");let r=Ot.get(We.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{return Ve.unlinkSync(Te.join(r,n,s,i+".js")),`Successfully deleted custom function: ${i}.js`}catch(o){throw Gt(new Error,go.DROP_FUNCTION,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,o)}}a(e7,"dropCustomFunction");function t7(e){e.project&&(e.project=Te.parse(e.project).name);let t=as.addComponentValidator(e);if(t)throw Gt(t,t.message,Ft.BAD_REQUEST);Ct.trace("adding component");let r=Ot.get(We.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=Te.join(r,n);return Ve.mkdirSync(s,{recursive:!0}),Ve.copySync(z9,s),`Successfully added project: ${n}`}catch(s){throw Gt(new Error,go.ADD_FUNCTION,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,s)}}a(t7,"addComponent");function r7(e){e.project&&(e.project=Te.parse(e.project).name);let t=as.dropCustomFunctionProjectValidator(e);if(t)throw Gt(t,t.message,Ft.BAD_REQUEST);Ct.trace("dropping custom function project");let r=Ot.get(We.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Ot.get(We.CONFIG_PARAMS.APPS);if(!q9.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 nu.updateConfigValue(We.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=Te.join(r,n);return Ve.rmSync(i,{recursive:!0}),`Successfully deleted project: ${n}`}catch(i){throw Gt(new Error,go.DROP_FUNCTION_PROJECT,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,i)}}a(r7,"dropCustomFunctionProject");async function n7(e){e.project&&(e.project=Te.parse(e.project).name);let t=as.packageComponentValidator(e);if(t)throw Gt(t,t.message,Ft.BAD_REQUEST);let r=Ot.get(We.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Ct.trace("packaging component",n);let s;try{s=await Ve.realpath(Te.join(r,n))}catch(l){if(l.code!==We.NODE_ERROR_CODES.ENOENT)throw l;try{s=await Ve.realpath(Te.join(Ot.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 Ve.ensureDir(cv);let i=Te.join(cv,`${n}.tar`),o={};(e.skip_node_modules===!0||e.skip_node_modules==="true")&&(o={ignore:l=>l.includes(Te.join(s,"node_modules"))}),lv.pack(s,o).pipe(Ve.createWriteStream(i,{overwrite:!0})),await new Promise(l=>setTimeout(l,2e3));let c=Ve.readFileSync(i,{encoding:"base64"});return await Ve.remove(i),{project:n,payload:c}}a(n7,"packageComponent");async function s7(e){e.project&&(e.project=Te.parse(e.project).name);let t=as.deployComponentValidator(e);if(t)throw Gt(t,t.message,Ft.BAD_REQUEST);let r=Ot.get(We.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i}=e;if(Ct.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let o;if(s){o=Te.join(r,n),i="file:"+o,await Ve.emptyDir(o);let E=W9.from(Buffer.from(s,"base64"));await new Promise((h,p)=>{E.pipe(lv.extract(o,{finish:h})).on("error",p)});let f=await Ve.readdir(o);f.length===1&&f[0]==="package"&&(await Ve.copy(Te.join(o,"package"),o),await Ve.remove(Te.join(o,"package")))}if(await nu.addConfig(n,{package:i}),!s){await Y9();let E=uv.get(K9.CONFIG_PARAMS.ROOTPATH);o=Te.join(E,"node_modules",n)}if(Q9)return;let c=new Map;c.isWorker=!0;let l=(Pf(),ie(Mf)),_;l.setErrorReporter(E=>_=E);let u=$9(o),d=l.component_errors.get(u);try{await l.loadComponent(o,c)}finally{l.component_errors.set(u,d)}if(_)throw _;return Ct.info("Installed component"),`Successfully deployed: ${n}`}a(s7,"deployComponent");async function i7(){let e=nu.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 l=await Ve.readdir(o,{withFileTypes:!0});for(let _ of l){let u=_.name;if(u.startsWith(".")||u==="node_modules")continue;let d=Te.join(o,u);if(_.isDirectory()||_.isSymbolicLink()){let E={name:u,entries:[]};c.entries.push(E),await r(d,E)}else{let E=await Ve.stat(d),f={name:Te.basename(u),mtime:E.mtime,size:E.size};c.entries.push(f)}}return c}catch(l){return Ct.warn("Error loading package",l),{error:l.toString(),entries:[]}}},"walk_dir"),n=await r(Ot.get(We.CONFIG_PARAMS.COMPONENTSROOT),{name:Ot.get(We.CONFIG_PARAMS.COMPONENTSROOT).split(Te.sep).slice(-1).pop(),entries:t});for(let o of n.entries)if(o.package){let c=await r(Te.join(Ot.get(We.CONFIG_PARAMS.ROOTPATH),"node_modules",o.name),{name:o.name,entries:[]});Object.assign(o,c)}let i=(Pf(),ie(Mf)).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(i7,"getComponents");async function o7(e){let t=as.getComponentFileValidator(e);if(t)throw Gt(t,t.message,Ft.BAD_REQUEST);let n=nu.getConfigObj()[e.project]||e.project==="harperdb"?Te.join(uv.get(We.CONFIG_PARAMS.ROOTPATH),"node_modules"):Ot.get(We.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await Ve.stat(Te.join(n,e.project,e.file));return{message:await Ve.readFile(Te.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 '${Te.join(e.project,e.file)}'`):i}}a(o7,"getComponentFile");async function a7(e){let t=as.setComponentFileValidator(e);if(t)throw Gt(t,t.message,Ft.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=Te.join(Ot.get(We.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);return e.payload!==void 0?(await Ve.ensureFile(n),await Ve.outputFile(n,e.payload,r)):await Ve.ensureDir(n),"Successfully set component: "+e.file}a(a7,"setComponentFile");async function c7(e){let t=as.dropComponentFileValidator(e);if(t)throw Gt(t,t.message,Ft.BAD_REQUEST);let r=e.file?Te.join(e.project,e.file):e.project,n=Te.join(Ot.get(We.CONFIG_PARAMS.COMPONENTSROOT),r);return await Ve.pathExists(n)&&await Ve.remove(n),nu.deleteConfigFromFile([e.project]),"Successfully dropped: "+r}a(c7,"dropComponent");_v.exports={customFunctionsStatus:J9,getCustomFunctions:j9,getCustomFunction:X9,setCustomFunction:Z9,dropCustomFunction:e7,addComponent:t7,dropCustomFunctionProject:r7,packageComponent:n7,deployComponent:s7,getComponents:i7,getComponentFile:o7,setComponentFile:a7,dropComponent:c7}});var pg=g((the,fv)=>{"use strict";var cs=require("joi"),dv=st();fv.exports={readTransactionLogValidator:l7,deleteTransactionLogsBeforeValidator:u7};function l7(e){let t=cs.object({schema:cs.string().required(),table:cs.string().required(),from:cs.date().timestamp(),to:cs.date().timestamp(),limit:cs.number().min(1)});return dv.validateBySchema(e,t)}a(l7,"readTransactionLogValidator");function u7(e){let t=cs.object({schema:cs.string().required(),table:cs.string().required(),timestamp:cs.date().timestamp().required()});return dv.validateBySchema(e,t)}a(u7,"deleteTransactionLogsBeforeValidator")});var Uf=g((nhe,Sv)=>{"use strict";var Sg=U(),su=Rt(),Ev=z(),hv=te(),mv=As(),{handleHDBError:Ma,hdb_errors:_7}=ne(),{HTTP_STATUS_CODES:Pa}=_7,{readTransactionLogValidator:d7,deleteTransactionLogsBeforeValidator:f7}=pg(),pv="This operation relies on clustering and cannot run with it disable.",E7="Logs successfully deleted from transaction log.",h7="All logs successfully deleted from transaction log.";Sv.exports={readTransactionLog:m7,deleteTransactionLogsBefore:p7};async function*m7(e){let t=d7(e);if(t)throw Ma(t,t.message,Pa.BAD_REQUEST,void 0,void 0,!0);if(!hv.get(Sg.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Ma(new Error,pv,Pa.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:n}=e,s=Ev.checkSchemaTableExist(r,n);if(s)throw Ma(new Error,s,Pa.NOT_FOUND,void 0,void 0,!0);let i=mv.createNatsTableStreamName(r,n),o=await su.viewStreamIterator(i,parseInt(e.from),e.limit);for await(let c of o){let l=Math.floor(c?.nats_timestamp/1e6);if(e.to&&l>e.to)break;let _={operation:c?.entry?.operation,user:c?.entry?.__origin?.user,timestamp:l,records:c?.entry?.records,attributes:c?.entry?.attributes};c?.entry?.operation===Sg.OPERATIONS_ENUM.DELETE&&(_.hash_values=c?.entry?.hash_values),yield _}}a(m7,"readTransactionLog");async function p7(e){let t=f7(e);if(t)throw Ma(t,t.message,Pa.BAD_REQUEST,void 0,void 0,!0);if(!hv.get(Sg.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Ma(new Error,pv,Pa.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:n,timestamp:s}=e,i=Ev.checkSchemaTableExist(r,n);if(i)throw Ma(new Error,i,Pa.NOT_FOUND,void 0,void 0,!0);let o=mv.createNatsTableStreamName(r,n),{jsm:c}=await su.getNATSReferences(),l=await su.getStreamInfo(o),_=new Date(l.state.first_ts).getTime();if(s<=_)return`No transactions exist before: ${s}`;let u=E7,d,E=new Date(l.state.last_ts).getTime();return s>E?(d=l.state.last_seq+1,u=h7):d=(await su.viewStream(o,parseInt(s),1))[0].nats_sequence,await su.purgeTableStream(r,n,{seq:d}),u}a(p7,"deleteTransactionLogsBefore")});var gv=g((ihe,Tv)=>{"use strict";var Tg=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}};Tv.exports=Tg});var Av=g((ahe,Rv)=>{"use strict";var gg=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};Rv.exports=gg});var Ag=g((lhe,bv)=>{"use strict";var Ov=gv(),S7=Av(),{HDB_ERROR_MSGS:T7}=Ur(),Rg=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=T7.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 Ov(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new S7(c,s[c]);i.push(l)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new Ov(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}};bv.exports=Rg});var xf=g((_he,Fv)=>{"use strict";var Og=un(),vf=qr(),hn=Pd(),au=si(),bg=zi(),g7=US(),R7=IL(),cu=Vr(),Bf=VS(),Dt=Y(),A7=KS(),O7=jd(),b7=NT(),y7=Zd(),N7=wT(),I7=CT(),w7=MT(),C7=UT(),yg=HT(),Bs=z(),D7=yP(),Ng=kT(),Iv=Ql(),En=U(),wv=MU(),L7=Sa(),Cv=Il(),Dv=(bf(),ie(Xl)),Lv=dr(),Jr=mg(),M7=require("alasql"),Mv=Uf(),Pv=Cf(),Uv=Ag(),{handleHDBError:wr,hdb_errors:vv}=ne(),{HDB_ERROR_MSGS:Wt,HTTP_STATUS_CODES:iu}=vv,V=new Map,Bv="delete",Oi="insert",Hs="read",Ro="update",ou="describe",yv=au.describeSchema.name,Nv=au.describeTable.name,Hv={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},P7="catchup",U7="handleGetJob",v7="handleGetJobsByStartDate",Hf={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},B7=[hn.createTable.name,hn.createAttribute.name,hn.dropTable.name,hn.dropAttribute.name],xv={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(Og.insert.name,new W(!1,[Oi]));V.set(Og.update.name,new W(!1,[Ro]));V.set(Og.upsert.name,new W(!1,[Oi,Ro]));V.set(vf.searchByConditions.name,new W(!1,[Hs]));V.set(vf.searchByHash.name,new W(!1,[Hs]));V.set(vf.searchByValue.name,new W(!1,[Hs]));V.set(vf.search.name,new W(!1,[Hs]));V.set(hn.createSchema.name,new W(!0,[]));V.set(hn.createTable.name,new W(!0,[]));V.set(hn.createAttribute.name,new W(!1,[Oi]));V.set(hn.dropSchema.name,new W(!0,[]));V.set(hn.dropTable.name,new W(!0,[]));V.set(hn.dropAttribute.name,new W(!0,[]));V.set(au.describeSchema.name,new W(!1,[Hs]));V.set(au.describeTable.name,new W(!1,[Hs]));V.set(bg.deleteRecord.name,new W(!1,[Bv]));V.set(cu.addUser.name,new W(!0,[]));V.set(cu.alterUser.name,new W(!0,[]));V.set(cu.dropUser.name,new W(!0,[]));V.set(cu.listUsersExternal.name,new W(!0,[]));V.set(Bf.listRoles.name,new W(!0,[]));V.set(Bf.addRole.name,new W(!0,[]));V.set(Bf.alterRole.name,new W(!0,[]));V.set(Bf.dropRole.name,new W(!0,[]));V.set(A7.name,new W(!0,[]));V.set(O7.name,new W(!0,[]));V.set(b7.name,new W(!0,[]));V.set(y7.name,new W(!0,[]));V.set(N7.name,new W(!0,[]));V.set(I7.name,new W(!0,[]));V.set(yg.setRoutes.name,new W(!0,[]));V.set(yg.getRoutes.name,new W(!0,[]));V.set(yg.deleteRoutes.name,new W(!0,[]));V.set(Lv.setConfiguration.name,new W(!0,[]));V.set(w7.clusterStatus.name,new W(!0,[]));V.set(C7.name,new W(!0,[]));V.set(Ng.getFingerprint.name,new W(!0,[]));V.set(Ng.setLicense.name,new W(!0,[]));V.set(bg.deleteFilesBefore.name,new W(!0,[]));V.set(bg.deleteAuditLogsBefore.name,new W(!0,[]));V.set(Iv.restart.name,new W(!0,[]));V.set(Iv.restartService.name,new W(!0,[]));V.set(g7.name,new W(!0,[]));V.set(R7.name,new W(!0,[Hs]));V.set(L7.systemInformation.name,new W(!0,[]));V.set(Lv.getConfiguration.name,new W(!0,[]));V.set(Mv.readTransactionLog.name,new W(!0,[]));V.set(Mv.deleteTransactionLogsBefore.name,new W(!0,[]));V.set(Pv.installModules.name,new W(!0,[]));V.set(Pv.auditModules.name,new W(!0,[]));V.set(Cv.createTokens.name,new W(!1,[]));V.set(Cv.refreshOperationToken.name,new W(!1,[]));V.set(Dv.login.name,new W(!1,[]));V.set(Dv.logout.name,new W(!1,[]));V.set(Jr.customFunctionsStatus.name,new W(!0,[]));V.set(Jr.getCustomFunctions.name,new W(!0,[]));V.set(Jr.getComponents.name,new W(!0,[]));V.set(Jr.getComponentFile.name,new W(!0,[]));V.set(Jr.setComponentFile.name,new W(!0,[]));V.set(Jr.dropComponent.name,new W(!0,[]));V.set(Jr.getCustomFunction.name,new W(!0,[]));V.set(Jr.setCustomFunction.name,new W(!0,[]));V.set(Jr.dropCustomFunction.name,new W(!0,[]));V.set(Jr.addComponent.name,new W(!0,[]));V.set(Jr.dropCustomFunctionProject.name,new W(!0,[]));V.set(Jr.packageComponent.name,new W(!0,[]));V.set(Jr.deployComponent.name,new W(!0,[]));V.set(Ng.getRegistrationInfo.name,new W(!1,[]));V.set(cu.userInfo.name,new W(!1,[]));V.set(au.describeAll.name,new W(!1,[]));V.set(U7,new W(!1,[]));V.set(v7,new W(!0,[]));V.set(P7,new W(!0,[]));V.set(Hf.CSV_DATA_LOAD,new W(!1,[Oi,Ro]));V.set(Hf.CSV_URL_LOAD,new W(!1,[Oi,Ro]));V.set(Hf.CSV_FILE_LOAD,new W(!1,[Oi,Ro]));V.set(Hf.IMPORT_FROM_S3,new W(!1,[Oi,Ro]));V.set(xv.EXPORT_TO_S3,new W(!0,[]));V.set(xv.EXPORT_LOCAL,new W(!0,[]));V.set(En.VALID_SQL_OPS_ENUM.DELETE,new W(!1,[Bv]));V.set(En.VALID_SQL_OPS_ENUM.SELECT,new W(!1,[Hs]));V.set(En.VALID_SQL_OPS_ENUM.INSERT,new W(!1,[Oi]));V.set(En.VALID_SQL_OPS_ENUM.UPDATE,new W(!1,[Ro]));Fv.exports={verifyPerms:x7,verifyPermsAst:H7,verifyBulkLoadAttributePerms:F7};function H7(e,t,r){if(Bs.isEmptyOrZeroLength(e))throw Dt.info("verify_perms_ast has an empty user parameter"),wr(new Error);if(Bs.isEmptyOrZeroLength(t))throw Dt.info("verify_perms_ast has an empty user parameter"),wr(new Error);if(Bs.isEmptyOrZeroLength(r))throw Dt.info("verify_perms_ast has a null operation parameter"),wr(new Error);try{let n=new Uv,s=new D7(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw Dt.info("No schemas defined in verifyPermsAst(), will not continue."),wr(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&Hv[r])throw wr(new Error,Wt.DROP_SYSTEM,iu.FORBIDDEN);if(c&&!l)return null;let _=wv.getRolePermissions(t.role);t.role.permission=_,!c&&e instanceof M7.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(_));for(let d=0;d<i.length;d++){let E=s.getTablesBySchemaName(i[d]);E&&o.set(i[d],E)}let u=Gv(t,r,o,n);return u||(o.forEach((d,E)=>{for(let f=0;f<d.length;f++){let h=s.getAttributesBySchemaTableName(E,d[f]),p=wg(t.role.permission,E,d[f]);Ig(h,p,r,d[f],E,n)}}),n.getPermsResponse())}catch(n){throw wr(n)}}a(H7,"verifyPermsAst");function x7(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw Dt.info("null required parameter in verifyPerms"),wr(new Error,Wt.DEFAULT_INVALID_REQUEST,iu.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 Uv;if(Bs.isEmptyOrZeroLength(e.hdb_user.role)||Bs.isEmptyOrZeroLength(e.hdb_user.role.permission))return Dt.info(`User ${e.hdb_user.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(Wt.USER_HAS_NO_PERMS(e.hdb_user.username));let l=!!e.hdb_user.role.permission.super_user,_=e.hdb_user.role.permission.structure_user,u=o.has(En.SYSTEM_SCHEMA_NAME)||s===En.SYSTEM_SCHEMA_NAME;if(u&&Hv[r])throw wr(new Error,Wt.DROP_SYSTEM,iu.FORBIDDEN);if(l&&!u||_===!0&&(r===hn.createSchema.name||r===hn.dropSchema.name))return null;if(B7.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=wv.getRolePermissions(e.hdb_user.role);if(e.hdb_user.role.permission=d,r===yv||r===Nv){if(s===En.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(Wt.SCHEMA_PERM_ERROR(s));if(!d.super_user){if(r===yv&&(!d[s]||!d[s][ou]))return c.handleInvalidItem(Wt.SCHEMA_NOT_FOUND(s));if(r===Nv&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][ou]))return c.handleInvalidItem(Wt.TABLE_NOT_FOUND(s,i))}}let E=Gv(e.hdb_user,r,o,c,n);if(E)return E;if(V.get(r)&&V.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&En.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let p=[],S=d[s].tables[i];S[En.PERMS_CRUD_ENUM.READ]&&(S.attribute_permissions.length>0?S.attribute_permissions.filter(R=>R[En.PERMS_CRUD_ENUM.READ]).forEach(R=>{p.push(R.attribute_name)}):p=global.hdb_schema[s][i].attributes.map(T=>T.attribute),e.get_attributes=p)}let f=G7(e),h=wg(e.hdb_user.role.permission,s,i);return Ig(f,h,r,i,s,c,n),c.getPermsResponse()}a(x7,"verifyPerms");function Gv(e,t,r,n,s){if(Bs.arrayHasEmptyValues([e,t,r]))throw Dt.info("hasPermissions has an invalid parameter"),wr(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 Dt.info(`operation ${t} not found.`),wr(new Error,Wt.OP_NOT_FOUND(t),iu.BAD_REQUEST);if(V.get(t)&&V.get(t).requires_su)return Dt.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(Wt.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][ou]===!1){n.addInvalidItem(Wt.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(Wt.SCHEMA_NOT_FOUND(l));continue}let _=r.get(l);for(let u of _){let d=o[l].tables[u];if(!d||d[ou]===!1)n.addInvalidItem(Wt.TABLE_NOT_FOUND(l,u));else try{let E=[],f=V.get(t).perms;!Bs.isEmpty(s)&&f.includes(s)&&(f=[s]);for(let h=0;h<f.length;h++){let p=f[h],S=d[p];(S==null||S===!1)&&(Dt.info(`Required ${p} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),E.push(p))}E.length>0&&n.addUnauthorizedTable(l,u,E)}catch(E){let f=Wt.UNKNOWN_OP_AUTH_ERROR(t,l,u);throw Dt.error(f),Dt.error(E),wr(vv.CHECK_LOGS_WRAPPER(f))}}}return r.size<2?n.getPermsResponse():null}a(Gv,"hasPermissions");function Ig(e,t,r,n,s,i,o){if(!e||!t)throw Dt.info("no attributes specified in checkAttributePerms."),wr(new Error);let c=V.get(r).perms;if(!c||c==="")throw Dt.info(`no permissions found for ${r} in checkAttributePerms().`),wr(new Error);if(Bs.isEmptyOrZeroLength(t))return Dt.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let u of e){let d=t.get(u);if(d){if(d[ou]===!1){i.addInvalidItem(Wt.ATTR_NOT_FOUND(s,n,u),s,n);continue}if(c)for(let E of c){if(En.TIME_STAMP_NAMES.includes(d.attribute_name)&&E!==Hs)throw wr(new Error,Wt.SYSTEM_TIMESTAMP_PERMS_ERR,iu.FORBIDDEN);d[E]===!1&&(l[d.attribute_name]?l[d.attribute_name].push(E):l[d.attribute_name]=[E])}}else i.addInvalidItem(Wt.ATTR_NOT_FOUND(s,n,u),s,n)}let _=Object.keys(l);_.length>0&&i.addUnauthorizedAttributes(_,s,n,l)}a(Ig,"checkAttributePerms");function G7(e){let t=new Set;try{if(e.action)return t;if(e.operation===En.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS&&e.conditions.forEach(r=>{t.add(r.search_attribute)}),e&&e.search_attribute&&t.add(e.search_attribute),!e.records||e.records.length===0){if(!e.get_attributes||!e.get_attributes.length===0)return t;for(let r=0;r<e.get_attributes.length;r++)t.add(e.get_attributes[r])}else for(let r=0;r<e.records.length;r++){let n=Object.keys(e.records[r]);for(let s=0;s<n.length;s++)t.add(n[s])}}catch(r){Dt.info(r)}return t}a(G7,"getRecordAttributes");function wg(e,t,r){let n=new Map;if(Bs.isEmpty(e))return Dt.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{Dt.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(wg,"getAttributePermissions");function F7(e,t,r,n,s,i,o){let c=new Set(i),l=wg(e,n,s);Ig(c,l,t,s,n,o,r)}a(F7,"verifyBulkLoadAttributePerms")});var Ff=g((fhe,Yv)=>{"use strict";Yv.exports={evaluateSQL:Z7,processAST:$v,convertSQLToAST:Vv,checkASTPermissions:kv};var q7=un(),qv=require("util"),k7=qv.callbackify(q7.insert),V7=qr().search,$7=dD().update,Y7=qv.callbackify($7),K7=ED().convertDelete,bi=require("alasql"),W7=xf(),Gf=Y(),Q7=hd(),z7=z(),lu=U(),{hdb_errors:J7,handleHDBError:Cg}=ne(),{HTTP_STATUS_CODES:Dg}=J7;Q7(bi);var j7=403,X7="There was a problem performing this insert. Please check the logs and try again.",Lg=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function Z7(e,t){let r=e.parsed_sql_object;if(!r){r=Vv(e.sql);let n,s=r.ast.statements[0];if(s instanceof bi.yy.Insert?n=s.into.databaseid:s instanceof bi.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof bi.yy.Update||s instanceof bi.yy.Delete?n=s.table.databaseid:Gf.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof bi.yy.Select)&&z7.isEmptyOrZeroLength(n))return t("No schema specified",null)}$v(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(Z7,"evaluateSQL");function kv(e,t){let r;try{r=W7.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(kv,"checkASTPermissions");function Vv(e){let t=new Lg;if(!e)throw Cg(new Error,"The 'sql' parameter is missing from the request body",Dg.BAD_REQUEST);try{let r=e.trim(),n=bi.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
19
- `);throw n[1]?Cg(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,Dg.BAD_REQUEST):Cg(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",Dg.BAD_REQUEST)}return t}a(Vv,"convertSQLToAST");function $v(e,t,r){try{let n=eee;if(!e.bypass_auth&&!t.permissions_checked){let i=kv(e,t);if(i&&i.length>0)return r(j7,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case lu.VALID_SQL_OPS_ENUM.SELECT:n=V7,s=t.ast.statements[0];break;case lu.VALID_SQL_OPS_ENUM.INSERT:n=tee;break;case lu.VALID_SQL_OPS_ENUM.UPDATE:n=Y7;break;case lu.VALID_SQL_OPS_ENUM.DELETE:n=K7;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($v,"processAST");function eee(e,t){Gf.info(e),t("unknown sql statement")}a(eee,"nullFunction");function tee({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=ree(i,e.values)}catch(o){return r(o)}k7(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){Gf.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(tee,"convertInsert");function ree(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]]=bi.compile(`SELECT ${s.toString()} AS [${lu.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw Gf.error(r),new Error(X7)}}a(ree,"createDataObjects")});var Mg=g((hhe,Wv)=>{"use strict";var{S3:nee,GetObjectCommand:see}=require("@aws-sdk/client-s3");Wv.exports={getFileStreamFromS3:iee,getS3AuthObj:Kv};async function iee(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await Kv(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new see(r))).Body}a(iee,"getFileStreamFromS3");function Kv(e,t,r){return new nee({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(Kv,"getS3AuthObj")});var qf=g((phe,r0)=>{"use strict";var Ug=qr(),oee=Ff(),aee=Mg(),{AsyncParser:cee,Transform:lee}=require("json2csv"),_u=require("stream"),jr=z(),Pg=require("fs-extra"),uee=require("path"),mn=Y(),{promisify:Jv}=require("util"),uu=z(),{handleHDBError:bt,hdb_errors:_ee}=ne(),{HDB_ERROR_MSGS:Cr,HTTP_STATUS_CODES:yt}=_ee,{streamAsJSON:dee}=(em(),ie(qb)),{Upload:fee}=require("@aws-sdk/lib-storage"),Qv=["search_by_value","search_by_hash","sql","search_by_conditions"],zv=["json","csv"],jv="json",Xv="csv",Eee="Successfully exported JSON locally.",hee="Successfully exported CSV locally.",mee=1e3,pee=Ug.searchByHash,See=Ug.searchByValue,Tee=Jv(oee.evaluateSQL),gee=Jv(_u.finished);r0.exports={export_to_s3:bee,export_local:Ree,toCsvStream:Zv};async function Ree(e){mn.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=e0(e);if(!jr.isEmpty(t))throw mn.error(t),bt(new Error,t,yt.BAD_REQUEST,void 0,void 0,!0);if(jr.isEmpty(e.path))throw mn.error(Cr.MISSING_VALUE("path")),bt(new Error,Cr.MISSING_VALUE("path"),yt.BAD_REQUEST,void 0,void 0,!0);let r=(jr.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(uee.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=jr.buildFolderPath(e.path,r);await Aee(e.path);let s=await t0(e);return await Oee(n,e.format,s)}a(Ree,"export_local");async function Aee(e){if(mn.trace("in confirmPath"),jr.isEmptyOrZeroLength(e))throw bt(new Error,`Invalid path: ${e}`,yt.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,mn.error(n),bt(new Error,n,yt.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 mn.error(r),bt(new Error,r,yt.BAD_REQUEST,void 0,void 0,!0)}return!0}a(Aee,"confirmPath");async function Oee(e,t,r){if(mn.trace("in saveToLocal"),uu.isEmptyOrZeroLength(e))throw bt(new Error,Cr.INVALID_VALUE("file_path"),yt.BAD_REQUEST,void 0,void 0,!0);if(uu.isEmptyOrZeroLength(t))throw bt(new Error,Cr.INVALID_VALUE("Source format"),yt.BAD_REQUEST,void 0,void 0,!0);if(uu.isEmpty(r))throw bt(new Error,Cr.NOT_FOUND("Data"),yt.BAD_REQUEST,void 0,void 0,!0);if(t===jv){let n=Pg.createWriteStream(e);return dee(r).pipe(n),await gee(n),{message:Eee,path:e}}else if(t===Xv){let n=Pg.createWriteStream(e),s=_u.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(u=>({label:u,value:u})));let c={objectMode:!0};return await new cee(i,c).fromInput(s).toOutput(n).promise(!1),{message:hee,path:e}}throw bt(new Error,Cr.INVALID_VALUE("format"),yt.BAD_REQUEST)}a(Oee,"saveToLocal");async function bee(e){if(!e.s3||Object.keys(e.s3).length===0)throw bt(new Error,Cr.MISSING_VALUE("S3 object"),yt.BAD_REQUEST);if(jr.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw bt(new Error,Cr.MISSING_VALUE("aws_access_key_id"),yt.BAD_REQUEST);if(jr.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw bt(new Error,Cr.MISSING_VALUE("aws_secret_access_key"),yt.BAD_REQUEST);if(jr.isEmptyOrZeroLength(e.s3.bucket))throw bt(new Error,Cr.MISSING_VALUE("bucket"),yt.BAD_REQUEST);if(jr.isEmptyOrZeroLength(e.s3.key))throw bt(new Error,Cr.MISSING_VALUE("key"),yt.BAD_REQUEST);if(jr.isEmptyOrZeroLength(e.s3.region))throw bt(new Error,Cr.MISSING_VALUE("region"),yt.BAD_REQUEST);let t=e0(e);if(!jr.isEmpty(t))throw bt(new Error,t,yt.BAD_REQUEST);mn.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await t0(e)}catch(l){throw mn.error(l),l}let n,s=await aee.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new _u.PassThrough;if(e.format===Xv){i=e.s3.key+".csv";let l=Zv(r,r.getColumns?.());l.on("error",_=>{throw _}),l.pipe(o)}else if(e.format===jv){i=e.s3.key+".json";let l=new _u.Readable;l.pipe(o),l.on("error",d=>{throw d}),l.push("[");let _=r.length,u="";for(let[d,E]of r.entries()){let f=d===_-1?JSON.stringify(E):JSON.stringify(E)+",";u+=f,d!==0&&d%mee===0&&(l.push(u),u="")}u.length!==0&&l.push(u),l.push("]"),l.push(null)}else throw bt(new Error,Cr.INVALID_VALUE("format"),yt.BAD_REQUEST);return new fee({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(bee,"export_to_s3");function Zv(e,t){let r=_u.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 lee(n,s);return r.pipe(i)}a(Zv,"toCsvStream");function e0(e){if(mn.trace("in exportCoreValidation"),jr.isEmpty(e.format))return"format missing";if(zv.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${zv.join(", ")}`;let t=e.search_operation.operation;if(jr.isEmpty(t))return"search_operation.operation missing";if(Qv.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${Qv.join(", ")}`}a(e0,"exportCoreValidation");async function t0(e){mn.trace("in getRecords");let t,r;if(uu.isEmpty(e.search_operation)||uu.isEmptyOrZeroLength(e.search_operation.operation))throw bt(new Error,Cr.INVALID_VALUE("Search operation"),yt.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=See;break;case"search_by_hash":t=pee;break;case"search_by_conditions":t=Ug.searchByConditions;break;case"sql":t=Tee;break;default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,mn.error(r),bt(new Error,r,yt.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(t0,"getRecords")});var _0={};qe(_0,{contentTypes:()=>xg,findBestSerializer:()=>$f,getDeserializer:()=>Oo,registerContentHandlers:()=>Gg,serialize:()=>Yf,serializeMessage:()=>To});function yee(e){try{return e?.[0]===123?Hg(e):e}catch{return e}}function Gg(e){e.register(Iee,{serializers:[{regex:/^application\/json$/,serializer:wc},{regex:/^application\/cbor$/,serializer:function(t){return new Ao.EncoderStream(fu).end(t)}},{regex:/^application\/(x-)?msgpack$/,serializer:function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?Vf.Readable.from((0,ls.encodeIter)(t,fu)):(0,ls.pack)(t)}},{regex:/^text\/csv$/,serializer:function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,kf.toCsvStream)(t)}}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,ls.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Ao.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function $f(e){let r=(e.headers.asObject||e.headers).accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let l of c){let[_,...u]=l.split(/\s*;\s*/),d=1,E={q:1};for(let h of u){let p=h.indexOf("=");E[h.substring(0,p)]=h.substring(p+1)}d=+E.q;let f=qt.get(_);if(f){let h=(f.q||1)*d;h>s&&(n=f,i=f.type||_,s=h,o=E)}}if(!n){if(r)throw new o0.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(qt.keys()).join(", "),406);n=qt.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function Yf(e,t,r){let n=s0&&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=$f(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,xs.createBrotliCompress)({params:{[xs.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?xs.constants.BROTLI_MODE_TEXT:xs.constants.BROTLI_MODE_GENERIC,[xs.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>s0?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,xs.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function To(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return du(e);let r=t.serialize;if(r)return r(e);let n=$f(t);return r=t.serialize=n.serializer.serialize,r(e)}function wee(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 Oo(e,t){e||(e="");let r=e.indexOf(";"),n;r>-1&&(n=e.slice(r+1),e=e.slice(0,r));let s=qt.get(e);if(t){if(s?.deserializeStream)return s.deserializeStream;let i=qt.get(e)?.deserialize||i0(e,n);return o=>wee(o).then(i)}return e&&qt.get(e)?.deserialize||i0(e,n)}function i0(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 Hg(r)}catch{}return{contentType:e||"application/octet-stream",data:r}}}function Cee(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 kf,ls,Ao,xs,o0,Vf,a0,vg,Bg,c0,l0,du,Hg,fu,qt,xg,n0,u0,Nee,Iee,s0,Ia=Re(()=>{em();kf=B(qf()),ls=require("msgpackr"),Ao=require("cbor-x"),xs=require("zlib"),o0=B(ne()),Vf=require("stream");ur();a0=require("../../index"),vg=B(te()),Bg=B(U()),c0=B(require("yaml")),l0=vg.default.get(Bg.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,du=l0?Fi:JSON.stringify,Hg=l0?Zh:JSON.parse,fu={useRecords:!1,useToJSON:!0},qt=new Map,xg=qt;it.contentTypes=xg;(0,a0._assignPackageExport)("contentTypes",xg);qt.set("application/json",{serializeStream:wc,serialize:du,deserialize:Hg,q:.8});n0=new Ao.Encoder(fu);qt.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new Ao.EncoderStream(fu).end(e)},serialize:n0.encode,deserialize:n0.decode,q:1});qt.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?Vf.Readable.from((0,ls.encodeIter)(e,fu)):(0,ls.pack)(e)},serialize:ls.pack,deserialize:ls.unpack,q:.9});qt.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,kf.toCsvStream)(e,e?.getColumns?.())},serialize(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),e&&!e[Symbol.iterator]&&(e=[e.toJSON?e.toJSON():e]),(0,kf.toCsvStream)(e,e?.getColumns?.())},q:.1});qt.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.2});qt.set("text/yaml",{serialize(e){return c0.stringify(e,{aliasDuplicateObjects:!1})},q:.7});qt.set("text/event-stream",{serializeStream:function(e){return Vf.Readable.from(Cee(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+`
20
- `),e.data){let r=e.data;typeof r=="object"&&(r=du(r)),t+="data: "+r+`
15
+ Database backup has not been removed and can be found here: ${s}`;Yd.error(l),console.error(l)}(0,JA.get)(yo.CONFIG_PARAMS.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,La.remove)(s))}(0,XA.updateConfigValue)(yo.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1)}async function SB(e){let t=await(0,AB.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function bB(e,t){console.log("copyDb start");let r=ct()[e],n;for(let f in r){n=r[f].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,TB.open)(new gB.default(t)),c=o.openDB(Fh.INTERNAL_DBIS_NAME),l,d=0,u=s.useReadTransaction();try{for(let{key:_,value:h}of s.getRange({transaction:u})){let p=h.is_hash_attribute||h.isPrimaryKey,S,g;if(p&&(S=h.compression,g=Gh(),g?h.compression=g:delete h.compression,S?.dictionary?.toString()===g?.dictionary?.toString()&&(S=null,g=null)),c.put(_,h),!(p||h.indexed))continue;let T=new RB.default(!p,p);T.encoding="binary",T.compression=S;let A=n.openDB(_,T);A.decoder=null,T.compression=g;let N=o.openDB(_,T);N.encoder=null,console.log("copying",_,"from",e,"to",t),await E(A,N,p,u)}let f=n.openDB(Fh.AUDIT_STORE_NAME,Kd);console.log("copying audit log"),E(i,f,!1,u);async function E(_,h,p,S){let g=0,T=0;for(let{key:A,value:N,version:V}of _.getRange({start:null,versions:p,transaction:S}))l=h.put(A,N,V),g++,S.openTimer&&(S.openTimer=0),T+=(A?.length||10)+N.length,d++>5e3&&(await l,console.log("copied",g,"entries",T,"bytes"),d=0);console.log("finish copying, copied",g,"entries",T,"bytes")}a(E,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{u.done(),o.close()}}var TB,kh,La,JA,gB,RB,Fh,yo,AB,XA,Yd,OB=Oe(()=>{Ne();TB=require("lmdb"),kh=require("path"),La=require("fs-extra"),JA=U(ie()),gB=U(Au()),RB=U(Ru()),Fh=U(Ft()),yo=U(B());Ei();AB=U(ro()),XA=U(dr()),Yd=U(X());a(Vre,"compactOnStart");a(SB,"getTotalDBRecordCount");a(bB,"copyDb")});var jd=I((tRe,LB)=>{"use strict";var $re=require("minimist"),{isMainThread:eb,parentPort:Qd,threadId:Zge}=require("worker_threads"),Ot=B(),{PROCESS_DESCRIPTORS_VALIDATE:ul}=Ot,Js=X(),tb=te(),Vh=WA(),qh=jt(),eRe=Pt(),wB=dr(),Xs=pB(),NB=Gc(),{compactOnStart:Yre}=(OB(),ae(yB)),Kre=l_(),{restartWorkers:$h,onMessageByType:Wre}=at(),{handleHDBError:Qre,hdb_errors:zre}=ce(),{HTTP_STATUS_CODES:jre}=zre,zd=ie();zd.initSync();var Wd=`Restarting HarperDB. This may take up to ${Ot.RESTART_TIMEOUT_MS/1e3} seconds.`,Jre="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",IB="Clustering is not enabled so cannot be restarted",Xre="Invalid service",dl,jn;LB.exports={restart:CB,restartService:rb};eb&&Wre(Ot.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await rb({service:e.workerType}):CB({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function CB(e){jn=Object.keys(e).length===0,dl=await Xs.isServiceRegistered(Ot.HDB_PROC_DESCRIPTOR);let t=$re(process.argv);if(t.service){await rb(t);return}if(jn&&!dl){console.error(Jre);return}if(jn&&console.log(Wd),dl){Xs.enterPM2Mode(),Js.notify(Wd);let r=Kre(Object.keys(Ot.CONFIG_PARAM_MAP),!0);return tb.isEmptyOrZeroLength(Object.keys(r))||wB.updateConfigValue(void 0,void 0,r,!0,!0),Zre(),Wd}return eb?(Js.notify(Wd),zd.get(Ot.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Yre(),setTimeout(()=>{$h()},50)):Qd.postMessage({type:Ot.ITC_EVENT_TYPES.RESTART}),Wd}a(CB,"restart");async function rb(e){let{service:t}=e;if(Ot.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw Qre(new Error,Xre,jre.BAD_REQUEST,void 0,void 0,!0);if(dl=await Xs.isServiceRegistered(Ot.HDB_PROC_DESCRIPTOR),!eb)return Qd.postMessage({type:Ot.ITC_EVENT_TYPES.RESTART,workerType:t}),Qd.ref(),new Promise(n=>{Qd.on("message",s=>{s.type==="restart-complete"&&(n(),Qd.unref())})});let r;switch(t){case ul.clustering:if(!zd.get(Ot.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=IB;break}jn&&console.log("Restarting clustering"),Js.notify("Restarting clustering"),await DB();break;case ul.clustering_config:case ul["clustering config"]:if(!zd.get(Ot.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=IB;break}jn&&console.log("Restarting clustering_config"),Js.notify("Restarting clustering_config"),await Xs.reloadClustering();break;case"custom_functions":case"custom functions":case ul.harperdb:case ul.http_workers:case ul.http:if(jn&&!dl){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}jn&&console.log("Restarting http_workers"),Js.notify("Restarting http_workers"),jn?await Xs.restart(Ot.HDB_PROC_DESCRIPTOR):await $h("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Js.error(r),jn&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(rb,"restartService");async function Zre(){await DB(),await Xs.restart(Ot.HDB_PROC_DESCRIPTOR),await tb.async_set_timeout(2e3),zd.get(Ot.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await ZA(),jn&&(await qh.closeConnection(),process.exit(0))}a(Zre,"restartPM2Mode");async function DB(){if(!wB.getConfigFromFile(Ot.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await NB.getHDBProcessInfo()).clustering.length===0)Js.trace("Clustering not running, restart will start clustering services"),await Vh.generateNatsConfig(!0),await Xs.startClusteringProcesses(),await Xs.startClusteringThreads(),await ZA(),jn&&await qh.closeConnection();else{await Vh.generateNatsConfig(!0),dl?(Js.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await Xs.restart(Ot.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Xs.restart(Ot.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await NB.getHDBProcessInfo()).clustering.forEach(s=>{Js.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await tb.async_set_timeout(3e3),await ZA(),await qh.updateLocalStreams(),jn&&await qh.closeConnection(),Js.trace("Restart clustering restarting ingest and reply service threads");let t=$h(Ot.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=$h(Ot.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(DB,"restartClustering");async function ZA(){await Vh.removeNatsConfig(Ot.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Vh.removeNatsConfig(Ot.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(ZA,"removeNatsConfig")});var qB=I((sRe,GB)=>{"use strict";var nRe=require("lodash"),sn=B(),{handleHDBError:PB,hdb_errors:ene}=ce(),{HDB_ERROR_MSGS:tne,HTTP_STATUS_CODES:rne}=ene,nb=X();GB.exports={getRolePermissions:sne};var Pa=Object.create(null),nne=a(e=>({key:e,perms:{}}),"perms_template_obj"),xB=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),BB=a((e=!1,t=!1,r=!1,n=!1)=>({[sn.PERMS_CRUD_ENUM.READ]:e,[sn.PERMS_CRUD_ENUM.INSERT]:t,[sn.PERMS_CRUD_ENUM.UPDATE]:r,[sn.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),sb=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...BB(t,r,n,s)}),"table_perms_template"),MB=a((e,t=BB())=>({attribute_name:e,describe:FB(t),[Jd]:t[Jd],[ib]:t[ib],[ob]:t[ob]}),"attr_perms_template"),UB=a((e,t=!1)=>({attribute_name:e,describe:t,[Jd]:t}),"timestamp_attr_perms_template"),{READ:Jd,INSERT:ib,UPDATE:ob}=sn.PERMS_CRUD_ENUM,HB=Object.values(sn.PERMS_CRUD_ENUM),kB=[Jd,ib,ob];function sne(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[sn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Pa[t]&&Pa[t].key===n)return Pa[t].perms;let s=ine(e,r);return Pa[t]?Pa[t].key=n:Pa[t]=nne(n),Pa[t].perms=s,s}catch(r){if(!e[sn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[sn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<sn.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 nb.error(n),nb.debug(r),PB(new Error,tne.OUTDATED_PERMS_TRANSLATION_ERROR,rne.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
16
+ ${r.stack}`;throw nb.error(n),PB(new Error)}}}a(sne,"getRolePermissions");function ine(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[sn.SYSTEM_SCHEMA_NAME]=n[sn.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]=one(t[i]);return}r[i]=xB(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],d=ane(c,l);r[i].describe||HB.forEach(u=>{d[u]&&(r[i].describe=!0)}),r[i].tables[o]=d}else r[i].tables[o]=sb()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=sb()})}),r}a(ine,"translateRolePermissions");function one(e){let t=xB(!0);return Object.keys(e).forEach(r=>{t.tables[r]=sb(!0,!0,!0,!0,!0)}),t}a(one,"createStructureUserPermissions");function ane(e,t){let{attribute_permissions:r}=e;if(r.length>0){let s=Object.assign({},e);s.attribute_permissions=[];let i=r.reduce((d,u)=>{let{attribute_name:f}=u,E=u;return sn.TIME_STAMP_NAMES.includes(f)&&(E=UB(f,u[Jd])),d[f]=E,d},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=MB(o);return t.attributes.forEach(({attribute:d})=>{if(i[d]){let u=i[d];u.describe=FB(u),s.attribute_permissions.push(u),c||cne(u,l)}else if(d!==o){let u;sn.TIME_STAMP_NAMES.includes(d)?u=UB(d):u=MB(d),s.attribute_permissions.push(u)}}),c||s.attribute_permissions.push(l),s.describe=vB(s),s}else return e.describe=vB(e),e}a(ane,"getTableAttrPerms");function vB(e){return HB.filter(t=>e[t]).length>0}a(vB,"getSchemaTableDescribePerm");function FB(e){return kB.filter(t=>e[t]).length>0}a(FB,"getAttributeDescribePerm");function cne(e,t){kB.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(cne,"checkForHashPerms")});var VB={};Ze(VB,{Headers:()=>Ui,appendHeader:()=>ab,mergeHeaders:()=>cb});function ab(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function cb(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new Ui(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var Ui,Xd=Oe(()=>{Ui=class extends Map{static{a(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(ab,"appendHeader");a(cb,"mergeHeaders")});var Zd={};Ze(Zd,{authentication:()=>jB,bypassAuth:()=>hne,login:()=>pne,logout:()=>Sne,start:()=>mne});function hne(){zB=!0}async function jB(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let _=e.isOperationsServer?fne?dne:[]:une?lne:[];if(_.includes(i)||_.includes("*")){if(e.method==="OPTIONS"){let h=new Ui([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Yh&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Yh&&o.push("Access-Control-Allow-Credentials","true")}}let l,d;if(Yh){i||(i=r.host);let _=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let p of h)if(p.startsWith(_)){let S=p.indexOf(";");l=p.slice(_.length,S===-1?p.length:S),d=await $B.get(l);break}e.session=d||(d={})}let u=a((_,h,p)=>{let S=new fl.AuthAuditLog(_,h,Er.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);S.auth_strategy=p,l&&(S.session_id=l),r.referer&&(S.referer=r.referer),r.origin&&(S.origin=r.origin),h===Er.AUTH_AUDIT_STATUS.SUCCESS?lb.notify(S):lb.error(S)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&lb.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let _=e.mtlsConfig.user;_!==null?((_===void 0||_==="Common Name"||_==="CN")&&(_=e.peerCertificate.subject.CN),e.user=await st.getUser(_,null,null),u(_,Er.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,fl.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let f;if(!e.user)if(n){if(f=Ma.get(n),!f){let _=n.indexOf(" "),h=n.slice(0,_),p=n.slice(_+1),S,g;try{switch(h){case"Basic":let T=atob(p),A=T.indexOf(":");S=T.slice(0,A),g=T.slice(A+1),f=S||g?await st.getUser(S,g,e):null;break;case"Bearer":try{f=await(0,Kh.validateOperationToken)(p)}catch(N){if(N.message==="invalid token")try{return await(0,Kh.validateRefreshToken)(p),c({status:-1})}catch{throw N}}break}}catch(T){return Ene&&(Ma.get(p)||(Ma.set(p,p),u(S,Er.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:Ua({error:T.message},e)})}Ma.set(n,f),_ne&&u(f.username,Er.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=f}else d?.user?e.user=await st.getUser(d.user,null,e):(zB&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,KB.getSuperUser)());Yh&&(e.session.update=function(_){if(!l){l=(0,WB.v4)();let p=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",p):E?.headers?.set&&E.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")):E?.headers?.set&&(i&&E.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),E.headers.set("X-Hdb-Session","Secure"))),_.id=l,$B.put(_)},e.login=async function(_,h){e.user=await st.getUser(_,h,e),e.session.update({user:e.user.username})},(f&&!d||d?.user?.username!==f?.username)&&r["user-agent"]?.startsWith("Mozilla")&&e.session.update({user:e.user.username}));let E=await t(e);return E&&(E.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&mo.loginPath?(E.status=302,E.headers.set("Location",mo.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(l){throw c(l)}function c(l){let d=o.length;if(d>0){let u=l.headers;u||(l.headers=u=new Ui);for(let f=0;f<d;){let E=o[f++];u.set(E,o[f++])}}return o=null,l}a(c,"applyResponseHeaders")}function mne({server:e,port:t}){e.http(jB,{port:t||"all"}),YB||(YB=!0,setInterval(()=>{Ma=new Map},Jn.get(Er.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),QB.user.addListener(()=>{Ma=new Map}))}async function pne(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 Sne(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var KB,Kh,WB,Jn,Er,fl,QB,lb,lne,une,dne,fne,$B,Yh,zB,_ne,Ene,Ma,YB,Wh=Oe(()=>{KB=U(yn());Lr();pd();Kh=U(_d());Ne();WB=require("uuid"),Jn=U(ie()),Er=U(B()),fl=U(X()),QB=U(Uu());Xd();_l();lb=(0,fl.loggerWithTag)("auth-event");Jn.initSync();lne=Jn.get(Er.CONFIG_PARAMS.HTTP_CORSACCESSLIST),une=Jn.get(Er.CONFIG_PARAMS.HTTP_CORS),dne=Jn.get(Er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),fne=Jn.get(Er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),$B=dt({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Yh=Jn.get(Er.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,zB=process.env.AUTHENTICATION_AUTHORIZELOCAL??Jn.get(Er.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,_ne=Jn.get(Er.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,Ene=Jn.get(Er.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Ma=new Map;st.onInvalidatedUser(()=>{Ma=new Map});a(hne,"bypassAuth");a(jB,"authentication");a(mne,"start");a(pne,"login");a(Sne,"logout")});var nH=I((_Re,rH)=>{"use strict";var ge=require("joi"),JB=require("fs-extra"),XB=require("path"),Ln=mt(),ZB=ie(),eH=B(),tH=X(),{hdb_errors:Tne}=ce(),{HDB_ERROR_MSGS:Ar}=Tne,vi=/^[a-zA-Z0-9-_]+$/,gne=/^[a-zA-Z0-9-_]+$/;rH.exports={getDropCustomFunctionValidator:Ane,setCustomFunctionValidator:bne,addComponentValidator:Ine,dropCustomFunctionProjectValidator:wne,packageComponentValidator:Cne,deployComponentValidator:Dne,setComponentFileValidator:yne,getComponentFileValidator:Nne,dropComponentFileValidator:One,addSSHKeyValidator:Lne,updateSSHKeyValidator:Pne,deleteSSHKeyValidator:Mne,setSSHKnownHostsValidator:Une};function Qh(e,t,r){try{let n=ZB.get(eH.CONFIG_PARAMS.COMPONENTSROOT),s=XB.join(n,t);return JB.existsSync(s)?e?t:r.message(Ar.PROJECT_EXISTS):e?r.message(Ar.NO_PROJECT):t}catch(n){return tH.error(n),r.message(Ar.VALIDATION_ERR)}}a(Qh,"checkProjectExists");function ef(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(ef,"checkFilePath");function Rne(e,t,r,n){try{let s=ZB.get(eH.CONFIG_PARAMS.COMPONENTSROOT),i=XB.join(s,e,t,r+".js");return JB.existsSync(i)?r:n.message(Ar.NO_FILE)}catch(s){return tH.error(s),n.message(Ar.VALIDATION_ERR)}}a(Rne,"checkFileExists");function Ane(e){let t=ge.object({project:ge.string().pattern(vi).custom(Qh.bind(null,!0)).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME}),type:ge.string().valid("helpers","routes").required(),file:ge.string().pattern(vi).custom(Rne.bind(null,e.project,e.type)).custom(ef).required().messages({"string.pattern.base":Ar.BAD_FILE_NAME})});return Ln.validateBySchema(e,t)}a(Ane,"getDropCustomFunctionValidator");function bne(e){let t=ge.object({project:ge.string().pattern(vi).custom(Qh.bind(null,!0)).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME}),type:ge.string().valid("helpers","routes").required(),file:ge.string().custom(ef).required(),function_content:ge.string().required()});return Ln.validateBySchema(e,t)}a(bne,"setCustomFunctionValidator");function yne(e){let t=ge.object({project:ge.string().pattern(vi).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME}),file:ge.string().custom(ef).required(),payload:ge.string().allow("").optional(),encoding:ge.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Ln.validateBySchema(e,t)}a(yne,"setComponentFileValidator");function One(e){let t=ge.object({project:ge.string().pattern(vi).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME}),file:ge.string().custom(ef).optional()});return Ln.validateBySchema(e,t)}a(One,"dropComponentFileValidator");function Nne(e){let t=ge.object({project:ge.string().required(),file:ge.string().custom(ef).required(),encoding:ge.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Ln.validateBySchema(e,t)}a(Nne,"getComponentFileValidator");function Ine(e){let t=ge.object({project:ge.string().pattern(vi).custom(Qh.bind(null,!1)).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME})});return Ln.validateBySchema(e,t)}a(Ine,"addComponentValidator");function wne(e){let t=ge.object({project:ge.string().pattern(vi).custom(Qh.bind(null,!0)).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME})});return Ln.validateBySchema(e,t)}a(wne,"dropCustomFunctionProjectValidator");function Cne(e){let t=ge.object({project:ge.string().pattern(vi).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME}),skip_node_modules:ge.boolean()});return Ln.validateBySchema(e,t)}a(Cne,"packageComponentValidator");function Dne(e){let t=ge.object({project:ge.string().pattern(vi).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME}),payload:ge.string().optional().messages({"string.pattern.base":Ar.BAD_PACKAGE}),package:ge.string().optional(),restart:ge.boolean().optional()});return Ln.validateBySchema(e,t)}a(Dne,"deployComponentValidator");function Lne(e){let t=ge.object({name:ge.string().pattern(gne).required().messages({"string.pattern.base":Ar.BAD_SSH_KEY_NAME}),key:ge.string().required(),host:ge.string().required(),hostname:ge.string().required(),known_hosts:ge.string().optional()});return Ln.validateBySchema(e,t)}a(Lne,"addSSHKeyValidator");function Pne(e){let t=ge.object({name:ge.string().required(),key:ge.string().required()});return Ln.validateBySchema(e,t)}a(Pne,"updateSSHKeyValidator");function Mne(e){let t=ge.object({name:ge.string().required()});return Ln.validateBySchema(e,t)}a(Mne,"deleteSSHKeyValidator");function Une(e){let t=ge.object({known_hosts:ge.string().required()});return Ln.validateBySchema(e,t)}a(Une,"setSSHKnownHostsValidator")});var Zh=I((hRe,lH)=>{"use strict";var zh=require("joi"),va=require("path"),Jh=require("fs-extra"),{exec:vne}=require("child_process"),xne=require("util"),sH=xne.promisify(vne),ml=B(),{handleHDBError:El,hdb_errors:Bne}=ce(),{HTTP_STATUS_CODES:hl}=Bne,Sl=ie(),Hne=mt(),pl=X();Sl.initSync();var ub=Sl.get(ml.CONFIG_PARAMS.COMPONENTSROOT),iH="npm install --omit=dev --json",kne=`${iH} --dry-run`,Fne=Sl.get(ml.CONFIG_PARAMS.ROOTPATH),jh=va.join(Fne,"ssh");lH.exports={installModules:$ne,auditModules:Yne,installAllRootModules:Gne,uninstallRootModule:qne,linkHarperdb:Vne};async function Gne(e=!1){await Xh();let t=!1,r=process.env;Jh.pathExistsSync(jh)&&Jh.readdirSync(jh).forEach(n=>{n.includes(".key")&&!t&&(r=Object.assign({GIT_SSH_COMMAND:"ssh -F "+va.join(jh,"config")+" -o UserKnownHostsFile="+va.join(jh,"known_hosts")},process.env),t=!0)}),await tf(e?"npm install --ignore-scripts":"npm install",Sl.get(ml.CONFIG_PARAMS.ROOTPATH),r)}a(Gne,"installAllRootModules");async function qne(e){await tf(`npm uninstall ${e}`,Sl.get(ml.CONFIG_PARAMS.ROOTPATH))}a(qne,"uninstallRootModule");async function Vne(){await Xh(),await tf(`npm link ${ml.PACKAGE_ROOT}`,Sl.get(ml.CONFIG_PARAMS.ROOTPATH))}a(Vne,"linkHarperdb");async function tf(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await sH(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
17
+ `,""))}return s&&!s.includes("Debugger listening")&&pl.error("Error running NPM command:",e,s),pl.trace(n,s),n?.replace(`
18
+ `,"")}a(tf,"runCommand");async function $ne(e){pl.info(`starting installModules for request: ${e}`);let t=cH(e);if(t)throw El(t,t.message,hl.BAD_REQUEST);let{projects:r,dry_run:n}=e,s=n===!0?kne:iH;await Xh(),await aH(r);let i={};for(let o=0,c=r.length;o<c;o++){let l=r[o];i[l]={npm_output:null,npm_error:null};let d=va.join(ub,l),u,f=null;try{let{stdout:E,stderr:_}=await sH(s,{cwd:d});u=E?E.replace(`
19
+ `,""):null,f=_?_.replace(`
20
+ `,""):null}catch(E){E.stderr?i[l].npm_error=oH(E.stderr):i[l].npm_error=E.message;continue}try{i[l].npm_output=JSON.parse(u)}catch{i[l].npm_output=u}try{i[l].npm_error=JSON.parse(f)}catch{i[l].npm_error=f}}return pl.info(`finished installModules with response ${i}`),i}a($ne,"installModules");function oH(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
21
+ `);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(oH,"parseNPMStdErr");async function Yne(e){pl.info(`starting auditModules for request: ${e}`);let t=cH(e);if(t)throw El(t,t.message,hl.BAD_REQUEST);let{projects:r}=e;await Xh(),await aH(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=va.join(ub,o);n[o]={npm_output:null,npm_error:null};try{let l=await tf("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=oH(l.stderr)}}return pl.info(`finished auditModules with response ${n}`),n}a(Yne,"auditModules");async function Xh(){try{return await tf("npm -v"),!0}catch{throw El(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",hl.BAD_REQUEST,void 0,void 0,!0)}}a(Xh,"checkNPMInstalled");async function aH(e){if(!Array.isArray(e)||e.length===0)throw El(new Error,"projects argument must be an array with at least 1 element",hl.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=va.join(ub,i.toString());if(!await Jh.pathExists(o)){t.push(i);continue}let l=va.join(o,"package.json");await Jh.pathExists(l)||r.push(i)}if(t.length>0)throw El(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,hl.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw El(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,hl.BAD_REQUEST,void 0,void 0,!0)}a(aH,"checkProjectPaths");function cH(e){let t=zh.object({projects:zh.array().min(1).items(zh.string()).required(),dry_run:zh.boolean().default(!1)});return Hne.validateBySchema(e,t)}a(cH,"modulesValidator")});var fb=I((pRe,EH)=>{"use strict";var Tl=require("fs-extra"),db=require("path"),em=X(),uH=te(),tm=B(),_H=ie(),Kne=dr();EH.exports=Wne;async function Wne(){let e=Qne(),t=_H.get(tm.CONFIG_PARAMS.ROOTPATH),r=db.join(t,"package.json"),n={dependencies:{harperdb:"file:"+tm.PACKAGE_ROOT}},s=db.join(t,"node_modules");Tl.ensureDirSync(s);let i,o=!0,c=!1;try{i=Tl.readJsonSync(r)}catch(l){if(uH.isEmptyOrZeroLength(e))return;if(l.code!==tm.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!uH.isEmptyOrZeroLength(e)){for(let{name:l,package:d}of e){let u=dH(d);n.dependencies[l]=u+d}if(!o){em.notify("Installing components"),await fH(r,n,null);return}for(let{name:l,package:d}of e){let u=i.dependencies[l],f=dH(d);if(u===void 0||u!==f+d){c=!0;break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(em.notify("Removing component",l),c=!0);c&&(em.notify("Updating components."),await fH(r,n,i))}a(Wne,"installComponents");function Qne(){let e=Kne.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(Qne,"getComponentsConfig");function dH(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":db.extname(e)||Tl.existsSync(e)?"file:":"github:"}a(dH,"getPkgPrefix");async function fH(e,t,r){em.trace("npm installing components package.json",t),Tl.writeFileSync(e,JSON.stringify(t,null," "));try{await Zh().installAllRootModules(_H.get(tm.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?Tl.writeFileSync(e,JSON.stringify(r,null," ")):Tl.unlinkSync(e),n}}a(fH,"installPackages")});var hb=I(SH=>{"use strict";var Se=require("fs-extra"),_b=require("fast-glob"),Re=require("path"),mH=require("tar-fs"),zne=require("gunzip-maybe"),TRe=require("uuid").v4,Eb=require("normalize-path"),on=nH(),Mt=X(),lt=B(),$t=ie(),rf=dr(),jne=te(),{PACKAGE_ROOT:Jne}=B(),{handleHDBError:Ut,hdb_errors:Xne}=ce(),{basename:Zne}=require("path"),ese=fb(),pH=ie(),tse=B(),{Readable:rse}=require("stream"),{isMainThread:nse}=require("worker_threads"),{HDB_ERROR_MSGS:xa,HTTP_STATUS_CODES:vt}=Xne,sse=at(),ise=Re.join(Jne,"application-template"),hH=Re.join($t.get(lt.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp"),ose=$t.get(lt.CONFIG_PARAMS.ROOTPATH),Oo=Re.join(ose,"ssh"),xi=Re.join(Oo,"known_hosts");function ase(){Mt.trace("getting custom api status");let e={};try{e={port:$t.get(lt.CONFIG_PARAMS.HTTP_PORT),directory:$t.get(lt.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Ut(new Error,xa.FUNCTION_STATUS,vt.INTERNAL_SERVER_ERROR,Mt.ERR,t)}return e}a(ase,"customFunctionsStatus");function cse(){Mt.trace("getting custom api endpoints");let e={},t=$t.get(lt.CONFIG_PARAMS.COMPONENTSROOT);try{_b.sync(Eb(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:_b.sync(Eb(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:_b.sync(Eb(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Ut(new Error,xa.GET_FUNCTIONS,vt.INTERNAL_SERVER_ERROR,Mt.ERR,r)}return e}a(cse,"getCustomFunctions");function lse(e){e.project&&(e.project=Re.parse(e.project).name),e.file&&(e.file=Re.parse(e.file).name);let t=on.getDropCustomFunctionValidator(e);if(t)throw Ut(t,t.message,vt.BAD_REQUEST);Mt.trace("getting custom api endpoint file content");let r=$t.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=Re.join(r,n,s,i+".js");try{return Se.readFileSync(o,{encoding:"utf8"})}catch(c){throw Ut(new Error,xa.GET_FUNCTION,vt.INTERNAL_SERVER_ERROR,Mt.ERR,c)}}a(lse,"getCustomFunction");function use(e){e.project&&(e.project=Re.parse(e.project).name),e.file&&(e.file=Re.parse(e.file).name);let t=on.setCustomFunctionValidator(e);if(t)throw Ut(t,t.message,vt.BAD_REQUEST);Mt.trace("setting custom function file content");let r=$t.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{return Se.outputFileSync(Re.join(r,n,s,i+".js"),o),`Successfully updated custom function: ${i}.js`}catch(c){throw Ut(new Error,xa.SET_FUNCTION,vt.INTERNAL_SERVER_ERROR,Mt.ERR,c)}}a(use,"setCustomFunction");function dse(e){e.project&&(e.project=Re.parse(e.project).name),e.file&&(e.file=Re.parse(e.file).name);let t=on.getDropCustomFunctionValidator(e);if(t)throw Ut(t,t.message,vt.BAD_REQUEST);Mt.trace("dropping custom function file");let r=$t.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{return Se.unlinkSync(Re.join(r,n,s,i+".js")),`Successfully deleted custom function: ${i}.js`}catch(o){throw Ut(new Error,xa.DROP_FUNCTION,vt.INTERNAL_SERVER_ERROR,Mt.ERR,o)}}a(dse,"dropCustomFunction");function fse(e){e.project&&(e.project=Re.parse(e.project).name);let t=on.addComponentValidator(e);if(t)throw Ut(t,t.message,vt.BAD_REQUEST);Mt.trace("adding component");let r=$t.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=Re.join(r,n);return Se.mkdirSync(s,{recursive:!0}),Se.copySync(ise,s),`Successfully added project: ${n}`}catch(s){throw Ut(new Error,xa.ADD_FUNCTION,vt.INTERNAL_SERVER_ERROR,Mt.ERR,s)}}a(fse,"addComponent");function _se(e){e.project&&(e.project=Re.parse(e.project).name);let t=on.dropCustomFunctionProjectValidator(e);if(t)throw Ut(t,t.message,vt.BAD_REQUEST);Mt.trace("dropping custom function project");let r=$t.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=$t.get(lt.CONFIG_PARAMS.APPS);if(!jne.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 rf.updateConfigValue(lt.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=Re.join(r,n);return Se.rmSync(i,{recursive:!0}),`Successfully deleted project: ${n}`}catch(i){throw Ut(new Error,xa.DROP_FUNCTION_PROJECT,vt.INTERNAL_SERVER_ERROR,Mt.ERR,i)}}a(_se,"dropCustomFunctionProject");async function Ese(e){e.project&&(e.project=Re.parse(e.project).name);let t=on.packageComponentValidator(e);if(t)throw Ut(t,t.message,vt.BAD_REQUEST);let r=$t.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Mt.trace("packaging component",n);let s;try{s=await Se.realpath(Re.join(r,n))}catch(l){if(l.code!==lt.NODE_ERROR_CODES.ENOENT)throw l;try{s=await Se.realpath(Re.join($t.get(lt.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(d){if(d.code===lt.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}await Se.ensureDir(hH);let i=Re.join(hH,`${n}.tar`),o={};(e.skip_node_modules===!0||e.skip_node_modules==="true")&&(o={ignore:l=>l.includes(Re.join(s,"node_modules"))}),mH.pack(s,o).pipe(Se.createWriteStream(i,{overwrite:!0})),await new Promise(l=>setTimeout(l,2e3));let c=Se.readFileSync(i,{encoding:"base64"});return await Se.remove(i),{project:n,payload:c}}a(Ese,"packageComponent");async function hse(e){e.project&&(e.project=Re.parse(e.project).name);let t=on.deployComponentValidator(e);if(t)throw Ut(t,t.message,vt.BAD_REQUEST);let r=$t.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i}=e;if(Mt.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let o;if(s){o=Re.join(r,n),i="file:"+o,await Se.emptyDir(o);let E=rse.from(Buffer.from(s,"base64"));await new Promise((h,p)=>{E.pipe(zne()).pipe(mH.extract(o,{finish:h})).on("error",p)});let _=await Se.readdir(o);_.length===1&&_[0]==="package"&&(await Se.copy(Re.join(o,"package"),o),await Se.remove(Re.join(o,"package")))}if(await rf.addConfig(n,{package:i}),!s){await ese();let E=pH.get(tse.CONFIG_PARAMS.ROOTPATH);o=Re.join(E,"node_modules",n)}if(nse)return;let c=new Map;c.isWorker=!0;let l=(nm(),ae(rm)),d;l.setErrorReporter(E=>d=E);let u=Zne(o),f=l.component_errors.get(u);try{await l.loadComponent(o,c)}finally{l.component_errors.set(u,f)}if(d)throw d;return Mt.info("Installed component"),e.restart===!0?(sse.restartWorkers("http"),`Successfully deployed: ${n}, restarting HarperDB`):`Successfully deployed: ${n}`}a(hse,"deployComponent");async function mse(){let e=rf.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 l=await Se.readdir(o,{withFileTypes:!0});for(let d of l){let u=d.name;if(u.startsWith(".")||u==="node_modules")continue;let f=Re.join(o,u);if(d.isDirectory()||d.isSymbolicLink()){let E={name:u,entries:[]};c.entries.push(E),await r(f,E)}else{let E=await Se.stat(f),_={name:Re.basename(u),mtime:E.mtime,size:E.size};c.entries.push(_)}}return c}catch(l){return Mt.warn("Error loading package",l),{error:l.toString(),entries:[]}}},"walk_dir"),n=await r($t.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{name:$t.get(lt.CONFIG_PARAMS.COMPONENTSROOT).split(Re.sep).slice(-1).pop(),entries:t});for(let o of n.entries)if(o.package){let c=await r(Re.join($t.get(lt.CONFIG_PARAMS.ROOTPATH),"node_modules",o.name),{name:o.name,entries:[]});Object.assign(o,c)}let i=(nm(),ae(rm)).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(mse,"getComponents");async function pse(e){let t=on.getComponentFileValidator(e);if(t)throw Ut(t,t.message,vt.BAD_REQUEST);let n=rf.getConfigObj()[e.project]||e.project==="harperdb"?Re.join(pH.get(lt.CONFIG_PARAMS.ROOTPATH),"node_modules"):$t.get(lt.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await Se.stat(Re.join(n,e.project,e.file));return{message:await Se.readFile(Re.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===lt.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${Re.join(e.project,e.file)}'`):i}}a(pse,"getComponentFile");async function Sse(e){let t=on.setComponentFileValidator(e);if(t)throw Ut(t,t.message,vt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=Re.join($t.get(lt.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);return e.payload!==void 0?(await Se.ensureFile(n),await Se.outputFile(n,e.payload,r)):await Se.ensureDir(n),"Successfully set component: "+e.file}a(Sse,"setComponentFile");async function Tse(e){let t=on.dropComponentFileValidator(e);if(t)throw Ut(t,t.message,vt.BAD_REQUEST);let r=e.file?Re.join(e.project,e.file):e.project,n=Re.join($t.get(lt.CONFIG_PARAMS.COMPONENTSROOT),r);return await Se.pathExists(n)&&await Se.remove(n),rf.deleteConfigFromFile([e.project]),"Successfully dropped: "+r}a(Tse,"dropComponent");async function gse(e){let t=on.addSSHKeyValidator(e);if(t)throw Ut(t,t.message,vt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;Mt.trace("adding ssh key",r);let c=Re.join(Oo,r+".key"),l=Re.join(Oo,"config");if(await Se.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await Se.outputFile(c,n),await Se.chmod(c,"0600");let d=`#${r}
22
+ Host ${s}
23
+ HostName ${i}
24
+ User git
25
+ IdentityFile ${c}
26
+ IdentitiesOnly yes`;await Se.pathExists(l)?await Se.appendFile(l,`
27
+ `+d):await Se.outputFile(l,d);let u="";if(await Se.pathExists(xi)||(await Se.writeFile(xi,""),await Se.chmod(xi,"0600")),i=="github.com"&&!(await Se.readFile(xi,"utf8")).includes("github.com"))try{let p=(await(await fetch("https://api.github.com/meta")).json()).ssh_keys;for(var f of p)Se.appendFile(xi,"github.com "+f+`
28
+ `)}catch{u=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}return o&&await Se.appendFile(xi,o),`Added ssh key: ${r}${u}`}a(gse,"addSSHKey");async function Rse(e){let t=on.updateSSHKeyValidator(e);if(t)throw Ut(t,t.message,vt.BAD_REQUEST);let{name:r,key:n}=e;Mt.trace("updating ssh key",r);let s=Re.join(Oo,r+".key");if(!await Se.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");return await Se.outputFile(s,n),`Updated ssh key: ${r}`}a(Rse,"updateSSHKey");async function Ase(e){let t=on.deleteSSHKeyValidator(e);if(t)throw Ut(t,t.message,vt.BAD_REQUEST);let{name:r}=e;Mt.trace("deleting ssh key",r);let n=Re.join(Oo,r+".key"),s=Re.join(Oo,"config");if(!await Se.pathExists(n))throw new Error("Key does not exist");let i=await Se.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");return i=i.replace(o,""),await Se.outputFile(s,i),Se.removeSync(n),`Deleted ssh key: ${r}`}a(Ase,"deleteSSHKey");async function bse(e){let t=[];return await Se.pathExists(Oo)&&(await Se.readdir(Oo)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(bse,"listSSHKeys");async function yse(e){let t=on.setSSHKnownHostsValidator(e);if(t)throw Ut(t,t.message,vt.BAD_REQUEST);let{known_hosts:r}=e;return await Se.outputFile(xi,r),"Known hosts successfully set"}a(yse,"setSSHKnownHosts");async function Ose(e){return await Se.pathExists(xi)?{known_hosts:await Se.readFile(xi,"utf8")}:{known_hosts:null}}a(Ose,"getSSHKnownHosts");Object.assign(SH,{customFunctionsStatus:ase,getCustomFunctions:cse,getCustomFunction:lse,setCustomFunction:use,dropCustomFunction:dse,addComponent:fse,dropCustomFunctionProject:_se,packageComponent:Ese,deployComponent:hse,getComponents:mse,getComponentFile:pse,setComponentFile:Sse,dropComponent:Tse,addSSHKey:gse,updateSSHKey:Rse,deleteSSHKey:Ase,listSSHKeys:bse,setSSHKnownHosts:yse,getSSHKnownHosts:Ose})});var mb=I((ARe,gH)=>{"use strict";var Xn=require("joi"),TH=mt();gH.exports={readTransactionLogValidator:Nse,deleteTransactionLogsBeforeValidator:Ise};function Nse(e){let t=Xn.object({schema:Xn.string(),database:Xn.string(),table:Xn.string().required(),from:Xn.date().timestamp(),to:Xn.date().timestamp(),limit:Xn.number().min(1)});return TH.validateBySchema(e,t)}a(Nse,"readTransactionLogValidator");function Ise(e){let t=Xn.object({schema:Xn.string(),database:Xn.string(),table:Xn.string().required(),timestamp:Xn.date().timestamp().required()});return TH.validateBySchema(e,t)}a(Ise,"deleteTransactionLogsBeforeValidator")});var om=I((yRe,NH)=>{"use strict";var pb=B(),nf=jt(),RH=te(),AH=ie(),bH=pi(),yH=X(),{handleHDBError:sm,hdb_errors:wse}=ce(),{HTTP_STATUS_CODES:im}=wse,{readTransactionLogValidator:Cse,deleteTransactionLogsBeforeValidator:Dse}=mb(),OH=$n(),Lse="Logs successfully deleted from transaction log.",Pse="All logs successfully deleted from transaction log.";NH.exports={readTransactionLog:Mse,deleteTransactionLogsBefore:vse};async function Mse(e){let t=Cse(e);if(t)throw sm(t,t.message,im.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=RH.checkSchemaTableExist(e.database,e.table);if(r)throw sm(new Error,r,im.NOT_FOUND,void 0,void 0,!0);return AH.get(pb.CONFIG_PARAMS.CLUSTERING_ENABLED)?await Use(e):(yH.info("Reading HarperDB logs used by Plexus"),(e.from||e.to)&&(e.search_type="timestamp",e.search_values=[e.from??0],e.to&&(e.search_values[1]=e.to)),OH.readAuditLog(e))}a(Mse,"readTransactionLog");async function*Use(e){let t=bH.createNatsTableStreamName(e.database,e.table),r=await nf.viewStreamIterator(t,parseInt(e.from),e.limit);for await(let n of r){let s=Math.floor(n?.nats_timestamp/1e6);if(e.to&&s>e.to)break;let i={operation:n?.entry?.operation,user:n?.entry?.__origin?.user,timestamp:s,records:n?.entry?.records,attributes:n?.entry?.attributes};n?.entry?.operation===pb.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(Use,"readTransactionLogNats");async function vse(e){let t=Dse(e);if(t)throw sm(t,t.message,im.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!AH.get(pb.CONFIG_PARAMS.CLUSTERING_ENABLED))return yH.info("Delete transaction logs called for Plexus"),OH.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=RH.checkSchemaTableExist(r,n);if(i)throw sm(new Error,i,im.NOT_FOUND,void 0,void 0,!0);let o=bH.createNatsTableStreamName(r,n),{jsm:c}=await nf.getNATSReferences(),l=await nf.getStreamInfo(o),d=new Date(l.state.first_ts).getTime();if(s<=d)return`No transactions exist before: ${s}`;let u=Lse,f,E=new Date(l.state.last_ts).getTime();return s>E?(f=l.state.last_seq+1,u=Pse):f=(await nf.viewStream(o,parseInt(s),1))[0].nats_sequence,await nf.purgeTableStream(r,n,{seq:f}),u}a(vse,"deleteTransactionLogsBefore")});var wH=I((NRe,IH)=>{"use strict";var Sb=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}};IH.exports=Sb});var DH=I((wRe,CH)=>{"use strict";var Tb=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};CH.exports=Tb});var Rb=I((DRe,PH)=>{"use strict";var LH=wH(),xse=DH(),{HDB_ERROR_MSGS:Bse}=En(),gb=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=Bse.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 LH(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new xse(c,s[c]);i.push(l)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new LH(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}};PH.exports=gb});var um=I((URe,zH)=>{"use strict";var Ab=Vn(),am=An(),es=kE(),af=ro(),bb=ea(),Hse=nR(),kse=yU(),cf=yn(),cm=fR(),ar=X(),Fse=hR(),Gse=Oh(),qse=bA(),Vse=Ih(),$se=NA(),Yse=IA(),Kse=DA(),Wse=PA(),yb=vA(),Bi=te(),Qse=vx(),Ob=FA(),vH=jd(),Zn=B(),xH=qB(),zse=Gc(),BH=_d(),HH=(Wh(),ae(Zd)),kH=dr(),Xt=hb(),jse=require("alasql"),FH=om(),GH=Zh(),lf=go(),qH=(Ia(),ae(Na)),VH=Rb(),{handleHDBError:an,hdb_errors:$H}=ce(),{addNodeBack:PRe,removeNodeBack:MRe}=(Ia(),ae(Na)),{HDB_ERROR_MSGS:br,HTTP_STATUS_CODES:sf}=$H,W=new Map,YH="delete",No="insert",Hi="read",Ba="update",of="describe",MH=af.describeSchema.name,UH=af.describeTable.name,KH={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},Jse="catchup",Xse="handleGetJob",Zse="handleGetJobsByStartDate",lm={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},eie=[es.createTable.name,es.createAttribute.name,es.dropTable.name,es.dropAttribute.name],WH={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}};W.set(Ab.insert.name,new z(!1,[No]));W.set(Ab.update.name,new z(!1,[Ba]));W.set(Ab.upsert.name,new z(!1,[No,Ba]));W.set(am.searchByConditions.name,new z(!1,[Hi]));W.set(am.searchByHash.name,new z(!1,[Hi]));W.set(am.searchByValue.name,new z(!1,[Hi]));W.set(am.search.name,new z(!1,[Hi]));W.set(es.createSchema.name,new z(!0,[]));W.set(es.createTable.name,new z(!0,[]));W.set(es.createAttribute.name,new z(!1,[No]));W.set(es.dropSchema.name,new z(!0,[]));W.set(es.dropTable.name,new z(!0,[]));W.set(es.dropAttribute.name,new z(!0,[]));W.set(af.describeSchema.name,new z(!1,[Hi]));W.set(af.describeTable.name,new z(!1,[Hi]));W.set(bb.deleteRecord.name,new z(!1,[YH]));W.set(cf.addUser.name,new z(!0,[]));W.set(cf.alterUser.name,new z(!0,[]));W.set(cf.dropUser.name,new z(!0,[]));W.set(cf.listUsersExternal.name,new z(!0,[]));W.set(cm.listRoles.name,new z(!0,[]));W.set(cm.addRole.name,new z(!0,[]));W.set(cm.alterRole.name,new z(!0,[]));W.set(cm.dropRole.name,new z(!0,[]));W.set(Fse.name,new z(!0,[]));W.set(Gse.name,new z(!0,[]));W.set(qse.name,new z(!0,[]));W.set(Vse.name,new z(!0,[]));W.set($se.name,new z(!0,[]));W.set(Yse.name,new z(!0,[]));W.set(yb.setRoutes.name,new z(!0,[]));W.set(yb.getRoutes.name,new z(!0,[]));W.set(yb.deleteRoutes.name,new z(!0,[]));W.set(kH.setConfiguration.name,new z(!0,[]));W.set(Kse.clusterStatus.name,new z(!0,[]));W.set(Wse.name,new z(!0,[]));W.set(Ob.getFingerprint.name,new z(!0,[]));W.set(Ob.setLicense.name,new z(!0,[]));W.set(bb.deleteFilesBefore.name,new z(!0,[]));W.set(bb.deleteAuditLogsBefore.name,new z(!0,[]));W.set(vH.restart.name,new z(!0,[]));W.set(vH.restartService.name,new z(!0,[]));W.set(Hse.name,new z(!0,[]));W.set(kse.name,new z(!0,[Hi]));W.set(zse.systemInformation.name,new z(!0,[]));W.set(kH.getConfiguration.name,new z(!0,[]));W.set(FH.readTransactionLog.name,new z(!0,[]));W.set(FH.deleteTransactionLogsBefore.name,new z(!0,[]));W.set(GH.installModules.name,new z(!0,[]));W.set(GH.auditModules.name,new z(!0,[]));W.set(lf.createCsr.name,new z(!0,[]));W.set(lf.signCertificate.name,new z(!0,[]));W.set(lf.listCertificates.name,new z(!0,[]));W.set(lf.addCertificate.name,new z(!0,[]));W.set(lf.removeCertificate.name,new z(!0,[]));W.set(qH.addNodeBack.name,new z(!0,[]));W.set(qH.removeNodeBack.name,new z(!0,[]));W.set(BH.createTokens.name,new z(!1,[]));W.set(BH.refreshOperationToken.name,new z(!1,[]));W.set(HH.login.name,new z(!1,[]));W.set(HH.logout.name,new z(!1,[]));W.set(Xt.customFunctionsStatus.name,new z(!0,[]));W.set(Xt.getCustomFunctions.name,new z(!0,[]));W.set(Xt.getComponents.name,new z(!0,[]));W.set(Xt.getComponentFile.name,new z(!0,[]));W.set(Xt.setComponentFile.name,new z(!0,[]));W.set(Xt.dropComponent.name,new z(!0,[]));W.set(Xt.getCustomFunction.name,new z(!0,[]));W.set(Xt.setCustomFunction.name,new z(!0,[]));W.set(Xt.dropCustomFunction.name,new z(!0,[]));W.set(Xt.addComponent.name,new z(!0,[]));W.set(Xt.dropCustomFunctionProject.name,new z(!0,[]));W.set(Xt.packageComponent.name,new z(!0,[]));W.set(Xt.deployComponent.name,new z(!0,[]));W.set(Xt.addSSHKey.name,new z(!0,[]));W.set(Xt.updateSSHKey.name,new z(!0,[]));W.set(Xt.deleteSSHKey.name,new z(!0,[]));W.set(Xt.listSSHKeys.name,new z(!0,[]));W.set(Xt.setSSHKnownHosts.name,new z(!0,[]));W.set(Xt.getSSHKnownHosts.name,new z(!0,[]));W.set(Ob.getRegistrationInfo.name,new z(!1,[]));W.set(cf.userInfo.name,new z(!1,[]));W.set(af.describeAll.name,new z(!1,[]));W.set(Xse,new z(!1,[]));W.set(Zse,new z(!0,[]));W.set(Jse,new z(!0,[]));W.set(lm.CSV_DATA_LOAD,new z(!1,[No,Ba]));W.set(lm.CSV_URL_LOAD,new z(!1,[No,Ba]));W.set(lm.CSV_FILE_LOAD,new z(!1,[No,Ba]));W.set(lm.IMPORT_FROM_S3,new z(!1,[No,Ba]));W.set(WH.EXPORT_TO_S3,new z(!0,[]));W.set(WH.EXPORT_LOCAL,new z(!0,[]));W.set(Zn.VALID_SQL_OPS_ENUM.DELETE,new z(!1,[YH]));W.set(Zn.VALID_SQL_OPS_ENUM.SELECT,new z(!1,[Hi]));W.set(Zn.VALID_SQL_OPS_ENUM.INSERT,new z(!1,[No]));W.set(Zn.VALID_SQL_OPS_ENUM.UPDATE,new z(!1,[Ba]));zH.exports={verifyPerms:rie,verifyPermsAst:tie,verifyBulkLoadAttributePerms:sie};function tie(e,t,r){if(Bi.isEmptyOrZeroLength(e))throw ar.info("verify_perms_ast has an empty user parameter"),an(new Error);if(Bi.isEmptyOrZeroLength(t))throw ar.info("verify_perms_ast has an empty user parameter"),an(new Error);if(Bi.isEmptyOrZeroLength(r))throw ar.info("verify_perms_ast has a null operation parameter"),an(new Error);try{let n=new VH,s=new Qse(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw ar.info("No schemas defined in verifyPermsAst(), will not continue."),an(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&KH[r])throw an(new Error,br.DROP_SYSTEM,sf.FORBIDDEN);if(c&&!l)return null;let d=xH.getRolePermissions(t.role);t.role.permission=d,!c&&e instanceof jse.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(d));for(let f=0;f<i.length;f++){let E=s.getTablesBySchemaName(i[f]);E&&o.set(i[f],E)}let u=QH(t,r,o,n);return u||(o.forEach((f,E)=>{for(let _=0;_<f.length;_++){let h=s.getAttributesBySchemaTableName(E,f[_]),p=Ib(t.role.permission,E,f[_]);Nb(h,p,r,f[_],E,n)}}),n.getPermsResponse())}catch(n){throw an(n)}}a(tie,"verifyPermsAst");function rie(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw ar.info("null required parameter in verifyPerms"),an(new Error,br.DEFAULT_INVALID_REQUEST,sf.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 VH;if(Bi.isEmptyOrZeroLength(e.hdb_user.role)||Bi.isEmptyOrZeroLength(e.hdb_user.role.permission))return ar.info(`User ${e.hdb_user.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(br.USER_HAS_NO_PERMS(e.hdb_user.username));let l=!!e.hdb_user.role.permission.super_user,d=e.hdb_user.role.permission.structure_user,u=o.has(Zn.SYSTEM_SCHEMA_NAME)||s===Zn.SYSTEM_SCHEMA_NAME;if(u&&KH[r])throw an(new Error,br.DROP_SYSTEM,sf.FORBIDDEN);if(l&&!u||d===!0&&(r===es.createSchema.name||r===es.dropSchema.name))return null;if(eie.indexOf(r)>=0&&(d===!0||Array.isArray(d)))return d===!0||d.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let f=xH.getRolePermissions(e.hdb_user.role);if(e.hdb_user.role.permission=f,r===MH||r===UH){if(s===Zn.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(br.SCHEMA_PERM_ERROR(s));if(!f.super_user){if(r===MH&&(!f[s]||!f[s][of]))return c.handleInvalidItem(br.SCHEMA_NOT_FOUND(s));if(r===UH&&(!f[s]||!f[s].tables[i]||!f[s].tables[i][of]))return c.handleInvalidItem(br.TABLE_NOT_FOUND(s,i))}}let E=QH(e.hdb_user,r,o,c,n);if(E)return E;if(W.get(r)&&W.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&Zn.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let p=[],S=f[s].tables[i];S[Zn.PERMS_CRUD_ENUM.READ]&&(S.attribute_permissions.length>0?S.attribute_permissions.filter(T=>T[Zn.PERMS_CRUD_ENUM.READ]).forEach(T=>{p.push(T.attribute_name)}):p=global.hdb_schema[s][i].attributes.map(g=>g.attribute),e.get_attributes=p)}let _=nie(e),h=Ib(e.hdb_user.role.permission,s,i);return Nb(_,h,r,i,s,c,n),c.getPermsResponse()}a(rie,"verifyPerms");function QH(e,t,r,n,s){if(Bi.arrayHasEmptyValues([e,t,r]))throw ar.info("hasPermissions has an invalid parameter"),an(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||W.get(t).requires_su))return null;if(!W.get(t))throw ar.info(`operation ${t} not found.`),an(new Error,br.OP_NOT_FOUND(t),sf.BAD_REQUEST);if(W.get(t)&&W.get(t).requires_su)return ar.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(br.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][of]===!1){n.addInvalidItem(br.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(br.SCHEMA_NOT_FOUND(l));continue}let d=r.get(l);for(let u of d){let f=o[l].tables[u];if(!f||f[of]===!1)n.addInvalidItem(br.TABLE_NOT_FOUND(l,u));else try{let E=[],_=W.get(t).perms;!Bi.isEmpty(s)&&_.includes(s)&&(_=[s]);for(let h=0;h<_.length;h++){let p=_[h],S=f[p];(S==null||S===!1)&&(ar.info(`Required ${p} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),E.push(p))}E.length>0&&n.addUnauthorizedTable(l,u,E)}catch(E){let _=br.UNKNOWN_OP_AUTH_ERROR(t,l,u);throw ar.error(_),ar.error(E),an($H.CHECK_LOGS_WRAPPER(_))}}}return r.size<2?n.getPermsResponse():null}a(QH,"hasPermissions");function Nb(e,t,r,n,s,i,o){if(!e||!t)throw ar.info("no attributes specified in checkAttributePerms."),an(new Error);let c=W.get(r).perms;if(!c||c==="")throw ar.info(`no permissions found for ${r} in checkAttributePerms().`),an(new Error);if(Bi.isEmptyOrZeroLength(t))return ar.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let u of e){let f=t.get(u);if(f){if(f[of]===!1){i.addInvalidItem(br.ATTR_NOT_FOUND(s,n,u),s,n);continue}if(c)for(let E of c){if(Zn.TIME_STAMP_NAMES.includes(f.attribute_name)&&E!==Hi)throw an(new Error,br.SYSTEM_TIMESTAMP_PERMS_ERR,sf.FORBIDDEN);f[E]===!1&&(l[f.attribute_name]?l[f.attribute_name].push(E):l[f.attribute_name]=[E])}}else i.addInvalidItem(br.ATTR_NOT_FOUND(s,n,u),s,n)}let d=Object.keys(l);d.length>0&&i.addUnauthorizedAttributes(d,s,n,l)}a(Nb,"checkAttributePerms");function nie(e){let t=new Set;try{if(e.action)return t;if(e.operation===Zn.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS&&e.conditions.forEach(r=>{t.add(r.search_attribute)}),e&&e.search_attribute&&t.add(e.search_attribute),!e.records||e.records.length===0){if(!e.get_attributes||!e.get_attributes.length===0)return t;for(let r=0;r<e.get_attributes.length;r++)t.add(e.get_attributes[r])}else for(let r=0;r<e.records.length;r++){let n=Object.keys(e.records[r]);for(let s=0;s<n.length;s++)t.add(n[s])}}catch(r){ar.info(r)}return t}a(nie,"getRecordAttributes");function Ib(e,t,r){let n=new Map;if(Bi.isEmpty(e))return ar.info("no hdb_user specified in getAttributePermissions"),n;if(e.super_user||!t||!r)return n;try{e[t].tables[r].attribute_permissions.forEach(s=>{n.has(s.attribute_name)||n.set(s.attribute_name,s)})}catch{ar.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(Ib,"getAttributePermissions");function sie(e,t,r,n,s,i,o){let c=new Set(i),l=Ib(e,n,s);Nb(c,l,t,s,n,o,r)}a(sie,"verifyBulkLoadAttributePerms")});var fm=I((xRe,ek)=>{"use strict";ek.exports={evaluateSQL:pie,processAST:ZH,convertSQLToAST:XH,checkASTPermissions:JH};var iie=Vn(),jH=require("util"),oie=jH.callbackify(iie.insert),aie=An().search,cie=lM().update,lie=jH.callbackify(cie),uie=dM().convertDelete,Io=require("alasql"),die=um(),dm=X(),fie=RE(),_ie=te(),uf=B(),{hdb_errors:Eie,handleHDBError:wb}=ce(),{HTTP_STATUS_CODES:Cb}=Eie;fie(Io);var hie=403,mie="There was a problem performing this insert. Please check the logs and try again.",Db=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function pie(e,t){let r=e.parsed_sql_object;if(!r){r=XH(e.sql);let n,s=r.ast.statements[0];if(s instanceof Io.yy.Insert?n=s.into.databaseid:s instanceof Io.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Io.yy.Update||s instanceof Io.yy.Delete?n=s.table.databaseid:dm.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Io.yy.Select)&&_ie.isEmptyOrZeroLength(n))return t("No schema specified",null)}ZH(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(pie,"evaluateSQL");function JH(e,t){let r;try{r=die.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(JH,"checkASTPermissions");function XH(e){let t=new Db;if(!e)throw wb(new Error,"The 'sql' parameter is missing from the request body",Cb.BAD_REQUEST);try{let r=e.trim(),n=Io.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
29
+ `);throw n[1]?wb(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,Cb.BAD_REQUEST):wb(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",Cb.BAD_REQUEST)}return t}a(XH,"convertSQLToAST");function ZH(e,t,r){try{let n=Sie;if(!e.bypass_auth&&!t.permissions_checked){let i=JH(e,t);if(i&&i.length>0)return r(hie,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case uf.VALID_SQL_OPS_ENUM.SELECT:n=aie,s=t.ast.statements[0];break;case uf.VALID_SQL_OPS_ENUM.INSERT:n=Tie;break;case uf.VALID_SQL_OPS_ENUM.UPDATE:n=lie;break;case uf.VALID_SQL_OPS_ENUM.DELETE:n=uie;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(ZH,"processAST");function Sie(e,t){dm.info(e),t("unknown sql statement")}a(Sie,"nullFunction");function Tie({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=gie(i,e.values)}catch(o){return r(o)}oie(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){dm.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(Tie,"convertInsert");function gie(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]]=Io.compile(`SELECT ${s.toString()} AS [${uf.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw dm.error(r),new Error(mie)}}a(gie,"createDataObjects")});var Lb=I((HRe,rk)=>{"use strict";var{S3:Rie,GetObjectCommand:Aie}=require("@aws-sdk/client-s3");rk.exports={getFileStreamFromS3:bie,getS3AuthObj:tk};async function bie(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await tk(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new Aie(r))).Body}a(bie,"getFileStreamFromS3");function tk(e,t,r){return new Rie({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(tk,"getS3AuthObj")});var _m=I((FRe,dk)=>{"use strict";var Mb=An(),yie=fm(),Oie=Lb(),{AsyncParser:Nie,Transform:Iie}=require("json2csv"),ff=require("stream"),Pn=te(),Pb=require("fs-extra"),wie=require("path"),ts=X(),{promisify:ik}=require("util"),df=te(),{handleHDBError:Zt,hdb_errors:Cie}=ce(),{HDB_ERROR_MSGS:cn,HTTP_STATUS_CODES:er}=Cie,{streamAsJSON:Die}=(yS(),ae(HI)),{Upload:Lie}=require("@aws-sdk/lib-storage"),nk=["search_by_value","search_by_hash","sql","search_by_conditions"],sk=["json","csv"],ok="json",ak="csv",Pie="Successfully exported JSON locally.",Mie="Successfully exported CSV locally.",Uie=1e3,vie=Mb.searchByHash,xie=Mb.searchByValue,Bie=ik(yie.evaluateSQL),Hie=ik(ff.finished);dk.exports={export_to_s3:qie,export_local:kie,toCsvStream:ck};async function kie(e){ts.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=lk(e);if(!Pn.isEmpty(t))throw ts.error(t),Zt(new Error,t,er.BAD_REQUEST,void 0,void 0,!0);if(Pn.isEmpty(e.path))throw ts.error(cn.MISSING_VALUE("path")),Zt(new Error,cn.MISSING_VALUE("path"),er.BAD_REQUEST,void 0,void 0,!0);let r=(Pn.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(wie.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=Pn.buildFolderPath(e.path,r);await Fie(e.path);let s=await uk(e);return await Gie(n,e.format,s)}a(kie,"export_local");async function Fie(e){if(ts.trace("in confirmPath"),Pn.isEmptyOrZeroLength(e))throw Zt(new Error,`Invalid path: ${e}`,er.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await Pb.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,ts.error(n),Zt(new Error,n,er.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 ts.error(r),Zt(new Error,r,er.BAD_REQUEST,void 0,void 0,!0)}return!0}a(Fie,"confirmPath");async function Gie(e,t,r){if(ts.trace("in saveToLocal"),df.isEmptyOrZeroLength(e))throw Zt(new Error,cn.INVALID_VALUE("file_path"),er.BAD_REQUEST,void 0,void 0,!0);if(df.isEmptyOrZeroLength(t))throw Zt(new Error,cn.INVALID_VALUE("Source format"),er.BAD_REQUEST,void 0,void 0,!0);if(df.isEmpty(r))throw Zt(new Error,cn.NOT_FOUND("Data"),er.BAD_REQUEST,void 0,void 0,!0);if(t===ok){let n=Pb.createWriteStream(e);return Die(r).pipe(n),await Hie(n),{message:Pie,path:e}}else if(t===ak){let n=Pb.createWriteStream(e),s=ff.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(u=>({label:u,value:u})));let c={objectMode:!0};return await new Nie(i,c).fromInput(s).toOutput(n).promise(!1),{message:Mie,path:e}}throw Zt(new Error,cn.INVALID_VALUE("format"),er.BAD_REQUEST)}a(Gie,"saveToLocal");async function qie(e){if(!e.s3||Object.keys(e.s3).length===0)throw Zt(new Error,cn.MISSING_VALUE("S3 object"),er.BAD_REQUEST);if(Pn.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw Zt(new Error,cn.MISSING_VALUE("aws_access_key_id"),er.BAD_REQUEST);if(Pn.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw Zt(new Error,cn.MISSING_VALUE("aws_secret_access_key"),er.BAD_REQUEST);if(Pn.isEmptyOrZeroLength(e.s3.bucket))throw Zt(new Error,cn.MISSING_VALUE("bucket"),er.BAD_REQUEST);if(Pn.isEmptyOrZeroLength(e.s3.key))throw Zt(new Error,cn.MISSING_VALUE("key"),er.BAD_REQUEST);if(Pn.isEmptyOrZeroLength(e.s3.region))throw Zt(new Error,cn.MISSING_VALUE("region"),er.BAD_REQUEST);let t=lk(e);if(!Pn.isEmpty(t))throw Zt(new Error,t,er.BAD_REQUEST);ts.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await uk(e)}catch(l){throw ts.error(l),l}let n,s=await Oie.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new ff.PassThrough;if(e.format===ak){i=e.s3.key+".csv";let l=ck(r,r.getColumns?.());l.on("error",d=>{throw d}),l.pipe(o)}else if(e.format===ok){i=e.s3.key+".json";let l=new ff.Readable;l.pipe(o),l.on("error",f=>{throw f}),l.push("[");let d=r.length,u="";for(let[f,E]of r.entries()){let _=f===d-1?JSON.stringify(E):JSON.stringify(E)+",";u+=_,f!==0&&f%Uie===0&&(l.push(u),u="")}u.length!==0&&l.push(u),l.push("]"),l.push(null)}else throw Zt(new Error,cn.INVALID_VALUE("format"),er.BAD_REQUEST);return new Lie({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(qie,"export_to_s3");function ck(e,t){let r=ff.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 Iie(n,s);return r.pipe(i)}a(ck,"toCsvStream");function lk(e){if(ts.trace("in exportCoreValidation"),Pn.isEmpty(e.format))return"format missing";if(sk.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${sk.join(", ")}`;let t=e.search_operation.operation;if(Pn.isEmpty(t))return"search_operation.operation missing";if(nk.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${nk.join(", ")}`}a(lk,"exportCoreValidation");async function uk(e){ts.trace("in getRecords");let t,r;if(df.isEmpty(e.search_operation)||df.isEmptyOrZeroLength(e.search_operation.operation))throw Zt(new Error,cn.INVALID_VALUE("Search operation"),er.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=xie;break;case"search_by_hash":t=vie;break;case"search_by_conditions":t=Mb.searchByConditions;break;case"sql":t=Bie;break;default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,ts.error(r),Zt(new Error,r,er.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(uk,"getRecords")});var gk={};Ze(gk,{contentTypes:()=>Bb,findBestSerializer:()=>mm,getDeserializer:()=>ka,registerContentHandlers:()=>Hb,serialize:()=>hf,serializeMessage:()=>Ua});function Vie(e){try{return e?.[0]===123?xb(e):e}catch{return e}}function Hb(e){e.register(Yie,{serializers:[{regex:/^application\/json$/,serializer:_u},{regex:/^application\/cbor$/,serializer:function(t){return new Ha.EncoderStream(Ef).end(t)}},{regex:/^application\/(x-)?msgpack$/,serializer:function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?hm.Readable.from((0,Zs.encodeIter)(t,Ef)):(0,Zs.pack)(t)}},{regex:/^text\/csv$/,serializer:function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,Em.toCsvStream)(t)}}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Zs.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Ha.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function mm(e){let r=(e.headers.asObject||e.headers).accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let l of c){let[d,...u]=l.split(/\s*;\s*/),f=1,E={q:1};for(let h of u){let p=h.indexOf("=");E[h.substring(0,p)]=h.substring(p+1)}f=+E.q;let _=hr.get(d);if(_){let h=(_.q||1)*f;h>s&&(n=_,i=_.type||d,s=h,o=E)}}if(!n){if(r)throw new hk.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(hr.keys()).join(", "),406);n=hr.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function hf(e,t,r){let n=_k&&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=mm(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,ki.createBrotliCompress)({params:{[ki.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?ki.constants.BROTLI_MODE_TEXT:ki.constants.BROTLI_MODE_GENERIC,[ki.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>_k?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,ki.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function Ua(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return _f(e);let r=t.serialize;if(r)return r(e);let n=mm(t);return r=t.serialize=n.serializer.serialize,r(e)}function Kie(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 ka(e,t){e||(e="");let r=e.indexOf(";"),n;r>-1&&(n=e.slice(r+1),e=e.slice(0,r));let s=hr.get(e);if(t){if(s?.deserializeStream)return s.deserializeStream;let i=hr.get(e)?.deserialize||Ek(e,n);return o=>Kie(o).then(i)}return e&&hr.get(e)?.deserialize||Ek(e,n)}function Ek(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 xb(r)}catch{}return{contentType:e||"application/octet-stream",data:r}}}function Wie(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 Em,Zs,Ha,ki,hk,hm,mk,Ub,vb,pk,Sk,_f,xb,Ef,hr,Bb,fk,Tk,$ie,Yie,_k,_l=Oe(()=>{yS();Em=U(_m()),Zs=require("msgpackr"),Ha=require("cbor-x"),ki=require("zlib"),hk=U(ce()),hm=require("stream");Lr();mk=require("../../index"),Ub=U(ie()),vb=U(B()),pk=U(require("yaml")),Sk=Ub.default.get(vb.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,_f=Sk?Vo:JSON.stringify,xb=Sk?bS:JSON.parse,Ef={useRecords:!1,useToJSON:!0},hr=new Map,Bb=hr;st.contentTypes=Bb;(0,mk._assignPackageExport)("contentTypes",Bb);hr.set("application/json",{serializeStream:_u,serialize:_f,deserialize:xb,q:.8});fk=new Ha.Encoder(Ef);hr.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new Ha.EncoderStream(Ef).end(e)},serialize:fk.encode,deserialize:fk.decode,q:1});hr.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?hm.Readable.from((0,Zs.encodeIter)(e,Ef)):(0,Zs.pack)(e)},serialize:Zs.pack,deserialize:Zs.unpack,q:.9});hr.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,Em.toCsvStream)(e,e?.getColumns?.())},serialize(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),e&&!e[Symbol.iterator]&&(e=[e.toJSON?e.toJSON():e]),(0,Em.toCsvStream)(e,e?.getColumns?.())},q:.1});hr.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.2});hr.set("text/yaml",{serialize(e){return pk.stringify(e,{aliasDuplicateObjects:!1})},q:.7});hr.set("text/event-stream",{serializeStream:function(e){return hm.Readable.from(Wie(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+`
30
+ `),e.data){let r=e.data;typeof r=="object"&&(r=_f(r)),t+="data: "+r+`
21
31
  `}return e.id&&(t+="id: "+e.id+`
22
32
  `),e.retry&&(t+="retry: "+e.retry+`
23
33
  `),t+`
24
- `}else return typeof e=="object"?`data: ${du(e)}
34
+ `}else return typeof e=="object"?`data: ${_f(e)}
25
35
 
26
36
  `:`data: ${e}
27
37
 
28
- `},compressible:!1,q:.8});qt.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()}});u0={type:"application/json",serializeStream:wc,serialize:du,deserialize:yee,q:.5};qt.set("*/*",u0);qt.set("",u0);a(yee,"tryJSONParse");a(Gg,"registerContentHandlers");Nee=require("fastify-plugin"),Iee=Nee(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=$f(n.raw);s.type(c),s.serializer(function(l){return(o.serializeStream||o.serialize)(l,{headers:{set:(_,u)=>{s.header(_,u)}}})})}),r()},{name:"content-type-negotiation"});a($f,"findBestSerializer");s0=vg.default.get(Bg.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(Yf,"serialize");a(To,"serializeMessage");a(wee,"streamToBuffer");a(Oo,"getDeserializer");a(i0,"deserializerUnknownType");a(Cee,"transformIterable")});function kg(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let d=_(l);for(let f=1;f<e.length;f++){let h=e[f],p=_(h);d=d.concat(p)}let E=new Set;return d.filter(f=>{let h=f.key??f;return E.has(h)?!1:(E.add(h),!0)})}else{let d=_(l),E=u(e.slice(1),!0,l.estimated_count);return E.length>0?o(d,E):d}function _(d){return d.conditions?kg(d.conditions,d.operator,r,n,s,i,o,c):Ba(d,n,d.descending||s.reverse===!0,r,s.allowFullScan,c)}a(_,"executeCondition");function u(d,E,f){return d.map((h,p)=>{if(h.conditions){let R=h.operator==="or",b=u(h.conditions,!R,f);return R?(C,H)=>b.some(v=>v(C,H)):(C,H)=>b.every(v=>v(C,H))}let S=(h.attribute||h[0])===r.primaryKey,T=$g(h,r,i,c,S,f);return E&&p<d.length-1&&f&&(f=xee(r.primaryStore,h.estimated_count,f)),T}).filter(Boolean)}a(u,"mapConditionsToFilters")}function Ba(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(Array.isArray(o)){let R=o[0],b=Fs(n.attributes,R);if(b.relationship){if(o.length<2)throw new Xr.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let C=b.definition?.tableClass||b.elements?.definition?.tableClass,H=new Map,v=Ba({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,C,s,H);if(b.relationship.to){i[o[0]]=H;let q=!!Fs(C.attributes,b.relationship.to)?.elements;v=Uee(v,b,C.primaryStore,q,H)}if(b.relationship.from){let q=a(M=>Ba({attribute:b.relationship.from,value:M},t,r,n,s,H),"searchEntry");b.elements?(i[o[0]]=H,v=vee(v,b,C.primaryStore,H,q)):v=v.flatMap(q)}return v}else if(o.length===1)o=o[0];else throw new Xr.ClientError("Unable to query by attribute "+JSON.stringify(o))}let _,u,d,E;c instanceof Date&&(c=c.getTime());let f;switch(Vg[l]||l){case"lt":_=!0,u=c;break;case"le":_=!0,u=c,d=!0;break;case"gt":_=c,E=!0;break;case"ge":_=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],_=c,u=c.slice(0),u[u.length-1]=us.MAXIMUM_KEY;break;case"starts_with":_=c.toString(),u=c+"\uFFFF";break;case"between":_=c[0],_ instanceof Date&&(_=_.getTime()),u=c[1],u instanceof Date&&(u=u.getTime()),d=!0;break;case"equals":case void 0:_=c,u=c,d=!0;break;case"ne":if(c===null){_=c,E=!0;break}case"sort":case"contains":case"ends_with":_=!0,f=!0;break;default:throw new Xr.ClientError(`Unknown query comparator "${l}"`)}if(r){let R=_;_=u,u=R,R=!E,E=!d,d=R}let h=o===n.primaryKey||o==null,p=h?n.primaryStore:n.indices[o],S;if(!p||p.isIndexing||f||c===null&&!p.indexNulls){if(s===!1&&!p)throw new Xr.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&f)throw new Xr.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(p?.isIndexing)throw new Xr.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&!p.indexNulls)throw new Xr.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=$g(e),!S)throw new Xr.ClientError(`Unknown search operator ${e.comparator}`)}let T={start:_,end:u,inclusiveEnd:d,exclusiveStart:E,values:!0,versions:h,transaction:t,reverse:r};if(h){let R=p.getRange(T).map(S?function({key:b,value:C}){return this.isSync?C&&S(C)?b:yi.SKIP:new Promise((H,v)=>setImmediate(()=>{try{H(C&&S(C)?b:yi.SKIP)}catch(q){v(q)}}))}:b=>b.value==null?yi.SKIP:b);return R.hasEntries=!0,R}else return p?p.getRange(T).map(S?function({key:R,value:b}){return this.isSync?S({[o]:R})?b:yi.SKIP:new Promise((C,H)=>setImmediate(()=>{try{C(S({[o]:R})?b:yi.SKIP)}catch(v){H(v)}}))}:({value:R})=>R):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:R,value:b}){return this.isSync?b&&S(b)?R:yi.SKIP:new Promise((C,H)=>setImmediate(()=>{try{C(b&&S(b)?R:yi.SKIP)}catch(v){H(v)}}))})}function Fs(e,t){if(Array.isArray(t))if(t.length>1){let r=Fs(e,t[0]),n=(r?.definition?.tableClass||r?.elements.definition?.tableClass)?.attributes;return n?Fs(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 Uee(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;s.hasMappings=!0;let o;return{next(){if(!i){let l=t.relationship.to,_=a((u,d)=>{let E=u;Array.isArray(u)&&(E=Hn(u),o=!0);let f=s.get(E);f?f.push(d):s.set(E,f=[d]),u!==E&&(f.key=u)},"add_entry");for(let u of e){let d=u.value??r.get(u.key??u),E=d?.[l];if(E!=null&&!s.filters?.some(f=>!f(d)))if(n)for(let f=0;f<E.length;f++)_(E[f],u);else _(E,u)}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 vee(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let l;if(o)for(;l=o.next(),!l.done;){let _=Hn(l.value);if(!c.has(_))return c.add(_),l}if(!i){let _=new Map;n.fromRecord=u=>u[t.relationship.from]?.filter?.(d=>_.has(Hn(d)));for(let u of e){if(n.filters){let d=r.get(u);if(n.filters.some(E=>!E(d)))continue}_.set(Hn(u),u)}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 $g(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let u=c[0],d=Fs(t.attributes,u),E=d.definition?.tableClass||d.elements.definition?.tableClass,f=n?.[u],h=$g({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},E,r,f?.[u]?.joined,c[1]===E.primaryKey,i);if(!h)return;if(f){f.filters||(f.filters=[]),f.filters.push(h);return}let p=t.propertyResolvers?.[u],S,T=a((R,b)=>{let C,H;if(p){if(p.from&&h.idFilter){if(!S)if(h.idFilter.idSet?.size===1){for(let q of h.idFilter.idSet)e={attribute:p.from,value:q};S=_(p.from,h.idFilter,!0,!0)}else S=_(p.from,h.idFilter,!1,!0);let v=S(R);return S.idFilter&&(T.idFilter=S.idFilter),v}H=p(R,r,b),C=H?.value}else C=R[u];return C?Array.isArray(C)?C.some(h):h(C,H):!1},"recordFilter");return T}}switch(l instanceof Date&&(l=l.getTime()),Vg[o]||o){case Fg.SEARCH_TYPES.EQUALS:case void 0:return _(c,u=>u===l,!0);case"contains":return _(c,u=>u?.toString().includes(l));case"ends_with":return _(c,u=>u?.toString().endsWith(l));case"starts_with":return _(c,u=>typeof u=="string"&&u.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],_(c,u=>{if(!Array.isArray(u))return!1;for(let d=0,E=l.length;d<E;d++)if(u[d]!==l[d])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),_(c,u=>(0,us.compareKeys)(u,l[0])>=0&&(0,us.compareKeys)(u,l[1])<=0,!0);case"gt":return _(c,u=>(0,us.compareKeys)(u,l)>0);case"ge":return _(c,u=>(0,us.compareKeys)(u,l)>=0);case"lt":return _(c,u=>(0,us.compareKeys)(u,l)<0);case"le":return _(c,u=>(0,us.compareKeys)(u,l)<=0);case"ne":return _(c,u=>(0,us.compareKeys)(u,l)!==0);case"sort":return()=>!0;default:throw new Xr.ClientError(`Unknown query comparator "${o}"`)}function _(u,d,E,f){let h;E=E&&!s&&t?.indices[u]&&i>3,E&&(e.estimated_count==null&&Wf(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(E=!1));let p=0,S=3;function T(R){let b=R[u],C;if(typeof b!="object"||!b||f?C=d(b):Array.isArray(b)?C=b.some(d):b instanceof Date&&(C=d(b.getTime())),E&&(S++,!C&&!T.idFilter&&++p/S*(i-S)>h)){let H=Ba(e,r.transaction.getReadTxn(),!1,t).map(Hn),v=new Set(H);T.idFilter=q=>v.has(Hn(q)),T.idFilter.idSet=v}return C}return a(T,"recordFilter"),s&&(T.idFilter=d),T}a(_,"attributeComparator")}function Wf(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/Gs(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=Vg[n]||n,n===Fg.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=Fs(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=Wf(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),l=e.indices[i.relationship.from];r.estimated_count=c+(l?c*Gs(e.indices[i.relationship.from])/(Gs(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=Gs(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=Mee*Gs(e.primaryStore)+1:n==="between"?r.estimated_count=Lee*Gs(e.primaryStore)+1:n==="sort"?r.estimated_count=Gs(e.primaryStore)+1:r.estimated_count=Dee*Gs(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function Qf(e){if(e)if(Ni=e,Ua.lastIndex=0,Bee.test(e))try{let t=Eu(new va,"");if(Dr!==Ni.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 ${Dr} in '${Ni}'`,t}else{let t=new URLSearchParams(e);return t.conditions=t,t}}function Eu(e,t){let r=Ua,n,s,i,o,c,l=decodeURIComponent,_;for(;n=r.exec(Ni);){Dr=r.lastIndex;let[,u,d]=n;if(o){if(u)throw new SyntaxError(`expected operator, but encountered '${u}'`);o=!1,c=!1}else c=!0;let E;switch(d){case"=":if(s){if(u.length<=2)i=u;else throw new SyntaxError(`invalid FIQL operator ${u}`);l=d0}else{if(l=decodeURIComponent,i="equals",!u)throw new SyntaxError("attribute must be specified before equality comparator");s=hu(u)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=Pee[d],l=qg[i]?d0:decodeURIComponent,!u)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=hu(u);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:l(u)};i==="eq"&&f0(h,u),Kf(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(hu(u)),s=void 0;break;case"(":Ua.lastIndex=Dr;let f=Eu(u?[]:new va,")");switch(u){case"":Kf(e,_),e.conditions.push(f);break;case"limit":switch(f.length){case 1:e.limit=+f[0];break;case 2:e.offset=+f[0],e.limit=f[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(f[0])&&f.length===1&&!f[0].name?(e.select=f[0],e.select.asArray=!0):f.length===1?e.select=f[0]:f.length===2&&f[1]===""?e.select=f.slice(0,1):e.select=f;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=E0(f);break;default:throw new SyntaxError(`unknown query function call ${u}`)}Ni[Dr]===","?r.lastIndex=++Dr:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!u)throw new SyntaxError("property sets must have a defined parent property name");Ua.lastIndex=Dr,E=Eu([],"}"),E.name=u,e.push(E),Ni[Dr]===","?r.lastIndex=++Dr:o=!0;break;case"[":Ua.lastIndex=Dr,u?(E=Eu(new va,"]"),E.name=u):E=Eu(e.conditions?new va:[],"]"),e.conditions?(Kf(e,_),e.conditions.push(E),s=null):e.push(E),Ni[Dr]===","?r.lastIndex=++Dr:o=!0;break;case")":case"]":case"}":if(t===d[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(u)};i==="eq"&&f0(h,u),Kf(e,_),e.conditions.push(h)}else if(u)throw new SyntaxError("no attribute or comparison specified")}else(u||e.length>0&&c)&&e.push(hu(u));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?Hee:Ua,r.lastIndex=Dr),Dr===Ni.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function Kf(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 hu(e){return e.indexOf(".")>-1?e.split(".").map(hu):decodeURIComponent(e)}function d0(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(isNaN(r)?decodeURIComponent(r):+r);if(t==="string")return decodeURIComponent(r);throw new Xr.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function f0(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new Xr.ClientError("wildcard can only be used at the end of a string")}function E0(e){let t=h0(e[0]);return e.length>1&&(t.next=E0(e.slice(1))),t}function h0(e){if(Array.isArray(e)){let t=h0(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 Hn(e){return Array.isArray(e)?e.join("\0"):e}function Gs(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function xee(e,t,r){return t*r/Gs(e)}var Xr,Fg,us,yi,Dee,Lee,Mee,Pee,qg,Vg,Bee,Ua,Hee,Dr,Ni,va,zf=Re(()=>{Xr=B(ne()),Fg=B(dt()),us=require("ordered-binary"),yi=require("lmdb"),Dee=.3,Lee=.1,Mee=.05,Pee={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},qg={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(kg,"executeConditions");a(Ba,"searchByIndex");a(Fs,"findAttribute");a(Uee,"joinTo");a(vee,"joinFrom");Vg={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($g,"filterByType");a(Wf,"estimateCondition");Bee=/[()[\]|!<>.]|(=\w*=)/,Ua=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,Hee=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(Qf,"parseQuery");a(Eu,"parseBlock");a(Kf,"assignOperator");a(hu,"decodeProperty");a(d0,"typedDecoding");a(f0,"wildcardDecoding");a(E0,"toSortObject");a(h0,"toSortEntry");va=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(Hn,"flattenKey");a(Gs,"estimatedEntryCount");a(xee,"intersectionEstimate")});function g0(e){let t={openapi:Gee,info:{title:"HarperDB HTTP REST interface",version:(0,T0.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:l}=n.Resource;if(c=c??"id",!c)continue;let _={},u=[];if(o)for(let{type:b,name:C,elements:H,relationship:v,definition:q}of o){if(v)b==="array"?_[C]={type:"array",items:{$ref:Ii+H.type}}:_[C]={$ref:Ii+b};else{let M=q??H?.definition;if(M){if(!t.components.schemas[M.type]){let Q={};M.properties.forEach(J=>{Q[J.name]=new Qg(Yg[J.type],J.type)}),t.components.schemas[M.type]=new S0(Q)}b==="array"?_[C]={type:"array",items:{$ref:Ii+M.type}}:_[C]={$ref:Ii+M.type}}else b==="array"?H.type==="Any"||H.type=="ID"?_[C]={type:"array",items:{format:H.type}}:_[C]={type:"array",items:new Qg(Yg[H.type],H.type)}:b==="Any"||b=="ID"?_[C]={format:b}:_[C]=new Qg(Yg[b],b)}u.push(new zg(C,"query",_[C]))}let d=Object.keys(_),E=new zg(c,"path",{format:"ID"});E.required=!0,E.description="primary key of record";let f=new zg("property","path",{enum:d});f.required=!0,t.components.schemas[i]=new S0(_);let h=l.post!==Resource.prototype.post||l.update,p=typeof l.put=="function",S=typeof l.get=="function",T=typeof l.delete=="function",R="/"+s+"/";h&&(t.paths[R]={},t.paths[R].post=new Fee(i,r,"create a new record auto-assigning a primary key")),S&&(t.paths[R]||(t.paths[R]={}),t.paths[R].get=new Kg(u,r,{200:new Wg({$ref:Ii+i})},"search for records by the specified property name and value pairs")),T&&(t.paths[R]||(t.paths[R]={}),t.paths[R].delete=new p0(u,r,"delete all the records that match the provided query",{204:new m0})),R="/"+s+"/{"+c+"}",S&&(t.paths[R]={},t.paths[R].get=new Kg([E],r,{200:new Wg({$ref:Ii+i})},"retrieve a record by its primary key")),p&&(t.paths[R]||(t.paths[R]={}),t.paths[R].put=new qee([E],r,i,"create or update the record with the URL path that maps to the record's primary key")),T&&(t.paths[R]||(t.paths[R]={}),t.paths[R].delete=new p0([E],r,"delete a record with the given primary key",{204:new m0})),S&&f.schema.enum.length>0&&(R="/"+s+"/{"+c+"}.{property}",t.paths[R]={},t.paths[R].get=new Kg([E,f],r,{200:new Wg({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function Fee(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Ii+e}}}},this.security=t,this.responses={200:{description:Jg,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function Kg(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function Wg(e){this.description=Jg,this.content={"application/json":{schema:e}}}function m0(){this.description="successfully processed request, no content returned to client"}function qee(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Ii+r}}}},this.responses={200:{description:Jg}}}function p0(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function S0(e){this.type="object",this.properties=e}function Qg(e,t){this.type=e,this.format=t}function zg(e,t,r){this.name=e,this.in=t,this.schema=r}var T0,Gee,Yg,Ii,Jg,R0=Re(()=>{T0=B(Yd()),Gee="3.0.3",Yg={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Ii="#/components/schemas/",Jg="successful operation";a(g0,"generateJsonApi");a(Fee,"Post");a(Kg,"Get");a(Wg,"Response200");a(m0,"Response204");a(qee,"Put");a(p0,"Delete");a(S0,"ResourceSchema");a(Qg,"Type");a(zg,"Parameter")});var jf={};qe(jf,{start:()=>$ee});async function Vee(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream"?"CONNECT":e.method;e.search&&Qf(e);let s=new Ai;try{e.responseHeaders=s;let i=e.url.slice(1),o,c;if(i!==A0){let h=Jf.getMatch(i);if(!h)return t(e);e.handlerPath=h.path,o={url:h.relativeURL,async:!0},c=h.Resource}let l=r["cache-control"];if(l){l=l.toLowerCase();let h=l.match(/max-age=(\d+)/)?.[1];h&&(e.expiresAt=h*1e3+Date.now()),l.includes("only-if-cached")&&(e.onlyIfCached=!0),l.includes("no-cache")&&(e.noCache=!0),l.includes("no-store")&&(e.noCacheStore=!0),l.includes("stale-if-error")&&(e.staleIfError=!0),l.includes("must-revalidate")&&(e.mustRevalidate=!0)}let _=await Je(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=Oo(r["content-type"],!0)(e.body,e.headers)}catch(h){throw new Ha.ClientError(h,400)}if(e.authorize=!0,i===A0&&n==="GET"){if(e?.user?.role?.permission?.super_user)return g0(Jf);throw new Ha.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 Ha.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Ha.ServerError(`Method ${n} is not recognized`,501)}}),u=200,d;if(_==null)u=n==="GET"||n==="HEAD"?404:204,jg.lastModified&&e.lastModified&&s.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d=e.lastModified){kee[0]=d;let h=String.fromCharCode(34,(Qt[0]&63)+62,(Qt[0]>>6)+(Qt[1]<<2&63)+62,(Qt[1]>>4)+(Qt[2]<<4&63)+62,(Qt[2]>>2)+62,(Qt[3]&63)+62,(Qt[3]>>6)+(Qt[4]<<2&63)+62,(Qt[4]>>4)+(Qt[5]<<4&63)+62,(Qt[5]>>2)+62,(Qt[6]&63)+62,(Qt[6]>>6)+(Qt[7]<<2&63)+62,34),p=r["if-none-match"];p&&h==p?(_?.onDone&&_.onDone(),u=304,_=void 0):s.setIfNone("ETag",h),jg.lastModified&&s.setIfNone("Last-Modified",new Date(d).toUTCString())}e.createdResource&&(u=201),e.newLocation&&s.setIfNone("Location",e.newLocation);let E={status:u,headers:s,body:void 0},f=_?.wasLoadedFromSource?.();return f!==void 0&&(E.wasCacheMiss=f,!f&&d&&s.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||d))/1e3))),_!==void 0&&(E.body=Yf(_,e,E),n==="HEAD"&&(E.body=void 0)),E}catch(i){i.statusCode?i.statusCode===500?bo.warn(i):bo.info(i):bo.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=Yf(i.contentType?i:i.toString(),e,o),o}}function $ee(e){jg=e,!O0&&(O0=!0,Jf=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return Vee(t,r)},e),e.server.ws(async(t,r,n)=>{mu++;let s=new Nn;b0||(b0=!0,El(l=>{mu>0&&l.push({metric:"ws-connections",connections:mu,byThread:!0})}));let i;t.on("error",l=>{i=!0,bo.warn(l)});let o;t.on("message",a(function(_){o||(o=Oo(r.headers.asObject["content-type"]));let u=o(_);s.push(u)},"message"));let c;t.on("close",()=>{mu--,Wr(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),_=Jf.getMatch(l);if(Wr(!!_,"connection","ws","connect"),_){r.handlerPath=_.path,Sr(h=>({count:h.count,total:mu}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let u={url:_.relativeURL,async:!0},d=_.Resource;c=(await Je(r,()=>d.connect(u,s,r)))[Symbol.asyncIterator]();let f;for(;!(f=await c.next()).done;){let h=To(f.value,r);t.send(h),Sr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){t.close(Yee[l.statusCode]||1011,l.toString()),t.close("login fialed")}t.close()},e))}var bo,Ha,Qt,kee,jg,A0,O0,Jf,b0,mu,Yee,y0=Re(()=>{Ia();ws();bo=B(Y()),Ha=B(ne());zf();Nc();ro();jl();R0();Qt=new Uint8Array(8),kee=new Float64Array(Qt.buffer,0,1),jg={},A0="openapi";a(Vee,"http");mu=0;a($ee,"start");Yee={401:3e3,403:3003}});var Xg=g((vhe,N0)=>{var{recordAction:Xf,recordActionBinary:Kee}=(ws(),ie(hl)),Wee=require("fastify-plugin"),Qee=200;N0.exports=Wee(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let o=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,_,u,d;l.config?.isOperation?(_=n.body?.operation,u="operation"):(_=l.url,u="fastify-route",d=l.method),Xf(o,"duration",_,d,u),Kee(s.raw.statusCode<400,"success",_,d,u);let E=Qee;i?.pipe?(i.on("data",S=>{E+=S.length}),i.on("end",()=>{Xf(performance.now()-c,"transfer",_,d,u),Xf(E,"bytes-sent",_,d,u)})):(E+=i?.length||0,Xf(E,"bytes-sent",_,d,u));let f=o.toFixed(3),h=s.getHeader("Server-Timing"),p=`db;dur=${f}`;s.header("Server-Timing",h?`${h}, ${p}`:p)}),r()},{name:"hdb-request-time"})});var sR=g((xhe,D0)=>{var rE=require("clone"),nE=st(),zee=z(),eE=U(),Bhe=Y(),Zg=require("fs"),tR=require("joi"),{string:tE}=tR.types(),{hdb_errors:Jee,handleHDBError:Zf}=ne(),{HDB_ERROR_MSGS:Hhe,HTTP_STATUS_CODES:eR}=Jee,{common_validators:xa}=Jn(),I0=" is required",jee=["insert","update","upsert"],rR={database:{presence:!1,format:xa.schema_format,length:xa.schema_length},schema:{presence:!1,format:xa.schema_format,length:xa.schema_length},table:{presence:!0,format:xa.schema_format,length:xa.schema_length},action:{inclusion:{within:jee,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},Xee={schema:tE.required(),table:tE.required(),action:tE.valid("insert","update","upsert")},{AWS_ACCESS_KEY:Zee,AWS_SECRET:ete,AWS_BUCKET:tte,AWS_FILE_KEY:rte,REGION:nte}=eE.S3_BUCKET_AUTH_KEYS,ste={s3:{presence:!0},[`s3.${Zee}`]:{presence:!0,type:"String"},[`s3.${ete}`]:{presence:!0,type:"String"},[`s3.${tte}`]:{presence:!0,type:"String"},[`s3.${rte}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${nte}`]:{presence:!0,type:"String"}},w0=rE(rR);w0.data.presence={message:I0};var C0=rE(rR);C0.file_path.presence={message:I0};var ite=Object.assign(rE(rR),ste),nR=rE(Xee);nR.csv_url=tE.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();nR.passthrough_headers=tR.object();function ote(e){let t=nE.validateObject(e,w0);return sE(e,t)}a(ote,"dataObject");function ate(e){let t=nE.validateBySchema(e,tR.object(nR));return sE(e,t)}a(ate,"urlObject");function cte(e){let t=nE.validateObject(e,C0);return sE(e,t)}a(cte,"fileObject");function lte(e){let t=nE.validateObject(e,ite);return sE(e,t)}a(lte,"s3FileObject");function sE(e,t){if(!t){let r=zee.checkGlobalSchemaTable(e.schema,e.table);if(r)return Zf(new Error,r,eR.BAD_REQUEST);if(e.operation===eE.OPERATIONS_ENUM.CSV_FILE_LOAD)try{Zg.accessSync(e.file_path,Zg.constants.R_OK|Zg.constants.F_OK)}catch(n){return n.code===eE.NODE_ERROR_CODES.ENOENT?Zf(n,`No such file or directory ${n.path}`,eR.BAD_REQUEST):n.code===eE.NODE_ERROR_CODES.EACCES?Zf(n,`Permission denied ${n.path}`,eR.BAD_REQUEST):Zf(n)}}return t}a(sE,"postValidateChecks");D0.exports={dataObject:ote,urlObject:ate,fileObject:cte,s3FileObject:lte}});var iR=g((Fhe,L0)=>{"use strict";var pu=Y(),iE=U();async function ute(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===iE.OPERATIONS_ENUM.INSERT||t.operation===iE.OPERATIONS_ENUM.UPDATE||t.operation===iE.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===iE.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(pu.info(i.message),i):i.http_resp_msg?(pu.error(`Error calling operation: ${e.name}`),pu.error(i.http_resp_msg),i):(pu.error(`Error calling operation: ${e.name}`),pu.error(i),i)}}a(ute,"callOperationFunctionAsAwait");L0.exports={callOperationFunctionAsAwait:ute}});var P0=g((khe,M0)=>{"use strict";var oR=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}},aR=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};M0.exports={BulkLoadFileObject:oR,BulkLoadDataObject:aR}});var v0=g(($he,U0)=>{"use strict";var cR=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};U0.exports=cR});var ER=g((Jhe,X0)=>{"use strict";var oE=un(),cE=sR(),_te=require("needle"),xn=U(),Khe=ct(),Ga=z(),{handleHDBError:lt,hdb_errors:$0}=ne(),{HTTP_STATUS_CODES:zt,HDB_ERROR_MSGS:Lt,CHECK_LOGS_WRAPPER:No}=$0,Fa=Y(),lR=require("papaparse");Ga.promisifyPapaParse();var Gn=require("fs-extra"),dte=require("path"),{chain:B0}=require("stream-chain"),H0=require("stream-json/streamers/StreamArray"),x0=require("stream-json/utils/Batch"),G0=require("stream-chain/utils/comp"),{finished:F0}=require("stream"),fte=te(),Y0=iR(),Ete=Mg(),{BulkLoadFileObject:_R,BulkLoadDataObject:hte}=P0(),dR=Ag(),{verifyBulkLoadAttributePerms:K0}=xf(),Whe=v0(),Qhe=Rt(),zhe=As(),{databases:mte}=(Ae(),ie(ke)),{coerceType:pte}=(lE(),ie(hR)),q0="No records parsed from csv file.",yo=`${fte.get("HDB_ROOT")}/tmp`,{schema_regex:Ste}=Jn(),k0=1024*1024*2,V0=5e3,Tte={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};X0.exports={csvDataLoad:gte,csvURLLoad:Rte,csvFileLoad:Ate,importFromS3:Ote};async function gte(e,t){let r=cE.dataObject(e);if(r)throw lt(r,r.message,zt.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=z0(e.schema,e.table),i=lR.parse(e.data,{header:!0,skipEmptyLines:!0,transform:uR.bind(null,s),dynamicTyping:!1}),o=new dR;e.hdb_user&&e.hdb_user.role&&e.hdb_user.role.permission&&e.hdb_user.role.permission.super_user!==!0&&K0(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 lt(new Error,c,zt.BAD_REQUEST,void 0,void 0,!0);let l=new hte(e.action,e.schema,e.table,i.data);return n=await Y0.callOperationFunctionAsAwait(J0,l,null),n.message===q0?q0:j0(n.records,n.number_written)}catch(s){throw Io(s)}}a(gte,"csvDataLoad");async function Rte(e){let t=cE.urlObject(e);if(t)throw lt(t,t.message,zt.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${yo}/${r}`;try{await bte(e,r)}catch(s){throw Fa.error(Lt.DOWNLOAD_FILE_ERR(r)+" - "+s),lt(s,No(Lt.DOWNLOAD_FILE_ERR(r)))}try{let s=new _R(this.job_operation_function.name,e.action,e.schema,e.table,n,xn.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission),i=await fR(s);return await aE(n),i}catch(s){throw await aE(n),Io(s)}}a(Rte,"csvURLLoad");async function Ate(e){let t=cE.fileObject(e);if(t)throw lt(t,t.message,zt.BAD_REQUEST,void 0,void 0,!0);let r=new _R(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,xn.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission);try{return await fR(r)}catch(n){throw Io(n)}}a(Ate,"csvFileLoad");async function Ote(e){let t=cE.s3FileObject(e);if(t)throw lt(t,t.message,zt.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=dte.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${yo}/${s}`;let i=new _R(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user.role.permission);await yte(s,e);let o=await fR(i);return await aE(r),o}catch(n){throw await aE(r),Io(n)}}a(Ote,"importFromS3");async function bte(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await _te("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 lt(n,s,n.statusCode,xn.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}Ite(r,e.csv_url),await Nte(t,r.raw)}a(bte,"downloadCSVFile");async function yte(e,t){try{let r=`${yo}/${e}`;await Gn.mkdirp(yo),await Gn.writeFile(`${yo}/${e}`,"",{flag:"a+"});let n=await Gn.createWriteStream(r),s=await Ete.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(){Fa.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Fa.error(Lt.S3_DOWNLOAD_ERR+" - "+r),lt(r,No(Lt.S3_DOWNLOAD_ERR))}}a(yte,"downloadFileFromS3");async function Nte(e,t){try{await Gn.mkdirp(yo),await Gn.writeFile(`${yo}/${e}`,t)}catch(r){throw Fa.error(Lt.WRITE_TEMP_FILE_ERR),lt(r,No(Lt.DEFAULT_BULK_LOAD_ERR))}}a(Nte,"writeFileToTempFolder");async function aE(e){if(e)try{await Gn.access(e),await Gn.unlink(e)}catch{Fa.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(aE,"deleteTempFile");function Ite(e,t){if(e.statusCode!==$0.HTTP_STATUS_CODES.OK)throw lt(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,zt.BAD_REQUEST);if(!Tte[e.headers["content-type"]])throw lt(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,zt.BAD_REQUEST);if(!e.raw)throw lt(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,zt.BAD_REQUEST)}a(Ite,"validateURLResponse");async function fR(e){try{let t;switch(e.file_type){case xn.VALID_S3_FILE_TYPES.CSV:t=await wte(e);break;case xn.VALID_S3_FILE_TYPES.JSON:t=await Cte(e);break;default:throw lt(new Error,Lt.DEFAULT_BULK_LOAD_ERR,zt.BAD_REQUEST,xn.LOG_LEVELS.ERROR,Lt.INVALID_FILE_EXT_ERR(e))}return j0(t.records,t.number_written)}catch(t){throw Io(t)}}a(fR,"fileLoad");async function W0(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 oE.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&K0(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=lt(c);r(l)}}a(W0,"validateChunk");async function Q0(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Ga.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Ga.isEmpty(c)&&!Ga.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(l=>{Object.keys(l).forEach(_=>c.add(_))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},l=await Y0.callOperationFunctionAsAwait(J0,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=lt(c,No(Lt.INSERT_CSV_ERR),zt.INTERNAL_SERVER_ERROR,xn.LOG_LEVELS.ERROR,Lt.INSERT_CSV_ERR+" - "+c);r(l)}}a(Q0,"insertChunk");async function wte(e){let t={records:0,number_written:0},r=z0(e.schema,e.table);try{let n=new dR,s=Gn.createReadStream(e.file_path,{highWaterMark:k0});s.setEncoding("utf8"),await lR.parsePromise(s,W0.bind(null,e,n),uR.bind(null,r));let i=n.getPermsResponse();if(i)throw lt(new Error,i,zt.BAD_REQUEST);return s=Gn.createReadStream(e.file_path,{highWaterMark:k0}),s.setEncoding("utf8"),await lR.parsePromise(s,Q0.bind(null,e,t),uR.bind(null,r)),s.destroy(),t}catch(n){throw lt(n,No(Lt.PAPA_PARSE_ERR),zt.INTERNAL_SERVER_ERROR,xn.LOG_LEVELS.ERROR,Lt.PAPA_PARSE_ERR+n)}}a(wte,"callPapaParse");function z0(e,t){let r=mte[e][t].attributes,n=new Map;for(let s of r)s.type&&n.set(s.name,i=>pte(i,s));return n}a(z0,"createTransformMap");function uR(e,t,r){let n=e.get(r);return n?n(t):Ga.autoCast(t)}a(uR,"typeFunction");async function Cte(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new dR,s=B0([Gn.createReadStream(e.file_path,{encoding:"utf-8"}),H0.withParser(),c=>c.value,new x0({batchSize:V0}),G0(async c=>{await W0(e,n,r,c)})]);await new Promise((c,l)=>{F0(s,_=>{_?l(_):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw lt(new Error,i,zt.BAD_REQUEST);let o=B0([Gn.createReadStream(e.file_path,{encoding:"utf-8"}),H0.withParser(),c=>c.value,new x0({batchSize:V0}),G0(async c=>{await Q0(e,t,r,c)})]);return await new Promise((c,l)=>{F0(o,_=>{_?l(_):c()}),o.resume()}),t}catch(n){throw lt(n,No(Lt.INSERT_JSON_ERR),zt.INTERNAL_SERVER_ERROR,xn.LOG_LEVELS.ERROR,Lt.INSERT_JSON_ERR+n)}}a(Cte,"insertJson");async function J0(e){let t={};try{e.data&&e.data.length>0&&Dte(e.data[0])?t=await Lte(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Fa.info(t.message))}catch(r){throw Io(r)}return t}a(J0,"callBulkFileLoad");function Dte(e){let t=Object.keys(e);for(let r of t)if(!Ste.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(Dte,"validateColumnNames");async function Lte(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=oE.insert;break;case"update":i=oE.update;break;case"upsert":i=oE.upsert;break;default:throw lt(new Error,Lt.INVALID_ACTION_PARAM_ERR(n),zt.BAD_REQUEST,xn.LOG_LEVELS.ERROR,Lt.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 u=global.hdb_schema[t][r].hash_attribute,d=e.length;for(;d--;)o.skipped_hashes.indexOf(e[d][u])>=0&&e.splice(d,1)}let l=Ga.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw Io(o)}}a(Lte,"bulkFileLoad");function j0(e,t){return`successfully loaded ${t} of ${e} records`}a(j0,"buildResponseMsg");function Io(e){return lt(e,No(Lt.DEFAULT_BULK_LOAD_ERR),zt.INTERNAL_SERVER_ERROR,xn.LOG_LEVELS.ERROR,Lt.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(Io,"buildTopLevelErrMsg")});var eB=g((Xhe,Z0)=>{"use strict";var mR=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};Z0.exports=mR});var nB=g((eme,rB)=>{"use strict";var Mte=U(),tB=require("moment"),Pte=require("uuid").v4,pR=class{static{a(this,"JobObject")}constructor(){this.id=Pte(),this.type=void 0,this.start_datetime=tB().valueOf(),this.created_datetime=tB().valueOf(),this.end_datetime=void 0,this.status=Mte.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};rB.exports=pR});var _E=g((rme,_B)=>{"use strict";var Ute=require("uuid").v4,cB=un(),lB=qr(),vte=es(),Bte=na(),Hte=eB(),je=U(),xte=nB(),Gte=zS(),pn=Y(),Fte=kc(),qa=z(),{promisify:qte}=require("util"),wo=require("moment"),kte=Ff(),uE=sR(),sB=Ym(),{deleteTransactionLogsBeforeValidator:Vte}=pg(),{handleHDBError:iB,hdb_errors:$te}=ne(),{HTTP_STATUS_CODES:oB}=$te,aB=lB.searchByValue,Yte=lB.searchByHash,Kte=cB.insert,Wte=qte(kte.evaluateSQL),Qte=cB.update;_B.exports={addJob:jte,updateJob:Zte,handleGetJob:zte,handleGetJobsByStartDate:Jte,getJobById:uB};async function zte(e){try{let t=await uB(e.id);return qa.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 pn.error("There was an error getting job",t),new Error(r)}}a(zte,"handleGetJob");async function Jte(e){try{let t=await Xte(e);if(pn.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=wo(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=wo(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 pn.error(r),new Error(r)}}a(Jte,"handleGetJobsByStartDate");async function jte(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||qa.isEmptyOrZeroLength(e.operation)){let u="job parameter is invalid";return pn.info(u),t.error=u,t}if(!je.JOB_TYPE_ENUM[e.operation])return pn.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case je.OPERATIONS_ENUM.CSV_FILE_LOAD:n=uE.fileObject(e);break;case je.OPERATIONS_ENUM.CSV_URL_LOAD:n=uE.urlObject(e);break;case je.OPERATIONS_ENUM.CSV_DATA_LOAD:n=uE.dataObject(e);break;case je.OPERATIONS_ENUM.IMPORT_FROM_S3:n=uE.s3FileObject(e);break;case je.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case je.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=sB(e,"date");break;case je.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=sB(e,"timestamp");break;case je.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=Vte(e);break;case je.OPERATIONS_ENUM.RESTART_SERVICE:if(je.PROCESS_DESCRIPTORS_VALIDATE[e.service]===void 0)throw iB(new Error,"Invalid service",oB.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw iB(n,n.message,oB.BAD_REQUEST,void 0,void 0,!0);let s=new xte;s.type=e.operation===je.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?je.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user.username;let i=new vte(je.SYSTEM_SCHEMA_NAME,je.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await aB(i))}catch(u){let d=`There was an error inserting a new job: ${u}`;return pn.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Ute();try{o=await aB(i)}catch(u){let d=`There was an error inserting a new job: ${u}`;return pn.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return pn.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new Fte(je.SYSTEM_SCHEMA_NAME,je.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),_;try{_=await Kte(l)}catch(u){return pn.error(`There was an error inserting a job for job type: ${e.operation} -- ${u}`),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 u=`Created a job with type ${s.type} and id ${s.id}`;t.message=u,t.createdJob=s,t.success=!0,pn.trace(u)}return t}a(jte,"addJob");async function Xte(e){let t=wo(e.from_date,wo.ISO_8601),r=wo(e.to_date,wo.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 Hte(n,e.hdb_user);try{return await Wte(s)}catch(i){throw pn.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(Xte,"getJobsInDateRange");async function uB(e){if(qa.isEmptyOrZeroLength(e))return qa.errorizeMessage("Invalid job ID specified.");let t=new Bte(je.SYSTEM_SCHEMA_NAME,je.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await Yte(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return pn.error(n),qa.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(uB,"getJobById");async function Zte(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(qa.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===je.JOB_STATUS_ENUM.COMPLETE||e.status===je.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=wo().valueOf());let t=new Gte(je.SYSTEM_SCHEMA_NAME,je.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await Qte(t),r}a(Zte,"updateJob")});var TB=g((sme,SB)=>{"use strict";var dB=z(),Mt=U(),ere=require("moment"),dE=ER(),Su=Y(),fB=_E(),EB=qf(),hB=zi(),mB=ot(),tre=Uf(),rre=Ql(),{parentPort:nre,isMainThread:pB}=require("worker_threads"),{onMessageByType:sre}=ot(),SR=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function ire(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(dB.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(dB.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Mt.JOB_TYPE_ENUM.csv_file_load:await _s(e,dE.csvFileLoad);break;case Mt.JOB_TYPE_ENUM.csv_url_load:await _s(e,dE.csvURLLoad);break;case Mt.JOB_TYPE_ENUM.csv_data_load:await _s(e,dE.csvDataLoad);break;case Mt.JOB_TYPE_ENUM.import_from_s3:await _s(e,dE.importFromS3);break;case Mt.JOB_TYPE_ENUM.empty_trash:break;case Mt.JOB_TYPE_ENUM.export_local:await _s(e,EB.export_local);break;case Mt.JOB_TYPE_ENUM.export_to_s3:await _s(e,EB.export_to_s3);break;case Mt.JOB_TYPE_ENUM.delete_files_before:case Mt.JOB_TYPE_ENUM.delete_records_before:await _s(e,hB.deleteFilesBefore);break;case Mt.JOB_TYPE_ENUM.delete_audit_logs_before:await _s(e,hB.deleteAuditLogsBefore);break;case Mt.JOB_TYPE_ENUM.delete_transaction_logs_before:await _s(e,tre.deleteTransactionLogsBefore);break;case Mt.JOB_TYPE_ENUM.restart_service:return await _s(e,rre.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(ire,"parseMessage");async function _s(e,t){try{e.job.status=Mt.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=ere().valueOf(),await fB.updateJob(e.job),await ore(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):Su.error(`There was an error running ${t.name} job with id ${e.job.id}`),Su.error(n),e.job.message=n,e.job.status=Mt.JOB_STATUS_ENUM.ERROR;try{await fB.updateJob(e.job)}catch(s){throw Su.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(_s,"runJob");async function ore(e){Su.trace("launching job thread:",e),pB?mB.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:Object.assign({},process.env,{[Mt.PROCESS_NAME_ENV_PROP]:`JOB-${e}`})}):nre.postMessage({type:Mt.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(ore,"launchJobThread");pB&&sre(Mt.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{mB.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:Object.assign({},process.env,{[Mt.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`})})}catch(r){Su.error(r)}});SB.exports={parseMessage:ire,RunnerMessage:SR}});var RB=g((ome,gB)=>{"use strict";var TR=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};gB.exports=TR});var NR=g((cme,yR)=>{"use strict";var pE=qr(),AR=Ff(),fE=ER(),qs=Pd(),EE=si(),gu=zi(),are=US(),Tu=Vr(),hE=VS(),Jt=mg(),mE=Y(),cre=KS(),lre=jd(),AB=NT(),ure=Zd(),_re=wT(),dre=CT(),fre=MT(),Ere=UT(),gR=HT(),OB=qf(),hre=xf(),OR=_E(),F=U(),{hdb_errors:Au,handleHDBError:Ru}=ne(),{HTTP_STATUS_CODES:bB}=Au,RR=kT(),yB=Ql(),UB=require("util"),ka=un(),mre=Os(),pre=Sa(),NB=TB(),IB=Il(),wB=(bf(),ie(Xl)),CB=dr(),DB=Uf(),LB=Cf(),{setServerUtilities:Sre}=(lE(),ie(hR)),{CONTEXT:Tre}=(In(),ie(Pp)),{_assignPackageExport:gre}=require("../../index"),{transformReq:Rre}=z(),{server:Are}=(ur(),ie(Hi)),or=mE.loggerWithTag("operation"),Ore=iR(),MB=pE.searchByHash,bre=pE.searchByValue,yre=UB.promisify(pE.search),Nre=UB.promisify(AR.evaluateSQL),Ire={[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},$=RB();async function vB(e,t){try{if(e.body.operation!=="read_log"&&(mE.log_level===F.LOG_LEVELS.INFO||mE.log_level===F.LOG_LEVELS.DEBUG||mE.log_level===F.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,...o}=e.body;or.info(o)}}catch(n){or.error(n)}let r=await Ore.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return Ire[e.body.operation]&&mre.setSchemaDataToGlobal(n=>{n&&or.error(n)}),r}a(vB,"processLocalTransaction");var PB=Cre();yR.exports={chooseOperation:BB,getOperationFunction:HB,operation:bR,processLocalTransaction:vB};Sre(yR.exports);Are.operation=bR;function BB(e){let t;try{t=HB(e)}catch(s){throw or.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=AR.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=AR.checkASTPermissions(e,i);if(o)throw or.error(`${bB.FORBIDDEN} from operation ${e.operation}`),or.warn(`User '${e.hdb_user.username}' is not permitted to ${e.operation}`),Ru(new Error,o,Au.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=hre.verifyPerms(i,s);if(o)throw or.error(`${bB.FORBIDDEN} from operation ${e.operation}`),or.warn(`User '${i.hdb_user.username}' is not permitted to ${i.operation}`),Ru(new Error,o,Au.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw Ru(s,"There was an error when trying to choose an operation path")}return r}a(BB,"chooseOperation");function HB(e){if(or.trace(`getOperationFunction with operation: ${e.operation}`),PB.has(e.operation))return PB.get(e.operation);throw Ru(new Error,Au.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),Au.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(HB,"getOperationFunction");gre("operation",bR);function bR(e,t){e.hdb_user=this[Tre]?.user,e.bypass_auth=!t;let r=BB(e);return vB({body:e},r)}a(bR,"operation");async function wre(e){or.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 ka.insert(i);break;case F.OPERATIONS_ENUM.UPDATE:o=await ka.update(i);break;case F.OPERATIONS_ENUM.UPSERT:o=await ka.upsert(i);break;case F.OPERATIONS_ENUM.DELETE:o=await gu.deleteRecord(i);break;default:or.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){or.info("Invalid operation in transaction"),or.error(o)}}a(wre,"catchup");async function Fn(e){Rre(e);let t,r;try{r=await OR.addJob(e),t=r.createdJob,or.info("addJob result",r);let n=new NB.RunnerMessage(t,e);return{message:await NB.parseMessage(n)??`Starting job with id ${t.id}`,job_id:t.id}}catch(n){let s=`There was an error executing job: ${n.http_resp_msg?n.http_resp_msg:n}`;throw or.error(s),Ru(n,s)}}a(Fn,"executeJob");function Cre(){let e=new Map;return e.set(F.OPERATIONS_ENUM.INSERT,new $(ka.insert)),e.set(F.OPERATIONS_ENUM.UPDATE,new $(ka.update)),e.set(F.OPERATIONS_ENUM.UPSERT,new $(ka.upsert)),e.set(F.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new $(pE.searchByConditions)),e.set(F.OPERATIONS_ENUM.SEARCH_BY_HASH,new $(MB)),e.set(F.OPERATIONS_ENUM.SEARCH_BY_ID,new $(MB)),e.set(F.OPERATIONS_ENUM.SEARCH_BY_VALUE,new $(bre)),e.set(F.OPERATIONS_ENUM.SEARCH,new $(yre)),e.set(F.OPERATIONS_ENUM.SQL,new $(Nre)),e.set(F.OPERATIONS_ENUM.CSV_DATA_LOAD,new $(Fn,fE.csvDataLoad)),e.set(F.OPERATIONS_ENUM.CSV_FILE_LOAD,new $(Fn,fE.csvFileLoad)),e.set(F.OPERATIONS_ENUM.CSV_URL_LOAD,new $(Fn,fE.csvURLLoad)),e.set(F.OPERATIONS_ENUM.IMPORT_FROM_S3,new $(Fn,fE.importFromS3)),e.set(F.OPERATIONS_ENUM.CREATE_SCHEMA,new $(qs.createSchema)),e.set(F.OPERATIONS_ENUM.CREATE_DATABASE,new $(qs.createSchema)),e.set(F.OPERATIONS_ENUM.CREATE_TABLE,new $(qs.createTable)),e.set(F.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new $(qs.createAttribute)),e.set(F.OPERATIONS_ENUM.DROP_SCHEMA,new $(qs.dropSchema)),e.set(F.OPERATIONS_ENUM.DROP_DATABASE,new $(qs.dropSchema)),e.set(F.OPERATIONS_ENUM.DROP_TABLE,new $(qs.dropTable)),e.set(F.OPERATIONS_ENUM.DROP_ATTRIBUTE,new $(qs.dropAttribute)),e.set(F.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new $(EE.describeSchema)),e.set(F.OPERATIONS_ENUM.DESCRIBE_DATABASE,new $(EE.describeSchema)),e.set(F.OPERATIONS_ENUM.DESCRIBE_TABLE,new $(EE.describeTable)),e.set(F.OPERATIONS_ENUM.DESCRIBE_ALL,new $(EE.describeAll)),e.set(F.OPERATIONS_ENUM.DELETE,new $(gu.deleteRecord)),e.set(F.OPERATIONS_ENUM.ADD_USER,new $(Tu.addUser)),e.set(F.OPERATIONS_ENUM.ALTER_USER,new $(Tu.alterUser)),e.set(F.OPERATIONS_ENUM.DROP_USER,new $(Tu.dropUser)),e.set(F.OPERATIONS_ENUM.LIST_USERS,new $(Tu.listUsersExternal)),e.set(F.OPERATIONS_ENUM.LIST_ROLES,new $(hE.listRoles)),e.set(F.OPERATIONS_ENUM.ADD_ROLE,new $(hE.addRole)),e.set(F.OPERATIONS_ENUM.ALTER_ROLE,new $(hE.alterRole)),e.set(F.OPERATIONS_ENUM.DROP_ROLE,new $(hE.dropRole)),e.set(F.OPERATIONS_ENUM.USER_INFO,new $(Tu.userInfo)),e.set(F.OPERATIONS_ENUM.READ_LOG,new $(cre)),e.set(F.OPERATIONS_ENUM.ADD_NODE,new $(lre)),e.set(F.OPERATIONS_ENUM.UPDATE_NODE,new $(AB)),e.set(F.OPERATIONS_ENUM.SET_NODE_REPLICATION,new $(AB)),e.set(F.OPERATIONS_ENUM.REMOVE_NODE,new $(ure)),e.set(F.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new $(_re)),e.set(F.OPERATIONS_ENUM.PURGE_STREAM,new $(dre)),e.set(F.OPERATIONS_ENUM.SET_CONFIGURATION,new $(CB.setConfiguration)),e.set(F.OPERATIONS_ENUM.CLUSTER_STATUS,new $(fre.clusterStatus)),e.set(F.OPERATIONS_ENUM.CLUSTER_NETWORK,new $(Ere)),e.set(F.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new $(gR.setRoutes)),e.set(F.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new $(gR.getRoutes)),e.set(F.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new $(gR.deleteRoutes)),e.set(F.OPERATIONS_ENUM.EXPORT_TO_S3,new $(Fn,OB.export_to_s3)),e.set(F.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new $(Fn,gu.deleteFilesBefore)),e.set(F.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new $(Fn,gu.deleteFilesBefore)),e.set(F.OPERATIONS_ENUM.EXPORT_LOCAL,new $(Fn,OB.export_local)),e.set(F.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new $(OR.handleGetJobsByStartDate)),e.set(F.OPERATIONS_ENUM.GET_JOB,new $(OR.handleGetJob)),e.set(F.OPERATIONS_ENUM.GET_FINGERPRINT,new $(RR.getFingerprint)),e.set(F.OPERATIONS_ENUM.SET_LICENSE,new $(RR.setLicense)),e.set(F.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new $(RR.getRegistrationInfo)),e.set(F.OPERATIONS_ENUM.RESTART,new $(yB.restart)),e.set(F.OPERATIONS_ENUM.RESTART_SERVICE,new $(Fn,yB.restartService)),e.set(F.OPERATIONS_ENUM.CATCHUP,new $(wre)),e.set(F.OPERATIONS_ENUM.SYSTEM_INFORMATION,new $(pre.systemInformation)),e.set(F.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new $(Fn,gu.deleteAuditLogsBefore)),e.set(F.OPERATIONS_ENUM.READ_AUDIT_LOG,new $(are)),e.set(F.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new $(IB.createTokens)),e.set(F.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new $(IB.refreshOperationToken)),e.set(F.OPERATIONS_ENUM.LOGIN,new $(wB.login)),e.set(F.OPERATIONS_ENUM.LOGOUT,new $(wB.logout)),e.set(F.OPERATIONS_ENUM.GET_CONFIGURATION,new $(CB.getConfiguration)),e.set(F.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new $(Jt.customFunctionsStatus)),e.set(F.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new $(Jt.getCustomFunctions)),e.set(F.OPERATIONS_ENUM.GET_COMPONENT_FILE,new $(Jt.getComponentFile)),e.set(F.OPERATIONS_ENUM.GET_COMPONENTS,new $(Jt.getComponents)),e.set(F.OPERATIONS_ENUM.SET_COMPONENT_FILE,new $(Jt.setComponentFile)),e.set(F.OPERATIONS_ENUM.DROP_COMPONENT,new $(Jt.dropComponent)),e.set(F.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new $(Jt.getCustomFunction)),e.set(F.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new $(Jt.setCustomFunction)),e.set(F.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new $(Jt.dropCustomFunction)),e.set(F.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new $(Jt.addComponent)),e.set(F.OPERATIONS_ENUM.ADD_COMPONENT,new $(Jt.addComponent)),e.set(F.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new $(Jt.dropCustomFunctionProject)),e.set(F.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new $(Jt.packageComponent)),e.set(F.OPERATIONS_ENUM.PACKAGE_COMPONENT,new $(Jt.packageComponent)),e.set(F.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new $(Jt.deployComponent)),e.set(F.OPERATIONS_ENUM.DEPLOY_COMPONENT,new $(Jt.deployComponent)),e.set(F.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new $(DB.readTransactionLog)),e.set(F.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new $(Fn,DB.deleteTransactionLogsBefore)),e.set(F.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new $(LB.installModules)),e.set(F.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new $(LB.auditModules)),e.set(F.OPERATIONS_ENUM.GET_BACKUP,new $(qs.getBackup)),e}a(Cre,"initializeOperationFunctionMap")});var TE=g((ume,FB)=>{"use strict";var IR=U(),Dre=z(),Ou=Y(),{handleHDBError:wR,hdb_errors:SE}=ne(),{isMainThread:Lre}=require("worker_threads"),{Readable:Mre}=require("stream"),xB=require("os"),Pre=require("util"),Ure=nT(),vre=Pre.promisify(Ure.authorize),GB=NR(),{createGzip:Bre,constants:Hre}=require("zlib");function xre(e){let t=`Found an uncaught exception with message: ${e.message}. ${xB.EOL}Stack: ${e.stack} ${xB.EOL}Terminating ${Lre?"HDB":"thread"}.`;console.error(t),Ou.fatal(t),process.exit(1)}a(xre,"handleServerUncaughtException");function Gre(e,t,r){if(Ou[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:SE.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(Gre,"serverErrorHandler");function Fre(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=wR(new Error,"Invalid JSON.",SE.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(Dre.isEmpty(e.body.operation)){let n=wR(new Error,"Request body must include an 'operation' property.",SE.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Fre,"reqBodyValidationHandler");function qre(e,t,r){let n;e.body.operation!==IR.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==IR.OPERATIONS_ENUM.LOGIN&&e.body.operation!==IR.OPERATIONS_ENUM.LOGOUT?vre(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{Ou.warn(s),Ou.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r(wR(s,i,SE.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(qre,"authHandler");async function kre(e,t,r=!1){let n;try{r&&(e.body.operation!=="configure_cluster"||e.body.operation!=="set_configuration")&&(e.body.bypass_auth=r),n=GB.chooseOperation(e.body);let s=await GB.processLocalTransaction(e,n);if(s instanceof Mre&&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(Bre({level:Hre.Z_BEST_SPEED})))}return s}catch(s){throw Ou.error(s),s}}a(kre,"handlePostRequest");FB.exports={authHandler:qre,handlePostRequest:kre,handleServerUncaughtException:xre,serverErrorHandler:Gre,reqBodyValidationHandler:Fre}});var $B=g((dme,VB)=>{"use strict";var Vre=require("fastify-plugin"),{handlePostRequest:qB,authHandler:$re,reqBodyValidationHandler:Yre}=TE();async function Kre(e){e.decorate("hdbCore",{preValidation:[Yre,$re],request:t=>kB(qB(t,response)),requestWithoutAuthentication:(t,r)=>kB(qB(t,r,!0))})}a(Kre,"hdbCore");async function kB(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(kB,"convertAsyncIterators");VB.exports=Vre(Kre)});var WB=g((hme,KB)=>{"use strict";var Eme=require("fs"),CR=te();CR.initSync();var{CONFIG_PARAMS:YB}=U(),Wre=1024*1024*1024;function Qre(e){let t=CR.get(YB.HTTP_TIMEOUT),r=CR.get(YB.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:Wre,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,https:e}}a(Qre,"getServerOptions");KB.exports=Qre});var JB=g((pme,zB)=>{"use strict";var DR=te();DR.initSync();var{CONFIG_PARAMS:QB}=U();function zre(){let e=DR.get(QB.HTTP_CORSACCESSLIST),t=DR.get(QB.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(zre,"getCORSOptions");zB.exports=zre});var ZB=g((Tme,XB)=>{"use strict";var jB=te();jB.initSync();var Jre=U();function jre(){return jB.get(Jre.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(jre,"getHeaderTimeoutConfig");XB.exports=jre});var MR={};qe(MR,{customFunctionsServer:()=>ene,ready:()=>EH,start:()=>Zre});function Zre(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){ks||(ks=fH(t),it.http((await ks).server));let o=await ks,c=(0,LR.dirname)(s),l=(0,LR.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!eH.has(c)){eH.add(c);try{o.register(rne(c,l))}catch(_){if(_.message==="Root plugin has already booted")$e.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw _}}},ready:EH}}async function ene(){try{$e.info("In Custom Functions Fastify server"+process.cwd()),$e.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),$e.debug(`Custom Functions server process ${process.pid} starting up.`),await tne();let e=oH.get(aH.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=ks=await fH(e)}catch(r){throw $e.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw $e.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){$e.error(`Custom Functions ${process.pid} Error: ${e}`),$e.error(e),process.exit(1)}}async function tne(){try{$e.info("Custom Functions starting configuration."),await cH.setUsersToGlobal(),$e.info("Custom Functions completed configuration.")}catch(e){$e.error(e)}}function rne(e,t){return async function(r){try{$e.info("Custom Functions starting buildRoutes"),$e.trace("Loading fastify routes folder "+e),(0,tH.existsSync)(e)&&r.register(iH.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:$e.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?$e.error(s.message):s&&$e.error(s),o()})}catch(n){$e.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function fH(e){$e.info("Custom Functions starting buildServer.");let t=(0,lH.default)(e),r=(0,rH.default)(t);r.server.headersTimeout=(0,_H.default)(),r.setErrorHandler(dH.serverErrorHandler);let n=(0,uH.default)();return n&&r.register(nH.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(sH.default),await r.register(Xre),await r.after(),Gg(r),$e.info("Custom Functions completed buildServer."),r}function EH(){if(ks)return ks.then?ks.then(e=>e.ready()):ks.ready()}var LR,tH,rH,nH,sH,iH,oH,aH,$e,Xre,cH,lH,uH,_H,dH,ks,eH,hH=Re(()=>{LR=require("path"),tH=require("fs"),rH=B(require("fastify")),nH=B(require("@fastify/cors")),sH=B(Xg()),iH=B(require("@fastify/autoload")),oH=B(te()),aH=B(U()),$e=B(Y()),Xre=B($B()),cH=B(Vr()),lH=B(WB()),uH=B(JB()),_H=B(ZB()),dH=B(TE());Ia();ur();eH=new Set;a(Zre,"start");a(ene,"customFunctionsServer");a(tne,"setUp");a(rne,"buildRouteFolder");a(fH,"buildServer");a(EH,"ready")});var PR={};qe(PR,{start:()=>nne});function nne(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,gH.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){pH||(pH=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=mH.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,SH.default)(s,(0,TH.realpathSync)(o))}}return i(s)},{runFirst:!0})),mH.set(r,n)}}}var SH,TH,gH,mH,pH,RH=Re(()=>{SH=B(require("send")),TH=require("fs"),gH=B(require("serve-static")),mH=new Map;a(nne,"start")});function one(){let e=(0,yH.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),vR=setInterval(()=>{AE.notify(e)},ine).unref())}function ane(e,t=1,r){if(UR++,(0,Vs.startWorker)("server/threads/threadServer.js",{name:Wa.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(_){_.type===Wa.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});sne.push(s),await s,Va.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=RE.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Va.indexOf(n);o>-1&&Va.splice(o,1)}if(a(i,"removeWorker"),$a){let o=$a;$a=[];for(let c of o)NH[c.localPort](null,c)}}}),r){let n=setInterval(()=>{BR?BR=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Vs.shutdownWorkers)(),UR=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function IH(e=0,t){if(typeof e=="string")try{(0,OE.existsSync)(e)&&(0,OE.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=cne:r=lne(t):r=HR;let n=(0,Ya.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=NH[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),BR=!0,r(o,(c,l)=>{if(!c){if(AH){let u=o._socket||new Ya.Socket({handle:o,writable:!0,readable:!0});AH.deliverSocket(u,e,l),u.resume()}else UR>0?($a.length===0&&setTimeout(()=>{$a.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,$a.push(o)):(console.log("start up a dynamic thread to handle request"),ane(0));Sr(!1,"socket-routed");return}c.requests++;let _=o.fd;if(_>=0)c.postMessage({port:e,fd:_,data:l});else{let u=o._socket||new Ya.Socket({handle:o,writable:!0,readable:!0});fne(u,c,e)}Sr(!0,"socket-routed")})};let s=ul();AE.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 HR(e,t){let r,n=0;for(let s of Va){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=gE)return gE=i,t(r);n=i}gE=0,t(r)}function cne(e,t){let r={};e.getpeername(r);let n=r.address,s=Ka.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);HR(e,o=>{Ka.set(n,{worker:o,lastUsed:i}),t(o)})}function lne(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new Ya.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],_=Ka.get(l),u=Date.now();if(_&&_.worker.threadId!==-1)return _.lastUsed=u,s(_.worker);HR(n,d=>{Ka.set(l,{worker:d,lastUsed:u}),s(d,o)})})}a(r,"findByHeaderAffinity")}function _ne(){gE=0;for(let e of Va)e.expectedIdle=e.recentELU.idle+une,e.requests=1;Va.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function fne(e,t,r){let n=dne++;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(),RE.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")),RE.delete(n)),s.event=="destroy"&&(e.destroy(),RE.delete(n))})}var Vs,Ya,Wa,AE,OE,bH,yH,Va,$a,NH,AH,UR,sne,vR,ine,BR,gE,OH,Ka,une,RE,dne,wH=Re(()=>{Vs=B(ot()),Ya=require("net"),Wa=B(U()),AE=B(Y()),OE=require("fs");ws();bH=require("worker_threads"),yH=B(Ji()),Va=[],$a=[],NH=[],UR=0,sne=[];bH.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Vs.onMessageFromWorkers)(e=>{e.type===Wa.ITC_EVENT_TYPES.RESTART&&vR&&(clearInterval(vR),one())}));ine=6e5;a(one,"licenseWarning");a(ane,"startHTTPWorker");a(IH,"startSocketServer");gE=0;a(HR,"findMostIdleWorker");OH=36e5,Ka=new Map;a(cne,"findByRemoteAddressAffinity");a(lne,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of Ka)r.lastUsed+OH<e&&Ka.delete(t)},OH).unref();une=1e3;a(_ne,"updateWorkerIdleness");(0,Vs.setMonitorListener)(_ne);RE=new Map,dne=1;a(fne,"proxySocket")});var qR={};qe(qR,{Request:()=>xR,createReuseportFd:()=>bE});var CH,xR,GR,FR,bE,yE=Re(()=>{CH=require("os"),xR=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 FR(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 GR(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},GR=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}pipe(t,r){return this.#e.pipe(t,r)}},FR=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,CH.platform)()!="win32"&&(bE=require("node-unix-socket").createReuseportFd)});var PH=g((Ume,MH)=>{"use strict";var Ene=require("cluster"),Co=te();Co.initSync();var LH=U(),Cme=require("util"),$s=Y(),Dme=require("fs"),hne=require("fastify"),Lme=ul(),mne=require("@fastify/cors"),pne=require("@fastify/compress"),Sne=require("@fastify/static"),Tne=Xg(),gne=require("path"),{PACKAGE_ROOT:Rne}=U(),Ane=Os(),One=z(),bne=Vr(),yne=Ji(),{server:Nne}=(ur(),ie(Hi)),{node_request_key:Mme}=(yE(),ie(qR)),{authHandler:Ine,handlePostRequest:wne,serverErrorHandler:Cne,reqBodyValidationHandler:Dne}=TE(),Pme=require("net"),{registerContentHandlers:Lne}=(Ia(),ie(_0)),Mne=6e4,Pne=1024*1024*1024,Une="TRUE",{CONFIG_PARAMS:bu}=LH,Qa;MH.exports={hdbServer:DH,start:DH};async function DH(e){try{$s.info("In Fastify server"+process.cwd()),$s.info(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),$s.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=Ene.isMaster,await vne();let t=e.securePort>0;Qa=Bne(t),await Qa.ready(),e||(e={}),e.isOperationsServer=!0;try{Nne.http(Qa.server,e),Qa.server.closeIdleConnections||await Qa.listen({port:0,host:"::"})}catch(r){throw Qa.close(),$s.error(r),$s.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),$s.fatal(t),process.exit(1)}}a(DH,"operationsServer");async function vne(){$s.trace("Configuring HarperDB process."),Ane.setSchemaDataToGlobal(),await bne.setUsersToGlobal(),await yne.getLicense()}a(vne,"setUp");function Bne(e){$s.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=Hne(e),r=hne(t);r.server.headersTimeout=Gne(),r.setErrorHandler(Cne);let n=xne();n&&r.register(mne,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,_){r.server.emit("unhandled",l.raw,_.raw)}),c()}),r.register(Tne),r.register(pne),r.register(Sne,{root:gne.join(Rne,"studio/build-local")}),Lne(r);let s=Co.get(LH.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!One.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[Dne,Ine],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),wne(i,o)}),r.get("/health",()=>"HarperDB is running."),$s.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(Bne,"buildServer");function Hne(e){let t=Co.get(bu.OPERATIONSAPI_NETWORK_TIMEOUT),r=Co.get(bu.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:Pne,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(Hne,"getServerOptions");function xne(){let e=Co.get(bu.OPERATIONSAPI_NETWORK_CORS),t=Co.get(bu.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===Une)&&(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(xne,"getCORSOpts");function Gne(){return Co.get(bu.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??Mne}a(Gne,"getHeaderTimeoutConfig")});var CE={};qe(CE,{disableNATS:()=>qne,publishToStream:()=>wE,setNATSReplicator:()=>kR,setPublishToStream:()=>kne,setSubscription:()=>KR,start:()=>Fne});function Fne(){yu.default.get(Nu.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&$ne()}function qne(e=!0){xH=e}function kne(e,t){wE=e,KR=t}function $ne(){if(xH||process.env._DISABLE_NATS)return;let e=mr(),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];kR(s,r,i)}}QR((r,n)=>{kR(r.tableName,r.databaseName,r),n&&FH(r)}),!UH&&(UH=!0)}function kR(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 $t{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){FH(i)}static subscribe(){let i=new Nn;return KR(t,e,i),i}static subscribeOnThisThread(i){return i<(yu.default.get(Nu.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??Vne)}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 NE(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=GH;return i}a(n,"getNATSTransaction")}function FH(e){let t=yu.default.get(Nu.default.CONFIG_PARAMS.CLUSTERING_NODENAME);wE(`${$R.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,YR.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 vH,$R,YR,BH,HH,yu,Nu,IE,xH,wE,KR,Vne,GH,UH,NE,VR,WR=Re(()=>{Ae();In();vH=B(Rt()),$R=B(ct()),YR=B(As());Nc();BH=B(AS()),HH=B(Hr()),yu=B(te()),Nu=B(U()),IE=B(Y());a(Fne,"start");a(qne,"disableNATS");wE=vH.publishToStream,KR=BH.setSubscription;a(kne,"setPublishToStream");Vne=2;a($ne,"assignReplicationSource");a(kR,"setNATSReplicator");a(FH,"publishSchema");NE=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=yu.default.get(Nu.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,_;for(let u of i){let d=u.table,E=u.operation=="put"?"upsert":u.operation;l||(IE.trace(`Sending transaction event ${E}`),_=l={operation:E,schema:s,table:d,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,E!=="delete"&&E!=="invalidate"&&(l.records=o)),l.table===d&&l.operation===E?(o.push(u.record),c.push(u.id)):_=_.next={operation:E,table:d,id:u.id,record:u.record},u.expiresAt&&(_.expiresAt=u.expiresAt)}l&&n.push(wE(`${$R.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,YR.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(u=>{throw IE.error("An error has occurred trying to replicate transaction",l,u),u.statusCode=504,u}))}return Promise.all(n)}},VR=class extends NE{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,HH.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};GH=new VR});var ex=g(wi=>{"use strict";var{isMainThread:jR,parentPort:wu,threadId:DE}=require("worker_threads"),{Socket:Yne,createServer:Kne}=require("net"),{createServer:Wne,IncomingMessage:Qne}=require("http"),{createServer:zne}=require("https"),{readFileSync:Jne,unlinkSync:qH,existsSync:jne}=require("fs"),Pt=Y(),xe=te(),ut=U(),{server:PE}=(ur(),ie(Hi)),{WebSocketServer:Xne}=require("ws"),{createSecureContext:Zne,createServer:ese}=require("node:tls"),{getTicketKeys:YH,restartNumber:tse,getWorkerIndex:Cu}=ot(),{Headers:KH,appendHeader:rse}=(jl(),ie(UU)),{recordAction:Iu,recordActionBinary:nse}=(ws(),ie(hl)),{Request:WH,createReuseportFd:kH}=(yE(),ie(qR)),{checkMemoryLimit:sse}=Ji(),{X509Certificate:ise}=require("crypto"),QH=require("tls"),ose=QH.createSecureContext,za;QH.createSecureContext=function(e){return za||ose(e)};var zH=xe.get(ut.CONFIG_PARAMS.THREADS_DEBUG);if(zH){let e;if(jR)e=xe.get(ut.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){Pt.info("Could not close debugger",t)}});else{let t=xe.get(ut.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&Cu()>=0&&(e=t+Cu())}if(e){let t=xe.get(ut.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=xe.get(ut.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){Pt.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&jR)try{require("inspector").open(9229)}catch(e){tse<=1&&Pt.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:qme,CONFIG_PARAMS:ase}=ut;xe.initSync();var cse=xe.get(ase.HTTP_SESSIONAFFINITY),ds={};wi.registerServer=tA;wi.httpServer=rA;wi.deliverSocket=eA;wi.startServers=JH;wi.when_components_loaded=null;wi.createSNICallback=nA;PE.http=rA;PE.request=dse;PE.socket=fse;PE.ws=Ese;var zR={},LE={},lse,Ys={},ME={},use=[],XR=[];function JH(){return wi.when_components_loaded=sA().loadRootComponents(!0).then(()=>{wu?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)eA(n,r,s);else if(t.requestId)_se(t);else if(t.type===ut.ITC_EVENT_TYPES.SHUTDOWN){Pt.trace("received shutdown request",DE);for(let i in ds){let o=ds[i],c;if(o.closeIdleConnections){let _=Object.getOwnPropertySymbols(o).find(E=>E.description.includes("connections")),u=0,d=setInterval(()=>{u++;let E=u>=100,f=o[_][E?"all":"idle"]();if(f.length===0){E&&clearInterval(d);return}u===1?Pt.info(`Closing ${f.length} idle connections`):E&&Pt.warn(`Forcefully closing ${f.length} active connections`);for(let h=0,p=f.length;h<p;h++){let S=f[h].socket;S._httpMessage&&!S._httpMessage.finished&&!E||(E?S.destroySoon():S.end(`HTTP/1.1 408 Request Timeout\r
38
+ `},compressible:!1,q:.8});hr.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()}});Tk={type:"application/json",serializeStream:_u,serialize:_f,deserialize:Vie,q:.5};hr.set("*/*",Tk);hr.set("",Tk);a(Vie,"tryJSONParse");a(Hb,"registerContentHandlers");$ie=require("fastify-plugin"),Yie=$ie(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=mm(n.raw);s.type(c),s.serializer(function(l){return(o.serializeStream||o.serialize)(l,{headers:{set:(d,u)=>{s.header(d,u)}}})})}),r()},{name:"content-type-negotiation"});a(mm,"findBestSerializer");_k=Ub.default.get(vb.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(hf,"serialize");a(Ua,"serializeMessage");a(Kie,"streamToBuffer");a(ka,"getDeserializer");a(Ek,"deserializerUnknownType");a(Wie,"transformIterable")});function Gb(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let f=d(l);for(let _=1;_<e.length;_++){let h=e[_],p=d(h);f=f.concat(p)}let E=new Set;return f.filter(_=>{let h=_.key??_;return E.has(h)?!1:(E.add(h),!0)})}else{let f=d(l),E=u(e.slice(1),!0,l.estimated_count);return E.length>0?o(f,E):f}function d(f){return f.conditions?Gb(f.conditions,f.operator,r,n,s,i,o,c):Al(f,n,f.descending||s.reverse===!0,r,s.allowFullScan,c)}a(d,"executeCondition");function u(f,E,_){return f.map((h,p)=>{if(h.conditions){let T=h.operator==="or",A=u(h.conditions,!T,_);return T?(N,V)=>A.some(v=>v(N,V)):(N,V)=>A.every(v=>v(N,V))}let S=(h.attribute||h[0])===r.primaryKey,g=Vb(h,r,i,c,S,_);return E&&p<f.length-1&&_&&(_=roe(r.primaryStore,h.estimated_count,_)),g}).filter(Boolean)}a(u,"mapConditionsToFilters")}function Al(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(Array.isArray(o)){let T=o[0],A=ti(n.attributes,T);if(A.relationship){if(o.length<2)throw new Mn.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let N=A.definition?.tableClass||A.elements?.definition?.tableClass,V=new Map,v=Al({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,N,s,V);if(A.relationship.to){i[o[0]]=V;let J=!!ti(N.attributes,A.relationship.to)?.elements;v=Xie(v,A,N.primaryStore,J,V)}if(A.relationship.from){let J=a($=>Al({attribute:A.relationship.from,value:$},t,r,n,s,V),"searchEntry");A.elements?(i[o[0]]=V,v=Zie(v,A,N.primaryStore,V,J)):v=v.flatMap(J)}return v}else if(o.length===1)o=o[0];else throw new Mn.ClientError("Unable to query by attribute "+JSON.stringify(o))}let d,u,f,E;c instanceof Date&&(c=c.getTime());let _;switch(qb[l]||l){case"lt":d=!0,u=c;break;case"le":d=!0,u=c,f=!0;break;case"gt":d=c,E=!0;break;case"ge":d=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],d=c,u=c.slice(0),u[u.length-1]=ei.MAXIMUM_KEY;break;case"starts_with":d=c.toString(),u=c+"\uFFFF";break;case"between":d=c[0],d instanceof Date&&(d=d.getTime()),u=c[1],u instanceof Date&&(u=u.getTime()),f=!0;break;case"equals":case void 0:d=c,u=c,f=!0;break;case"ne":if(c===null){d=c,E=!0;break}case"sort":case"contains":case"ends_with":d=!0,_=!0;break;default:throw new Mn.ClientError(`Unknown query comparator "${l}"`)}if(r){let T=d;d=u,u=T,T=!E,E=!f,f=T}let h=o===n.primaryKey||o==null,p=h?n.primaryStore:n.indices[o],S;if(!p||p.isIndexing||_||c===null&&!p.indexNulls){if(s===!1&&!p)throw new Mn.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&_)throw new Mn.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(p?.isIndexing)throw new Mn.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&!p.indexNulls)throw new Mn.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(S=Vb(e),!S)throw new Mn.ClientError(`Unknown search operator ${e.comparator}`)}let g={start:d,end:u,inclusiveEnd:f,exclusiveStart:E,values:!0,versions:h,transaction:t,reverse:r};if(h){let T=p.getRange(g).map(S?function({key:A,value:N}){return this.isSync?N&&S(N)?A:wo.SKIP:new Promise((V,v)=>setImmediate(()=>{try{V(N&&S(N)?A:wo.SKIP)}catch(J){v(J)}}))}:A=>A.value==null?wo.SKIP:A);return T.hasEntries=!0,T}else return p?p.getRange(g).map(S?function({key:T,value:A}){return this.isSync?S({[o]:T})?A:wo.SKIP:new Promise((N,V)=>setImmediate(()=>{try{N(S({[o]:T})?A:wo.SKIP)}catch(v){V(v)}}))}:({value:T})=>T):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:T,value:A}){return this.isSync?A&&S(A)?T:wo.SKIP:new Promise((N,V)=>setImmediate(()=>{try{N(A&&S(A)?T:wo.SKIP)}catch(v){V(v)}}))})}function ti(e,t){if(Array.isArray(t))if(t.length>1){let r=ti(e,t[0]),n=(r?.definition?.tableClass||r?.elements.definition?.tableClass)?.attributes;return n?ti(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 Xie(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;s.hasMappings=!0;let o;return{next(){if(!i){let l=t.relationship.to,d=a((u,f)=>{let E=u;Array.isArray(u)&&(E=As(u),o=!0);let _=s.get(E);_?_.push(f):s.set(E,_=[f]),u!==E&&(_.key=u)},"add_entry");for(let u of e){let f=u.value??r.get(u.key??u),E=f?.[l];if(E!=null&&!s.filters?.some(_=>!_(f)))if(n)for(let _=0;_<E.length;_++)d(E[_],u);else d(E,u)}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}},return(){if(i?.return)return i.return()}}}})}function Zie(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let l;if(o)for(;l=o.next(),!l.done;){let d=As(l.value);if(!c.has(d))return c.add(d),l}if(!i){let d=new Map;n.fromRecord=u=>u[t.relationship.from]?.filter?.(f=>d.has(As(f)));for(let u of e){if(n.filters){let f=r.get(u);if(n.filters.some(E=>!E(f)))continue}d.set(As(u),u)}return i=d.values()[Symbol.iterator](),this.next()}do{let d=i.next();return d.done?d:(o=s(d.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function Vb(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let u=c[0],f=ti(t.attributes,u),E=f.definition?.tableClass||f.elements.definition?.tableClass,_=n?.[u],h=Vb({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},E,r,_?.[u]?.joined,c[1]===E.primaryKey,i);if(!h)return;if(_){_.filters||(_.filters=[]),_.filters.push(h);return}let p=t.propertyResolvers?.[u],S,g=a((T,A)=>{let N,V;if(p){if(p.from&&h.idFilter){if(!S)if(h.idFilter.idSet?.size===1){for(let J of h.idFilter.idSet)e={attribute:p.from,value:J};S=d(p.from,h.idFilter,!0,!0)}else S=d(p.from,h.idFilter,!1,!0);let v=S(T);return S.idFilter&&(g.idFilter=S.idFilter),v}V=p(T,r,A),N=V?.value}else N=T[u];return N?Array.isArray(N)?N.some(h):h(N,V):!1},"recordFilter");return g}}switch(l instanceof Date&&(l=l.getTime()),qb[o]||o){case kb.SEARCH_TYPES.EQUALS:case void 0:return d(c,u=>u===l,!0);case"contains":return d(c,u=>u?.toString().includes(l));case"ends_with":return d(c,u=>u?.toString().endsWith(l));case"starts_with":return d(c,u=>typeof u=="string"&&u.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],d(c,u=>{if(!Array.isArray(u))return!1;for(let f=0,E=l.length;f<E;f++)if(u[f]!==l[f])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),d(c,u=>(0,ei.compareKeys)(u,l[0])>=0&&(0,ei.compareKeys)(u,l[1])<=0,!0);case"gt":return d(c,u=>(0,ei.compareKeys)(u,l)>0);case"ge":return d(c,u=>(0,ei.compareKeys)(u,l)>=0);case"lt":return d(c,u=>(0,ei.compareKeys)(u,l)<0);case"le":return d(c,u=>(0,ei.compareKeys)(u,l)<=0);case"ne":return d(c,u=>(0,ei.compareKeys)(u,l)!==0);case"sort":return()=>!0;default:throw new Mn.ClientError(`Unknown query comparator "${o}"`)}function d(u,f,E,_){let h;E=E&&!s&&t?.indices[u]&&i>3,E&&(e.estimated_count==null&&Sm(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(E=!1));let p=0,S=3;function g(T){let A=T[u],N;if(typeof A!="object"||!A||_?N=f(A):Array.isArray(A)?N=A.some(f):A instanceof Date&&(N=f(A.getTime())),E&&(S++,!N&&!g.idFilter&&++p/S*(i-S)>h)){let V=Al(e,r.transaction.getReadTxn(),!1,t).map(As),v=new Set(V);g.idFilter=J=>v.has(As(J)),g.idFilter.idSet=v}return N}return a(g,"recordFilter"),s&&(g.idFilter=f),g}a(d,"attributeComparator")}function Sm(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/Fi(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=qb[n]||n,n===kb.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=ti(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=Sm(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),l=e.indices[i.relationship.from];r.estimated_count=c+(l?c*Fi(e.indices[i.relationship.from])/(Fi(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=Fi(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=jie*Fi(e.primaryStore)+1:n==="between"?r.estimated_count=zie*Fi(e.primaryStore)+1:n==="sort"?r.estimated_count=Fi(e.primaryStore)+1:r.estimated_count=Qie*Fi(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function Tm(e){if(e)if(Co=e,gl.lastIndex=0,eoe.test(e))try{let t=mf(new Rl,"");if(ln!==Co.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 ${ln} in '${Co}'`,t}else return new URLSearchParams(e)}function mf(e,t){let r=gl,n,s,i,o,c,l=decodeURIComponent,d;for(;n=r.exec(Co);){ln=r.lastIndex;let[,u,f]=n;if(o){if(u)throw new SyntaxError(`expected operator, but encountered '${u}'`);o=!1,c=!1}else c=!0;let E;switch(f){case"=":if(s){if(u.length<=2)i=u;else throw new SyntaxError(`invalid FIQL operator ${u}`);l=Rk}else{if(l=decodeURIComponent,i="equals",!u)throw new SyntaxError("attribute must be specified before equality comparator");s=pf(u)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=Jie[f],l=Fb[i]?Rk:decodeURIComponent,!u)throw new SyntaxError(`attribute must be specified before comparator ${f}`);s=pf(u);break;case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${f[0]?"'"+f[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${f?"'"+f+"'":"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:l(u)};i==="eq"&&Ak(h,u),pm(e,d),e.conditions.push(h)}f==="&"&&(d="and"),f==="|"&&(d="or"),s=void 0;break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(pf(u)),s=void 0;break;case"(":gl.lastIndex=ln;let _=mf(u?[]:new Rl,")");switch(u){case"":pm(e,d),e.conditions.push(_);break;case"limit":switch(_.length){case 1:e.limit=+_[0];break;case 2:e.offset=+_[0],e.limit=_[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(_[0])&&_.length===1&&!_[0].name?(e.select=_[0],e.select.asArray=!0):_.length===1?e.select=_[0]:_.length===2&&_[1]===""?e.select=_.slice(0,1):e.select=_;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=bk(_);break;default:throw new SyntaxError(`unknown query function call ${u}`)}Co[ln]===","?r.lastIndex=++ln:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!u)throw new SyntaxError("property sets must have a defined parent property name");gl.lastIndex=ln,E=mf([],"}"),E.name=u,e.push(E),Co[ln]===","?r.lastIndex=++ln:o=!0;break;case"[":gl.lastIndex=ln,u?(E=mf(new Rl,"]"),E.name=u):E=mf(e.conditions?new Rl:[],"]"),e.conditions?(pm(e,d),e.conditions.push(E),s=null):e.push(E),Co[ln]===","?r.lastIndex=++ln:o=!0;break;case")":case"]":case"}":if(t===f[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(u)};i==="eq"&&Ak(h,u),pm(e,d),e.conditions.push(h)}else if(u)throw new SyntaxError("no attribute or comparison specified")}else(u||e.length>0&&c)&&e.push(pf(u));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${f[0]}'`):new SyntaxError(`unexpected token '${f[0]}'`);default:throw new SyntaxError(`unexpected operator '${f}'`)}if(t!==")"&&(r=s?toe:gl,r.lastIndex=ln),ln===Co.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function pm(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 pf(e){return e.indexOf(".")>-1?e.split(".").map(pf):decodeURIComponent(e)}function Rk(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return r[0]==="$"?parseInt(r.slice(1),36):+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(isNaN(r)?decodeURIComponent(r):+r);if(t==="string")return decodeURIComponent(r);throw new Mn.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function Ak(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new Mn.ClientError("wildcard can only be used at the end of a string")}function bk(e){let t=yk(e[0]);return e.length>1&&(t.next=bk(e.slice(1))),t}function yk(e){if(Array.isArray(e)){let t=yk(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 As(e){return Array.isArray(e)?e.join("\0"):e}function Fi(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function roe(e,t,r){return t*r/Fi(e)}var Mn,kb,ei,wo,Qie,zie,jie,Jie,Fb,qb,eoe,gl,toe,ln,Co,Rl,Fa,Sf=Oe(()=>{Mn=U(ce()),kb=U(Ft()),ei=require("ordered-binary"),wo=require("lmdb"),Qie=.3,zie=.1,jie=.05,Jie={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},Fb={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(Gb,"executeConditions");a(Al,"searchByIndex");a(ti,"findAttribute");a(Xie,"joinTo");a(Zie,"joinFrom");qb={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(Vb,"filterByType");a(Sm,"estimateCondition");eoe=/[()[\]|!<>.]|(=\w*=)/,gl=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,toe=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(Tm,"parseQuery");a(mf,"parseBlock");a(pm,"assignOperator");a(pf,"decodeProperty");a(Rk,"typedDecoding");a(Ak,"wildcardDecoding");a(bk,"toSortObject");a(yk,"toSortEntry");Rl=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(As,"flattenKey");a(Fi,"estimatedEntryCount");a(roe,"intersectionEstimate");Fa=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});function Ck(e){let t={openapi:noe,info:{title:"HarperDB HTTP REST interface",version:(0,wk.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:l}=n.Resource;if(c=c??"id",!c)continue;let d={},u=[];if(o)for(let{type:A,name:N,elements:V,relationship:v,definition:J}of o){if(v)A==="array"?d[N]={type:"array",items:{$ref:Do+V.type}}:d[N]={$ref:Do+A};else{let $=J??V?.definition;if($){if(!t.components.schemas[$.type]){let F={};$.properties.forEach(ne=>{F[ne.name]=new Wb($b[ne.type],ne.type)}),t.components.schemas[$.type]=new Ik(F)}A==="array"?d[N]={type:"array",items:{$ref:Do+$.type}}:d[N]={$ref:Do+$.type}}else A==="array"?V.type==="Any"||V.type=="ID"?d[N]={type:"array",items:{format:V.type}}:d[N]={type:"array",items:new Wb($b[V.type],V.type)}:A==="Any"||A=="ID"?d[N]={format:A}:d[N]=new Wb($b[A],A)}u.push(new Qb(N,"query",d[N]))}let f=Object.keys(d),E=new Qb(c,"path",{format:"ID"});E.required=!0,E.description="primary key of record";let _=new Qb("property","path",{enum:f});_.required=!0,t.components.schemas[i]=new Ik(d);let h=l.post!==Resource.prototype.post||l.update,p=typeof l.put=="function",S=typeof l.get=="function",g=typeof l.delete=="function",T="/"+s+"/";h&&(t.paths[T]={},t.paths[T].post=new soe(i,r,"create a new record auto-assigning a primary key")),S&&(t.paths[T]||(t.paths[T]={}),t.paths[T].get=new Yb(u,r,{200:new Kb({$ref:Do+i})},"search for records by the specified property name and value pairs")),g&&(t.paths[T]||(t.paths[T]={}),t.paths[T].delete=new Nk(u,r,"delete all the records that match the provided query",{204:new Ok})),T="/"+s+"/{"+c+"}",S&&(t.paths[T]={},t.paths[T].get=new Yb([E],r,{200:new Kb({$ref:Do+i})},"retrieve a record by its primary key")),p&&(t.paths[T]||(t.paths[T]={}),t.paths[T].put=new ioe([E],r,i,"create or update the record with the URL path that maps to the record's primary key")),g&&(t.paths[T]||(t.paths[T]={}),t.paths[T].delete=new Nk([E],r,"delete a record with the given primary key",{204:new Ok})),S&&_.schema.enum.length>0&&(T="/"+s+"/{"+c+"}.{property}",t.paths[T]={},t.paths[T].get=new Yb([E,_],r,{200:new Kb({enum:f})},"used to retrieve the specified property of the specified record"))}return t}function soe(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Do+e}}}},this.security=t,this.responses={200:{description:zb,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function Yb(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function Kb(e){this.description=zb,this.content={"application/json":{schema:e}}}function Ok(){this.description="successfully processed request, no content returned to client"}function ioe(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Do+r}}}},this.responses={200:{description:zb}}}function Nk(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function Ik(e){this.type="object",this.properties=e}function Wb(e,t){this.type=e,this.format=t}function Qb(e,t,r){this.name=e,this.in=t,this.schema=r}var wk,noe,$b,Do,zb,Dk=Oe(()=>{wk=U(JE()),noe="3.0.3",$b={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Do="#/components/schemas/",zb="successful operation";a(Ck,"generateJsonApi");a(soe,"Post");a(Yb,"Get");a(Kb,"Response200");a(Ok,"Response204");a(ioe,"Put");a(Nk,"Delete");a(Ik,"ResourceSchema");a(Wb,"Type");a(Qb,"Parameter")});var Rm={};Ze(Rm,{start:()=>coe});async function aoe(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&Tm(e);let i=new Ui;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==Lk){let S=gm.getMatch(o,n?"sse":"rest");if(!S)return t(e);e.handlerPath=S.path,c=new Fa(S.relativeURL),c.async=!0,l=S.Resource}let d=r["cache-control"];if(d){let S=Uk(d);for(let g of S)switch(g.name){case"max-age":e.expiresAt=g.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}let u=r["x-replicate-to"];if(u){let S=Uk(u).map(g=>(g.next?.name==="confirm"&&g.next.value>=0&&(e.replicatedConfirmation=+g.next.value),g.name));e.replicateTo=S.length===1&&+S[0]>=0?+S[0]:S[0]==="*"?void 0:S}let f=await Tt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=ka(r["content-type"],!0)(e.body,e.headers)}catch(S){throw new bl.ClientError(S,400)}if(e.authorize=!0,o===Lk&&s==="GET"){if(e?.user?.role?.permission?.super_user)return Ck(gm);throw new bl.ServerError("Forbidden",403)}switch(s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new bl.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new bl.ServerError(`Method ${s} is not recognized`,501)}}),E=200,_;if(f==null)E=s==="GET"||s==="HEAD"?404:204,jb.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else{if(f.status>0&&f.headers)return f.headers=cb(f.headers,i),f.data!==void 0&&(f.body=hf(f.data,e,f)),f;if(_=e.lastModified){ooe[0]=_;let S=String.fromCharCode(34,(yr[0]&63)+62,(yr[0]>>6)+(yr[1]<<2&63)+62,(yr[1]>>4)+(yr[2]<<4&63)+62,(yr[2]>>2)+62,(yr[3]&63)+62,(yr[3]>>6)+(yr[4]<<2&63)+62,(yr[4]>>4)+(yr[5]<<4&63)+62,(yr[5]>>2)+62,(yr[6]&63)+62,(yr[6]>>6)+(yr[7]<<2&63)+62,34),g=r["if-none-match"];g&&S==g?(f?.onDone&&f.onDone(),E=304,f=void 0):i.setIfNone("ETag",S),jb.lastModified&&i.setIfNone("Last-Modified",new Date(_).toUTCString())}}e.createdResource&&(E=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:E,headers:i,body:void 0},p=f?.wasLoadedFromSource?.();return p!==void 0&&(h.wasCacheMiss=p,!p&&_&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||_))/1e3))),f!==void 0&&(h.body=hf(f,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?Ga.warn(o):Ga.info(o):Ga.error(o),o.statusCode===405&&(o.method&&(o.message+=` to handle HTTP method ${o.method.toUpperCase()||""}`),o.allow&&(o.allow.push("trace","head","options"),i.setIfNone("Allow",o.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:o.statusCode||500,headers:i,body:void 0};return c.body=hf(o.contentType?o:o.toString(),e,c),c}}function coe(e){jb=e,!Pk&&(Pk=!0,gm=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return aoe(t,r)},e),e.server.ws(async(t,r,n)=>{Tf++;let s=new Sn;Mk||(Mk=!0,td(l=>{Tf>0&&l.push({metric:"ws-connections",connections:Tf,byThread:!0})}));let i;t.on("error",l=>{i=!0,Ga.warn(l)});let o;t.on("message",a(function(d){o||(o=ka(r.headers.asObject["content-type"]));let u=o(d);s.push(u)},"message"));let c;t.on("close",()=>{Tf--,wn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),d=gm.getMatch(l,"ws");if(wn(!!d,"connection","ws","connect"),d){r.handlerPath=d.path,Qr(h=>({count:h.count,total:Tf}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let u=new Fa(d.relativeURL),f=d.Resource;c=(await Tt(r,()=>f.connect(u,s,r)))[Symbol.asyncIterator]();let _;for(;!(_=await c.next()).done;){let h=Ua(_.value,r);t.send(h),Qr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){t.close(loe[l.statusCode]||1011,l.toString())}t.close()},e))}function Uk(e){return e.split(/\s*,\s*/).map(r=>{let n,s=r.split(/\s*;\s*/),i;for(;i=s.pop();)if(i.includes("=")){let[o,c]=i.split(/\s*=\s*/);n={name:o.toLowerCase(),value:c,next:n}}else n={name:i.toLowerCase(),next:n};return n})}var Ga,bl,yr,ooe,jb,Lk,Pk,gm,Mk,Tf,loe,vk=Oe(()=>{_l();bi();Ga=U(X()),bl=U(ce());Sf();cc();aa();Xd();Dk();Sf();yr=new Uint8Array(8),ooe=new Float64Array(yr.buffer,0,1),jb={},Lk="openapi";a(aoe,"http");Tf=0;a(coe,"start");loe={401:3e3,403:3003};a(Uk,"parseHeaderValue")});var Jb=I((iAe,xk)=>{var{recordAction:Am,recordActionBinary:uoe}=(bi(),ae(rd)),doe=require("fastify-plugin"),foe=200;xk.exports=doe(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let o=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,d,u,f;l.config?.isOperation?(d=n.body?.operation,u="operation"):(d=l.url,u="fastify-route",f=l.method),Am(o,"duration",d,f,u),uoe(s.raw.statusCode<400,"success",d,f,u);let E=foe;i?.pipe?(i.on("data",S=>{E+=S.length}),i.on("end",()=>{Am(performance.now()-c,"transfer",d,f,u),Am(E,"bytes-sent",d,f,u)})):(E+=i?.length||0,Am(E,"bytes-sent",d,f,u));let _=o.toFixed(3),h=s.getHeader("Server-Timing"),p=`db;dur=${_}`;s.header("Server-Timing",h?`${h}, ${p}`:p)}),r()},{name:"hdb-request-time"})});var ny=I((cAe,Fk)=>{var Nm=require("clone"),Im=mt(),_oe=te(),ym=B(),oAe=X(),Xb=require("fs"),ey=require("joi"),{string:Om}=ey.types(),{hdb_errors:Eoe,handleHDBError:bm}=ce(),{HDB_ERROR_MSGS:aAe,HTTP_STATUS_CODES:Zb}=Eoe,{common_validators:yl}=Bs(),Bk=" is required",hoe=["insert","update","upsert"],ty={database:{presence:!1,format:yl.schema_format,length:yl.schema_length},schema:{presence:!1,format:yl.schema_format,length:yl.schema_length},table:{presence:!0,format:yl.schema_format,length:yl.schema_length},action:{inclusion:{within:hoe,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},moe={schema:Om.required(),table:Om.required(),action:Om.valid("insert","update","upsert")},{AWS_ACCESS_KEY:poe,AWS_SECRET:Soe,AWS_BUCKET:Toe,AWS_FILE_KEY:goe,REGION:Roe}=ym.S3_BUCKET_AUTH_KEYS,Aoe={s3:{presence:!0},[`s3.${poe}`]:{presence:!0,type:"String"},[`s3.${Soe}`]:{presence:!0,type:"String"},[`s3.${Toe}`]:{presence:!0,type:"String"},[`s3.${goe}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${Roe}`]:{presence:!0,type:"String"}},Hk=Nm(ty);Hk.data.presence={message:Bk};var kk=Nm(ty);kk.file_path.presence={message:Bk};var boe=Object.assign(Nm(ty),Aoe),ry=Nm(moe);ry.csv_url=Om.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();ry.passthrough_headers=ey.object();function yoe(e){let t=Im.validateObject(e,Hk);return wm(e,t)}a(yoe,"dataObject");function Ooe(e){let t=Im.validateBySchema(e,ey.object(ry));return wm(e,t)}a(Ooe,"urlObject");function Noe(e){let t=Im.validateObject(e,kk);return wm(e,t)}a(Noe,"fileObject");function Ioe(e){let t=Im.validateObject(e,boe);return wm(e,t)}a(Ioe,"s3FileObject");function wm(e,t){if(!t){let r=_oe.checkGlobalSchemaTable(e.schema,e.table);if(r)return bm(new Error,r,Zb.BAD_REQUEST);if(e.operation===ym.OPERATIONS_ENUM.CSV_FILE_LOAD)try{Xb.accessSync(e.file_path,Xb.constants.R_OK|Xb.constants.F_OK)}catch(n){return n.code===ym.NODE_ERROR_CODES.ENOENT?bm(n,`No such file or directory ${n.path}`,Zb.BAD_REQUEST):n.code===ym.NODE_ERROR_CODES.EACCES?bm(n,`Permission denied ${n.path}`,Zb.BAD_REQUEST):bm(n)}}return t}a(wm,"postValidateChecks");Fk.exports={dataObject:yoe,urlObject:Ooe,fileObject:Noe,s3FileObject:Ioe}});var sy=I((uAe,Gk)=>{"use strict";var gf=X(),Cm=B();async function woe(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===Cm.OPERATIONS_ENUM.INSERT||t.operation===Cm.OPERATIONS_ENUM.UPDATE||t.operation===Cm.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===Cm.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(gf.info(i.message),i):i.http_resp_msg?(gf.error(`Error calling operation: ${e.name}`),gf.error(i.http_resp_msg),i):(gf.error(`Error calling operation: ${e.name}`),gf.error(i),i)}}a(woe,"callOperationFunctionAsAwait");Gk.exports={callOperationFunctionAsAwait:woe}});var Vk=I((fAe,qk)=>{"use strict";var iy=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}},oy=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};qk.exports={BulkLoadFileObject:iy,BulkLoadDataObject:oy}});var Yk=I((EAe,$k)=>{"use strict";var ay=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};$k.exports=ay});var _y=I((gAe,cF)=>{"use strict";var Dm=Vn(),Pm=ny(),Coe=require("needle"),bs=B(),mAe=Pt(),Ol=te(),{handleHDBError:xt,hdb_errors:eF}=ce(),{HTTP_STATUS_CODES:Or,HDB_ERROR_MSGS:cr,CHECK_LOGS_WRAPPER:Va}=eF,Nl=X(),cy=require("papaparse");Ol.promisifyPapaParse();var ys=require("fs-extra"),Doe=require("path"),{chain:Kk}=require("stream-chain"),Wk=require("stream-json/streamers/StreamArray"),Qk=require("stream-json/utils/Batch"),zk=require("stream-chain/utils/comp"),{finished:jk}=require("stream"),Loe=ie(),tF=sy(),Poe=Lb(),{BulkLoadFileObject:uy,BulkLoadDataObject:Moe}=Vk(),dy=Rb(),{verifyBulkLoadAttributePerms:rF}=um(),pAe=Yk(),SAe=jt(),TAe=pi(),{databases:Uoe}=(Ne(),ae(it)),{coerceType:voe}=(Mm(),ae(Ey)),Jk="No records parsed from csv file.",qa=`${Loe.get("HDB_ROOT")}/tmp`,{schema_regex:xoe}=Bs(),Xk=1024*1024*2,Zk=5e3,Boe={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};cF.exports={csvDataLoad:Hoe,csvURLLoad:koe,csvFileLoad:Foe,importFromS3:Goe};async function Hoe(e,t){let r=Pm.dataObject(e);if(r)throw xt(r,r.message,Or.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=iF(e.schema,e.table),i=cy.parse(e.data,{header:!0,skipEmptyLines:!0,transform:ly.bind(null,s),dynamicTyping:!1}),o=new dy;e.hdb_user&&e.hdb_user.role&&e.hdb_user.role.permission&&e.hdb_user.role.permission.super_user!==!0&&rF(e.hdb_user.role.permission,this.job_operation_function.name,e.action,e.schema,e.table,i.meta.fields,o);let c=o.getPermsResponse();if(c)throw xt(new Error,c,Or.BAD_REQUEST,void 0,void 0,!0);let l=new Moe(e.action,e.schema,e.table,i.data);return n=await tF.callOperationFunctionAsAwait(oF,l,null),n.message===Jk?Jk:aF(n.records,n.number_written)}catch(s){throw $a(s)}}a(Hoe,"csvDataLoad");async function koe(e){let t=Pm.urlObject(e);if(t)throw xt(t,t.message,Or.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${qa}/${r}`;try{await qoe(e,r)}catch(s){throw Nl.error(cr.DOWNLOAD_FILE_ERR(r)+" - "+s),xt(s,Va(cr.DOWNLOAD_FILE_ERR(r)))}try{let s=new uy(this.job_operation_function.name,e.action,e.schema,e.table,n,bs.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission),i=await fy(s);return await Lm(n),i}catch(s){throw await Lm(n),$a(s)}}a(koe,"csvURLLoad");async function Foe(e){let t=Pm.fileObject(e);if(t)throw xt(t,t.message,Or.BAD_REQUEST,void 0,void 0,!0);let r=new uy(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,bs.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission);try{return await fy(r)}catch(n){throw $a(n)}}a(Foe,"csvFileLoad");async function Goe(e){let t=Pm.s3FileObject(e);if(t)throw xt(t,t.message,Or.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=Doe.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${qa}/${s}`;let i=new uy(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user.role.permission);await Voe(s,e);let o=await fy(i);return await Lm(r),o}catch(n){throw await Lm(r),$a(n)}}a(Goe,"importFromS3");async function qoe(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await Coe("get",e.csv_url,n)}catch(n){let s=`Error downloading CSV file from ${e.csv_url}, status code: ${n.statusCode}. Check the log for more information.`;throw xt(n,s,n.statusCode,bs.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}Yoe(r,e.csv_url),await $oe(t,r.raw)}a(qoe,"downloadCSVFile");async function Voe(e,t){try{let r=`${qa}/${e}`;await ys.mkdirp(qa),await ys.writeFile(`${qa}/${e}`,"",{flag:"a+"});let n=await ys.createWriteStream(r),s=await Poe.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(){Nl.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Nl.error(cr.S3_DOWNLOAD_ERR+" - "+r),xt(r,Va(cr.S3_DOWNLOAD_ERR))}}a(Voe,"downloadFileFromS3");async function $oe(e,t){try{await ys.mkdirp(qa),await ys.writeFile(`${qa}/${e}`,t)}catch(r){throw Nl.error(cr.WRITE_TEMP_FILE_ERR),xt(r,Va(cr.DEFAULT_BULK_LOAD_ERR))}}a($oe,"writeFileToTempFolder");async function Lm(e){if(e)try{await ys.access(e),await ys.unlink(e)}catch{Nl.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(Lm,"deleteTempFile");function Yoe(e,t){if(e.statusCode!==eF.HTTP_STATUS_CODES.OK)throw xt(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Or.BAD_REQUEST);if(!Boe[e.headers["content-type"]])throw xt(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Or.BAD_REQUEST);if(!e.raw)throw xt(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Or.BAD_REQUEST)}a(Yoe,"validateURLResponse");async function fy(e){try{let t;switch(e.file_type){case bs.VALID_S3_FILE_TYPES.CSV:t=await Koe(e);break;case bs.VALID_S3_FILE_TYPES.JSON:t=await Woe(e);break;default:throw xt(new Error,cr.DEFAULT_BULK_LOAD_ERR,Or.BAD_REQUEST,bs.LOG_LEVELS.ERROR,cr.INVALID_FILE_EXT_ERR(e))}return aF(t.records,t.number_written)}catch(t){throw $a(t)}}a(fy,"fileLoad");async function nF(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 Dm.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&rF(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=xt(c);r(l)}}a(nF,"validateChunk");async function sF(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Ol.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Ol.isEmpty(c)&&!Ol.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(l=>{Object.keys(l).forEach(d=>c.add(d))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},l=await tF.callOperationFunctionAsAwait(oF,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=xt(c,Va(cr.INSERT_CSV_ERR),Or.INTERNAL_SERVER_ERROR,bs.LOG_LEVELS.ERROR,cr.INSERT_CSV_ERR+" - "+c);r(l)}}a(sF,"insertChunk");async function Koe(e){let t={records:0,number_written:0},r=iF(e.schema,e.table);try{let n=new dy,s=ys.createReadStream(e.file_path,{highWaterMark:Xk});s.setEncoding("utf8"),await cy.parsePromise(s,nF.bind(null,e,n),ly.bind(null,r));let i=n.getPermsResponse();if(i)throw xt(new Error,i,Or.BAD_REQUEST);return s=ys.createReadStream(e.file_path,{highWaterMark:Xk}),s.setEncoding("utf8"),await cy.parsePromise(s,sF.bind(null,e,t),ly.bind(null,r)),s.destroy(),t}catch(n){throw xt(n,Va(cr.PAPA_PARSE_ERR),Or.INTERNAL_SERVER_ERROR,bs.LOG_LEVELS.ERROR,cr.PAPA_PARSE_ERR+n)}}a(Koe,"callPapaParse");function iF(e,t){let r=Uoe[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>voe(i,s));return n}a(iF,"createTransformMap");function ly(e,t,r){let n=e.get(r);return n?n(t):Ol.autoCast(t)}a(ly,"typeFunction");async function Woe(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new dy,s=Kk([ys.createReadStream(e.file_path,{encoding:"utf-8"}),Wk.withParser(),c=>c.value,new Qk({batchSize:Zk}),zk(async c=>{await nF(e,n,r,c)})]);await new Promise((c,l)=>{jk(s,d=>{d?l(d):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw xt(new Error,i,Or.BAD_REQUEST);let o=Kk([ys.createReadStream(e.file_path,{encoding:"utf-8"}),Wk.withParser(),c=>c.value,new Qk({batchSize:Zk}),zk(async c=>{await sF(e,t,r,c)})]);return await new Promise((c,l)=>{jk(o,d=>{d?l(d):c()}),o.resume()}),t}catch(n){throw xt(n,Va(cr.INSERT_JSON_ERR),Or.INTERNAL_SERVER_ERROR,bs.LOG_LEVELS.ERROR,cr.INSERT_JSON_ERR+n)}}a(Woe,"insertJson");async function oF(e){let t={};try{e.data&&e.data.length>0&&Qoe(e.data[0])?t=await zoe(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Nl.info(t.message))}catch(r){throw $a(r)}return t}a(oF,"callBulkFileLoad");function Qoe(e){let t=Object.keys(e);for(let r of t)if(!xoe.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(Qoe,"validateColumnNames");async function zoe(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=Dm.insert;break;case"update":i=Dm.update;break;case"upsert":i=Dm.upsert;break;default:throw xt(new Error,cr.INVALID_ACTION_PARAM_ERR(n),Or.BAD_REQUEST,bs.LOG_LEVELS.ERROR,cr.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 u=global.hdb_schema[t][r].hash_attribute,f=e.length;for(;f--;)o.skipped_hashes.indexOf(e[f][u])>=0&&e.splice(f,1)}let l=Ol.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw $a(o)}}a(zoe,"bulkFileLoad");function aF(e,t){return`successfully loaded ${t} of ${e} records`}a(aF,"buildResponseMsg");function $a(e){return xt(e,Va(cr.DEFAULT_BULK_LOAD_ERR),Or.INTERNAL_SERVER_ERROR,bs.LOG_LEVELS.ERROR,cr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a($a,"buildTopLevelErrMsg")});var uF=I((AAe,lF)=>{"use strict";var hy=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};lF.exports=hy});var _F=I((yAe,fF)=>{"use strict";var joe=B(),dF=require("moment"),Joe=require("uuid").v4,my=class{static{a(this,"JobObject")}constructor(){this.id=Joe(),this.type=void 0,this.start_datetime=dF().valueOf(),this.created_datetime=dF().valueOf(),this.end_datetime=void 0,this.status=joe.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};fF.exports=my});var vm=I((NAe,RF)=>{"use strict";var Xoe=require("uuid").v4,SF=Vn(),TF=An(),Zoe=Gs(),eae=Oc(),tae=uF(),gt=B(),rae=_F(),nae=SR(),rs=X(),sae=Cu(),Il=te(),{promisify:iae}=require("util"),Ya=require("moment"),oae=fm(),Um=ny(),EF=hT(),{deleteTransactionLogsBeforeValidator:aae}=mb(),{handleHDBError:hF,hdb_errors:cae}=ce(),{HTTP_STATUS_CODES:mF}=cae,pF=TF.searchByValue,lae=TF.searchByHash,uae=SF.insert,dae=iae(oae.evaluateSQL),fae=SF.update;RF.exports={addJob:hae,updateJob:pae,handleGetJob:_ae,handleGetJobsByStartDate:Eae,getJobById:gF};async function _ae(e){try{let t=await gF(e.id);return Il.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 rs.error("There was an error getting job",t),new Error(r)}}a(_ae,"handleGetJob");async function Eae(e){try{let t=await mae(e);if(rs.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=Ya(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Ya(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 rs.error(r),new Error(r)}}a(Eae,"handleGetJobsByStartDate");async function hae(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||Il.isEmptyOrZeroLength(e.operation)){let u="job parameter is invalid";return rs.info(u),t.error=u,t}if(!gt.JOB_TYPE_ENUM[e.operation])return rs.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case gt.OPERATIONS_ENUM.CSV_FILE_LOAD:n=Um.fileObject(e);break;case gt.OPERATIONS_ENUM.CSV_URL_LOAD:n=Um.urlObject(e);break;case gt.OPERATIONS_ENUM.CSV_DATA_LOAD:n=Um.dataObject(e);break;case gt.OPERATIONS_ENUM.IMPORT_FROM_S3:n=Um.s3FileObject(e);break;case gt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case gt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=EF(e,"date");break;case gt.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=EF(e,"timestamp");break;case gt.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=aae(e);break;case gt.OPERATIONS_ENUM.RESTART_SERVICE:if(gt.PROCESS_DESCRIPTORS_VALIDATE[e.service]===void 0)throw hF(new Error,"Invalid service",mF.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw hF(n,n.message,mF.BAD_REQUEST,void 0,void 0,!0);let s=new rae;s.type=e.operation===gt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?gt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user.username;let i=new Zoe(gt.SYSTEM_SCHEMA_NAME,gt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await pF(i))}catch(u){let f=`There was an error inserting a new job: ${u}`;return rs.error(f),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Xoe();try{o=await pF(i)}catch(u){let f=`There was an error inserting a new job: ${u}`;return rs.error(f),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return rs.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new sae(gt.SYSTEM_SCHEMA_NAME,gt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),d;try{d=await uae(l)}catch(u){return rs.error(`There was an error inserting a job for job type: ${e.operation} -- ${u}`),t.success=!1,t}if(d.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let u=`Created a job with type ${s.type} and id ${s.id}`;t.message=u,t.createdJob=s,t.success=!0,rs.trace(u)}return t}a(hae,"addJob");async function mae(e){let t=Ya(e.from_date,Ya.ISO_8601),r=Ya(e.to_date,Ya.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 tae(n,e.hdb_user);try{return await dae(s)}catch(i){throw rs.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(mae,"getJobsInDateRange");async function gF(e){if(Il.isEmptyOrZeroLength(e))return Il.errorizeMessage("Invalid job ID specified.");let t=new eae(gt.SYSTEM_SCHEMA_NAME,gt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await lae(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return rs.error(n),Il.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(gF,"getJobById");async function pae(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(Il.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===gt.JOB_STATUS_ENUM.COMPLETE||e.status===gt.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Ya().valueOf());let t=new nae(gt.SYSTEM_SCHEMA_NAME,gt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await fae(t),r}a(pae,"updateJob")});var CF=I((wAe,wF)=>{"use strict";var AF=te(),lr=B(),Sae=require("moment"),xm=_y(),Rf=X(),bF=vm(),yF=_m(),OF=ea(),NF=at(),Tae=om(),gae=jd(),{parentPort:Rae,isMainThread:IF}=require("worker_threads"),{onMessageByType:Aae}=at(),py=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function bae(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(AF.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(AF.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case lr.JOB_TYPE_ENUM.csv_file_load:await ri(e,xm.csvFileLoad);break;case lr.JOB_TYPE_ENUM.csv_url_load:await ri(e,xm.csvURLLoad);break;case lr.JOB_TYPE_ENUM.csv_data_load:await ri(e,xm.csvDataLoad);break;case lr.JOB_TYPE_ENUM.import_from_s3:await ri(e,xm.importFromS3);break;case lr.JOB_TYPE_ENUM.empty_trash:break;case lr.JOB_TYPE_ENUM.export_local:await ri(e,yF.export_local);break;case lr.JOB_TYPE_ENUM.export_to_s3:await ri(e,yF.export_to_s3);break;case lr.JOB_TYPE_ENUM.delete_files_before:case lr.JOB_TYPE_ENUM.delete_records_before:await ri(e,OF.deleteFilesBefore);break;case lr.JOB_TYPE_ENUM.delete_audit_logs_before:await ri(e,OF.deleteAuditLogsBefore);break;case lr.JOB_TYPE_ENUM.delete_transaction_logs_before:await ri(e,Tae.deleteTransactionLogsBefore);break;case lr.JOB_TYPE_ENUM.restart_service:return await ri(e,gae.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(bae,"parseMessage");async function ri(e,t){try{e.job.status=lr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=Sae().valueOf(),await bF.updateJob(e.job),await yae(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):Rf.error(`There was an error running ${t.name} job with id ${e.job.id}`),Rf.error(n),e.job.message=n,e.job.status=lr.JOB_STATUS_ENUM.ERROR;try{await bF.updateJob(e.job)}catch(s){throw Rf.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(ri,"runJob");async function yae(e){Rf.trace("launching job thread:",e),IF?NF.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:Object.assign({},process.env,{[lr.PROCESS_NAME_ENV_PROP]:`JOB-${e}`})}):Rae.postMessage({type:lr.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(yae,"launchJobThread");IF&&Aae(lr.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{NF.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:Object.assign({},process.env,{[lr.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`})})}catch(r){Rf.error(r)}});wF.exports={parseMessage:bae,RunnerMessage:py}});var LF=I((DAe,DF)=>{"use strict";var Sy=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};DF.exports=Sy});var Oy=I((MAe,yy)=>{"use strict";var Gm=An(),Ry=fm(),Bm=_y(),Gi=kE(),Hm=ro(),yf=ea(),Oae=nR(),Af=yn(),km=fR(),Nt=hb(),Fm=X(),Nae=hR(),Iae=Oh(),PF=bA(),wae=Ih(),Cae=NA(),Dae=IA(),Lae=DA(),Pae=PA(),Ty=vA(),MF=_m(),Mae=um(),Ay=vm(),G=B(),{hdb_errors:Nf,handleHDBError:Of}=ce(),{HTTP_STATUS_CODES:UF}=Nf,gy=FA(),vF=jd(),YF=require("util"),wl=Vn(),Uae=Si(),vae=Gc(),xF=CF(),BF=_d(),HF=(Wh(),ae(Zd)),kF=dr(),FF=om(),GF=Zh(),{setServerUtilities:xae}=(Mm(),ae(Ey)),{CONTEXT:PAe}=(us(),ae(ng)),{_assignPackageExport:Bae}=require("../../index"),{transformReq:Hae}=te(),{server:kae}=(Lr(),ae(Fo)),kr=Fm.loggerWithTag("operation"),bf=go(),qF=(Ia(),ae(Na)),Fae=sy(),VF=Gm.searchByHash,Gae=Gm.searchByValue,qae=YF.promisify(Gm.search),Vae=YF.promisify(Ry.evaluateSQL),$ae={[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},Q=LF();async function KF(e,t){try{if(e.body.operation!=="read_log"&&(Fm.log_level===G.LOG_LEVELS.INFO||Fm.log_level===G.LOG_LEVELS.DEBUG||Fm.log_level===G.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,...o}=e.body;kr.info(o)}}catch(n){kr.error(n)}let r=await Fae.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return $ae[e.body.operation]&&Uae.setSchemaDataToGlobal(n=>{n&&kr.error(n)}),r}a(KF,"processLocalTransaction");var $F=Kae();yy.exports={chooseOperation:WF,getOperationFunction:QF,operation:by,processLocalTransaction:KF};xae(yy.exports);kae.operation=by;function WF(e){let t;try{t=QF(e)}catch(s){throw kr.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=Ry.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=Ry.checkASTPermissions(e,i);if(o)throw kr.error(`${UF.FORBIDDEN} from operation ${e.operation}`),kr.warn(`User '${e.hdb_user.username}' is not permitted to ${e.operation}`),Of(new Error,o,Nf.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=Mae.verifyPerms(i,s);if(o)throw kr.error(`${UF.FORBIDDEN} from operation ${e.operation}`),kr.warn(`User '${i.hdb_user.username}' is not permitted to ${i.operation}`),Of(new Error,o,Nf.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw Of(s,"There was an error when trying to choose an operation path")}return r}a(WF,"chooseOperation");function QF(e){if(kr.trace(`getOperationFunction with operation: ${e.operation}`),$F.has(e.operation))return $F.get(e.operation);throw Of(new Error,Nf.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),Nf.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(QF,"getOperationFunction");Bae("operation",by);function by(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=WF(e);return KF({body:e},n)}a(by,"operation");async function Yae(e){kr.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 wl.insert(i);break;case G.OPERATIONS_ENUM.UPDATE:o=await wl.update(i);break;case G.OPERATIONS_ENUM.UPSERT:o=await wl.upsert(i);break;case G.OPERATIONS_ENUM.DELETE:o=await yf.deleteRecord(i);break;default:kr.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){kr.info("Invalid operation in transaction"),kr.error(o)}}a(Yae,"catchup");async function Os(e){Hae(e);let t,r;try{r=await Ay.addJob(e),t=r.createdJob,kr.info("addJob result",r);let n=new xF.RunnerMessage(t,e);return{message:await xF.parseMessage(n)??`Starting job with id ${t.id}`,job_id:t.id}}catch(n){let s=`There was an error executing job: ${n.http_resp_msg?n.http_resp_msg:n}`;throw kr.error(s),Of(n,s)}}a(Os,"executeJob");function Kae(){let e=new Map;return e.set(G.OPERATIONS_ENUM.INSERT,new Q(wl.insert)),e.set(G.OPERATIONS_ENUM.UPDATE,new Q(wl.update)),e.set(G.OPERATIONS_ENUM.UPSERT,new Q(wl.upsert)),e.set(G.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new Q(Gm.searchByConditions)),e.set(G.OPERATIONS_ENUM.SEARCH_BY_HASH,new Q(VF)),e.set(G.OPERATIONS_ENUM.SEARCH_BY_ID,new Q(VF)),e.set(G.OPERATIONS_ENUM.SEARCH_BY_VALUE,new Q(Gae)),e.set(G.OPERATIONS_ENUM.SEARCH,new Q(qae)),e.set(G.OPERATIONS_ENUM.SQL,new Q(Vae)),e.set(G.OPERATIONS_ENUM.CSV_DATA_LOAD,new Q(Os,Bm.csvDataLoad)),e.set(G.OPERATIONS_ENUM.CSV_FILE_LOAD,new Q(Os,Bm.csvFileLoad)),e.set(G.OPERATIONS_ENUM.CSV_URL_LOAD,new Q(Os,Bm.csvURLLoad)),e.set(G.OPERATIONS_ENUM.IMPORT_FROM_S3,new Q(Os,Bm.importFromS3)),e.set(G.OPERATIONS_ENUM.CREATE_SCHEMA,new Q(Gi.createSchema)),e.set(G.OPERATIONS_ENUM.CREATE_DATABASE,new Q(Gi.createSchema)),e.set(G.OPERATIONS_ENUM.CREATE_TABLE,new Q(Gi.createTable)),e.set(G.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new Q(Gi.createAttribute)),e.set(G.OPERATIONS_ENUM.DROP_SCHEMA,new Q(Gi.dropSchema)),e.set(G.OPERATIONS_ENUM.DROP_DATABASE,new Q(Gi.dropSchema)),e.set(G.OPERATIONS_ENUM.DROP_TABLE,new Q(Gi.dropTable)),e.set(G.OPERATIONS_ENUM.DROP_ATTRIBUTE,new Q(Gi.dropAttribute)),e.set(G.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new Q(Hm.describeSchema)),e.set(G.OPERATIONS_ENUM.DESCRIBE_DATABASE,new Q(Hm.describeSchema)),e.set(G.OPERATIONS_ENUM.DESCRIBE_TABLE,new Q(Hm.describeTable)),e.set(G.OPERATIONS_ENUM.DESCRIBE_ALL,new Q(Hm.describeAll)),e.set(G.OPERATIONS_ENUM.DELETE,new Q(yf.deleteRecord)),e.set(G.OPERATIONS_ENUM.ADD_USER,new Q(Af.addUser)),e.set(G.OPERATIONS_ENUM.ALTER_USER,new Q(Af.alterUser)),e.set(G.OPERATIONS_ENUM.DROP_USER,new Q(Af.dropUser)),e.set(G.OPERATIONS_ENUM.LIST_USERS,new Q(Af.listUsersExternal)),e.set(G.OPERATIONS_ENUM.LIST_ROLES,new Q(km.listRoles)),e.set(G.OPERATIONS_ENUM.ADD_ROLE,new Q(km.addRole)),e.set(G.OPERATIONS_ENUM.ALTER_ROLE,new Q(km.alterRole)),e.set(G.OPERATIONS_ENUM.DROP_ROLE,new Q(km.dropRole)),e.set(G.OPERATIONS_ENUM.USER_INFO,new Q(Af.userInfo)),e.set(G.OPERATIONS_ENUM.READ_LOG,new Q(Nae)),e.set(G.OPERATIONS_ENUM.ADD_NODE,new Q(Iae)),e.set(G.OPERATIONS_ENUM.UPDATE_NODE,new Q(PF)),e.set(G.OPERATIONS_ENUM.SET_NODE_REPLICATION,new Q(PF)),e.set(G.OPERATIONS_ENUM.REMOVE_NODE,new Q(wae)),e.set(G.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new Q(Cae)),e.set(G.OPERATIONS_ENUM.PURGE_STREAM,new Q(Dae)),e.set(G.OPERATIONS_ENUM.SET_CONFIGURATION,new Q(kF.setConfiguration)),e.set(G.OPERATIONS_ENUM.CLUSTER_STATUS,new Q(Lae.clusterStatus)),e.set(G.OPERATIONS_ENUM.CLUSTER_NETWORK,new Q(Pae)),e.set(G.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new Q(Ty.setRoutes)),e.set(G.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new Q(Ty.getRoutes)),e.set(G.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new Q(Ty.deleteRoutes)),e.set(G.OPERATIONS_ENUM.EXPORT_TO_S3,new Q(Os,MF.export_to_s3)),e.set(G.OPERATIONS_ENUM.CREATE_CSR,new Q(bf.createCsr)),e.set(G.OPERATIONS_ENUM.SIGN_CERTIFICATE,new Q(bf.signCertificate)),e.set(G.OPERATIONS_ENUM.LIST_CERTIFICATES,new Q(bf.listCertificates)),e.set(G.OPERATIONS_ENUM.ADD_CERTIFICATES,new Q(bf.addCertificate)),e.set(G.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new Q(bf.removeCertificate)),e.set(G.OPERATIONS_ENUM.ADD_NODE_BACK,new Q(qF.addNodeBack)),e.set(G.OPERATIONS_ENUM.REMOVE_NODE_BACK,new Q(qF.removeNodeBack)),e.set(G.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new Q(Os,yf.deleteFilesBefore)),e.set(G.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new Q(Os,yf.deleteFilesBefore)),e.set(G.OPERATIONS_ENUM.EXPORT_LOCAL,new Q(Os,MF.export_local)),e.set(G.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new Q(Ay.handleGetJobsByStartDate)),e.set(G.OPERATIONS_ENUM.GET_JOB,new Q(Ay.handleGetJob)),e.set(G.OPERATIONS_ENUM.GET_FINGERPRINT,new Q(gy.getFingerprint)),e.set(G.OPERATIONS_ENUM.SET_LICENSE,new Q(gy.setLicense)),e.set(G.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new Q(gy.getRegistrationInfo)),e.set(G.OPERATIONS_ENUM.RESTART,new Q(vF.restart)),e.set(G.OPERATIONS_ENUM.RESTART_SERVICE,new Q(Os,vF.restartService)),e.set(G.OPERATIONS_ENUM.CATCHUP,new Q(Yae)),e.set(G.OPERATIONS_ENUM.SYSTEM_INFORMATION,new Q(vae.systemInformation)),e.set(G.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new Q(Os,yf.deleteAuditLogsBefore)),e.set(G.OPERATIONS_ENUM.READ_AUDIT_LOG,new Q(Oae)),e.set(G.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new Q(BF.createTokens)),e.set(G.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new Q(BF.refreshOperationToken)),e.set(G.OPERATIONS_ENUM.LOGIN,new Q(HF.login)),e.set(G.OPERATIONS_ENUM.LOGOUT,new Q(HF.logout)),e.set(G.OPERATIONS_ENUM.GET_CONFIGURATION,new Q(kF.getConfiguration)),e.set(G.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new Q(Nt.customFunctionsStatus)),e.set(G.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new Q(Nt.getCustomFunctions)),e.set(G.OPERATIONS_ENUM.GET_COMPONENT_FILE,new Q(Nt.getComponentFile)),e.set(G.OPERATIONS_ENUM.GET_COMPONENTS,new Q(Nt.getComponents)),e.set(G.OPERATIONS_ENUM.SET_COMPONENT_FILE,new Q(Nt.setComponentFile)),e.set(G.OPERATIONS_ENUM.DROP_COMPONENT,new Q(Nt.dropComponent)),e.set(G.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new Q(Nt.getCustomFunction)),e.set(G.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new Q(Nt.setCustomFunction)),e.set(G.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new Q(Nt.dropCustomFunction)),e.set(G.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new Q(Nt.addComponent)),e.set(G.OPERATIONS_ENUM.ADD_COMPONENT,new Q(Nt.addComponent)),e.set(G.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new Q(Nt.dropCustomFunctionProject)),e.set(G.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new Q(Nt.packageComponent)),e.set(G.OPERATIONS_ENUM.PACKAGE_COMPONENT,new Q(Nt.packageComponent)),e.set(G.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new Q(Nt.deployComponent)),e.set(G.OPERATIONS_ENUM.DEPLOY_COMPONENT,new Q(Nt.deployComponent)),e.set(G.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new Q(FF.readTransactionLog)),e.set(G.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new Q(Os,FF.deleteTransactionLogsBefore)),e.set(G.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new Q(GF.installModules)),e.set(G.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new Q(GF.auditModules)),e.set(G.OPERATIONS_ENUM.GET_BACKUP,new Q(Gi.getBackup)),e.set(G.OPERATIONS_ENUM.ADD_SSH_KEY,new Q(Nt.addSSHKey)),e.set(G.OPERATIONS_ENUM.UPDATE_SSH_KEY,new Q(Nt.updateSSHKey)),e.set(G.OPERATIONS_ENUM.DELETE_SSH_KEY,new Q(Nt.deleteSSHKey)),e.set(G.OPERATIONS_ENUM.LIST_SSH_KEYS,new Q(Nt.listSSHKeys)),e.set(G.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new Q(Nt.setSSHKnownHosts)),e.set(G.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new Q(Nt.getSSHKnownHosts)),e}a(Kae,"initializeOperationFunctionMap")});var Vm=I((vAe,JF)=>{"use strict";var Ny=B(),Wae=te(),If=X(),{handleHDBError:Iy,hdb_errors:qm}=ce(),{isMainThread:Qae}=require("worker_threads"),{Readable:zae}=require("stream"),zF=require("os"),jae=require("util"),Jae=NR(),Xae=jae.promisify(Jae.authorize),jF=Oy(),{createGzip:Zae,constants:ece}=require("zlib");function tce(e){let t=`Found an uncaught exception with message: ${e.message}. ${zF.EOL}Stack: ${e.stack} ${zF.EOL}Terminating ${Qae?"HDB":"thread"}.`;console.error(t),If.fatal(t),process.exit(1)}a(tce,"handleServerUncaughtException");function rce(e,t,r){if(If[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:qm.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(rce,"serverErrorHandler");function nce(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=Iy(new Error,"Invalid JSON.",qm.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(Wae.isEmpty(e.body.operation)){let n=Iy(new Error,"Request body must include an 'operation' property.",qm.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(nce,"reqBodyValidationHandler");function sce(e,t,r){let n;e.body.operation!==Ny.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==Ny.OPERATIONS_ENUM.LOGIN&&e.body.operation!==Ny.OPERATIONS_ENUM.LOGOUT?Xae(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{If.warn(s),If.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r(Iy(s,i,qm.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(sce,"authHandler");async function ice(e,t,r=!1){let n;try{r&&(e.body.operation!=="configure_cluster"||e.body.operation!=="set_configuration")&&(e.body.bypass_auth=r),n=jF.chooseOperation(e.body);let s=await jF.processLocalTransaction(e,n);if(s instanceof zae&&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(Zae({level:ece.Z_BEST_SPEED})))}return s}catch(s){throw If.error(s),s}}a(ice,"handlePostRequest");JF.exports={authHandler:sce,handlePostRequest:ice,handleServerUncaughtException:tce,serverErrorHandler:rce,reqBodyValidationHandler:nce}});var tG=I((BAe,eG)=>{"use strict";var oce=require("fastify-plugin"),{handlePostRequest:XF,authHandler:ace,reqBodyValidationHandler:cce}=Vm();async function lce(e){e.decorate("hdbCore",{preValidation:[cce,ace],request:t=>ZF(XF(t,response)),requestWithoutAuthentication:(t,r)=>ZF(XF(t,r,!0))})}a(lce,"hdbCore");async function ZF(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(ZF,"convertAsyncIterators");eG.exports=oce(lce)});var sG=I((FAe,nG)=>{"use strict";var kAe=require("fs"),wy=ie();wy.initSync();var{CONFIG_PARAMS:rG}=B(),uce=1024*1024*1024;function dce(e){let t=wy.get(rG.HTTP_TIMEOUT),r=wy.get(rG.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:uce,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,https:e}}a(dce,"getServerOptions");nG.exports=dce});var aG=I((qAe,oG)=>{"use strict";var Cy=ie();Cy.initSync();var{CONFIG_PARAMS:iG}=B();function fce(){let e=Cy.get(iG.HTTP_CORSACCESSLIST),t=Cy.get(iG.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(fce,"getCORSOptions");oG.exports=fce});var uG=I(($Ae,lG)=>{"use strict";var cG=ie();cG.initSync();var _ce=B();function Ece(){return cG.get(_ce.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(Ece,"getHeaderTimeoutConfig");lG.exports=Ece});var Ly={};Ze(Ly,{customFunctionsServer:()=>pce,ready:()=>OG,start:()=>mce});function mce(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){qi||(qi=yG(t),st.http((await qi).server));let o=await qi,c=(0,Dy.dirname)(s),l=(0,Dy.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!dG.has(c)){dG.add(c);try{o.register(Tce(c,l))}catch(d){if(d.message==="Root plugin has already booted")ut.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw d}}},ready:OG}}async function pce(){try{ut.info("In Custom Functions Fastify server"+process.cwd()),ut.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),ut.debug(`Custom Functions server process ${process.pid} starting up.`),await Sce();let e=pG.get(SG.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=qi=await yG(e)}catch(r){throw ut.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw ut.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){ut.error(`Custom Functions ${process.pid} Error: ${e}`),ut.error(e),process.exit(1)}}async function Sce(){try{ut.info("Custom Functions starting configuration."),await TG.setUsersToGlobal(),ut.info("Custom Functions completed configuration.")}catch(e){ut.error(e)}}function Tce(e,t){return async function(r){try{ut.info("Custom Functions starting buildRoutes"),ut.trace("Loading fastify routes folder "+e),(0,fG.existsSync)(e)&&r.register(mG.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:ut.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?ut.error(s.message):s&&ut.error(s),o()})}catch(n){ut.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function yG(e){ut.info("Custom Functions starting buildServer.");let t=(0,gG.default)(e),r=(0,_G.default)(t);r.server.headersTimeout=(0,AG.default)(),r.setErrorHandler(bG.serverErrorHandler);let n=(0,RG.default)();return n&&r.register(EG.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(hG.default),await r.register(hce),await r.after(),Hb(r),ut.info("Custom Functions completed buildServer."),r}function OG(){if(qi)return qi.then?qi.then(e=>e.ready()):qi.ready()}var Dy,fG,_G,EG,hG,mG,pG,SG,ut,hce,TG,gG,RG,AG,bG,qi,dG,NG=Oe(()=>{Dy=require("path"),fG=require("fs"),_G=U(require("fastify")),EG=U(require("@fastify/cors")),hG=U(Jb()),mG=U(require("@fastify/autoload")),pG=U(ie()),SG=U(B()),ut=U(X()),hce=U(tG()),TG=U(yn()),gG=U(sG()),RG=U(aG()),AG=U(uG()),bG=U(Vm());_l();Lr();dG=new Set;a(mce,"start");a(pce,"customFunctionsServer");a(Sce,"setUp");a(Tce,"buildRouteFolder");a(yG,"buildServer");a(OG,"ready")});var Py={};Ze(Py,{start:()=>gce});function gce(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,LG.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){wG||(wG=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=IG.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,CG.default)(s,(0,DG.realpathSync)(o))}}return i(s)},{runFirst:!0})),IG.set(r,n)}}}var CG,DG,LG,IG,wG,PG=Oe(()=>{CG=U(require("send")),DG=require("fs"),LG=U(require("serve-static")),IG=new Map;a(gce,"start")});function bce(){let e=(0,xG.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),Uy=setInterval(()=>{Km.notify(e)},Ace).unref())}function yce(e,t=1,r){if(My++,(0,ni.startWorker)("server/threads/threadServer.js",{name:Ml.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(d){d.type===Ml.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});Rce.push(s),await s,Cl.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=Ym.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Cl.indexOf(n);o>-1&&Cl.splice(o,1)}if(a(i,"removeWorker"),Dl){let o=Dl;Dl=[];for(let c of o)BG[c.localPort](null,c)}}}),r){let n=setInterval(()=>{vy?vy=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,ni.shutdownWorkers)(),My=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function HG(e=0,t){if(typeof e=="string")try{(0,Wm.existsSync)(e)&&(0,Wm.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=Oce:r=Nce(t):r=xy;let n=(0,Ll.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=BG[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),vy=!0,r(o,(c,l)=>{if(!c){if(MG){let u=o._socket||new Ll.Socket({handle:o,writable:!0,readable:!0});MG.deliverSocket(u,e,l),u.resume()}else My>0?(Dl.length===0&&setTimeout(()=>{Dl.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,Dl.push(o)):(console.log("start up a dynamic thread to handle request"),yce(0));Qr(!1,"socket-routed");return}c.requests++;let d=o.fd;if(d>=0)c.postMessage({port:e,fd:d,data:l});else{let u=o._socket||new Ll.Socket({handle:o,writable:!0,readable:!0});Dce(u,c,e)}Qr(!0,"socket-routed")})};let s=Ju();Km.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 xy(e,t){let r,n=0;for(let s of Cl){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=$m)return $m=i,t(r);n=i}$m=0,t(r)}function Oce(e,t){let r={};e.getpeername(r);let n=r.address,s=Pl.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);xy(e,o=>{Pl.set(n,{worker:o,lastUsed:i}),t(o)})}function Nce(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new Ll.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],d=Pl.get(l),u=Date.now();if(d&&d.worker.threadId!==-1)return d.lastUsed=u,s(d.worker);xy(n,f=>{Pl.set(l,{worker:f,lastUsed:u}),s(f,o)})})}a(r,"findByHeaderAffinity")}function wce(){$m=0;for(let e of Cl)e.expectedIdle=e.recentELU.idle+Ice,e.requests=1;Cl.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function Dce(e,t,r){let n=Cce++;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(),Ym.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")),Ym.delete(n)),s.event=="destroy"&&(e.destroy(),Ym.delete(n))})}var ni,Ll,Ml,Km,Wm,vG,xG,Cl,Dl,BG,MG,My,Rce,Uy,Ace,vy,$m,UG,Pl,Ice,Ym,Cce,kG=Oe(()=>{ni=U(at()),Ll=require("net"),Ml=U(B()),Km=U(X()),Wm=require("fs");bi();vG=require("worker_threads"),xG=U(ta()),Cl=[],Dl=[],BG=[],My=0,Rce=[];vG.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,ni.onMessageFromWorkers)(e=>{e.type===Ml.ITC_EVENT_TYPES.RESTART&&Uy&&(clearInterval(Uy),bce())}));Ace=6e5;a(bce,"licenseWarning");a(yce,"startHTTPWorker");a(HG,"startSocketServer");$m=0;a(xy,"findMostIdleWorker");UG=36e5,Pl=new Map;a(Oce,"findByRemoteAddressAffinity");a(Nce,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of Pl)r.lastUsed+UG<e&&Pl.delete(t)},UG).unref();Ice=1e3;a(wce,"updateWorkerIdleness");(0,ni.setMonitorListener)(wce);Ym=new Map,Cce=1;a(Dce,"proxySocket")});var Fy={};Ze(Fy,{Request:()=>By,createReuseportFd:()=>Qm});var FG,By,Hy,ky,Qm,zm=Oe(()=>{FG=require("os"),By=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 ky(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 Hy(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},Hy=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}pipe(t,r){return this.#e.pipe(t,r)}},ky=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,FG.platform)()!="win32"&&(Qm=require("node-unix-socket").createReuseportFd)});var $G=I((ibe,VG)=>{"use strict";var Lce=require("cluster"),Ka=ie();Ka.initSync();var qG=B(),ebe=require("util"),Vi=X(),tbe=require("fs"),Pce=require("fastify"),rbe=Ju(),Mce=require("@fastify/cors"),Uce=require("@fastify/compress"),vce=require("@fastify/static"),xce=Jb(),Bce=require("path"),{PACKAGE_ROOT:Hce}=B(),kce=Si(),Fce=te(),Gce=yn(),qce=ta(),{server:Vce}=(Lr(),ae(Fo)),{node_request_key:nbe}=(zm(),ae(Fy)),{authHandler:$ce,handlePostRequest:Yce,serverErrorHandler:Kce,reqBodyValidationHandler:Wce}=Vm(),sbe=require("net"),{registerContentHandlers:Qce}=(_l(),ae(gk)),zce=6e4,jce=1024*1024*1024,Jce="TRUE",{CONFIG_PARAMS:wf}=qG,Ul;VG.exports={hdbServer:GG,start:GG};async function GG(e){try{Vi.debug("In Fastify server"+process.cwd()),Vi.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Vi.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=Lce.isMaster,await Xce();let t=e.securePort>0;Ul=Zce(t),await Ul.ready(),e||(e={}),e.isOperationsServer=!0;try{Vce.http(Ul.server,e),Ul.server.closeIdleConnections||await Ul.listen({port:0,host:"::"})}catch(r){throw Ul.close(),Vi.error(r),Vi.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Vi.fatal(t),process.exit(1)}}a(GG,"operationsServer");async function Xce(){Vi.trace("Configuring HarperDB process."),kce.setSchemaDataToGlobal(),await Gce.setUsersToGlobal(),await qce.getLicense()}a(Xce,"setUp");function Zce(e){Vi.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=ele(e),r=Pce(t);r.server.headersTimeout=rle(),r.setErrorHandler(Kce);let n=tle();n&&r.register(Mce,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,d){r.server.emit("unhandled",l.raw,d.raw)}),c()}),r.register(xce),r.register(Uce),r.register(vce,{root:Bce.join(Hce,"studio/build-local")}),Qce(r);let s=Ka.get(qG.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!Fce.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[Wce,$ce],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),Yce(i,o)}),r.get("/health",()=>"HarperDB is running."),Vi.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(Zce,"buildServer");function ele(e){let t=Ka.get(wf.OPERATIONSAPI_NETWORK_TIMEOUT),r=Ka.get(wf.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:jce,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(ele,"getServerOptions");function tle(){let e=Ka.get(wf.OPERATIONSAPI_NETWORK_CORS),t=Ka.get(wf.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===Jce)&&(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(tle,"getCORSOpts");function rle(){return Ka.get(wf.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??zce}a(rle,"getHeaderTimeoutConfig")});var Zm={};Ze(Zm,{disableNATS:()=>sle,publishToStream:()=>Xm,setNATSReplicator:()=>Gy,setPublishToStream:()=>ile,setSubscription:()=>Yy,start:()=>nle});function nle(){Cf.default.get(Df.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&ale()}function sle(e=!0){zG=e}function ile(e,t){Xm=e,Yy=t}function ale(){if(zG||process.env._DISABLE_NATS)return;let e=ct(),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];Gy(s,r,i)}}Ra((r,n)=>{Gy(r.tableName,r.databaseName,r),n&&JG(r)}),!YG&&(YG=!0)}function Gy(e,t,r){if(t==="system"&&cle.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends pr{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this[We],record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this[We]})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this[We],record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this[We],record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this[We]})}static defineSchema(i){JG(i)}static subscribe(){let i=new Sn;return Yy(t,e,i),i}static subscribeOnThisThread(i){return i<(Cf.default.get(Df.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??ole)}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 jm(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=jG;return i}a(n,"getNATSTransaction")}function JG(e){let t=Cf.default.get(Df.default.CONFIG_PARAMS.CLUSTERING_NODENAME);Xm(`${Vy.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,$y.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 KG,Vy,$y,WG,QG,Cf,Df,Jm,zG,Xm,Yy,ole,jG,YG,cle,jm,qy,Ky=Oe(()=>{Ne();us();KG=U(jt()),Vy=U(Pt()),$y=U(pi());cc();WG=U(Yg()),QG=U(pn()),Cf=U(ie()),Df=U(B()),Jm=U(X());a(nle,"start");a(sle,"disableNATS");Xm=KG.publishToStream,Yy=WG.setSubscription;a(ile,"setPublishToStream");ole=2;a(ale,"assignReplicationSource");cle=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(Gy,"setNATSReplicator");a(JG,"publishSchema");jm=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=Cf.default.get(Df.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,d;for(let u of i){let f=u.table,E=u.operation=="put"?"upsert":u.operation;l||(Jm.trace(`Sending transaction event ${E}`),d=l={operation:E,schema:s,table:f,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,E!=="delete"&&E!=="invalidate"&&(l.records=o)),l.table===f&&l.operation===E?(o.push(u.record),c.push(u.id)):d=d.next={operation:E,table:f,id:u.id,record:u.record},u.expiresAt&&(d.expiresAt=u.expiresAt)}l&&n.push(Xm(`${Vy.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,$y.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(u=>{throw Jm.error("An error has occurred trying to replicate transaction",l,u),u.statusCode=504,u}))}return Promise.all(n)}},qy=class extends jm{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,QG.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};jG=new qy});var uq=I(Lo=>{"use strict";var{isMainThread:Qy,parentPort:Uf,threadId:tp,workerData:lle}=require("worker_threads"),{Socket:ule,createServer:dle}=require("net"),{createServer:fle,IncomingMessage:_le}=require("http"),{createServer:Ele}=require("https"),{unlinkSync:eq,existsSync:hle}=require("fs"),Fr=X(),Et=ie(),Yt=B(),{server:np}=(Lr(),ae(Fo)),{WebSocketServer:mle}=require("ws"),{createServer:ple}=require("node:tls"),{getTicketKeys:Sle,restartNumber:Tle,getWorkerIndex:vf}=at(),{Headers:zy,appendHeader:gle}=(Xd(),ae(VB)),{recordAction:Lf,recordActionBinary:Rle}=(bi(),ae(rd)),{Request:tq,createReuseportFd:Mf}=(zm(),ae(Fy)),{checkMemoryLimit:Ale}=ta(),{createTLSSelector:rq}=go(),{resolvePath:nq}=dr(),sq=Et.get(Yt.CONFIG_PARAMS.THREADS_DEBUG);if(sq){let e;if(Qy)e=Et.get(Yt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){Fr.info("Could not close debugger",t)}});else{let t=Et.get(Yt.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&vf()>=0&&(e=t+vf())}if(e){let t=Et.get(Yt.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=Et.get(Yt.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){Fr.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&Qy)try{require("inspector").open(9229)}catch(e){Tle<=1&&Fr.trace("Could not start debugging on port 9229, you may already be debugging:",e.message)}process.on("uncaughtException",e=>{e.isHandled||e.code==="ECONNRESET"||e.code==="ECONNREFUSED"||e.message!=="write EIO"&&console.error("uncaughtException",e)});var{HDB_SETTINGS_NAMES:fbe,CONFIG_PARAMS:ble}=Yt;Et.initSync();var yle=Et.get(ble.HTTP_SESSIONAFFINITY),si={};Lo.registerServer=Zy;Lo.httpServer=eO;Lo.deliverSocket=Xy;Lo.startServers=iq;Lo.listenOnPorts=oq;Lo.when_components_loaded=null;np.http=eO;np.request=wle;np.socket=Cle;np.ws=Dle;var Wy={},Pf={},Ole,ep={},rp={},Nle=[],jy=[];function iq(){return Lo.when_components_loaded=tO().loadRootComponents(!0).then(()=>{Uf?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)Xy(n,r,s);else if(t.requestId)Ile(t);else if(t.type===Yt.ITC_EVENT_TYPES.SHUTDOWN){Fr.trace("received shutdown request",tp);for(let i in si){let o=si[i],c;if(o.closeIdleConnections){let d=Object.getOwnPropertySymbols(o).find(E=>E.description.includes("connections")),u=0,f=setInterval(()=>{u++;let E=u>=100,_=o[d][E?"all":"idle"]();if(_.length===0){E&&clearInterval(f);return}u===1?Fr.info(`Closing ${_.length} idle connections`):E&&Fr.warn(`Forcefully closing ${_.length} active connections`);for(let h=0,p=_.length;h<p;h++){let S=_[h].socket;S._httpMessage&&!S._httpMessage.finished&&!E||(E?S.destroySoon():S.end(`HTTP/1.1 408 Request Timeout\r
29
39
  Connection: close\r
30
40
  \r
31
- `))}},25).unref()}o.close?.(()=>{if(xe.get(ut.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&Cu()==0)try{qH(xe.get(ut.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,DE),o.cantCleanupProperly||Pt.warn("Had to forcefully exit the thread",DE),process.exit(0)},5e3).unref()})}if(zH||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Pt.info("Could not close debugger",i)}}}).ref();let e=[];if(kH&&!cse)for(let t in ds){let r=ds[t];if(isNaN(t)&&Cu()==0){jne(t)&&qH(t),e.push(new Promise((i,o)=>{r.listen({path:t},()=>{i(),Pt.info("Domain socket listening on "+t)}).on("error",o)}));continue}let n=xe.get(ut.CONFIG_PARAMS.HTTP_THREADRANGE);if(n){let i=typeof n=="string"?n.split("-"):n,o=Cu();if(o<i[0]||o>i[1])continue}let s;try{s=kH(+t,"::")}catch(i){console.error(`Unable to bind to port ${t}`,i);continue}e.push(new Promise((i,o)=>{r.listen({fd:s},()=>{i(),Pt.trace("Listening on port "+t,DE)}).on("error",o)}))}Promise.all(e).then(()=>{wu?.postMessage({type:ut.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(JH,"startServers");jR||JH();function eA(e,t,r){let n=e?.read?e:new Yne({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=ds[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=ds[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(Pt.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(eA,"deliverSocket");var VH=new Map;function _se(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=VH.get(s),r){case"connection":i=eA(void 0,t),VH.set(s,i),i.write=(c,l,_)=>(wu.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),_&&_(),!0),i.end=(c,l,_)=>(wu.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),_&&_(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),wu.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(_se,"proxyRequest");function tA(e,t,r=!0){!+t&&t!==xe.get(ut.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&(t=parseInt(xe.get(ut.CONFIG_PARAMS.HTTP_PORT),10));let n=ds[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",$H),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else ds[t]=e;e.on("unhandled",$H)}a(tA,"registerServer");function jH(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=[],xe.get(ut.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:xe.get(ut.CONFIG_PARAMS.HTTP_PORT),secure:xe.get(ut.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),xe.get(ut.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:xe.get(ut.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&xe.get(ut.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:xe.get(ut.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),secure:!1}),t}a(jH,"getPorts");function rA(e,t){for(let{port:r,secure:n}of jH(t))XH(r,n,t?.isOperationsServer),typeof e=="function"?XR[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||r}):(e.isSecure=n,tA(e,r,!1)),ME[r]=ZR(XR,r),lse=ZR(use,r)}a(rA,"httpServer");function XH(e,t,r){if(!Ys[e]){let n=r?"operationsApi_network":"http",s={noDelay:!0,keepAliveTimeout:xe.get(n+"_keepAliveTimeout"),headersTimeout:xe.get(n+"_headersTimeout"),requestTimeout:xe.get(n+"_timeout")},i=xe.get(n+"_mtls"),o=xe.get(n+"_mtls_required");if(t){n=r?"operationsApi_":"";let l=xe.get(n+"tls");Object.assign(s,{allowHTTP1:!0,rejectUnauthorized:!!o,requestCert:!!i,ticketKeys:YH(),maxHeaderSize:xe.get(ut.CONFIG_PARAMS.HTTP_MAXHEADERSIZE),SNICallback:nA(l)})}let c=sse();Ys[e]=(t?zne:Wne)(s,async(l,_)=>{try{let d=performance.now(),E=new WH(l,_);r&&(E.isOperationsServer=!0);let f=await ME[e](E);if(!f){if(E._nodeResponse.statusCode)return;f=ZH(E)}if(c?f.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):f.headers?.set?.("Server","HarperDB"),f.status===-1){for(let H of f.headers||[])_.setHeader(H[0],H[1]);return l.baseRequest=E,_.baseResponse=f,Ys[e].emit("unhandled",l,_)}let h=f.status||200,p=performance.now(),S=p-d,T=f.body,R;if(!f.handlesHeaders){let H=f.headers||new KH;T?T.length>=0&&(typeof T=="string"?H.set("Content-Length",Buffer.byteLength(T)):H.set("Content-Length",T.length),R=!0):(H.set("Content-Length","0"),R=!0);let v=`hdb;dur=${S.toFixed(2)}`;f.wasCacheMiss&&(v+=", miss"),rse(H,"Server-Timing",v,!0),_.writeHead(h,H&&(H[Symbol.iterator]?Array.from(H):H)),R&&_.end(T)}let b=E.handlerPath,C=E.method;if(Iu(S,"duration",b,C,f.wasCacheMiss==null?void 0:f.wasCacheMiss?"cache-miss":"cache-hit"),nse(h<400,"success",b,C),!R)if(T?.pipe){T.pipe(_),T.destroy&&_.on("close",()=>{T.destroy()});let H=0;T.on("data",v=>{H+=v.length}),T.on("end",()=>{Iu(performance.now()-p,"transfer",b,C),Iu(H,"bytes-sent",b,C)})}else T?.then?T.then(H=>{_.end(H)},u):_.end(T)}catch(d){u(d)}function u(d){let E=d.headers;_.writeHead(d.statusCode||500,E&&(E[Symbol.iterator]?Array.from(E):E)),_.end(d.toString()),d.statusCode?d.statusCode===500?Pt.warn(d):Pt.info(d):Pt.error(d)}a(u,"onError")}),i&&(Ys[e].mtlsConfig=i),t&&(Ys[e].on("secureConnection",l=>{l._parent.startTime&&Iu(performance.now()-l._parent.startTime,"tls-handshake",e),Iu(l.isSessionReused(),"tls-reused",e)}),Ys[e].isSecure=!0,s.SNICallback(null,(l,_)=>{try{za=_,_&&Ys[e].setSecureContext(_.options)}finally{za=null}})),tA(Ys[e],e)}return Ys[e]}a(XH,"getHTTPServer");function ZR(e,t){let r=ZH;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(ZR,"makeCallbackChain");function ZH(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new KH}}a(ZH,"unhandled");function dse(e,t){rA(e,{requestOnly:!0,...t})}a(dse,"onRequest");function fse(e,t){let r;if(t.securePort){let n=Object.assign({},xe.get("tls"));t.mtls?.certificateAuthority&&(n.certificateAuthority=t.mtls.certificateAuthority);let s={noDelay:!0,rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,SNICallback:nA(n)};r=ese(s,e),s.SNICallback(null,(i,o)=>{try{za=o,o&&r.setSecureContext(o.options)}finally{za=null}}),ds[t.securePort]=r}return t.port&&(r=Kne({noDelay:!0},e),ds[t.port]=r),r}a(fse,"onSocket");Object.defineProperty(Qne.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 Ese(e,t){let r;for(let{port:n,secure:s}of jH(t)){LE[n]||(LE[n]=new Xne({server:r=XH(n,s)}),LE[n].on("connection",async(c,l)=>{try{let _=new WH(l);_.isWebSocket=!0;let u=ME[n](_),d=l.headers["sec-websocket-protocol"]||"",E=zR[n];if(d){let f;for(let h=0;h<E.length;h++){let p=E[h];p.protocol===d&&(f=!0,p.listener(c,_,u))}if(f)return}for(let f=0;f<E.length;f++){let h=E[f];h.protocol||h.listener(c,_,u)}}catch(_){Pt.warn("Error handling WebSocket connection",_)}}),LE[n].on("error",c=>{console.log("Error in setting up WebSocket server",c)}));let i=t?.subProtocol||"",o=zR[n];o||(o=zR[n]=[]),o.push({listener:e,protocol:i}),ME[n]=ZR(XR,n)}return r}a(Ese,"onWebSocket");function $H(e,t){t.writeHead(404),t.end(`Not found
32
- `)}a($H,"defaultNotFound");function JR(e){return e.startsWith("-----BEGIN")?e:Jne(e)}a(JR,"readPEM");function nA(e){let t=[];for(let o=0;e[o];o++)t.push(e[o]);t.length||t.push(e);let r=new Map,n,s,i=!1;for(let o of t){let c=JR(o.privateKey),l=JR(o.certificate),_=o.certificateAuthority&&JR(o.certificateAuthority);if(!c||!l)throw new Error("Missing private key or certificate for secure server");let u={ciphers:o.ciphers,ca:_,ticketKeys:YH()},d=Zne(u);d.options=u,u.instantiatedContext=d,d.context.setCert(l),d.context.setKey(c,void 0),u.cert=l,u.key=c,d.certStart=l.slice(0,100).toString(),n||(n=d);let E=new ise(l);d.subject=E.subject;let f=o.hostname??o.host??o.hostnames??o.hosts??(E.subjectAltName?E.subjectAltName.split(",").map(h=>{let p=h.indexOf(":");return h.slice(p+1)}):[E.subject.match(/CN=(.*)/)?.[1]]);Array.isArray(f)||(f=[f]);for(let h of f)h?(h[0]==="*"&&(i=!0,h=h.slice(1)),r.has(h)||r.set(h,d),!s&&h.match(/\d+\.\d+\.\d+\.\d+/)&&(s=d)):Pt.error("No hostname found for certificate at",o.certificate)}return(o,c)=>{let l=o;for(;;){let _=r.get(l);if(_)return Pt.debug("Found certificate for",o,_.certStart),c(null,_);if(i&&l){let u=l.indexOf(".",1);u<0?l="":l=l.slice(u)}else break}Pt.debug("No certificate found to match",o,"using the first certificate"),o?c(null,n):c(null,s)}}a(nA,"createSNICallback")});async function sx({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await iA.get(e,{returnNonexistent:!0});i=new cA(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await iA.get(e);o&&o.delete()}i=new vE(e,t)}return n&&(n.id=e,n.user={username:t?.username},Du.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function oA(){return UE++,UE>65500&&(UE=1),UE}function aA(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=Ri.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 tx,Ci,rx,nx,iA,Du,UE,vE,cA,ix=Re(()=>{Ae();Jl();tx=B(Hr()),Ci=B(Y());ro();rx=B(ot()),nx=B(ex());ur();iA=ft({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),Du=ft({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,rx.getWorkerIndex)()===0&&(async()=>{await nx.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of Du.search({})){let t=e.data,r=Object.assign({},e);r.user?.username&&(r.user=await it.getUser(r.user.username)),Je(r,()=>{try{aA(r,t,r)}catch{(0,Ci.warn)("Failed to publish will",t)}Du.delete(e.id,r)})}})();a(sx,"getSession");UE=1;a(oA,"getNextMessageId");vE=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,_;if(c>-1?(l=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 u=this.subscriptions.find(T=>T.topic===s),d;u?(d=i>0,u.end(),this.subscriptions.splice(this.subscriptions.indexOf(u),1)):d=i===2;let E={search:l,async:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,Ci.trace)("Resuming subscription from",s,"from",o);let f=Ri.getMatch(_);if(!f){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(E.url=f.relativeURL,E.url.indexOf("+")>-1||E.url.indexOf("#")>-1){let T=E.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(E.isCollection=!0,T.indexOf("+")===T.length-1)E.onlyChildren=!0,E.url="/"+T.slice(0,T.length-1);else{let R=T.split("/"),b;for(let v=0;v<R.length;v++)if(R[v].indexOf("+")>-1)if(R[v]==="+")b=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&b)throw new Error("Filters can not be combined");let C=!0;R[R.length-1]==="#"&&(R.length--,C=!1),b&&(n=a(v=>{let q=v.id;if(!Array.isArray(q)||C&&q.length!==R.length)return!1;for(let M=0;M<R.length;M++)if(R[M]!=="+"&&R[M]!==q[M])return!1;return!0},"filter"));let H=R.indexOf("+");E.url="/"+(H>-1?R.slice(0,H):R).concat("").join("/")}}let h=f.path,p=f.Resource,S=await Je(E,async()=>{let T=this.createContext();T.topic=s,T.retainHandling=i;let R=await p.subscribe(E,T);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 b of R)try{let C;if(b.type&&b.type!=="put"&&b.type!=="delete"&&b.type!=="message"&&b.type!=="patch"||n&&!n(b))continue;r?(b.topic=s,C=this.needsAcknowledge(b)):(b.acknowledge?.(),C=oA());let H=b.id;Array.isArray(H)&&(H=ya(H)),H==null&&(H=""),this.listener(h+"/"+H,b.value,C,t)}catch(C){(0,Ci.warn)(C)}})(),R});return S.topic=s,S.qos=t.qos,this.subscriptions.push(S),S}resume(){}needsAcknowledge(t){let r=oA();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(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return aA(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();Je(r,async()=>{try{if(!t){let n=await Du.get(this.sessionId);n?.doesExist()&&await aA(n,n.data,r)}}finally{await Du.delete(this.sessionId)}}).catch(n=>{(0,Ci.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(aA,"publish");cA=class extends vE{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=oA(),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,Ci.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,tx.getNextMonotonicTime)()),(0,Ci.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),iA.put(this.sessionRecord)}}});var uA={};qe(uA,{bypassAuth:()=>hse,start:()=>mse});function hse(){ux=!0}function mse({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new lx.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c,l=r?.mtls;return n&&(c=e.ws((_,u,d)=>{if(_.protocol==="mqtt"){o.events.emit("connection",_),jt.debug("Received WebSocket connection for MQTT from",_._socket.remoteAddress);let{onMessage:E,onClose:f}=ax(_,(h,p)=>{if(_.send(h),p&&_._socket.writableNeedDrain)return new Promise(S=>this._socket.once("drain",S))},u,Promise.resolve(d).then(()=>u?.user),o);_.on("message",E),_.on("close",f),_.on("error",h=>{jt.info("WebSocket error",h)})}},Object.assign({subProtocol:"mqtt"},n))),(t||s)&&(c=e.socket(async _=>{let u;if(o.events.emit("connection",_),jt.debug(`Received ${_.getCertificate?"SSL":"TCP"} connection for MQTT from ${_.remoteAddress}`),l){if(_.authorized)try{let f=l.user;if(f!==null){(f===void 0||f==="Common Name"||f==="CN")&&(f=_.getPeerCertificate().subject.CN);try{u=await e.getUser(f,null,null),(0,Ja.get)(Xt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&HE.notify({username:u?.username,status:Xt.AUTH_AUDIT_STATUS.SUCCESS,type:Xt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:_.remoteAddress})}catch(h){throw(0,Ja.get)(Xt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&HE.error({username:f,status:Xt.AUTH_AUDIT_STATUS.FAILURE,type:Xt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:_.remoteAddress}),h}}else jt.debug("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",_.remoteAddress)}catch(f){o.events.emit("error",f,_),jt.error(f)}else if(l.required)return jt.info(`Unauthorized connection attempt, no authorized client certificate provided, error: ${_.authorizationError}`),_.end()}!u&&ux&&_.remoteAddress.includes("127.0.0.1")&&(u=await(0,cx.getSuperUser)(),jt.debug("Auto-authorizing local connection",u?.username));let{onMessage:d,onClose:E}=ax(_,f=>_.write(f),null,u,o);_.on("data",d),_.on("close",E),_.on("error",f=>{jt.info("Socket error",f)})},{port:t,securePort:s,mtls:l})),c}function ax(e,t,r,n,s){ox||(ox=!0,El(d=>{BE>0&&d.push({metric:"mqtt-connections",connections:BE,byThread:!0})}));let i;BE++;let o,c={protocolVersion:4},l=(0,xE.parser)({protocolVersion:5});function _(d){l.parse(d)}a(_,"onMessage");function u(){BE--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),Wr(!1,"connection","mqtt","disconnect"),jt.debug("MQTT connection was closed",e.remoteAddress))}return a(u,"onClose"),l.on("packet",async d=>{n?.then&&(n=await n),o?.then&&await o;let E=d.topic,f=E?.indexOf("/",1),h=f>0?E.slice(0,f):E;Sr(d.length,"bytes-received",h,S(d),"mqtt");try{switch(o?.receivedPacket?.(),d.cmd){case"connect":if(c.protocolVersion=d.protocolVersion,d.username)try{n=await it.getUser(d.username,d.password.toString(),r),(0,Ja.get)(Xt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&HE.notify({username:n?.username,status:Xt.AUTH_AUDIT_STATUS.SUCCESS,type:Xt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(M){return(0,Ja.get)(Xt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&HE.error({username:d.username,status:Xt.AUTH_AUDIT_STATUS.FAILURE,type:Xt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,M),Wr(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),Wr(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let M=e.deserialize||(e.deserialize=Oo(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?M(d.will.payload):void 0,delete d.will.payload}o=sx({user:n,...d}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(M){return jt.error(M),s.events.emit("auth-failed",d,e,M),Wr(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:M.code||5,returnCode:M.code||128})}s.events.emit("connected",o,e),Wr(!0,"connection","mqtt","connect"),p({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((M,Q,J,j)=>{try{let ae=M.indexOf("/",1),ce=ae>0?M.slice(0,ae):M;p({cmd:"publish",topic:M,payload:T(Q),messageId:J||Math.floor(Math.random()*1e8),qos:j.qos},ce)}catch(ae){jt.error(ae),o?.disconnect(),s.sessions.delete(o)}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let R=[];for(let M of d.subscriptions){let Q;try{Q=(await o.addSubscription(M,M.qos>=1)).qos||0}catch(J){s.events.emit("error",J,e,M,o),jt.error(J),Q=c.protocolVersion<5?128:J.statusCode===403?135:J.statusCode===404?143:128}R.push(Q)}await o.committed,p({cmd:"suback",granted:R,messageId:d.messageId});break;case"unsubscribe":{let M=[];for(let Q of d.unsubscriptions)M.push(o.removeSubscription(Q)?0:17);p({cmd:"unsuback",granted:M,messageId:d.messageId});break}case"pubrel":p({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let b=d.qos===2?"pubrec":"puback",C=e.deserialize||(e.deserialize=Oo(r?.headers.get?.("content-type"))),v=(d.payload?.length||0)>0?C(d.payload):void 0,q;try{q=await o.publish(d,v)}catch(M){s.events.emit("error",M,e,d,o),jt.warn(M),d.qos>0&&p({cmd:b,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&p({cmd:b,messageId:d.messageId,reasonCode:q===!1?144:0},d.topic);break;case"pubrec":p({cmd:"pubrel",messageId:d.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(d.messageId);break;case"pingreq":p({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),Wr(!0,"connection","mqtt","disconnect"),jt.debug("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(R){s.events.emit("error",R,e,d,o),jt.error(R),p({cmd:"disconnect"})}function p(R,b){let C=(0,xE.generate)(R,c);t(C),Sr(C.length,"bytes-sent",b,S(R),"mqtt")}a(p,"sendPacket");function S(R){return R.qos>0?R.cmd+",qos="+R.qos:R.cmd}a(S,"packetMethodName");function T(R){return To(R,r)}a(T,"serialize")}),l.on("error",d=>{jt.warn("MQTT parsing error, closing connection:",d.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:_,onClose:u}}var xE,cx,Ja,Xt,lA,lx,HE,jt,ux,ox,BE,_x=Re(()=>{xE=require("mqtt-packet");ix();cx=B(Vr());Ia();ws();ur();Ja=B(te()),Xt=B(U()),lA=B(Y()),lx=require("events"),HE=(0,lA.loggerWithTag)("auth-event"),jt=(0,lA.loggerWithTag)("mqtt"),ux=(0,Ja.get)(Xt.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(hse,"bypassAuth");a(mse,"start");BE=0;a(ax,"onSocket")});var Mf={};qe(Mf,{component_errors:()=>Xa,loadComponent:()=>GE,loadComponentDirectories:()=>gx,setErrorReporter:()=>gse});function gx(e,t){t&&(dA=t),e&&(fA=e);let r=[];if((0,Xe.existsSync)(_A)){let s=(0,Xe.readdirSync)(_A,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,tt.join)(_A,o);r.push(GE(c,dA,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(GE(n,dA,n,!1,null,process.env.DEV_MODE)),Promise.all(r).then(()=>{Tx=!0})}function gse(e){Lu=e}async function GE(e,t,r,n,s,i){let o=(0,Xe.realpathSync)(e);if(!fx.has(o)){fx.set(o,!0),s&&(fA=s);try{let c;n&&(Xa=new Map);let l=(0,tt.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,Xe.existsSync)(l)?c=n?(0,Sx.getConfigObj)():(0,Ex.parseDocument)((0,Xe.readFileSync)(l,"utf8"),{simpleKeys:!0}).toJSON():c=EA;let _=(0,tt.join)(e,"node_modules","harperdb");try{Do.isMainThread&&(n||(0,Xe.existsSync)(_)&&(0,Xe.realpathSync)(ec.PACKAGE_ROOT)!==(0,Xe.realpathSync)(_))&&((0,Xe.rmSync)(_,{recursive:!0,force:!0}),(0,Xe.existsSync)((0,tt.join)(e,"node_modules"))||(0,Xe.mkdirSync)((0,tt.join)(e,"node_modules")),(0,Xe.symlinkSync)(ec.PACKAGE_ROOT,_,"dir"))}catch(E){ja.default.error("Error symlinking harperdb module",E)}let u=[],d=n;for(let E in c){let f=c[E];if(Xa.set(n?E:(0,tt.basename)(e),!1),!f)continue;let h,p=f.package;try{if(p){let C=e,H;for(;!(0,Xe.existsSync)(H=(0,tt.join)(C,"node_modules",E));)if(C=(0,tt.dirname)(C),C.length<(0,px.getHdbBasePath)().length){H=null;break}if(H)h=await GE(H,t,r,!1),d=!0;else throw new Error(`Unable to find package ${E}:${p}`)}else h=Tse[E];if(!h)continue;u.push(h);let S=a(C=>(C.origin=r,ft(C)),"ensureTable"),T=f.network||(f.port||f.securePort)&&f,R=T?.securePort||T?.https&&T.port,b=!T?.https&&T?.port;if(Do.isMainThread&&(h=await h.startOnMainThread?.({server:it,ensureTable:S,port:b,securePort:R,resources:t,...f})||h,n&&T))for(let C of[b,R])try{if(+C&&!dx.includes(C)){let H=hA.get(ec.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);H&&ja.default.warn("Session affinity is not recommended and may cause memory leaks"),(H||!bE)&&(dx.push(C),IH(C,H))}}catch(H){console.error("Error listening on socket",C,H,E)}if(t.isWorker&&(h=await h.start?.({server:it,ensureTable:S,port:b,securePort:R,resources:t,...f})||h),fA.set(h,!0),(h.handleFile||h.handleDirectory)&&f.files){if(f.files.includes(".."))throw(0,mx.handleHDBError)("Can not reference parent directories");let C=(0,tt.join)(e,f.files).replace(/\\/g,"/"),H=C.indexOf("/*");if(H>-1&&f.files!==EA[E]?.files&&!(0,Xe.existsSync)(C.slice(0,H)))throw new Error(`The path '${C.slice(0,H)}' does not exist and cannot be used as the base of the resolved 'files' path value '${f.files}'`);let v=(0,tt.basename)(e),q=f.path||"/";q=q.startsWith("/")?q:q.startsWith("./")?"/"+v+q.slice(2):q==="."?"/"+v:"/"+v+"/"+q;let M,Q,J;if(f.root){let ae=f.root;ae.startsWith("/")&&(ae=ae.slice(1)),ae.endsWith("/")&&(ae=ae.slice(0,-1)),ae+="/",Q=(0,tt.join)(e,ae)}else(J=C.indexOf("/*"))>-1&&(Q=C.slice(0,J+1),M=(0,tt.relative)(e,Q));let j=!1;if(Do.isMainThread&&h.setupDirectory&&(j=await h.setupDirectory?.(q,Q,t)),t.isWorker&&h.handleDirectory&&(j=await h.handleDirectory?.(q,Q,t)),j)continue;for(let ae of await(0,hx.default)(C,{onlyFiles:!1,objectMode:!0})){let{path:ce,dirent:ge}=ae;d=!0;let Ge=(0,tt.relative)(e,ce).replace(/\\/g,"/");if(M)if(Ge.startsWith(M))Ge=Ge.slice(M.length+1);else throw new Error(`The root path '${f.root}' does not reference a valid part of the file path '${Ge}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Ne=q+(q.endsWith("/")?"":"/")+Ge;try{if(ge.isFile()){let ve=await Sse(ce);Do.isMainThread&&await h.setupFile?.(ve,Ne,ce,t),t.isWorker&&await h.handleFile?.(ve,Ne,ce,t)}else Do.isMainThread&&await h.setupDirectory?.(Ne,ce,t),t.isWorker&&await h.handleDirectory?.(Ne,ce,t)}catch(ve){ve.message=`Could not load ${ge.isFile()?"file":"directory"} '${ce}'${f.module?" using '"+f.module+"'":""} for application '${e}' due to: ${ve.message}`,Lu?.(ve),((0,Za.getWorkerIndex)()===0?console:ja.default).error(ve),t.set(f.path||"/",new Mu(ve)),Xa.set(n?E:(0,tt.basename)(e),ve.message)}}}}catch(S){S.message=`Could not load component '${E}' for application '${(0,tt.basename)(e)}' due to: ${S.message}`,Lu?.(S),((0,Za.getWorkerIndex)()===0?console:ja.default).error(S),t.set(f.path||"/",new Mu(S),null,!0),Xa.set(n?E:(0,tt.basename)(e),S.message)}}if(Do.isMainThread&&!Tx&&i&&(0,Za.watchDir)(e,async()=>gx()),c.extensionModule)return await S_((0,tt.join)(e,c.extensionModule));if(!d&&t.isWorker){let E=`${e} did not load any modules, resources, or files, is this a valid component?`;Lu?.(new Error(E)),((0,Za.getWorkerIndex)()===0?console:ja.default).error(E),Xa.set((0,tt.basename)(e),E)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,Lu?.(c),t.set("",new Mu(c))}}}var Xe,tt,Do,Ex,hA,ec,hx,Za,ja,mx,px,pse,Sx,Sse,_A,fA,Tx,dA,Xa,Tse,EA,dx,fx,Lu,Mu,Pf=Re(()=>{Xe=require("fs"),tt=require("path"),Do=require("worker_threads"),Ex=require("yaml"),hA=B(te()),ec=B(U());Cb();Pb();Ub();y0();hH();RH();hx=B(require("fast-glob")),Za=B(ot()),ja=B(Y());Wh();ur();mx=B(ne());In();Ae();wH();px=B(te()),pse=B(PH());bf();WR();_x();Sx=B(dr());yE();({readFile:Sse}=Xe.promises),_A=hA.get(ec.CONFIG_PARAMS.COMPONENTSROOT),fA=new Map,Xa=new Map;a(gx,"loadComponentDirectories");Tse={REST:jf,rest:jf,graphqlSchema:Kh,jsResource:zh,fastifyRoutes:MR,login:jh,static:PR,operationsApi:pse,customFunctions:{},http:{},clustering:CE,authentication:Xl,mqtt:uA},EA={rest:!0,graphqlSchema:{files:"*.graphql"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(EA,"static",{value:{files:"web/**"}});dx=[],fx=new Map;a(gse,"setErrorReporter");a(GE,"loadComponent");Mu=class extends $t{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 sA=g((upe,Ax)=>{var{isMainThread:Rx}=require("worker_threads"),{getTables:Rse}=(Ae(),ie(ke)),{loadComponentDirectories:Ase,loadComponent:Ose}=(Pf(),ie(Mf)),{resetResources:bse}=(Jl(),ie(PU)),yse=fg(),Nse=dr(),{dirname:Ise}=require("path"),{getConnection:wse}=Rt(),Cse=te(),Dse=U(),mA=new Map;async function Lse(e=!1){!Rx&&Cse.get(Dse.CONFIG_PARAMS.CLUSTERING_ENABLED)&&wse();try{Rx&&await yse()}catch(n){console.error(n)}let t=bse();Rse(),t.isWorker=e,await Ose(Ise(Nse.getConfigFilePath()),t,"hdb",!0,mA),await Ase(mA,t);let r=[];for(let[n]of mA)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(Lse,"loadRootComponents");Ax.exports.loadRootComponents=Lse});var ot=g((dpe,Li)=>{"use strict";var{Worker:Mse,MessageChannel:Pse,parentPort:Es,isMainThread:RA,threadId:Use,workerData:Ks}=require("worker_threads"),{PACKAGE_ROOT:vse}=U(),{join:Nx,isAbsolute:Bse,extname:Hse}=require("path"),{server:Ix}=(ur(),ie(Hi)),{watch:xse,readdir:Gse}=require("fs/promises"),{totalmem:Ox}=require("os"),Pu=U(),wx=te(),Ws=Y(),{randomBytes:Fse}=require("crypto"),{_assignPackageExport:qse}=require("../../index"),kse=U(),bx=1024*1024,Di=[],Sn=[],Vse=50,AA=1e4,$se="restart",Cx="request_thread_info",Dx="resource_report",Lx="thread_info",Mx="added-port",Yse="ack",pA;qse("threads",Sn);Li.exports={startWorker:SA,restartWorkers:bA,shutdownWorkers:Jse,workers:Di,setMonitorListener:sie,onMessageFromWorkers:jse,onMessageByType:Gx,broadcast:Zse,broadcastWithAcknowledgement:tie,setChildListenerByType:zse,getWorkerIndex:Px,getWorkerCount:Ux,getTicketKeys:Bx,setMainIsWorker:Wse,setTerminateTimeout:Kse,restartNumber:Ks?.restartNumber||1};Sn.onMessageByType=Gx;Sn.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Sn.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};var OA;function Kse(e){AA=e}a(Kse,"setTerminateTimeout");function Px(){return Ks?Ks.workerIndex:OA?0:void 0}a(Px,"getWorkerIndex");function Ux(){return Ks?Ks.workerCount:OA?1:void 0}a(Ux,"getWorkerCount");function Wse(e){OA=e}a(Wse,"setMainIsWorker");var vx=1,FE;function Bx(){return FE||(FE=RA?Fse(48):Ks.ticketKeys,FE)}a(Bx,"getTicketKeys");Object.defineProperty(Ix,"workerIndex",{get(){return Px()}});Object.defineProperty(Ix,"workerCount",{get(){return Ux()}});var Hx={[Cx](e,t){rie(t)},[Dx](e,t){nie(t,e)}};function SA(e,t={}){let r=process.constrainedMemory?.()||Ox();r=Math.min(r,Ox(),2e4*bx);let n=wx.get(Pu.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/bx/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Sn){let _=new Pse;_.existingPort=l,i.push(_),o.push(_.port2)}Hse(e)||(e+=".js");let c=new Mse(Bse(e)?e:Nx(vse,e),Object.assign({resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:vx=t.threadCount,name:t.name,restartNumber:Li.exports.restartNumber,ticketKeys:Bx()},transferList:o},t));for(let{port1:l,existingPort:_}of i)_.postMessage({type:Mx,port:l,threadId:c.threadId},[l]);return kE(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>SA(e,t),c.on("error",l=>{Ws.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{Di.splice(Di.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<Vse?(t.unexpectedRestarts=c.unexpectedRestarts+1,SA(e,t)):Ws.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{Hx[l.type]?.(l,c)}),Di.push(c),oie(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(SA,"startWorker");var Qse=[Pu.THREAD_TYPES.HTTP];async function bA(e=null,t=Math.max(vx>3,1),r=!0){if(RA){if(r){let{loadRootComponents:o}=sA();await o()}Li.exports.restartNumber++,t<1&&(t=t*Di.length);let n=[],s=[];for(let o of Di.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Ws.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Li.exports.restartNumber,type:Pu.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=Qse.indexOf(o.name)>-1,l=new Promise(_=>{let u=setTimeout(()=>o.terminate(),AA*2).unref();o.on("exit",()=>{clearTimeout(u),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),_()})});if(n.push(l),c&&r){let _=o.startCopy(),u=new Promise(d=>{let E=a(f=>{f.type===kse.ITC_EVENT_TYPES.CHILD_STARTED&&(Ws.trace("Worker has started",_.threadId),d(),s.splice(s.indexOf(u)),_.off("message",E))},"startListener");Ws.trace("Waiting for worker to start",_.threadId),_.on("message",E)});s.push(u),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}=Ql();r&&(e==="http"||!e)&&wx.get(Pu.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else Es.postMessage({type:$se,workerType:e})}a(bA,"restartWorkers");function zse(e,t){Hx[e]=t}a(zse,"setChildListenerByType");function Jse(e){return bA(e,1/0,!1)}a(Jse,"shutdownWorkers");var xx=[];function jse(e){xx.push(e)}a(jse,"onMessageFromWorkers");var TA=new Map;function Gx(e,t){let r=TA.get(e);r||TA.set(e,r=[]),r.push(t)}a(Gx,"onMessageByType");var Xse=10;async function Zse(e){let t=0;for(let r of Sn)try{r.postMessage(e),t++>Xse&&(t=0,await new Promise(setImmediate))}catch(n){Ws.error("Unable to send message to worker",n)}}a(Zse,"broadcast");var qE=new Map,eie=1;function tie(e){return new Promise(t=>{let r=0;for(let n of Sn)try{let s=eie++,i=a(()=>{qE.delete(s),--r===0&&t(),n!==Es&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,qE.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of qE)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Ws.error("Unable to send message to worker",s)}r===0&&t()})}a(tie,"broadcastWithAcknowledgement");function rie(e){e.postMessage({type:Lx,workers:Fx()})}a(rie,"sendThreadInfo");function Fx(){let e=Date.now();return Di.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(Fx,"getChildWorkerInfo");function nie(e,t){e.resources=t,e.resources.updated=Date.now()}a(nie,"recordResourceReport");var gA;function sie(e){gA=e}a(sie,"setMonitorListener");var iie=1e3,yx=!1;function oie(){yx||(yx=!0,setInterval(()=>{for(let e of Di){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}gA&&gA()},iie).unref())}a(oie,"startMonitoring");var aie=1e3;if(Es){kE(Es);for(let e=0,t=Ks.addPorts.length;e<t;e++){let r=Ks.addPorts[e];r.threadId=Ks.addThreadIds[e],kE(r)}setInterval(()=>{let e=process.memoryUsage();Es.postMessage({type:Dx,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},aie).unref(),pA=a(()=>new Promise((e,t)=>{Es.on("message",r),Es.postMessage({type:Cx});function r(n){n.type===Lx&&(Es.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else pA=Fx;Li.exports.getThreadInfo=pA;function kE(e,t){Sn.push(e),e.on("message",r=>{if(r.type===Mx)r.port.threadId=r.threadId,kE(r.port);else if(r.type===Yse){let n=qE.get(r.id);n&&n()}else{for(let s of xx)s(r,e);let n=TA.get(r.type);if(n)for(let s of n)try{s(r,e)}catch(i){Ws.error(i)}}}).on("close",()=>{Sn.splice(Sn.indexOf(e),1)}).on("exit",()=>{Sn.splice(Sn.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(kE,"addPort");if(RA){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await Gse(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(Nx(s,o.name));try{for await(let{filename:o}of xse(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await bA(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");Li.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else Es.on("message",async e=>{let{type:t}=e;t===Pu.ITC_EVENT_TYPES.SHUTDOWN&&(Li.exports.restartNumber=e.restartNumber,Es.unref(),setTimeout(()=>{Ws.warn("Thread did not voluntarily terminate",Use),process.exit(0)},AA).unref())})});var OC={};qe(OC,{AUDIT_STORE_OPTIONS:()=>mf,createAuditEntry:()=>O_,openAuditStore:()=>KE,readAuditEntry:()=>Bt,setAuditRetention:()=>lie,transactionKeyEncoder:()=>zx});function KE(e){let t=e.auditStore=e.openDB(Kx.AUDIT_STORE_NAME,mf);t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,{remove(){delete r[i]}}};let n=null;function s(i=VE){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let o=0,c;try{for(let{key:l,value:_}of t.getRange({start:0,snapshot:!1,end:Date.now()-yA})){if((_[0]&15)===wA){let u=Bt(_),d=u.tableId;r[d]?.(u.recordId)}if(c=t.remove(l),await new Promise(setImmediate),++o>=cie){i=10;break}}await c}finally{o===0&&(i=Math.min(i<<1,yA/10)),s(i)}},i).unref()}return a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,YE.getWorkerIndex)()===(0,YE.getWorkerCount)()-1&&s(VE),t}function lie(e,t=VE){yA=e,VE=t}function O_(e,t,r,n,s,i,o){let c=Jx[i];if(!c)throw new Error(`Invalid audit entry type ${i}`);let l=1;n&&(n>1?tc.setFloat64(0,n):Tn.set(fm),l=9),E(0),E(t),d(r),tc.setFloat64(l,e),l+=8,s?d(s):Tn[l++]=0,Tn[n?8:0]=c;let u=Tn.subarray(0,l);if(o)return Buffer.concat([u,o]);return u;function d(f){let h=l;l+=1,l=(0,rc.writeKey)(f,Tn,l);let p=l-h-1;p>127?p>16383?(DA.error("Key or username was too large for audit entry",f),l=h+1,Tn[h]=0):(Tn.copyWithin(h+2,h+1,l),tc.setUint16(h,p|32768),l++):Tn[h]=p}function E(f){f<128?Tn[l++]=f:f<16384?(tc.setUint16(l,f|32768),l+=2):f<1056964608?(tc.setUint32(l,f|3221225472),l+=4):(Tn[l]=255,tc.setUint32(l+1,f),l+=5)}}function Bt(e){try{let t=e.dataView||(e.dataView=new CA(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,l=t.position+=o,_=t.readFloat64();o=t.readInt();let u=t.position,d=t.position+=o;return{type:Jx[n&7],tableId:i,get recordId(){return Yx(e,c,l)},version:_,previousLocalTime:r,get user(){return d>u?Yx(e,u,d):void 0},getValue(E,f,h){if(n&NA||n&IA&&!f)return E.decoder.decode(e.subarray(t.position));if(n&IA&&h)return LA(E.getEntry(this.recordId),h,E)}}}catch(t){return DA.error("Reading audit entry error",t,e),{}}}function Yx(e,t,r){let n=e.subarray(t,r);return(0,rc.readKey)(n,0,r-t)}var rc,$E,Kx,Wx,YE,Qx,DA,Tn,tc,zx,mf,yA,cie,VE,NA,IA,qx,wA,kx,Vx,$x,Jx,CA,ti=Re(()=>{rc=require("ordered-binary"),$E=B(te()),Kx=B(dt()),Wx=B(U()),YE=B(ot()),Qx=B(z());Pc();DA=B(Y());WE();(0,$E.initSync)();Tn=Buffer.alloc(1024),tc=new DataView(Tn.buffer,Tn.byteOffset,1024),zx={writeKey(e,t,r){return e===Mc?(t.set(Mc,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,rc.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,rc.readKey)(e,t,r)}},mf={encoding:"binary",keyEncoder:zx},yA=(0,Qx.convertToMS)((0,$E.get)(Wx.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,cie=1e3,VE=1e4;a(KE,"openAuditStore");a(lie,"setAuditRetention");NA=16,IA=32,qx=1,wA=2,kx=3,Vx=4,$x=5,Jx={put:qx|NA,[qx]:"put",delete:wA,[wA]:"delete",message:kx|NA,[kx]:"message",invalidate:Vx,[Vx]:"invalidate",patch:$x|IA,[$x]:"patch"};a(O_,"createAuditEntry");a(Bt,"readAuditEntry");CA=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(Yx,"readKeySafely")});var MA={};qe(MA,{add:()=>QE,applyReverse:()=>jx,getRecordAtTime:()=>LA,rebuildUpdateBefore:()=>zE});function QE(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function zE(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,QE(r,n,s)}}else r||(r={}),r[n]=e[n];return r}function jx(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=uie[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=Xx}}function LA(e,t,r){let n=r.rootStore.auditStore,s=Object.assign({},e.value),i=e.localTime;for(;i>t;){let l=n.get(i),_=Bt(l);switch(_.type){case"put":s=_.getValue(r);break;case"patch":jx(s,_.getValue(r));break;case"delete":s=null}i=_.previousLocalTime}let o={},c=0;for(let l in s)s[l]===Xx&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),_=Bt(l),u;switch(_.type){case"put":u=_.getValue(r);break;case"patch":u=_.getValue(r);break}for(let d in u)o[d]&&(s[d]=u[d],o[d]=!1,c--);i=_.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var uie,Xx,WE=Re(()=>{ti();a(QE,"add");QE.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};uie={add:QE};a(zE,"rebuildUpdateBefore");a(jx,"applyReverse");Xx={};a(LA,"getRecordAtTime")});function Zr(e){return e[Nt]||(e[Nt]=Object.create(null))}function eh(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,l,_;if(o.resolve)_={get(){return o.resolve(this,this[ye])},set(u){return o.set(this,u)},configurable:!0};else{switch(o.type){case"String":l=a(function(u){if(!(typeof u=="string"||u==null&&o.nullable!==!1))throw new gn.ClientError(`${c} must be a string, attempt to assign ${u}`);Zr(this)[c]=u},"set");break;case"ID":l=a(function(u){if(!(typeof u=="string"||u?.length>0&&u.every?.(d=>typeof d=="string")||u==null&&o.nullable!==!1))throw new gn.ClientError(`${c} must be a string, attempt to assign ${u}`);Zr(this)[c]=u},"set");break;case"Float":case"Number":l=a(function(u){let d=u?.__op__?u.value:u;if(!(typeof d=="number"||u==null&&o.nullable!==!1))throw new gn.ClientError(`${c} must be a number, attempt to assign ${d}`);Zr(this)[c]=u},"set");break;case"Int":l=a(function(u){let d=u?.__op__?u.value:u;if(!(d>>0===d||u==null&&o.nullable!==!1))if(typeof d=="number"&&Math.abs((d>>0)-d)<=1)d=Math.round(d),u?.__op__?u.value=d:u=d;else throw new gn.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${u}`);Zr(this)[c]=u},"set");break;case"Long":l=a(function(u){let d=u?.__op__?u.value:u;if(!(Math.round(d)===u&&Math.abs(d)<=9007199254740992||u==null&&o.nullable!==!1))if(typeof d=="number"&&Math.abs(d)<=9007199254740992)d=Math.round(d),u?.__op__?u.value=d:u=d;else throw new gn.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${u}`);Zr(this)[c]=u},"set");break;case"BigInt":l=a(function(u){let d=u?.__op__?u.value:u;if(!(typeof d=="bigint"||u==null&&o.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=BigInt(d),u?.__op__?u.value=d:u=d;else throw new gn.ClientError(`${c} must be a number, attempt to assign ${u}`);Zr(this)[c]=u},"set");break;case"Boolean":l=a(function(u){if(!(typeof u=="boolean"||u==null&&o.nullable!==!1))throw new gn.ClientError(`${c} must be a boolean, attempt to assign ${u}`);Zr(this)[c]=u},"set");break;case"Date":l=a(function(u){if(!(u instanceof Date||u==null&&o.nullable!==!1))if(typeof u=="string"||typeof u=="number")u=new Date(u);else throw new gn.ClientError(`${c} must be a Date, attempt to assign ${u}`);Zr(this)[c]=u},"set");break;case"Bytes":l=a(function(u){if(!(u instanceof Uint8Array||u==null&&o.nullable!==!1))throw new gn.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${u}`);Zr(this)[c]=u},"set");break;case"Any":case void 0:l=a(function(u){Zr(this)[c]=u},"set");break;default:l=a(function(u){if(!(typeof u=="object"||u==null&&o.nullable!==!1))throw new gn.ClientError(`${c} must be an object, attempt to assign ${u}`);Zr(this)[c]=u},"set")}_={get(){let u=this[Nt];if(u&&c in u){let E=u[c];if(E?.__op__){let f=this[de]?.[c];return E.update(f)}return E}let d=this[de]?.[c];if(d&&typeof d=="object"){let E=eG(d,o);if(E)return u||(u=this[Nt]=Object.create(null)),u[c]=E}return d},set:l,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 l=this[Nt];return l?.[o]!==void 0?l[o]:this[de]?.[o]}),i("set",function(o,c){let l=n[o];if(l)return l.set.call(this,c);if(t.sealed)throw new gn.ClientError("Can not add a property to a sealed table schema");Zr(this)[o]=c}),i("deleteProperty",function(o){Zr(this)[o]=void 0}),i("toJSON",function(){let o=this[Nt],c;for(let _ in o){c||(c=Object.assign({},this[de]));let u=o[_];if(u?.__op__){let d=c[_];u=u.update(d)}c[_]=u}return Object.keys(this).length>0&&(c||(c=Object.assign({},this[de])),Object.assign(c,this)),c||this[de]}),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 eG(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?.[de])throw new Error("Can not track an already tracked object, check for circular references");this[de]=s}},eh(r,t)),new r(e)):new JE(e);case Array:let n=new XE(e.length);n[de]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=eG(o,t?.elements)),n[s]=o}return n;default:return e}}function dd(e){let t=e[Nt],r;for(let s in t){r||(r=Object.assign({},e[de]));let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=dd(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=Object.assign({},e[de])),Object.assign(r,e)),r||e[de]}function Mo(e,t=e[Nt]){let r;if(Zx.call(e,de)&&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=Mo(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[de]));let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=MA[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Mo(s);r[n]=s}return r?Object.freeze(r):Zx.call(e,de)?e[de]:e}function jE(e){let t=e[de];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[Lo]||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?.[de]===s){if(jE(i))return!0}else return!0}}else{let r=e[Nt];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[de]===i){if(jE(s))return!0}else return!0}else return!0}}return!1}var gn,Nt,JE,Zx,Lo,XE,ZE,fd=Re(()=>{In();gn=B(ne());WE();Nt=Symbol("own-data");a(Zr,"getChanges");a(eh,"assignTrackedAccessors");a(eG,"trackObject");JE=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[de])throw new Error("Can not track an already tracked object, check for circular references");this[de]=t}};eh(JE,{});a(dd,"collapseData");Zx=Object.prototype.hasOwnProperty;a(Mo,"deepFreeze");a(jE,"hasChanges");Lo=Symbol.for("has-array-changes"),XE=class extends Array{static{a(this,"TrackedArray")}[Lo];constructor(t){super(t)}splice(...t){return this[Lo]=!0,super.splice(...t)}push(...t){return this[Lo]=!0,super.push(...t)}pop(){return this[Lo]=!0,super.pop()}unshift(...t){return this[Lo]=!0,super.unshift(...t)}shift(){return this[Lo]=!0,super.shift()}};XE.prototype.constructor=Array;ZE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var Pp={};qe(Pp,{CONTEXT:()=>ye,ID_PROPERTY:()=>Me,IS_COLLECTION:()=>qn,RECORD_PROPERTY:()=>de,Resource:()=>$t,snake_case:()=>die,transformForSelect:()=>rh});function die(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function tG(e,t){if(Uu=!1,e==="")return null;if(e=e.slice(1),e.indexOf("/")===-1)return e===""?(Uu=!0,null):(e.startsWith("$")&&(e=parseInt(e,36)),t.coerceId(decodeURIComponent(e)));let r=e.split("/"),n=new UA;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Uu=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}function en(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,_,u;if(r?(o?(u=i,o=o[ye]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(u=s,c=u[this.primaryKey]??null,o=i[ye]||i):u=i:(u=s,c=u[Me]??u[this.primaryKey]??null),c==null&&(_=!0)):i?o=i[ye]||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(l=s,s[Symbol.iterator]){c=[],_=!0;for(let f of s){if(typeof f=="object"&&f)break;c.push(f)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,_=!1)))}else{if(typeof(c=s.url)=="string"){let f=c.indexOf("?");if(f>-1){let p=this.parseQuery(c.slice(f+1));l?l=Object.assign(p,l):l=p,c=c.slice(0,f)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),_=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(l?.ensureLoaded!=null||l?.async||_?(d=Object.assign({},t),l?.ensureLoaded!=null&&(d.ensureLoaded=l.ensureLoaded),l?.async&&(d.async=l.async),_&&(d.isCollection=!0)):d=t,o.transaction){let f=this.getResource(c,o,d);return f.then?f.then(E):E(f)}else return Je(o,()=>{let f=this.getResource(c,o,d);return f.then?f.then(E):E(f)},d);function E(f){if(o.authorize){o.authorize=!1;let h=t.type==="read"?f.allowRead(o.user,l,o):t.type==="update"?f.doesExist?.()===!1?f.allowCreate(o.user,u,o):f.allowUpdate(o.user,u,o):t.type==="create"?f.allowCreate(o.user,u,o):f.allowDelete(o.user,l,o);if(h?.then)return h.then(p=>{if(!p)throw new th(o.user);return typeof u?.then=="function"?u.then(S=>e(f,l,o,S)):e(f,l,o,u)});if(!h)throw new th(o.user)}return typeof u?.then=="function"?u.then(h=>e(f,l,o,h)):e(f,l,o,u)}a(E,"authorizeActionOnResource")}}function tn(e,t){let r=new sG.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 PA(e,t,r){let n=e[de];if(n){let s=e[Nt];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 rh(e,t){let r=t?.propertyResolvers,n=t[ye],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):PA(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let _=[],u=i(PA(l,r,n));for(let d of e)_.push(u(d));return _},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(E=>E&&typeof E=="object"?c(E):E);let _={},u=i(PA(l,r,n)),d;for(let E of e){let f=u(E);f===void 0&&o&&(f=null),f?.then?(d||(d=[]),d.push(f.then(h=>_[E.name||E]=h))):_[E.name||E]=f}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 l=s[c.name];if(!l){let u=r[c.name]?.definition?.tableClass;l=s[c.name]=rh(c.select||c,u)}let _=o(c.name);return l(_)}else return o(c);else return c}}a(i,"handleProperty")}var rG,nG,sG,ye,Me,qn,de,_ie,$t,th,Uu,UA,In=Re(()=>{rG=require("crypto");Nc();nG=require("../../index"),sG=B(ne());fd();ro();zf();ye=Symbol.for("context"),Me=Symbol.for("primary-key"),qn=Symbol("is-collection"),de=Symbol("stored-record"),_ie={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},$t=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[Me]=t;let n=r?.[ye];this[ye]=n!==void 0?n:r||null}static get=en(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let _=rh(l,t.constructor);return typeof c?.map=="function"?c.map(_):_(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=en(function(t,r,n,s){if(Array.isArray(s)&&t[qn]){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,_=l.getResource(c[l.primaryKey],n,{async:!0});_.then?i.push(_.then(u=>u.put(c,n))):i.push(_.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):tn(t,"put")},{hasContent:!0,type:"update"});static patch=en(function(t,r,n,s){return t.patch?t.patch(s,r):tn(t,"patch")},{hasContent:!0,type:"update"});static delete=en(function(t,r,n,s){return t.delete?t.delete(r):tn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,rG.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),n||(n={}),Je(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):tn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>s):s})}static invalidate=en(function(t,r,n,s){return t.invalidate?t.invalidate(r):tn(t,"delete")},{hasContent:!1,type:"update"});static post=en(function(t,r,n,s){return t[Me]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=en(function(t,r,n,s){return t.connect?t.connect(s,r):tn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=en(function(t,r,n,s){return t.subscribe?t.subscribe(r):tn(t,"subscribe")},{type:"read"});static publish=en(function(t,r,n,s){return t[Me]!=null&&t.update?.(),t.publish?t.publish(s,r):tn(t,"publish")},{hasContent:!0,type:"create"});static search=en(function(t,r,n,s){let i=t.search?t.search(r):tn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=rh(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=en(function(t,r,n,s){return t.search?t.search(s,r):tn(t,"search")},{hasContent:!0,type:"read"});static copy=en(function(t,r,n,s){return t.copy?t.copy(s,r):tn(t,"copy")},{type:"create"});static move=en(function(t,r,n,s){return t.move?t.move(s,r):tn(t,"move")},{type:"delete"});post(t){if(this[qn])return this.constructor.create(this[Me],t,this[ye]);tn(this,"post")}static isCollection(t){return t?.[qn]}static coerceId(t){return t}static parseQuery(t){return Qf(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&&_ie[o];if(c)r.headers.set("accept",c);else if(n)n.property=o;else return{query:{property:o},id:tG(t,this),isCollection:Uu}}let i=tG(t,this);return Uu?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[ye],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let _=l.asMap.get(t);if(s=_?.find(u=>u.constructor===c),s)return s;_||l.asMap.set(t,_=[]),_.push(s=new c(t,i))}else{if(s=l.find(_=>_[Me]===t&&_.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let _=new Map;for(let u of l){let d=u[Me],E=_.get(d);E?E.push(u):_.set(d,[u])}i.resourceCache.length=0,i.resourceCache.asMap=_}}}else s=new c(t,i);return o&&(s[qn]=!0),s}subscribe(t){return new Nn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Nn}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[ye]}};$t.prototype[ye]=null;(0,nG._assignPackageExport)("Resource",$t);a(die,"snake_case");th=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(tG,"pathToId");UA=class extends Array{static{a(this,"MulitPartId")}toString(){return this.join("/")}};a(en,"transactional");a(tn,"missingMethod");a(PA,"selectFromObject");a(rh,"transformForSelect")});function aG(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=oG,fie(e.primaryStore,e.auditStore)):(c=iG,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{cG(iG[i])})));let l=c[i]||(c[i]=[]);l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now());let _=l[o];_||(_=l[o]=new Map,_.envs=l,_.tableId=o,_.store=e.primaryStore),t=ya(t);let u=new BA(r);u.startTime=n;let d=_.get(t);return d?d.push(u):(_.set(t,d=[u]),d.tables=_,d.key=t),u.subscriptions=d,u}function cG(e){if(!e)return;let t=e.auditStore;try{t.resetReadTxn()}catch(n){throw n.message+=" in "+path,n}let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Bt(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l,_=ya(i.recordId),u=0;do{let d=o.get(_);if(d){for(let f of d)if(!(u>0&&!(f.includeDescendants&&!(f.onlyChildren&&u>1)))){if(f.startTime>=n){(0,vA.info)("omitting",c,f.startTime,n);continue}try{let h;f.supportsTransactions&&f.txnInProgress!==i.version&&(h=!0,f.txnInProgress||(r?r.push(f):r=[f]),f.txnInProgress=i.version),f.listener(c,i,n,h)}catch(h){console.error(h),(0,vA.info)(h)}}}if(_==null)break;let E=_.lastIndexOf?.("/",_.length-2);E>-1?_=_.slice(0,E):_=null,u++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function fie(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let l=oG[s];if(!l)return;let _=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now(),cG(l),r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")},"acquiredLock");r.attemptLock("thread-local-writes",_)&&_()})}}var vA,iG,oG,BA,lG=Re(()=>{vA=B(Y());Nc();Jl();ti();iG=Object.create(null),oG=Object.create(null);a(aG,"addSubscription");BA=class extends Nn{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(cG,"notifyFromTransactionData");a(fie,"listenToCommits")});var hR={};qe(hR,{coerceType:()=>nh,makeTable:()=>oh,setServerUtilities:()=>Aie,updateResource:()=>sh});function oh(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:_,dbisDB:u,sealed:d}=e,{expirationMS:E,evictionMS:f,audit:h,trackDeletes:p}=e,{attributes:S}=e;S||(S=[]);let T=mm(i,n,l),R=0,b,C,H={},v=Promise.resolve(),q,M,Q;for(let K of S)(K.assignCreatedTime||K.name==="__createdtime__")&&(q=K),(K.assignUpdatedTime||K.name==="__updatedtime__")&&(M=K),K.expiresAt&&(Q=K),K.isPrimaryKey&&(H=K);let J,j=[],ae=[],ce=1,ge=2,Ge={},Ne={},ve=864e5,Qu,zu,Qs,QA=!1,mh,ph,FG=i.getRange({start:!1,end:!1}).constructor,qG=10,kG=6;h&&jA();class Qe extends $t{static name=s;static primaryStore=i;static auditStore=l;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=q;static updatedTimeProperty=M;static propertyResolvers;static sources=[];static get expirationMS(){return E}static dbisDB=u;static schemaDefined=_;static sourcedFrom(m,A){A&&(this.sourceOptions=A,(A.expiration||A.eviction||A.scanInterval)&&this.setTTLExpiration(A)),A?.intermediateSource?(m.intermediateSource=!0,this.sources.unshift(m)):this.sources.push(m),C=m.get&&(!m.get.reliesOnPrototype||m.prototype.get);let w=a(L=>{let N=this.sources.slice(0,-1);if(N=N.filter(P=>P[L]&&(!P[L].reliesOnPrototype||P.prototype[L])),N.length>0)if(N.length===1){let P=N[0];return(k,D,x)=>{if(k?.source!==P)return P[L](D,x,k)}}else return(P,k,D)=>{let x=[];for(let G of N){if(P?.source===G)break;x.push(G[L](k,D,P))}return Promise.all(x)}},"getApplyToIntermediateSource"),y=this.sources[this.sources.length-1],O=a(L=>{if(y[L]&&(!y[L].reliesOnPrototype||y.prototype[L]))return(N,P,k)=>{if(!N?.source)return y[L](P,k,N)}},"getApplyToCanonicalSource");return Ge={put:O("put"),patch:O("patch"),delete:O("delete"),publish:O("publish")},Ne={put:w("put"),patch:w("patch"),delete:w("delete"),publish:w("publish"),invalidate:w("invalidate")},(async()=>{let L=!1,N=a(async(P,k)=>{let D=P.value,x=P.table?at[c][P.table]:Qe;if(c===Vn.SYSTEM_SCHEMA_NAME&&(P.table===Vn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||P.table===Vn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(L=!0),P.id===void 0&&(P.id=D[x.primaryKey],P.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(P));P.source=m;let G=await x.getResource(P.id,k,nc);switch(P.type){case"put":return G._writeUpdate(D,!0,nc);case"patch":return G._writeUpdate(D,!1,nc);case"delete":return G._writeDelete(nc);case"publish":return G._writePublish(D,nc);case"invalidate":return G.invalidate(nc);default:rt.error("Unknown operation",P.type,P.id)}},"writeUpdate");try{let P=m.subscribe;P&&p==null&&(p=!0);let k=m.subscribeOnThisThread?m.subscribeOnThisThread((0,Uo.getWorkerIndex)()):(0,Uo.getWorkerIndex)()===0,D=P&&k&&await m.subscribe?.({crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0});if(D){let x;for await(let G of D)try{if(!(G.type==="transaction"?G.writes[0]:G)){rt.error("Bad subscription event",G);continue}if(G.source=m,x)if(G.beginTxn)x.resolve();else{N(G,x);continue}if(G.type==="end_txn")continue;let me=Je(G,()=>{if(G.type==="transaction"){let ee=[];for(let Pe of G.writes)try{ee.push(N(Pe,G))}catch(le){throw le.message+=" writing "+JSON.stringify(Pe)+" of event "+JSON.stringify(G),le}return Promise.all(ee)}else if(G.type==="define_schema"){let ee=this.attributes.slice(0),Pe;for(let le of G.attributes)ee.find(Fe=>Fe.name===le.name)||(ee.push(le),Pe=!0);Pe&&(ft({table:s,database:c,attributes:ee,origin:"cluster"}),qu.signalSchemaChange(new ku.SchemaEventMsg(process.pid,Vn.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return G.beginTxn?(x=G,N(G,G),new Promise(ee=>{x.resolve=ee})):N(G,G)});L&&(await me,qu.signalUserChange(new ku.UserEventMsg(process.pid))),G.onCommit&&(me?.then?me.then(G.onCommit):G.onCommit())}catch(se){rt.error("error in subscription handler",se)}}}catch(P){rt.error(P)}})(),this}static getResource(m,A,w){let y=super.getResource(m,A,w);if(m!=null){ac(m);try{if(y.hasOwnProperty(de))return y;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let O=!w?.async||i.cache?.get(m),L=An(A),N=L.getReadTxn();if(N?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return Sh(m,A,{transaction:N},O,P=>{if(P?sh(y,P):y[de]=null,A.onlyIfCached&&A.noCacheStore){if(!y.doesExist())throw new rn.ServerError("Entry is not cached",504)}else if(w?.ensureLoaded){let k=Th(m,P,A,y);if(k)return L?.disregardReadTxn(),y[HA]=!0,GA(k,D=>(sh(y,D),y))}return y})}catch(O){throw O.message.includes("Unable to serialize object")&&(O.message+=": "+JSON.stringify(m)),O}}return y}ensureLoaded(){let m=Th(this[Me],this[Lr],this[ye]);if(m)return this[HA]=!0,GA(m,A=>{this[Lr]=A,this[de]=A.value,this[Gu]=A.version})}static setTTLExpiration(m){if(typeof m=="number")E=m*1e3,f||(f=0);else if(m&&typeof m=="object")E=m.expiration*1e3,f=(m.eviction||0)*1e3,ve=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(E<0)throw new Error("Expiration can not be negative");ve=ve||(E+f)/4,Rh()}static enableAuditing(m=!0){h=m,m&&jA(),Qe.audit=m}static coerceId(m){return m===""?null:nh(m,H)}static async dropTable(){if(delete at[c][s],c===o){for(let m of S)u.remove(Qe.tableName+"/"+m.name),r[m.name]?.drop();u.remove(Qe.tableName+"/"),i.drop(),await u.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));qu.signalSchemaChange(new ku.SchemaEventMsg(process.pid,Vn.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this[qn])return this.search(m);if(this[Me]===null){if(m?.conditions)return this.search(m);let A=Qe.getRecordCount();return{recordCount:A.recordCount,estimatedRecordRange:A.estimatedRange,records:"./",name:s,database:c,attributes:S}}if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this[ye]?.returnNonexistent)return this}allowRead(m,A){let w=ju(m);if(w?.read){if(w.isSuperUser)return!0;let y=w.attribute_permissions,O=A?.select;if(y?.length>0||QA&&O){if(A||(A={}),O){let L=y?.length>0&&xA(y,"read");A.select=O.map(N=>{let P=N.name||N;if(!L||L[P]){let k=Qs[P]?.definition?.tableClass;if(k){if(N.name||(N={name:N}),!k.prototype.allowRead.call(null,m,N))return!1;if(!N.select)return N.name}return N}}).filter(Boolean)}else A.select=y.filter(L=>L.read&&!Qs[L.attribute_name]).map(L=>L.attribute_name);return A}else return!0}}allowUpdate(m,A){let w=ju(m);if(w?.update){let y=w.attribute_permissions;if(y?.length>0){let O=xA(y,"update");for(let L in A)if(!O[L])return!1;for(let L of y){let N=L.attribute_name;!L.update&&!(N in A)&&(A[N]=this.getProperty(N))}}return!0}}allowCreate(m,A){if(this[qn]){let w=ju(m);if(w?.insert){let y=w.attribute_permissions;if(y?.length>0){let O=xA(y,"insert");for(let L in A)if(!O[L])return!1}else return!0}}else return this.allowUpdate(m,{})}allowDelete(m){return ju(m)?.delete}update(m,A){if(!An(this[ye]))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let y;return typeof m=="object"&&m&&(A?(Object.isFrozen(m)&&(m=Object.assign({},m)),this[de]={},this[Nt]=m):(y=this[Nt],y&&(m=Object.assign(y,m)),this[Nt]=y=m)),this._writeUpdate(this[Nt],A),this}addTo(m,A){if(typeof A=="number"||typeof A=="bigint")this[vu]===_G?this.set(m,(+this.getProperty(m)||0)+A):(this[vu]||this.update(),this.set(m,new ZE(A)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,A){if(typeof A=="number")return this.addTo(m,-A);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this[Lr]}invalidate(m){let A=this[ye],w=this[Me];ac(w),An(this[ye]).addWrite({key:w,store:i,invalidated:!0,entry:this[Lr],nodeName:this[ye]?.nodeName,before:Ge.invalidate?.bind(this,A,w),beforeIntermediate:Ne.invalidate?.bind(this,A,w),commit:(O,L)=>{if(L?.version>O)return;let N=null;for(let P in r)N||(N={}),N[P]=this.getProperty(P);T(w,N,this[Lr],O,Bu,h,this[ye],0,"invalidate")}})}static evict(m,A,w){let y=this.Source,O;if(!((C||h)&&(!A||(O=i.getEntry(m),!O||!A)||O.version!==w))){if(C){if(i.hasLock(m,O.version))return;let L;for(let N in r)L||(L={}),L[N]=A[N];if(L)return T(m,L,O,w,Hu,null,null,0,null,!0)}return i.ifVersion(m,w,()=>{Ju(m,A,null)}),h?T(m,null,O,w,Hu,null,null,0,null,!0):i.remove(m,w)}}lock(){throw new Error("Not yet implemented")}static operation(m,A){return m.table||=s,m.schema||=c,pG.operation(m,A)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,A,w){let y=this[ye],O=An(y),L=this[Me];ac(L);let N=this[Lr];this[vu]=A?_G:Tie;let P={key:L,store:i,entry:N,nodeName:y?.nodeName,validate:k=>{m||(m=this[Nt]),A||m&&jE(this[Nt]===m?this:m)?y?.source||(O.checkOverloaded(),this.validate(m,!A),M&&(m[M.name]=M.type==="Date"?new Date(k):M.type==="String"?new Date(k).toISOString():k),A&&(t&&m[t]!==L&&(m[t]=L),q&&(N?.value?m[q.name]=N?.value[q.name]:m[q.name]=q.type==="Date"?new Date(k):q.type==="String"?new Date(k).toISOString():k),m=Mo(m))):O.removeWrite(P)},before:A?Ge.put?()=>Ge.put(y,L,m):null:Ge.patch?()=>Ge.patch(y,L,m):Ge.put?()=>Ge.put(y,L,Mo(this)):null,beforeIntermediate:A?Ne.put?()=>Ne.put(y,L,m):null:Ne.patch?()=>Ne.patch(y,L,m):Ne.put?()=>Ne.put(y,L,Mo(this)):null,commit:(k,D,x)=>{if(x){if(y&&D?.version>(y.lastModified||0)&&(y.lastModified=D.version),this[Lr]=D,D?.value?.[de])throw new Error("Can not assign a record to a record, check for circular references");A||(this[de]=D?.value??null)}this[Nt]=void 0,this[Gu]=k;let G=D?.value,se=m;if(this[vu]=0,D?.version>=k)if(h){let le=D.localTime,Fe=D.version;for(;se&&(le>k||Fe>=k&&le>0);){let re=l.get(le);if(!re)break;let X=Bt(re);if(Fe=X.version,Fe>k){if(X.type==="patch"){let pe=X.getValue(i);se=zE(se,pe)}else if(X.type==="put"||X.type==="delete")return}else if(Fe===k)return;le=X.previousLocalTime}}else{if(A)return;se=zE(se,G)}let me;if(A?me=se:(this[de]=G,me=A?se:Mo(this,se)),this[de]=me,me?.[de])throw new Error("Can not assign a record to a record, check for circular references");let ee;A||(ee=m),Ju(L,G,me);let Pe=A?"put":"patch";T(L,me,D,k,0,h,y,y.expiresAt||(E?E+Date.now():0),Pe,!1,ee)}};O.addWrite(P)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this[qn]){for await(let A of this.search(m))(await Qe.getResource(A[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this[de]?this._writeDelete(m):!1}_writeDelete(m){let A=An(this[ye]),w=this[Me];ac(w);let y=this[ye];return A.addWrite({key:w,store:i,resource:this,nodeName:y?.nodeName,before:Ge.delete?.bind(this,y,w),beforeIntermediate:Ne.delete?.bind(this,y,w),commit:(O,L,N)=>{let P=L?.value;N&&(y&&L?.version>(y.lastModified||0)&&(y.lastModified=L.version),sh(this,L)),!(L?.version>O)&&(Ju(this[Me],P),rt.trace("Write delete entry",w,O),h||p?(T(w,null,this[Lr],O,0,h,this[ye],0,"delete"),h||Rh()):i.remove(this[Me]))}}),!0}search(m){let A=this[ye],w=An(A);if(!m)throw new Error("No query provided");let y=m.conditions;y?y.length===void 0&&(y=y[Symbol.iterator]?Array.from(y):[y]):y=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this[Me]&&(y=[{attribute:null,comparator:"prefix",value:this[Me]}].concat(y));let O,L={};function N(X,pe){let Be;switch(pe){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 "+pe)}let $n=Be&&{},zs;for(let Ye of X){if(Ye.conditions){Ye.conditions=N(Ye.conditions,Ye.operator);continue}let kt=Ye[0]??Ye.attribute,on=kt==null?H:Fs(S,kt);if(on){if(Be){let Yn=Hn(kt),Vt=$n[Yn];Vt?(Vt.push(Ye),zs=!0):$n[Yn]=[Ye]}(on.type||qg[Ye.comparator])&&(Ye[1]===void 0?Ye.value=k(Ye.value,on):Ye[1]=k(Ye[1],on))}else if(kt!=null)throw(0,rn.handleHDBError)(new Error,`${kt} is not a defined attribute`,404)}if(m.enforceExecutionOrder)return X;if(zs)for(let Ye in $n){let kt=$n[Ye],on=kt.length;if(on>1)for(let Yn=0;Yn<on;Yn++){let Vt=kt[Yn];if(Vt.comparator==="ge"||Vt.comparator==="greater_than_equal")for(let Js=0;Js<on;Js++){let xo=kt[Js];(xo.comparator==="le"||xo.comparator==="less_than_equal")&&(Vt.comparator="between",Vt.value=[Vt.value,xo.value],X.splice(X.indexOf(xo),1))}if(Vt.comparator==="equals"||!Vt.comparator){for(let Js=0;Js<on;Js++)if(Js!==Yn){let xo=kt[Js];X.splice(X.indexOf(xo),1)}break}}}return X}a(N,"prepareConditions");function P(X,pe){if(m.enforceExecutionOrder)return X;for(let Be of X)Be.conditions&&(Be.conditions=P(Be.conditions,Be.operator));return X.length>1&&pe!=="or"?(0,mG.sortBy)(X,Wf(Qe)):X}a(P,"orderConditions");function k(X,pe){return Array.isArray(X)?X.map(Be=>nh(Be,pe)):nh(X,pe)}a(k,"coerceTypedValues");let D=m.operator;(y.length>0||D)&&(y=N(y,D));let x=typeof m.sort=="object"&&m.sort,G;if(x&&D!=="or"){let X=x.attribute;if(O=y.find(pe=>Hn(pe.attribute)===Hn(X)),!O){let pe=Fs(S,X);if(!pe)throw(0,rn.handleHDBError)(new Error,`${Array.isArray(X)?X.join("."):X} is not a defined attribute`,404);if(pe.indexed)O={attribute:X,comparator:"sort"},y.push(O);else if(y.length===0&&!m.allowFullScan)throw(0,rn.handleHDBError)(new Error,`${Array.isArray(X)?X.join("."):X} is not indexed and not combined with any other conditions`,404)}O&&(O.descending=!!x.descending)}y=P(y,D),x&&(O&&y[0]===O?x.next&&(G={dbOrderedAttribute:x.attribute,attribute:x.next.attribute,descending:x.next.descending,next:x.next.next}):(O&&y.splice(y.indexOf(O),1),G=x));let se=m.select;if(y.length===0&&(y=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:y,operator:D,postOrdering:G,selectApplied:!!se};let me=w.useReadTxn(),ee=kg(y,D,Qe,me,m,A,(X,pe)=>zA(X,se,A,me,pe),L),Pe=m.ensureLoaded!==!1;G||(ee=re(ee));let le=Qe.transformEntryForSelect(se,A,me,L,Pe,!0),Fe=Qe.transformToOrderedSelect(ee,se,G,me,A,le);function re(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(re,"applyOffset"),G&&(Fe=re(Fe)),Fe.onDone=()=>{Fe.onDone=null,w.doneReadTxn()},Fe.selectApplied=!0,Fe.getColumns=()=>{if(se){let X=[];for(let pe of se)pe==="*"?X.push(...S.map(Be=>Be.name)):X.push(pe.name||pe);return X}return S.map(X=>X.name)},Fe}static transformToOrderedSelect(m,A,w,y,O,L){let N=new FG;if(w){m=zA(m,A,y,O,null);let P;N.iterate=function(){let D,x=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),G,se=w.dbOrderedAttribute,me,ee,Pe=!0;function le(re){let X=re.next&&le(re.next),pe=re.descending;return(Be,$n)=>{let zs=gh(Be,re.attribute,y),Ye=gh($n,re.attribute,y),kt=pe?(0,vo.compareKeys)(Ye,zs):(0,vo.compareKeys)(zs,Ye);return kt===0?X?.(Be,$n)||0:kt}}a(le,"createComparator");let Fe=le(w);return{async next(){let re;if(D)if(re=D.next(),re.done){if(G)return N.onDone&&N.onDone(),re}else return{value:await L.call(this,re.value)};P=[],me&&P.push(me);do if(re=await x.next(),re.done){if(G=!0,P.length)break;return N.onDone&&N.onDone(),re}else{let X=re.value;if(X?.then&&(X=await X),se){let pe=gh(X,se,y);if(Pe)Pe=!1,ee=pe;else if(pe!==ee){ee=pe,me=X;break}}P.push(X)}while(!0);return w.isGrouped,P.sort(Fe),D=P[Symbol.iterator](),re=D.next(),re.done?(N.onDone&&N.onDone(),re):{value:await L.call(this,re.value)}},return(){N.onDone&&N.onDone(),x.return()},throw(){N.onDone&&N.onDone(),x.throw()}}};let k=a(D=>{if(typeof A=="object"&&Array.isArray(D.attribute))for(let x=0;x<A.length;x++){let G=A[x],se;if(G.name===D.attribute[0]){for(se=G.sort||(G.sort={});se.next;)se=se.next;se.attribute=D.attribute.slice(1),se.descending=D.descending}else G===D.attribute[0]&&(A[x]=se={name:G,sort:{attribute:D.attribute.slice(1),descending:D.descending}})}D.next&&k(D.next)},"applySortingOnSelect");k(w)}else N.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),N=N.map(L);return N}static transformEntryForSelect(m,A,w,y,O,L){if(m&&(m===t||m?.length===1&&m[0]===t)){let D=a(x=>(A?.transaction?.stale&&(A.transaction.stale=!1),x?.key??x),"transform");return m===t?D:m.asArray?x=>[D(x)]:x=>({[t]:D(x)})}let N;O&&C&&!m?.every(D=>{let x;return typeof D=="object"?x=D.name:x=D,r[x]||x===t})&&(N=!0);let P,k=a(function(D){let x;if(A?.transaction?.stale&&(A.transaction.stale=!1),D!=null){if(mh=D,x=D.value||D.deref?.(),!x&&(D.key===void 0||D.deref)){if(D=Sh(D.key??D,A,{transaction:w,lazy:m?.length<4},this.isSync,G=>G),D?.then)return D.then(k.bind(this));x=D?.value}if(N&&(D.metadataFlags&(Bu|Hu)||D.expiresAt&&D.expiresAt<Date.now())){let G=Th(D.key??D,D,A);if(G?.then)return G.then(k)}}if(x==null)return L?Po.SKIP:x;if(m&&!(m[0]==="*"&&m.length===1)){let G,se=a((ee,Pe)=>{let le;typeof ee=="object"?le=ee.name:le=ee;let Fe=Qs?.[le],re;if(Fe){let X=y?.[le];if(X)if(X.hasMappings){let Be=Fe.from?x[Fe.from]:Hn(D.key);re=X.get(Be),re||(re=[])}else re=X.fromRecord?.(x);else re=Fe(x,A,D);let pe=a(Be=>{if(Be&&typeof Be=="object"){let $n=Fe.definition?.tableClass||Qe;P||(P={});let zs=P[le]||(P[le]=$n.transformEntryForSelect(le===ee?null:ee.select||(Array.isArray(ee)?ee:null),A,w,X,O));if(Array.isArray(Be)){let Ye=[],kt=$n.transformToOrderedSelect(Be,ee.select,typeof ee.sort=="object"&&ee.sort,A,w,zs)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),on=a(Vt=>{for(;!Vt.done;){if(Vt?.then)return Vt.then(on);Ye.push(Vt.value),Vt=kt.next()}Pe(Ye,le)},"nextValue"),Yn=on(kt.next());Yn&&(G||(G=[]),G.push(Yn));return}else if(Be=zs.call(this,Be),Be?.then){G||(G=[]),G.push(Be.then(Ye=>Pe(Ye,le)));return}}Pe(Be,le)},"handleResolvedValue");re?.then?(G||(G=[]),G.push(re.then(pe))):pe(re);return}else re=x[le],re&&typeof re=="object"&&le!==ee&&(re=Qe.transformEntryForSelect(ee.select||ee,A,w,null)({value:re}));Pe(re,le)},"selectAttribute"),me;if(typeof m=="string")se(m,ee=>{me=ee});else if(Array.isArray(m))if(m.asArray)me=[],m.forEach((ee,Pe)=>{ee==="*"?m[Pe]=x:se(ee,le=>me[Pe]=le)});else{me={};let ee=m.forceNulls;for(let Pe of m)if(Pe==="*")for(let le in x)me[le]=x[le];else se(Pe,(le,Fe)=>{le===void 0&&ee&&(le=null),me[Fe]=le})}else throw new rn.ClientError("Invalid select"+m);return G?Promise.all(G).then(()=>me):me}return x},"transform");return k}async subscribe(m){if(!l)throw new Error("Can not subscribe to a table without an audit log");h||ft({table:s,database:c,schemaDefined:_,attributes:S,audit:!0}),m||(m={});let A=!m.rawEvents,w=aG(Qe,this[Me]??null,function(N,P,k,D){try{let x=P.getValue?.(i,A);if(!x&&P.type==="patch"&&A){let G=i.getEntry(N);G?.version===P.version?x=G.value:x=P.getValue?.(i,!0,k),P.type="put"}this.send({id:N,timestamp:k,value:x,version:P.version,type:P.type,beginTxn:D})}catch(x){rt.error(x)}},m.startTime||0,m);this[qn]&&(w.includeDescendants=!0,m.onlyChildren&&(w.onlyChildren=!0)),m.supportsTransactions&&(w.supportsTransactions=!0);let y=this[Me],O=m.previousCount;O>1e3&&(O=1e3);let L=m.startTime;if(this[qn]){if(L){if(O)throw new rn.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:N,value:P}of l.getRange({start:L,exclusiveStart:!0})){let k=Bt(P);if(k.tableId!==n)continue;let D=k.recordId;if(y==null||EG(y,D)){let x=k.getValue(i,A,N);w.send({id:D,timestamp:N,value:x,version:k.version,type:k.type})}w.startTime=N}}else if(O){let N=[];for(let{key:P,value:k}of l.getRange({start:"z",end:!1,reverse:!0}))try{let D=Bt(k);if(D.tableId!==n)continue;let x=D.recordId;if(y==null||EG(y,x)){let G=D.getValue(i,A,P);if(N.push({id:x,timestamp:P,value:G,version:D.version,type:D.type}),--O<=0)break}}catch(D){rt.error("Error getting history entry",P,D)}for(let P=N.length;P>0;)w.send(N[--P]);N[0]&&(w.startTime=N[0].timestamp)}else if(!m.omitCurrent)for(let{key:N,value:P,version:k,localTime:D}of i.getRange({start:y??!1,end:y==null?void 0:[y,vo.MAXIMUM_KEY],versions:!0}))P&&w.send({id:N,timestamp:D,value:P,version:k,type:"put"})}else{O&&!L&&(L=0);let N=this[Lr]?.localTime;if(N===hm&&(i.cache?.delete(y),this[Lr]=i.getEntry(y),rt.trace("re-retrieved record",N,this[Lr]?.localTime),N=this[Lr]?.localTime),rt.trace("Subscription from",L,"from",y,N),L<N){let P=[],k=N;do{let D=l.get(k);if(D){m.omitCurrent=!0;let x=Bt(D),G=x.getValue(i,A,k);A&&(x.type="put"),P.push({id:y,value:G,timestamp:k,...x}),k=x.previousLocalTime}else break;O&&O--}while(k>L&&O!==0);for(let D=P.length;D>0;)w.send(P[--D]);w.startTime=N}!m.omitCurrent&&this.doesExist()&&w.send({id:y,timestamp:N,value:this[de],version:this[Gu],type:"put"})}return m.listener&&w.on("data",m.listener),w}doesExist(){return!!(this[de]||this[vu])}publish(m,A){this._writePublish(m,A)}_writePublish(m,A){let w=An(this[ye]),y=this[Me]||null;ac(y);let O=this[ye];w.addWrite({key:y,store:i,entry:this[Lr],nodeName:O?.nodeName,validate:()=>{O?.source||(w.checkOverloaded(),this.validate(m))},before:Ge.publish?.bind(this,O,y,m),beforeIntermediate:Ne.publish?.bind(this,O,y,m),commit:(L,N,P)=>{N===void 0&&p&&!h&&Rh(),T(y,N?.value??null,N,N?.version||L,0,!0,O,N?.expiresAt,"message",!1,m)}})}validate(m,A){let w,y=a((O,L,N)=>{if(L.type&&O!=null)if(A&&O.__op__&&(O=O.value),L.properties){typeof O!="object"&&(w||(w=[])).push(`Value ${kn(O)} in property ${N} must be an object${L.type?" ("+L.type+")":""}`);let P=L.properties;for(let k=0,D=P.length;k<D;k++){let x=P[k],G=y(O[x.name],x,N+"."+x.name);G&&(O[x.name]=G)}if(L.sealed&&O!=null&&typeof O=="object")for(let k in O)P.find(D=>D.name===k)||(w||(w=[])).push(`Property ${k} is not allowed within object in property ${N}`)}else switch(L.type){case"Int":(typeof O!="number"||O>>0!==O)&&(w||(w=[])).push(`Value ${kn(O)} in property ${N} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof O!="number"||!(Math.floor(O)===O&&Math.abs(O)<=9007199254740992))&&(w||(w=[])).push(`Value ${kn(O)} in property ${N} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof O!="number"&&(w||(w=[])).push(`Value ${kn(O)} in property ${N} must be a number`);break;case"ID":typeof O=="string"||O?.length>0&&O.every?.(P=>typeof P=="string")||(w||(w=[])).push(`Value ${kn(O)} in property ${N} must be a string, or an array of strings`);break;case"String":typeof O!="string"&&(w||(w=[])).push(`Value ${kn(O)} in property ${N} must be a string`);break;case"Boolean":typeof O!="boolean"&&(w||(w=[])).push(`Value ${kn(O)} in property ${N} must be a boolean`);break;case"Date":if(!(O instanceof Date)){if(typeof O=="string"||typeof O=="number")return new Date(O);(w||(w=[])).push(`Value ${kn(O)} in property ${N} must be a Date`)}break;case"BigInt":if(typeof O!="bigint"){if(typeof O=="string"||typeof O=="number")return BigInt(O);(w||(w=[])).push(`Value ${kn(O)} in property ${N} must be a bigint`)}break;case"Bytes":O instanceof Uint8Array||(w||(w=[])).push(`Value ${kn(O)} in property ${N} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(O)){if(L.elements)for(let P=0,k=O.length;P<k;P++){let D=O[P],x=y(D,L.elements,N+"[*]");x&&(O[P]=x)}}else(w||(w=[])).push(`Value ${kn(O)} in property ${N} must be a Buffer or Uint8Array`);break}L.nullable===!1&&O==null&&(w||(w=[])).push(`Property ${N} is required (and not does not allow null values)`)},"validateValue");for(let O=0,L=S.length;O<L;O++){let N=S[O];if(!N.relationship&&(!A||N.name in m)){let P=y(m[N.name],N,N.name);P&&(m[N.name]=P)}}if(d)for(let O in m)S.find(L=>L.name===O)||(w||(w=[])).push(`Property ${O} is not allowed`);if(w)throw new rn.ClientError(w.join(". "))}getUpdatedTime(){return this[Gu]}wasLoadedFromSource(){return C?!!this[HA]:void 0}static async addAttributes(m){let A=S.slice(0);for(let w of m){if(!w.name)throw new rn.ClientError("Attribute name is required");if(w.name.match(/[`/]/))throw new rn.ClientError("Attribute names cannot include backticks or forward slashes");A.push(w)}return ft({table:s,database:c,schemaDefined:_,attributes:A}),Qe.indexingOperation}static async removeAttributes(m){let A=S.filter(w=>!m.includes(w.name));return ft({table:s,database:c,schemaDefined:_,attributes:A}),Qe.indexingOperation}static getRecordCount(m){let A=i.getStats().entryCount,w=5e3,y=1e3,O;A>w&&!m?.exactCount&&(O=y);let L=0;for(let{value:N}of i.getRange({start:!0,lazy:!0,limit:O}))N!=null&&L++;if(O){let N=L;L=0;for(let{value:Pe}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:O}))Pe!=null&&L++;let P=O*2,k=(L+N)/P,D=Math.pow((L-N+1)/O/2,2)+k*(1-k)/P,x=Math.max(Math.sqrt(D)*A,1),G=Math.round(k*A),se=Math.max(G-1.96*x,0),me=Math.min(G+1.96*x,A),ee=Math.pow(10,Math.round(Math.log10(x)));return ee>G&&(ee=ee/10),L=Math.round(G/ee)*ee,{recordCount:L,estimatedRange:[Math.round(se),Math.round(me)]}}return{recordCount:L}}static updatedAttributes(){Qs=this.propertyResolvers={$id:(m,A,w)=>({value:w.key}),$updatedtime:(m,A,w)=>w.version,$record:(m,A,w)=>w?{value:m}:m};for(let m of this.attributes){m.resolve=null;let A=m.relationship;if(A)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),QA=!0,A.to)m.elements?.definition?(Qs[m.name]=m.resolve=(w,y,O)=>{let L=w[A.from?A.from:t],N=m.elements.definition.tableClass;return O?Ba({attribute:A.to,value:L},An(y).getReadTxn(),!1,N,!1).asArray:N.search([{attribute:A.to,value:L}],y).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,A.from&&(m.resolve.from=A.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(A.from){let w=m.definition||m.elements?.definition;w?(Qs[m.name]=m.resolve=(y,O,L)=>{let N=y[A.from];if(N!==void 0){if(m.elements){let P,k=N.map(D=>{let x=L?w.tableClass.primaryStore.getEntry(D,{transaction:An(O).getReadTxn()}):w.tableClass.get(D,O);return x?.then&&(P=!0),x});return A.filterMissing?P?Promise.all(k).then(D=>D.filter(hG)):k.filter(hG):P?Promise.all(k):k}return L?w.tableClass.primaryStore.getEntry(N,{transaction:An(O).getReadTxn()}):w.tableClass.get(N,O)}},m.set=(y,O)=>{if(Array.isArray(O)){let L=O.map(N=>N[Me]||N[w.tableClass.primaryKey]);y[A.from]=L}else{let L=O[Me]||O[w.tableClass.primaryKey];y[A.from]=L}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=A.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`)}eh(this,this)}static async deleteHistory(m=0){let A;for(let{key:w,value:y}of l.getRange({start:0,end:m}))await xu(),Bt(y).tableId===n&&(A=l.remove(w));await A}static async*getHistory(m=0,A=1/0){for(let{key:w,value:y}of l.getRange({start:m,end:A})){await xu();let O=Bt(y);O.tableId===n&&(yield{id:O.recordId,localTime:w,version:O.version,type:O.type,value:O.getValue(i,!0,w),user:O.user})}}static async getHistoryOfRecord(m){let A=[];if(m==null)throw new Error("An id is required");let w=i.getEntry(m);if(!w)return A;let y=w.localTime;if(!y)throw new Error("The entry does not have a local audit time");let O=0;do{await xu();let L=l.get(y);if(L){let N=Bt(L);A.push({id:N.recordId,localTime:y,version:N.version,type:N.type,value:N.getValue(i,!0,y),user:N.user}),y=N.previousLocalTime}else break}while(O<1e3&&y);return A.reverse()}static cleanup(){J?.remove()}}Qe.updatedAttributes();let VG=Qe.prototype;return VG[Sie]=!0,E&&Qe.setTTLExpiration(E/1e3),Q&&$G(),Qe;function Ju(K,m,A){let w;for(let y in r){let O=r[y],L=O.isIndexing,N=A?.[y],P=m?.[y];if(N===P&&!L)continue;w=!0;let k=O.indexNulls,D=(0,Fu.getIndexedValues)(N,k),x=(0,Fu.getIndexedValues)(P,k);if(x?.length>0){let G=new Set(x);if(D=D?D.filter(se=>{if(G.has(se))G.delete(se);else return!0}):[],x=Array.from(G),(x.length>0||D.length>0)&&uG){let se=x.concat(D).map(me=>({key:me,value:K}));O.prefetch(se,fG)}for(let se=0,me=x.length;se<me;se++)O.remove(x[se],K)}else D?.length>0&&uG&&O.prefetch(D.map(G=>({key:G,value:K})),fG);if(D)for(let G=0,se=D.length;G<se;G++)O.put(D[G],K)}return w}a(Ju,"updateIndices");function ac(K){switch(typeof K){case"number":return!0;case"string":if(K.length<659)return!0;if(K.length>dG)throw new Error("Primary key size is too large: "+K.length);break;case"object":if(K===null)return!0;break;case"bigint":if(K<2n**64n&&K>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof K)}if((0,vo.writeKey)(K,gie,0)>dG)throw new Error("Primary key size is too large: "+K.length);return!0}a(ac,"checkValidId");function Sh(K,m,A,w,y){let O=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),A.transaction?.isDone)return y(null,K);let L=i.getEntry(K,A);return L&&m&&(L?.version>(m.lastModified||0)&&(m.lastModified=L.version),L?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=L.localTime)),y(L,K)},"whenPrefetched");return w?O():ce>0?(ce--,O()):new Promise((L,N)=>{ce===0?(ce--,i.prefetch([K],()=>{P(),k()})):(j.push(K),ae.push(k),j.length>kG&&(ce--,P()));function P(){if(j.length>0){let D=ae;i.prefetch(j,()=>{ce===-1?P():ce++;for(let x of D)x()}),j=[],ae=[],ge>2&&ge--}else ce=ge,ge<qG&&ge++}a(P,"prefetch");function k(){try{L(O())}catch(D){N(D)}}a(k,"load")})}a(Sh,"loadLocalRecord");function ju(K){if(!K?.role)return;let m=K.role.permission;if(m.super_user)return Rie;let A=m[c],w,y=A?.tables;if(y)return y[s];if(c==="data"&&(w=m[s])&&!w.tables)return w}a(ju,"getTablePermissions");function Th(K,m,A,w){if(C){let y;if(A.noCache?y=!0:(m?(!m.value||m.metadataFlags&(Bu|Hu)||m.expiresAt&&m.expiresAt<Date.now())&&(y=!0):y=!0,Wr(!y,"cache-hit",s)),y){let O=JA(K,m,A).then(L=>(L?.value?.[de]&&rt.error("Can not assign a record with a record property"),A&&(L?.version>(A.lastModified||0)&&(A.lastModified=L.version),A.lastRefreshed=Date.now()),L));if(A?.onlyIfCached||m?.value&&w?.allowStaleWhileRevalidate?.(m,K)){if(O.catch(L=>rt.warn(L)),A?.onlyIfCached&&!w.doesExist())throw new rn.ServerError("Entry is not cached",504);return}else return O}}}a(Th,"ensureLoadedFromSource");function An(K){let m=K?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let A=m.next;if(!A)return m=m.next=new to,m.lmdbDb=i,m;m=A}while(!0)}else return new ud}a(An,"txnForContext");function gh(K,m,A){if(!K)return;mh=K;let w=K.value||K.deref?.()||(mh=i.getEntry(K.key))?.value;if(typeof m=="object"){let O=Qs,L=w;for(let N=0,P=m.length;N<P;N++){let k=m[N],D=O?.[k];L=D&&L?D(L,A,!0)?.value:L?.[k],O=D?.definition?.tableClass?.propertyResolvers}return L}let y=Qs[m];return y?y(w,A):w[m]}a(gh,"getAttributeValue");function zA(K,m,A,w,y){let O=y?.length,L={transaction:w,lazy:O>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},N;function P(k,D){let x=k?.value;if(!x)return Po.SKIP;for(let G=0;G<O;G++)if(!N?.includes(G)&&!y[G](x,k))return Po.SKIP;return D!==void 0&&(k.key=D),k}if(a(P,"processEntry"),O>0||!K.hasEntries){let k=K.map(D=>{if(N=null,typeof D=="object"&&D?.key!==void 0)return O>0?P(D):D;if(D==null)return Po.SKIP;for(let x=0;x<O;x++){let se=y[x].idFilter;if(se){if(!se(D))return Po.SKIP;N||(N=[]),N.push(x)}}return Sh(D,A,L,!1,P)});return Array.isArray(K)&&(k=k.filter(D=>D!==Po.SKIP)),k.hasEntries=!0,k}return K}a(zA,"transformToEntries");async function JA(K,m,A){let w=m?.metadataFlags,y=m?.version,O,L;if(!i.attemptLock(K,y,()=>{clearTimeout(L);let D=i.getEntry(K);!D||!D.value||D.metadataFlags&(Bu|Hu)?O(JA(K,i.getEntry(K),A)):O(D)}))return new Promise(D=>{O=D,L=setTimeout(()=>{i.unlock(K,y)},pie)});let N=m?.value,P={requestContext:A,replacingRecord:N,replacingVersion:y,noCacheStore:!1,source:null,resourceCache:A?.resourceCache},k=A?.responseHeaders;return new Promise((D,x)=>{let G;GA(Je(P,async se=>{let me=performance.now(),ee,Pe,le;try{for(let pe of Qe.sources)if(pe.get&&(!pe.get.reliesOnPrototype||pe.prototype.get)&&(P.source=pe,ee=await pe.get(K,P),ee))break;le=w&Bu;let re=P.lastModified||le&&y;Pe=le||re>y||!N,re||(re=(0,Fu.getNextMonotonicTime)());let X=performance.now()-me;if(Sr(X,"cache-resolution",s),k&&ug(k,"Server-Timing",`cache-resolve;dur=${X.toFixed(2)}`,!0),se.timestamp=re,E&&!P.expiresAt&&(P.expiresAt=Date.now()+E),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]!==K&&(ee[t]=K)}G=!0,D({version:re,value:ee})}catch(re){re.message+=` while resolving record ${K} for ${s}`,N&&((re.code==="ECONNRESET"||re.code==="ECONNREFUSED"||re.code==="EAI_AGAIN")&&!A?.mustRevalidate||A?.staleIfError&&(re.statusCode===500||re.statusCode===502||re.statusCode===503||re.statusCode===504))?(D({version:y,value:N}),rt.trace(re.message,"(returned stale record)")):x(re),P.transaction.abort();return}if(A?.noCacheStore||P.noCacheStore){P.transaction.abort();return}An(P).addWrite({key:K,store:i,entry:m,nodeName:"source",commit:(re,X)=>{if(X?.version!==y)return;let pe=Ju(K,N,ee);ee?(Ne.put?.(P,K,ee),T(K,ee,X,re,0,h&&Pe||null,P,P.expiresAt,"put",!!le)):(Ne.delete?.(P,K),h||p?T(K,null,X,re,0,h&&Pe||null,P,0,"delete",!!le):i.remove(K,y))}})}),()=>{i.unlock(K,y)},se=>{i.unlock(K,y),G&&rt.error("Error committing cache update",se)})})}a(JA,"getFromSource");function Rh(){if(ve!==Qu&&(Qu=ve,(0,Uo.getWorkerIndex)()===(0,Uo.getWorkerCount)()-1)){if(zu&&clearTimeout(zu),!ve)return;let K=new Date;K.setMonth(0),K.setDate(1),K.setHours(0),K.setMinutes(0),K.setSeconds(0);let m=Math.ceil((Date.now()-K.getTime())/ve)*ve+K.getTime(),A=a(w=>{rt.trace(`Scheduled next cleanup scan at ${new Date(w)}ms`),zu=setTimeout(()=>v=v.then(async()=>{if(A(Math.max(w+ve,Date.now())),i.rootStore.status!=="open"){clearTimeout(zu);return}let y=50,O=new Array(y),L=0;rt.trace(`Starting cleanup scan for ${s}`);try{let N=0;for(let{key:P,value:k,version:D,expiresAt:x}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let G;k===null&&!h&&D+mie<Date.now()?G=i.remove(P,D):x&&x+f<Date.now()&&(G=Qe.evict(P,k,D),N++),G&&(await O[L],O[L]=G.catch(se=>{rt.error("Cleanup error",se)}),++L>=y&&(L=0)),await xu()}rt.trace(`Finished cleanup scan for ${s}, evicted ${N} entries`)}catch(N){rt.trace(`Error in cleanup scan for ${s}:`,N)}}),Math.min(w-Date.now(),2147483647)).unref()},"startNextTimer");A(m)}}a(Rh,"scheduleCleanup");function jA(){J=l?.addDeleteRemovalCallback(n,K=>{let m=i.getEntry(K);m?.value===null&&i.remove(K,m.version)})}a(jA,"addDeleteRemoval");function $G(){(0,Uo.getWorkerIndex)()===0&&setInterval(async()=>{if(!ph){ph=!0;try{let K=Q.name,m=r[K];if(!m)throw new Error(`expiresAt attribute ${Q} must be indexed`);for(let A of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let w of m.getValues(A)){let y=i.getEntry(w);y?.value?y.value[K]<Date.now()&&Qe.evict(w,y.value,y.version):i.ifVersion(w,y?.version,()=>m.remove(A,w))}await xu()}}catch(K){rt.error("Error in evicting old records",K)}finally{ph=!1}}},hie).unref()}a($G,"runRecordExpirationEviction")}function xA(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 fG(){}function Aie(e){pG=e}function nh(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"?isNaN(e)?e==="null"?null:(Oie.test(e)||(e+="Z"),new Date(e)):new Date(+e):!r||r==="Any"?(0,ih.autoCast)(e):e}function EG(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 GA(e,t,r){return e?.then?e.then(t,r):t(e)}function sh(e,t){e[Lr]=t,e[de]=t?.value??null,e[Gu]=t?.version}function hG(e){return e!=null}function kn(e){try{return JSON.stringify(e)}catch{return e}}var Vn,Po,Fu,mG,Vu,rn,qu,ku,rt,vo,Uo,ih,Eie,pG,hie,mie,uG,pie,Gu,Sie,Lr,vu,_G,Tie,HA,nc,Bu,Hu,gie,dG,Rie,Jpe,Oie,xu,lE=Re(()=>{Vn=B(U()),Po=require("lmdb"),Fu=B(Hr()),mG=require("lodash");In();tS();Vu=B(te());lG();rn=B(ne()),qu=B(bs()),ku=B(Ln());Ae();zf();rt=B(Y());fd();ro();vo=require("ordered-binary"),Uo=B(ot());ti();ih=B(z());Pc();ws();WE();jl();Eie=new Uint8Array(9);Eie[8]=192;hie=6e4,mie=864e5;Vu.initSync();uG=Vu.get(Vn.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),pie=1e4,Gu=Symbol.for("version"),Sie=Symbol.for("incremental-update"),Lr=Symbol("entry"),vu=Symbol("is-saving"),_G=1,Tie=2,HA=Symbol("loaded-from-source"),nc={isNotification:!0,ensureLoaded:!1},Bu=1,Hu=8,gie=Buffer.allocUnsafeSlow(8192),dG=1978,Rie={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},Jpe=(0,ih.convertToMS)(Vu.get(Vn.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(oh,"makeTable");a(xA,"attributesAsObject");a(fG,"noop");a(Aie,"setServerUtilities");Oie=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(nh,"coerceType");a(EG,"isDescendantId");xu=a(()=>new Promise(setImmediate),"rest");a(GA,"when");a(sh,"updateResource");a(hG,"exists");a(kn,"stringify")});var ke={};qe(ke,{database:()=>ia,databases:()=>at,dropDatabase:()=>oS,dropTableMeta:()=>wie,getDatabases:()=>mr,getDefaultCompression:()=>pf,getTables:()=>bie,onUpdatedTable:()=>QR,readMetaDb:()=>$u,resetDatabases:()=>Vl,table:()=>ft,tables:()=>xr});function bie(){return _h||mr(),xr||{}}function mr(){if(_h)return at;_h=!0,oc=new Map;let e=(0,pt.getHdbBasePath)()&&(0,nt.join)((0,pt.getHdbBasePath)(),Ut.DATABASES_DIR_NAME),t=(0,pt.get)(Ut.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,pt.get)(Ut.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,nn.existsSync)(e)?e:(0,nt.join)((0,pt.getHdbBasePath)(),Ut.LEGACY_DATABASES_DIR_NAME)),!!e){if((0,nn.existsSync)(e))for(let r of(0,nn.readdirSync)(e,{withFileTypes:!0})){let n=(0,nt.basename)(r.name,".mdb");r.isFile()&&(0,nt.extname)(r.name).toLowerCase()===".mdb"&&!t[n]?.path&&$u((0,nt.join)(e,r.name),null,n)}if((0,nn.existsSync)((0,ic.getBaseSchemaPath)())){for(let r of(0,nn.readdirSync)((0,ic.getBaseSchemaPath)(),{withFileTypes:!0}))if(!r.isFile()){let n=(0,nt.join)((0,ic.getBaseSchemaPath)(),r.name),s=(0,nt.join)((0,ic.getTransactionAuditStoreBasePath)(),r.name);for(let i of(0,nn.readdirSync)(n,{withFileTypes:!0}))if(i.isFile()&&(0,nt.extname)(i.name).toLowerCase()===".mdb"){let o=(0,nt.join)(s,i.name);$u((0,nt.join)(n,i.name),(0,nt.basename)(i.name,".mdb"),r.name,o,!0)}}}if(t)for(let r in t){let n=t[r],s=n.path;if((0,nn.existsSync)(s))for(let o of(0,nn.readdirSync)(s,{withFileTypes:!0}))o.isFile()&&(0,nt.extname)(o.name).toLowerCase()===".mdb"&&$u((0,nt.join)(s,o.name),(0,nt.basename)(o.name,".mdb"),r);let i=n.tables;if(i)for(let o in i){let c=i[o],l=(0,nt.join)(c.path,(0,nt.basename)(o+".mdb"));(0,nn.existsSync)(l)&&$u(l,o,r,null,!0)}}for(let r in at){let n=oc.get(r);if(n){let s=at[r];r.includes("delete")&&Rn.trace(`defined tables ${Array.from(n.keys())}`);for(let i in s)n.has(i)||(Rn.trace(`delete table class ${i}`),delete s[i])}else if(delete at[r],r==="data"){for(let s in xr)delete xr[s];delete xr[dh]}}return oc=null,at}}function Vl(){_h=!1;for(let[,e]of Mi)e.needsDeletion=!0;mr();for(let[e,t]of Mi)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),Mi.delete(e));return at}function $u(e,t,r=kA,n,s){let i=new FA.default(e,!1);try{let o=Mi.get(e);o?o.needsDeletion=!1:(o=(0,ch.open)(i),Mi.set(e,o));let c=new Bo.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(ah.INTERNAL_DBIS_NAME,c)),_=o.auditStore;_||(n?(0,nn.existsSync)(n)&&(i.path=n,_=(0,ch.open)(i),_.isLegacy=!0):_=KE(o));let u=RG(r),d=u[dh],E=new Map;for(let{key:f,value:h}of l.getRange({start:!1})){let[p,S]=f.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=E.get(p);T||E.set(p,T={attributes:[]}),(S==null||h.is_hash_attribute)&&(T.primary=h),S!=null&&T.attributes.push(h),Object.defineProperty(h,"key",{value:f,configurable:!0})}for(let[f,h]of E){let{attributes:p,primary:S}=h;if(!S){for(let j of p)if(j.is_hash_attribute||j.isPrimaryKey){S=j;break}if(!S){Rn.fatal(`Unable to find a primary key attribute on table ${f}, with attributes: ${JSON.stringify(p)}`);continue}}let T=u[f],R={},b=[],C,H,v=typeof S.audit=="boolean"?S.audit:(0,pt.get)(Ut.CONFIG_PARAMS.LOGGING_AUDITLOG),q=S.trackDeletes,M=S.expiration,Q=S.eviction,J=S.sealed;if(T)R=T.indices,b=T.attributes,T.schemaVersion++;else{C=S.tableId,C?C>=(l.get(sc)||0)&&l.putSync(sc,C+1):(S.tableId=C=l.get(sc),C||(C=1),l.putSync(sc,C+1),l.putSync(S.key,S));let j=new Bo.default(!S.is_hash_attribute,S.is_hash_attribute);if(j.compression=S.compression,j.compression){let ae=(0,pt.get)(Ut.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||gG;j.compression.threshold=ae}H=b_(o.openDB(S.key,j)),H.rootStore=o,H.tableId=C}for(let j of p){j.attribute=j.name;try{if(!j.is_hash_attribute&&(j.indexed||j.attribute&&!j.name)){if(!R[j.name]){let ce=new Bo.default(!j.is_hash_attribute,j.is_hash_attribute);R[j.name]=o.openDB(j.key,ce),R[j.name].indexNulls=j.indexNulls}let ae=b.find(ce=>ce.name===j.name);ae?b.splice(b.indexOf(ae),1,j):b.push(j)}}catch(ae){Rn.error("Error trying to update attribute",j,b,R,ae)}}if(!T){T=AG(u,f,oh({primaryStore:H,auditStore:_,audit:v,sealed:J,expirationMS:M&&M*1e3,evictionMS:Q&&Q*1e3,trackDeletes:q,tableName:f,tableId:C,primaryKey:S.name,databasePath:s?r+"/"+f:r,databaseName:r,indices:R,attributes:p,schemaDefined:S.schemaDefined,dbisDB:l})),T.schemaVersion=1;for(let j of VA)j(T)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function RG(e){let t=at[e];if(t||(e==="data"?t=at[e]=xr:e==="system"?Object.defineProperty(at,"system",{value:t=Object.create(null),configurable:!0}):t=at[e]=Object.create(null)),oc&&!oc.has(e)){let r=new Set;t[dh]=r,oc.set(e,r)}return t}function AG(e,t,r){return e[t]=r,r}function ia({database:e,table:t}){e||(e=kA),mr();let r=RG(e),n=(0,nt.join)((0,pt.getHdbBasePath)(),Ut.DATABASES_DIR_NAME),s=(0,pt.get)(Ut.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,pt.get)(Ut.CONFIG_PARAMS.STORAGE_PATH)||((0,nn.existsSync)(n)?n:(0,nt.join)((0,pt.getHdbBasePath)(),Ut.LEGACY_DATABASES_DIR_NAME));let o=(0,nt.join)(n,(i?t:e)+".mdb"),c=Mi.get(o);if(!c){let l=new FA.default(o,!1);c=(0,ch.open)(l),Mi.set(o,c)}return c}async function oS(e){if(!at[e])throw new Error("Schema does not exist");let t=at[e],r;for(let n in t)r=t[n].primaryStore.rootStore,Mi.delete(r.path),r.status==="open"&&(await r.close(),await Yu.remove(r.path));if(r||(r=ia({database:e,table:null}),r.status==="open"&&(await r.close(),await Yu.remove(r.path))),e==="data"){for(let n in xr)delete xr[n];delete xr[dh]}delete at[e]}function ft({table:e,database:t,expiration:r,eviction:n,scanInterval:s,attributes:i,audit:o,sealed:c,trackDeletes:l,schemaDefined:_,origin:u}){t||(t=kA);let d=ia({database:t,table:e}),E=at[t],f=E?.[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 R=new Bo.default(!1);for(let M of i)M.attribute&&!M.name?(M.name=M.attribute,M.indexed=!0):M.attribute=M.name,M.expiresAt&&(M.indexed=!0);let b,C;if(f){if(h=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 M=d.auditStore;M||(M=KE(d)),p=i.find(ae=>ae.isPrimaryKey)||{},h=p.name,p.is_hash_attribute=!0,p.schemaDefined=_,p.compression=pf(),l&&(p.trackDeletes=!0),o=p.audit=typeof o=="boolean"?o:(0,pt.get)(Ut.CONFIG_PARAMS.LOGGING_AUDITLOG),r&&(p.expiration=r),n&&(p.eviction=n),typeof c=="boolean"&&(p.sealed=c),u&&(p.origins?p.origins.includes(u)||p.origins.push(u):p.origins=[u]),Rn.trace(`${e} table loading, opening primary store`);let Q=new Bo.default(!1,!0);Q.compression=p.compression;let J=e+"/",j=b_(d.openDB(J,Q));j.rootStore=d,T=d.dbisDb=d.openDB(ah.INTERNAL_DBIS_NAME,R),j.tableId=T.get(sc),j.tableId||(j.tableId=1),T.putSync(sc,j.tableId+1),p.tableId=j.tableId,f=AG(E,e,oh({primaryStore:j,auditStore:M,audit:o,sealed:c,trackDeletes:l,expirationMS:r&&r*1e3,evictionMS:n&&n*1e3,primaryKey:h,tableName:e,tableId:j.tableId,databasePath:t,databaseName:t,indices:{},attributes:i,schemaDefined:_,dbisDB:T})),f.schemaVersion=1,b=!0,q(),T.put(J,p)}S=f.indices,T=T||(d.dbisDb=d.openDB(ah.INTERNAL_DBIS_NAME,R)),f.dbisDB=T;let H=[];for(let{key:M,value:Q}of T.getRange({start:!0})){let[J,j]=M.toString().split("/");if(j===""&&(j=Q.name),j){if(J!==e)continue}else j=J;if(!i.find(ce=>ce.name===j)?.indexed&&Q.indexed&&!Q.isPrimaryKey){q(),b=!0,T.remove(M);let ce=f.indices[J];ce&&H.push(ce)}}let v=[];try{for(let M of i||[]){if(M.relationship)continue;let Q=e+"/"+(M.name||"");Object.defineProperty(M,"key",{value:Q,configurable:!0});let J=T.get(Q);if(M.isPrimaryKey){if(J=J||T.get(Q=e+"/")||{},o!==f.audit||c!==c||(+r||void 0)!==(+J.expiration||void 0)||(+n||void 0)!==(+J.eviction||void 0)){let ae=Object.assign({},J);typeof o=="boolean"&&(o&&f.enableAuditing(o),ae.audit=o),r&&(ae.expiration=+r),n&&(ae.eviction=+n),c!==void 0&&(ae.sealed=c),b=!0,q(),T.put(Q,ae)}continue}J?.attribute&&!J.name&&(J.indexed=!0);let j=!J||J.type!==M.type||J.indexed!==M.indexed||J.nullable!==M.nullable||JSON.stringify(J.attributes)!==JSON.stringify(M.attributes)||JSON.stringify(J.elements)!==JSON.stringify(M.elements);if(M.indexed){let ae=new Bo.default(!0,!1),ce=d.openDB(Q,ae);(j||J.indexingPID&&J.indexingPID!==process.pid||J.restartNumber<Ku.workerData?.restartNumber)&&(b=!0,q(),J=T.get(Q),(j||J.indexingPID&&J.indexingPID!==process.pid||J.restartNumber<Ku.workerData?.restartNumber)&&(b=!0,M.indexNulls===void 0&&(M.indexNulls=!0),f.primaryStore.getStats().entryCount>0&&(M.lastIndexedKey=J?.lastIndexedKey||!1,M.indexingPID=process.pid,ce.isIndexing=!0,Object.defineProperty(M,"dbi",{value:ce}),v.push(M))),T.put(Q,M)),J?.indexNulls&&M.indexNulls===void 0&&(M.indexNulls=!0),ce.indexNulls=M.indexNulls,S[M.name]=ce}else j&&(b=!0,q(),T.put(Q,M))}}finally{C&&C()}if(b&&(f.schemaVersion++,f.updatedAttributes()),Rn.trace(`${e} table loading, running index`),v.length>0||H.length>0?f.indexingOperation=Iie(f,v,H):b&&lh.signalSchemaChange(new uh.SchemaEventMsg(process.pid,"schema-change",f.databaseName,f.tableName)),f.origin=u,b)for(let M of VA)M(f,u!=="cluster");return(r||n||s)&&f.setTTLExpiration({expiration:r,eviction:n,scanInterval:s}),Rn.trace(`${e} table loaded`),f;function q(){C||d.transactionSync(()=>({then(M){C=M}}))}a(q,"startTxn")}async function Iie(e,t,r){try{let n=e.schemaVersion;await lh.signalSchemaChange(new uh.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let l of r)s=l.drop();let i,o=0,c=t.length;if(await new Promise(l=>setImmediate(l)),c>0){let l=0;for(let{key:_,value:u,version:d}of e.primaryStore.getRange({start:t[0].lastIndexedKey,lazy:c<4,versions:!0,snapshot:!1}))if(u){if(l++,s=e.primaryStore.ifVersion(_,d,()=>{for(let E=0;E<c;E++){let f=t[E],h=f.name,p=(0,SG.getIndexedValues)(u[h]);if(p)for(let S=0,T=p.length;S<T;S++)f.dbi.put(p[S],_)}}),s.then(()=>l--,E=>{l--,Rn.error(E)}),Ku.workerData&&Ku.workerData.restartNumber!==TG.restartNumber&&(i=!0),++o%100===0||i){for(let E of t)E.lastIndexedKey=_,e.dbisDB.put(E.key,E);if(i)return}l>yie?await s:l>Nie&&await new Promise(E=>setImmediate(E))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await lh.signalSchemaChange(new uh.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName))}catch(n){Rn.error("Error in indexing",n)}}function wie({table:e,database:t}){let r=ia({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 QR(e){VA.push(e)}function pf(){let e=(0,pt.get)(Ut.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,pt.get)(Ut.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,pt.get)(Ut.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||gG,n={startingOffset:32};return t&&(n.dictionary=Yu.readFileSync(t)),r&&(n.threshold=r),e&&n}var pt,ah,ch,nt,nn,ic,Bo,FA,Ut,Yu,qA,SG,lh,uh,Ku,Rn,TG,kA,dh,gG,xr,at,sc,VA,_h,Mi,oc,yie,Nie,Ae=Re(()=>{pt=B(te()),ah=B(dt()),ch=require("lmdb"),nt=require("path"),nn=require("fs"),ic=B(ze());lE();Bo=B(Uc()),FA=B(vc()),Ut=B(U()),Yu=B(require("fs-extra")),qA=require("../../index"),SG=B(Hr()),lh=B(bs()),uh=B(Ln()),Ku=require("worker_threads"),Rn=B(Y()),TG=B(ot());ti();Pc();kA="data",dh=Symbol("defined-tables"),gG=((0,pt.get)(Ut.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,pt.initSync)();xr=Object.create(null),at=Object.create(null);(0,qA._assignPackageExport)("databases",at);(0,qA._assignPackageExport)("tables",xr);sc=Symbol.for("next-table-id"),VA=[],Mi=new Map;a(bie,"getTables");a(mr,"getDatabases");a(Vl,"resetDatabases");a($u,"readMetaDb");a(RG,"ensureDB");a(AG,"setTable");a(ia,"database");a(oS,"dropDatabase");a(ft,"table");yie=1e3,Nie=10;a(Iie,"runIndexing");a(wie,"dropTableMeta");a(QR,"onUpdatedTable");a(pf,"getDefaultCompression")});var z=g((iSe,BG)=>{"use strict";var Pi=require("path"),IG=require("fs-extra"),Mr=Y(),OG=require("fs-extra"),fh=require("os"),Cie=require("net"),Die=require("recursive-iterator"),_t=U(),Lie=DO(),bG=require("papaparse"),Eh=require("moment"),{inspect:Mie}=require("util"),yG=require("is-number"),sSe=require("lodash"),Pie=require("minimist"),Uie=require("https"),vie=require("http"),{hdb_errors:hh}=ne(),Bie=/^((\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)))$/,wG=require("util").promisify(setTimeout),Hie=100,xie=5,Gie="",Fie=4,NG={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};BG.exports={isEmpty:sn,isEmptyOrZeroLength:hs,arrayHasEmptyValues:Vie,arrayHasEmptyOrZeroLengthValues:$ie,buildFolderPath:Yie,isBoolean:CG,errorizeMessage:qie,stripFileExtension:Wie,autoCast:Qie,autoCastJSON:DG,autoCastJSONDeep:YA,removeDir:zie,compareVersions:Jie,isCompatibleDataVersion:jie,escapeRawValue:Xie,unescapeValue:Zie,stringifyProps:eoe,timeoutPromise:roe,isClusterOperation:soe,getClusterUser:ooe,checkGlobalSchemaTable:ioe,getHomeDir:MG,getPropsFilePath:toe,promisifyPapaParse:aoe,removeBOM:PG,createEventPromise:coe,checkProcessRunning:loe,checkSchemaTableExist:uoe,checkSchemaExists:UG,checkTableExists:vG,getStartOfTomorrowInSeconds:_oe,getLimitKey:doe,isObject:Kie,isNotEmptyAndHasValue:kie,autoCasterIsNumberCheck:LG,backtickASTSchemaItems:foe,isPortTaken:noe,createForkArgs:Eoe,autoCastBoolean:hoe,async_set_timeout:wG,getTableHashAttribute:moe,doesSchemaExist:poe,doesTableExist:Soe,stringifyObj:Toe,ms_to_time:goe,changeExtension:Roe,getEnvCliRootPath:KA,noBootFile:Aoe,httpRequest:Ooe,transformReq:boe,convertToMS:yoe,PACKAGE_ROOT:_t.PACKAGE_ROOT};function qie(e){return e instanceof Error?e:new Error(e)}a(qie,"errorizeMessage");function sn(e){return e==null}a(sn,"isEmpty");function kie(e){return!sn(e)&&(e||e===0||e===""||CG(e))}a(kie,"isNotEmptyAndHasValue");function hs(e){return sn(e)||e.length===0||e.size===0}a(hs,"isEmptyOrZeroLength");function Vie(e){if(sn(e))return!0;for(let t=0;t<e.length;t++)if(sn(e[t]))return!0;return!1}a(Vie,"arrayHasEmptyValues");function $ie(e){if(hs(e))return!0;for(let t=0;t<e.length;t++)if(hs(e[t]))return!0;return!1}a($ie,"arrayHasEmptyOrZeroLengthValues");function Yie(...e){try{return e.join(Pi.sep)}catch{console.error(e)}}a(Yie,"buildFolderPath");function CG(e){return sn(e)?!1:e===!0||e===!1}a(CG,"isBoolean");function Kie(e){return sn(e)?!1:typeof e=="object"}a(Kie,"isObject");function Wie(e){return hs(e)?Gie:e.slice(0,-Fie)}a(Wie,"stripFileExtension");function Qie(e){return sn(e)||e===""||typeof e!="string"?e:NG[e]!==void 0?NG[e]:LG(e)===!0?Number(e):Bie.test(e)?new Date(e):e}a(Qie,"autoCast");function DG(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(DG,"autoCastJSON");function YA(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=YA(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=YA(r);n!==r&&(e[t]=n)}return e}else return DG(e)}a(YA,"autoCastJSONDeep");function LG(e){if(e.startsWith("0.")&&yG(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&yG(e))}a(LG,"autoCasterIsNumberCheck");async function zie(e){if(hs(e))throw new Error(`Directory path: ${e} does not exist`);try{await OG.emptyDir(e),await OG.remove(e)}catch(t){throw Mr.error(`Error removing files in ${e} -- ${t}`),t}}a(zie,"removeDir");function Jie(e,t){if(hs(e)){Mr.info("Invalid current version sent as parameter.");return}if(hs(t)){Mr.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let _=0;_<l;_++)if(r=parseInt(o[_],10)-parseInt(c[_],10),r)return r;return o.length-c.length}a(Jie,"compareVersions");function jie(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(jie,"isCompatibleDataVersion");function Xie(e){if(sn(e))return e;let t=String(e);return t==="."?_t.UNICODE_PERIOD:t===".."?_t.UNICODE_PERIOD+_t.UNICODE_PERIOD:t.replace(_t.FORWARD_SLASH_REGEX,_t.UNICODE_FORWARD_SLASH)}a(Xie,"escapeRawValue");function Zie(e){if(sn(e))return e;let t=String(e);return t===_t.UNICODE_PERIOD?".":t===_t.UNICODE_PERIOD+_t.UNICODE_PERIOD?"..":String(e).replace(_t.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(Zie,"unescapeValue");function eoe(e,t){if(sn(e))return Mr.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+fh.EOL}!hs(n)&&n[0]===";"?r+=" "+n+s+fh.EOL:hs(n)||(r+=n+"="+s+fh.EOL)}catch{Mr.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(eoe,"stringifyProps");function MG(){let e;try{e=fh.homedir()}catch{e=process.env.HOME}return e||(e="~/"),e}a(MG,"getHomeDir");function toe(){let e=Pi.join(MG(),_t.HDB_HOME_DIR_NAME,_t.BOOT_PROPS_FILE_NAME);return IG.existsSync(e)||(e=Pi.join(__dirname,"../","hdb_boot_properties.file")),e}a(toe,"getPropsFilePath");function roe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:function(){clearTimeout(r)}}}a(roe,"timeoutPromise");async function noe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=Cie.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(noe,"isPortTaken");function soe(e){try{return _t.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Mr.error(`Error checking operation against cluster ops ${t}`)}return!1}a(soe,"isClusterOperation");function ioe(e,t){let r=(Ae(),ie(ke)).getDatabases();if(!r[e])return hh.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return hh.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(ioe,"checkGlobalSchemaTable");function ooe(e,t){if(sn(t)){Mr.warn("No CLUSTERING_USER defined, clustering disabled");return}if(sn(e)||hs(e)){Mr.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){Mr.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){Mr.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(ooe,"getClusterUser");function aoe(){bG.parsePromise=function(e,t,r){return new Promise(function(n,s){bG.parse(e,{header:!0,transformHeader:PG,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(aoe,"promisifyPapaParse");function PG(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(PG,"removeBOM");function coe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;Mr.info(`Got cluster status event response: ${Mie(s)}`);try{i.cancel()}catch{Mr.error("Error trying to cancel timeout.")}n(s)})})}a(coe,"createEventPromise");async function loe(e){let t=!0,r=0;do await wG(Hie*r++),(await Lie.findPs(e)).length>0&&(t=!1);while(t&&r<xie);if(t)throw new Error(`process ${e} was not started`)}a(loe,"checkProcessRunning");function uoe(e,t){let r=UG(e);if(r)return r;let n=vG(e,t);if(n)return n}a(uoe,"checkSchemaTableExist");function UG(e){let{getDatabases:t}=(Ae(),ie(ke));if(!t()[e])return hh.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(UG,"checkSchemaExists");function vG(e,t){let{getDatabases:r}=(Ae(),ie(ke));if(!r()[e][t])return hh.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(vG,"checkTableExists");function _oe(){let e=Eh().utc().add(1,_t.MOMENT_DAYS_TAG).startOf(_t.MOMENT_DAYS_TAG).unix(),t=Eh().utc().unix();return e-t}a(_oe,"getStartOfTomorrowInSeconds");function doe(){return Eh().utc().format("DD-MM-YYYY")}a(doe,"getLimitKey");function foe(e){try{let t=new Die(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){Mr.error("Got an error back ticking items."),Mr.error(t)}}a(foe,"backtickASTSchemaItems");function Eoe(e){return[e]}a(Eoe,"createForkArgs");function hoe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(hoe,"autoCastBoolean");function moe(e,t){let{getDatabases:r}=(Ae(),ie(ke)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(moe,"getTableHashAttribute");function poe(e){let{getDatabases:t}=(Ae(),ie(ke));return t()[e]!==void 0}a(poe,"doesSchemaExist");function Soe(e,t){let{getDatabases:r}=(Ae(),ie(ke));return r()[e]?.[t]!==void 0}a(Soe,"doesTableExist");function Toe(e){try{return JSON.stringify(e)}catch{return e}}a(Toe,"stringifyObj");function goe(e){let t=Eh.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(goe,"ms_to_time");function Roe(e,t){let r=Pi.basename(e,Pi.extname(e));return Pi.join(Pi.dirname(e),r+t)}a(Roe,"changeExtension");function KA(){if(process.env[_t.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[_t.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=Pie(process.argv);if(e[_t.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[_t.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(KA,"getEnvCliRootPath");var $A;function Aoe(){if($A)return $A;let e=KA();if(KA()&&IG.pathExistsSync(Pi.join(e,_t.HDB_CONFIG_FILE)))return $A=!0,!0}a(Aoe,"noBootFile");function Ooe(e,t){let r;return e.protocol==="http:"?r=vie:r=Uie,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8");let c={body:"",headers:o.headers};o.on("data",l=>{c.body+=l}),o.on("end",()=>{n(c)})});i.on("error",o=>{s(o)}),i.write(JSON.stringify(t)),i.end()})}a(Ooe,"httpRequest");function boe(e){if(!e.schema&&!e.database){e.schema=_t.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(boe,"transformReq");function yoe(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(yoe,"convertToMS")});var WA=U(),HG=z(),Wu=Y(),Noe=Os(),Ioe=Vr(),woe=NR(),{start:Coe}=(WR(),ie(CE)),{closeConnection:Doe}=Rt(),xG=require("moment"),GG=_E(),{cloneDeep:Loe}=require("lodash"),Moe=process.env[WA.PROCESS_NAME_ENV_PROP],Ho=Moe.substring(4);a(async function(){let t={id:Ho,request:void 0},r=0;try{Wu.notify("Starting job:",Ho),Coe(),Noe.setSchemaDataToGlobal(),await Ioe.setUsersToGlobal();let n=await GG.getJobById(Ho);if(HG.isEmptyOrZeroLength(n))throw new Error(`Unable to find a record in hdb_job for job: ${Ho}`);let{request:s}=n[0];if(HG.isEmptyOrZeroLength(s))throw new Error("Did not find job request in hdb_job table, unable to proceed");s=Loe(s);let i=woe.getOperationFunction(s);Wu.trace("Running operation:",s.operation,"for job",Ho);let o=await i.job_operation_function(s);Wu.trace("Result from job:",Ho,o),t.status=WA.JOB_STATUS_ENUM.COMPLETE,t.message=o,t.end_datetime=xG().valueOf(),Wu.notify("Successfully completed job:",Ho)}catch(n){r=1,Wu.error(n),t.status=WA.JOB_STATUS_ENUM.ERROR,t.message=n.message?n.message:n,t.end_datetime=xG().valueOf()}finally{await GG.updateJob(t),await Doe(),setTimeout(()=>{process.exit(r)},3e3).unref()}},"job")();
41
+ `))}},25).unref()}o.close?.(()=>{if(Et.get(Yt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&vf()==0)try{eq(nq(Et.get(Yt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,tp),o.cantCleanupProperly||Fr.warn("Had to forcefully exit the thread",tp),process.exit(0)},5e3).unref()})}if(sq||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Fr.info("Could not close debugger",i)}}}).ref();let e;Mf&&!yle&&(e=oq()),Promise.resolve(e).then(()=>{Uf?.postMessage({type:Yt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(iq,"startServers");function oq(){let e=[];for(let t in si){let r=si[t];if(t.includes?.("/")&&vf()==0){hle(t)&&eq(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o(),Fr.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=Et.get(Yt.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=vf();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?Mf?n={fd:Mf(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:Mf?n={fd:Mf(+t,"::")}:n={port:t}}catch(o){console.error(`Unable to bind to port ${t}`,o);continue}e.push(new Promise((o,c)=>{r.listen(n,()=>{o(),Fr.trace("Listening on port "+t,tp)}).on("error",c)}))}return Promise.all(e)}a(oq,"listenOnPorts");!Qy&&!lle.noServerStart&&iq();function Xy(e,t,r){let n=e?.read?e:new ule({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=si[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=si[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(Fr.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(Xy,"deliverSocket");var XG=new Map;function Ile(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=XG.get(s),r){case"connection":i=Xy(void 0,t),XG.set(s,i),i.write=(c,l,d)=>(Uf.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),d&&d(),!0),i.end=(c,l,d)=>(Uf.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),d&&d(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),Uf.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(Ile,"proxyRequest");function Zy(e,t,r=!0){t||(t=Et.get(Yt.CONFIG_PARAMS.HTTP_PORT));let n=si[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",ZG),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else si[t]=e;e.on("unhandled",ZG)}a(Zy,"registerServer");function aq(e){let t=[],r=e?.securePort;return r&&t.push({port:r,secure:!0}),r=e?.port,r&&t.push({port:r,secure:!1}),t.length===0&&(t=[],Et.get(Yt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:Et.get(Yt.CONFIG_PARAMS.HTTP_PORT),secure:Et.get(Yt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),Et.get(Yt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:Et.get(Yt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&Et.get(Yt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:nq(Et.get(Yt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(aq,"getPorts");function eO(e,t){for(let{port:r,secure:n}of aq(t))cq(r,n,t?.isOperationsServer),typeof e=="function"?jy[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||r}):(e.isSecure=n,Zy(e,r,!1)),rp[r]=Jy(jy,r),Ole=Jy(Nle,r)}a(eO,"httpServer");function cq(e,t,r){if(!ep[e]){let n=r?"operationsApi_network":"http",s={noDelay:!0,keepAliveTimeout:Et.get(n+"_keepAliveTimeout"),headersTimeout:Et.get(n+"_headersTimeout"),requestTimeout:Et.get(n+"_timeout"),highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600},i=Et.get(n+"_mtls"),o=Et.get(n+"_mtls_required");t&&Object.assign(s,{allowHTTP1:!0,rejectUnauthorized:!!o,requestCert:!!(i||r),ticketKeys:Sle(),maxHeaderSize:Et.get(Yt.CONFIG_PARAMS.HTTP_MAXHEADERSIZE),SNICallback:rq(r?"operations-api":"server",i),ALPNCallback:function(d){return d.protocols.includes("harperdb-replication")&&(this.isReplicationConnection=!0),"http/1.1"},ALPNProtocols:null});let c=Ale(),l=ep[e]=(t?Ele:fle)(s,async(d,u)=>{try{let E=performance.now(),_=new tq(d,u);r&&(_.isOperationsServer=!0);let h=await rp[e](_);if(!h){if(_._nodeResponse.statusCode)return;h=lq(_)}if(h.headers?.set||(h.headers=new zy(h.headers)),c?h.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):h.headers?.set?.("Server","HarperDB"),h.status===-1){for(let v of h.headers||[])u.setHeader(v[0],v[1]);return d.baseRequest=_,u.baseResponse=h,ep[e].emit("unhandled",d,u)}let p=h.status||200,S=performance.now(),g=S-E,T=h.body,A;if(!h.handlesHeaders){let v=h.headers||new zy;T?T.length>=0&&(typeof T=="string"?v.set("Content-Length",Buffer.byteLength(T)):v.set("Content-Length",T.length),A=!0):(v.set("Content-Length","0"),A=!0);let J=`hdb;dur=${g.toFixed(2)}`;h.wasCacheMiss&&(J+=", miss"),gle(v,"Server-Timing",J,!0),u.writeHead(p,v&&(v[Symbol.iterator]?Array.from(v):v)),A&&u.end(T)}let N=_.handlerPath,V=_.method;if(Lf(g,"duration",N,V,h.wasCacheMiss==null?void 0:h.wasCacheMiss?"cache-miss":"cache-hit"),Rle(p<400,"success",N,V),!A)if(T?.pipe){T.pipe(u),T.destroy&&u.on("close",()=>{T.destroy()});let v=0;T.on("data",J=>{v+=J.length}),T.on("end",()=>{Lf(performance.now()-S,"transfer",N,V),Lf(v,"bytes-sent",N,V)})}else T?.then?T.then(v=>{u.end(v)},f):u.end(T)}catch(E){f(E)}function f(E){let _=E.headers;u.writeHead(E.statusCode||500,_&&(_[Symbol.iterator]?Array.from(_):_)),u.end(E.toString()),E.statusCode?E.statusCode===500?Fr.warn(E):Fr.info(E):Fr.error(E)}a(f,"onError")});t&&(l.ports||(l.ports=[]),l.ports.push(e),s.SNICallback.initialize(l),i&&(l.mtlsConfig=i),l.on("secureConnection",d=>{d._parent.startTime&&Lf(performance.now()-d._parent.startTime,"tls-handshake",e),Lf(d.isSessionReused(),"tls-reused",e)}),l.isSecure=!0),Zy(l,e)}return ep[e]}a(cq,"getHTTPServer");function Jy(e,t){let r=lq;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(Jy,"makeCallbackChain");function lq(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new zy}}a(lq,"unhandled");function wle(e,t){eO(e,{requestOnly:!0,...t})}a(wle,"onRequest");function Cle(e,t){let r;if(t.securePort){let n=rq("server",t.mtls);r=ple({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),si[t.securePort]=r}return t.port&&(r=dle(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),si[t.port]=r),r}a(Cle,"onSocket");Object.defineProperty(_le.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 Dle(e,t){let r=[];for(let{port:n,secure:s}of aq(t)){if(!Pf[n]){let c;Pf[n]=new mle({server:c=cq(n,s,t?.isOperationsServer)}),c._ws=Pf[n],r.push(c),Pf[n].on("connection",async(l,d)=>{try{let u=new tq(d);u.isWebSocket=!0;let f=rp[n](u),E=d.headers["sec-websocket-protocol"],_=Wy[n],h;if(E){for(let p=0;p<_.length;p++){let S=_[p];S.protocol===E&&(h=!0,S.listener(l,u,f))}if(h)return}for(let p=0;p<_.length;p++){let S=_[p];S.protocol||(S.listener(l,u,f),h=!0)}h||l.close(1008,"No handler for protocol")}catch(u){Fr.warn("Error handling WebSocket connection",u)}}),Pf[n].on("error",l=>{console.log("Error in setting up WebSocket server",l)})}let i=t?.subProtocol||"",o=Wy[n];o||(o=Wy[n]=[]),o.push({listener:e,protocol:i}),rp[n]=Jy(jy,n)}return r}a(Dle,"onWebSocket");function ZG(e,t){t.writeHead(404),t.end(`Not found
42
+ `)}a(ZG,"defaultNotFound")});async function Eq({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await rO.get(e,{returnNonexistent:!0});i=new iO(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await rO.get(e);o&&o.delete()}i=new ip(e,t)}return n&&(n.id=e,n.user={username:t?.username},xf.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function nO(){return sp++,sp>65500&&(sp=1),sp}function sO(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=mo.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return Tt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var dq,Po,fq,_q,rO,xf,sp,ip,iO,hq=Oe(()=>{Ne();pd();dq=U(pn()),Po=U(X());aa();fq=U(at()),_q=U(uq());Lr();rO=dt({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),xf=dt({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,fq.getWorkerIndex)()===0&&(async()=>{await _q.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of xf.search({})){let t=e.data,r=Object.assign({},e);r.user?.username&&(r.user=await st.getUser(r.user.username)),Tt(r,()=>{try{sO(r,t,r)}catch{(0,Po.warn)("Failed to publish will",t)}xf.delete(e.id,r)})}})();a(Eq,"getSession");sp=1;a(nO,"getNextMessageId");ip=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,d;if(c>-1?(l=s.slice(c),d=s.slice(0,c)):d=s,!d)throw new Error("No topic provided");if(d.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let u=this.subscriptions.find(g=>g.topic===s),f;u?(f=i>0,u.end(),this.subscriptions.splice(this.subscriptions.indexOf(u),1)):f=i===2;let E={search:l,async:!0,user:this.user,startTime:o,omitCurrent:f,url:""};o&&(0,Po.trace)("Resuming subscription from",s,"from",o);let _=mo.getMatch(d,"mqtt");if(!_){let g=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw g.statusCode=404,g}if(E.url=_.relativeURL,E.url.indexOf("+")>-1||E.url.indexOf("#")>-1){let g=E.url.slice(1);if(g.indexOf("#")>-1&&g.indexOf("#")!==g.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(E.isCollection=!0,g.indexOf("+")===g.length-1)E.onlyChildren=!0,E.url="/"+g.slice(0,g.length-1);else{let T=g.split("/"),A;for(let v=0;v<T.length;v++)if(T[v].indexOf("+")>-1)if(T[v]==="+")A=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&A)throw new Error("Filters can not be combined");let N=!0;T[T.length-1]==="#"&&(T.length--,N=!1),A&&(n=a(v=>{let J=v.id;if(!Array.isArray(J)||N&&J.length!==T.length)return!1;for(let $=0;$<T.length;$++)if(T[$]!=="+"&&T[$]!==J[$])return!1;return!0},"filter"));let V=T.indexOf("+");E.url="/"+(V>-1?T.slice(0,V):T).concat("").join("/")}}let h=_.path,p=_.Resource,S=await Tt(E,async()=>{let g=this.createContext();g.topic=s,g.retainHandling=i;let T=await p.subscribe(E,g);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 A of T)try{let N;if(A.type&&A.type!=="put"&&A.type!=="delete"&&A.type!=="message"&&A.type!=="patch"||n&&!n(A))continue;r?(A.topic=s,N=this.needsAcknowledge(A)):(A.acknowledge?.(),N=nO());let V=A.id;Array.isArray(V)&&(V=Vc(V)),V==null&&(V=""),this.listener(h+"/"+V,A.value,N,t)}catch(N){(0,Po.warn)(N)}})(),T});return S.topic=s,S.qos=t.qos,this.subscriptions.push(S),S}resume(){}needsAcknowledge(t){let r=nO();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(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return sO(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();Tt(r,async()=>{try{if(!t){let n=await xf.get(this.sessionId);n?.doesExist()&&await sO(n,n.data,r)}}finally{await xf.delete(this.sessionId)}}).catch(n=>{(0,Po.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(sO,"publish");iO=class extends ip{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=nO(),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,Po.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,dq.getNextMonotonicTime)()),(0,Po.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),rO.put(this.sessionRecord)}}});var aO={};Ze(aO,{bypassAuth:()=>Lle,start:()=>Ple});function Lle(){gq=!0}function Ple({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new Tq.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((d,u,f)=>{if(d.protocol==="mqtt"){o.events.emit("connection",d),Nr.debug?.("Received WebSocket connection for MQTT from",d._socket.remoteAddress);let{onMessage:E,onClose:_}=pq(d,(h,p)=>{if(d.send(h),p&&d._socket.writableNeedDrain)return new Promise(S=>this._socket.once("drain",S))},u,Promise.resolve(f).then(()=>u?.user),o);d.on("message",E),d.on("close",_),d.on("error",h=>{Nr.info?.("WebSocket error",h)})}},Object.assign({subProtocol:"mqtt"},n))),(t||s)&&c.push(e.socket(async d=>{let u;if(o.events.emit("connection",d),Nr.debug?.(`Received ${d.getCertificate?"SSL":"TCP"} connection for MQTT from ${d.remoteAddress}`),l){if(d.authorized)try{let _=l.user;if(_!==null){(_===void 0||_==="Common Name"||_==="CN")&&(_=d.getPeerCertificate().subject.CN);try{u=await e.getUser(_,null,null),(0,vl.get)(Ir.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ap.notify({username:u?.username,status:Ir.AUTH_AUDIT_STATUS.SUCCESS,type:Ir.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:d.remoteAddress})}catch(h){throw(0,vl.get)(Ir.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ap.error?.({username:_,status:Ir.AUTH_AUDIT_STATUS.FAILURE,type:Ir.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:d.remoteAddress}),h}}else Nr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",d.remoteAddress)}catch(_){o.events.emit("error",_,d),Nr.error?.(_)}else if(l.required)return Nr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${d.authorizationError}`),d.end()}!u&&gq&&d.remoteAddress.includes("127.0.0.1")&&(u=await(0,Sq.getSuperUser)(),Nr.debug?.("Auto-authorizing local connection",u?.username));let{onMessage:f,onClose:E}=pq(d,_=>d.write(_),null,u,o);d.on("data",f),d.on("close",E),d.on("error",_=>{Nr.info?.("Socket error",_)})},{port:t,securePort:s,mtls:l})),c}function pq(e,t,r,n,s){mq||(mq=!0,td(f=>{op>0&&f.push({metric:"mqtt-connections",connections:op,byThread:!0})}));let i;op++;let o,c={protocolVersion:4},l=(0,cp.parser)({protocolVersion:5});function d(f){l.parse(f)}a(d,"onMessage");function u(){op--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),wn(!1,"connection","mqtt","disconnect"),Nr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(u,"onClose"),l.on("packet",async f=>{n?.then&&(n=await n),o?.then&&await o;let E=f.topic,_=E?.indexOf("/",1),h=_>0?E.slice(0,_):E;Qr(f.length,"bytes-received",h,S(f),"mqtt");try{switch(o?.receivedPacket?.(),f.cmd){case"connect":if(c.protocolVersion=f.protocolVersion,f.username)try{n=await st.getUser(f.username,f.password.toString(),r),(0,vl.get)(Ir.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ap.notify({username:n?.username,status:Ir.AUTH_AUDIT_STATUS.SUCCESS,type:Ir.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch($){return(0,vl.get)(Ir.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ap.error?.({username:f.username,status:Ir.AUTH_AUDIT_STATUS.FAILURE,type:Ir.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",f,e,$),wn(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",f,e),wn(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(f,n),f.will){let $=e.deserialize||(e.deserialize=ka(r?.headers.get?.("content-type")));f.will.data=f.will.payload?.length>0?$(f.will.payload):void 0,delete f.will.payload}o=Eq({user:n,...f}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch($){return Nr.error?.($),s.events.emit("auth-failed",f,e,$),wn(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:$.code||5,returnCode:$.code||128})}s.events.emit("connected",o,e),wn(!0,"connection","mqtt","connect"),p({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener(($,F,ne,ee)=>{try{let Z=$.indexOf("/",1),le=Z>0?$.slice(0,Z):$;p({cmd:"publish",topic:$,payload:g(F),messageId:ne||Math.floor(Math.random()*1e8),qos:ee.qos},le)}catch(Z){Nr.error?.(Z),o?.disconnect(),s.sessions.delete(o)}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let T=[];for(let $ of f.subscriptions){let F;try{F=(await o.addSubscription($,$.qos>=1)).qos||0}catch(ne){s.events.emit("error",ne,e,$,o),Nr.error?.(ne),F=c.protocolVersion<5?128:ne.statusCode===403?135:ne.statusCode===404?143:128}T.push(F)}await o.committed,p({cmd:"suback",granted:T,messageId:f.messageId});break;case"unsubscribe":{let $=[];for(let F of f.unsubscriptions)$.push(o.removeSubscription(F)?0:17);p({cmd:"unsuback",granted:$,messageId:f.messageId});break}case"pubrel":p({cmd:"pubcomp",messageId:f.messageId,reasonCode:0});return;case"publish":let A=f.qos===2?"pubrec":"puback",N=e.deserialize||(e.deserialize=ka(r?.headers.get?.("content-type"))),v=(f.payload?.length||0)>0?N(f.payload):void 0,J;try{J=await o.publish(f,v)}catch($){s.events.emit("error",$,e,f,o),Nr.warn?.($),f.qos>0&&p({cmd:A,messageId:f.messageId,reasonCode:128},f.topic);break}f.qos>0&&p({cmd:A,messageId:f.messageId,reasonCode:J===!1?144:0},f.topic);break;case"pubrec":p({cmd:"pubrel",messageId:f.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(f.messageId);break;case"pingreq":p({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),wn(!0,"connection","mqtt","disconnect"),Nr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(T){s.events.emit("error",T,e,f,o),Nr.error?.(T),p({cmd:"disconnect"})}function p(T,A){let N=(0,cp.generate)(T,c);t(N),Qr(N.length,"bytes-sent",A,S(T),"mqtt")}a(p,"sendPacket");function S(T){return T.qos>0?T.cmd+",qos="+T.qos:T.cmd}a(S,"packetMethodName");function g(T){return Ua(T,r)}a(g,"serialize")}),l.on("error",f=>{Nr.warn("MQTT parsing error, closing connection:",f.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:d,onClose:u}}var cp,Sq,vl,Ir,oO,Tq,ap,Nr,gq,mq,op,Rq=Oe(()=>{cp=require("mqtt-packet");hq();Sq=U(yn());_l();bi();Lr();vl=U(ie()),Ir=U(B()),oO=U(hd()),Tq=require("events"),ap=(0,oO.loggerWithTag)("auth-event"),Nr=(0,oO.loggerWithTag)("mqtt"),gq=(0,vl.get)(Ir.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(Lle,"bypassAuth");a(Ple,"start");op=0;a(pq,"onSocket")});var rm={};Ze(rm,{component_errors:()=>Bl,loadComponent:()=>lp,loadComponentDirectories:()=>Cq,setErrorReporter:()=>xle});function Cq(e,t){t&&(lO=t),e&&(uO=e);let r=[];if((0,Rt.existsSync)(cO)){let s=(0,Rt.readdirSync)(cO,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,It.join)(cO,o);r.push(lp(c,lO,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(lp(n,lO,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{wq=!0})}function xle(e){Bf=e}async function lp(e,t,r,n,s,i){let o=(0,Rt.realpathSync)(e);if(!bq.has(o)){bq.set(o,!0),s&&(uO=s);try{let c;n&&(Bl=new Map);let l=(0,It.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,Rt.existsSync)(l)?c=n?(0,up.getConfigObj)():(0,yq.parseDocument)((0,Rt.readFileSync)(l,"utf8")).toJSON():c=dO;let d=(0,It.join)(e,"node_modules","harperdb");try{Wa.isMainThread&&(n||(0,Rt.existsSync)(d)&&(0,Rt.realpathSync)(kl.PACKAGE_ROOT)!==(0,Rt.realpathSync)(d))&&((0,Rt.rmSync)(d,{recursive:!0,force:!0}),(0,Rt.existsSync)((0,It.join)(e,"node_modules"))||(0,Rt.mkdirSync)((0,It.join)(e,"node_modules")),(0,Rt.symlinkSync)(kl.PACKAGE_ROOT,d,"dir"))}catch(f){xl.default.error("Error symlinking harperdb module",f)}let u=n;for(let f in c){let E=c[f];if(Bl.set(n?f:(0,It.basename)(e),!1),!E)continue;let _,h=E.package;try{if(h){let A=e,N;for(;!(0,Rt.existsSync)(N=(0,It.join)(A,"node_modules",f));)if(A=(0,It.dirname)(A),A.length<(0,Iq.getHdbBasePath)().length){N=null;break}if(N)_=await lp(N,t,r,!1),u=!0;else throw new Error(`Unable to find package ${f}:${h}`)}else _=vle[f];if(!_)continue;let p=a(A=>(A.origin=r,dt(A)),"ensureTable"),S=E.network||(E.port||E.securePort)&&E,g=S?.securePort||S?.https&&S.port,T=!S?.https&&S?.port;if(Wa.isMainThread&&(_=await _.startOnMainThread?.({server:st,ensureTable:p,port:T,securePort:g,resources:t,...E})||_,n&&S))for(let A of[T,g])try{if(+A&&!Aq.includes(A)){let N=fO.get(kl.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);N&&xl.default.warn("Session affinity is not recommended and may cause memory leaks"),(N||!Qm)&&(Aq.push(A),HG(A,N))}}catch(N){console.error("Error listening on socket",A,N,f)}if(t.isWorker&&(_=await _.start?.({server:st,ensureTable:p,port:T,securePort:g,resources:t,...E})||_),uO.set(_,!0),(_.handleFile||_.handleDirectory||_.setupFile||_.setupDirectory)&&E.files!=null){if(E.files.includes(".."))throw(0,Nq.handleHDBError)("Can not reference parent directories");let A=(0,It.join)(e,E.files).replace(/\\/g,"/"),N=A.indexOf("/*");if(N>-1&&E.files!==dO[f]?.files&&!(0,Rt.existsSync)(A.slice(0,N)))throw new Error(`The path '${A.slice(0,N)}' does not exist and cannot be used as the base of the resolved 'files' path value '${E.files}'`);let V=(0,It.basename)(e),v=E.path||"/";v=v.startsWith("/")?v:v.startsWith("./")?"/"+V+v.slice(2):v==="."?"/"+V:"/"+V+"/"+v;let J,$,F;if(E.root){let ee=E.root;ee.startsWith("/")&&(ee=ee.slice(1)),ee.endsWith("/")&&(ee=ee.slice(0,-1)),ee+="/",$=(0,It.join)(e,ee)}else(F=A.indexOf("/*"))>-1&&($=A.slice(0,F+1),J=(0,It.relative)(e,$));let ne=!1;if(Wa.isMainThread&&_.setupDirectory&&(ne=await _.setupDirectory?.(v,$,t)),t.isWorker&&_.handleDirectory&&(ne=await _.handleDirectory?.(v,$,t)),ne)continue;for(let ee of await(0,Oq.default)(A,{onlyFiles:!1,objectMode:!0})){let{path:Z,dirent:le}=ee;u=!0;let fe=(0,It.relative)(e,Z).replace(/\\/g,"/");if(J)if(fe.startsWith(J))fe=fe.slice(J.length+1);else throw new Error(`The root path '${E.root}' does not reference a valid part of the file path '${fe}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let je=v+(v.endsWith("/")?"":"/")+fe;try{if(le.isFile()){let ye=await Ule(Z);Wa.isMainThread&&await _.setupFile?.(ye,je,Z,t),t.isWorker&&await _.handleFile?.(ye,je,Z,t)}else Wa.isMainThread&&await _.setupDirectory?.(je,Z,t),t.isWorker&&await _.handleDirectory?.(je,Z,t)}catch(ye){ye.message=`Could not load ${le.isFile()?"file":"directory"} '${Z}'${E.module?" using '"+E.module+"'":""} for application '${e}' due to: ${ye.message}`,Bf?.(ye),((0,Hl.getWorkerIndex)()===0?console:xl.default).error(ye),t.set(E.path||"/",new Hf(ye)),Bl.set(n?f:(0,It.basename)(e),ye.message)}}}}catch(p){p.message=`Could not load component '${f}' for application '${(0,It.basename)(e)}' due to: ${p.message}`,Bf?.(p),((0,Hl.getWorkerIndex)()===0?console:xl.default).error(p),t.set(E.path||"/",new Hf(p),null,!0),Bl.set(n?f:(0,It.basename)(e),p.message)}}if(Wa.isMainThread&&!wq&&i&&(0,Hl.watchDir)(e,async()=>Cq()),c.extensionModule)return await b_((0,It.join)(e,c.extensionModule));if(!u&&t.isWorker){let f=`${e} did not load any modules, resources, or files, is this a valid component?`;Bf?.(new Error(f)),((0,Hl.getWorkerIndex)()===0?console:xl.default).error(f),Bl.set((0,It.basename)(e),f)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,Bf?.(c),t.set("",new Hf(c))}}}var Rt,It,Wa,yq,fO,kl,Oq,Hl,xl,Nq,Iq,Mle,up,Ule,cO,uO,wq,lO,Bl,vle,dO,Aq,bq,Bf,Hf,nm=Oe(()=>{Rt=require("fs"),It=require("path"),Wa=require("worker_threads"),yq=require("yaml"),fO=U(ie()),kl=U(B());NI();DI();LI();vk();NG();PG();Oq=U(require("fast-glob")),Hl=U(at()),xl=U(X());pS();Lr();Nq=U(ce());Ne();kG();Iq=U(ie()),Mle=U($G());Wh();Ky();Oi();Rq();up=U(dr());zm();({readFile:Ule}=Rt.promises),cO=(0,up.resolvePath)(fO.get(kl.CONFIG_PARAMS.COMPONENTSROOT)),uO=new Map,Bl=new Map;a(Cq,"loadComponentDirectories");vle={REST:Rm,rest:Rm,graphqlSchema:mS,jsResource:TS,fastifyRoutes:Ly,login:RS,static:Py,operationsApi:Mle,customFunctions:{},http:{},clustering:Zm,replication:Od,authentication:Zd,mqtt:aO},dO={rest:!0,graphqlSchema:{files:"*.graphql"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(dO,"static",{value:{files:"web/**"}});Aq=[],bq=new Map;a(xle,"setErrorReporter");a(lp,"loadComponent");Hf=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var tO=I((vbe,Lq)=>{var{isMainThread:Dq}=require("worker_threads"),{getTables:Ble,getDatabases:Mbe,table:Ube}=(Ne(),ae(it)),{loadComponentDirectories:Hle,loadComponent:kle}=(nm(),ae(rm)),{resetResources:Fle}=(pd(),ae(Pv)),Gle=fb(),qle=dr(),{dirname:Vle}=require("path"),{getConnection:$le}=jt(),Yle=ie(),{CONFIG_PARAMS:Kle}=B(),{loadCertificates:Wle}=go(),_O=new Map;async function Qle(e=!1){!Dq&&Yle.get(Kle.CLUSTERING_ENABLED)&&$le();try{Dq&&await Gle()}catch(n){console.error(n)}let t=Fle();Ble(),t.isWorker=e,await Wle(),await kle(Vle(qle.getConfigFilePath()),t,"hdb",!0,_O),await Hle(_O,t);let r=[];for(let[n]of _O)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(Qle,"loadRootComponents");Lq.exports.loadRootComponents=Qle});var at=I((Bbe,Ns)=>{"use strict";var{Worker:zle,MessageChannel:jle,parentPort:ii,isMainThread:SO,threadId:Jle,workerData:oi}=require("worker_threads"),{PACKAGE_ROOT:Xle}=B(),{join:vq,isAbsolute:Zle,extname:eue}=require("path"),{server:xq}=(Lr(),ae(Fo)),{watch:tue,readdir:rue}=require("fs/promises"),{totalmem:Pq}=require("os"),kf=B(),Bq=ie(),ai=X(),{randomBytes:nue}=require("crypto"),{_assignPackageExport:sue}=require("../../index"),iue=B(),Mq=1024*1024,Mo=[],ns=[],oue=50,TO=1e4,aue="restart",Hq="request_thread_info",kq="resource_report",Fq="thread_info",Gq="added-port",cue="ack",EO;sue("threads",ns);Ns.exports={startWorker:hO,restartWorkers:RO,shutdownWorkers:_ue,workers:Mo,setMonitorListener:Rue,onMessageFromWorkers:Eue,onMessageByType:Qq,broadcast:mue,broadcastWithAcknowledgement:Sue,setChildListenerByType:fue,getWorkerIndex:qq,getWorkerCount:Vq,getTicketKeys:Yq,setMainIsWorker:uue,setTerminateTimeout:lue,restartNumber:oi?.restartNumber||1};ns.onMessageByType=Qq;ns.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=ns.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};Ns.exports.whenThreadsStarted=new Promise(e=>{Ns.exports.threadsHaveStarted=e});var gO;function lue(e){TO=e}a(lue,"setTerminateTimeout");function qq(){return oi?oi.workerIndex:gO?0:void 0}a(qq,"getWorkerIndex");function Vq(){return oi?oi.workerCount:gO?1:void 0}a(Vq,"getWorkerCount");function uue(e){gO=e,Ns.exports.threadsHaveStarted()}a(uue,"setMainIsWorker");var $q=1,dp;function Yq(){return dp||(dp=SO?nue(48):oi.ticketKeys,dp)}a(Yq,"getTicketKeys");Object.defineProperty(xq,"workerIndex",{get(){return qq()}});Object.defineProperty(xq,"workerCount",{get(){return Vq()}});var Kq={[Hq](e,t){Tue(t)},[kq](e,t){gue(t,e)}};function hO(e,t={}){let r=process.constrainedMemory?.()||Pq();r=Math.min(r,Pq(),2e4*Mq);let n=Bq.get(kf.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/Mq/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of ns){let d=new jle;d.existingPort=l,i.push(d),o.push(d.port2)}eue(e)||(e+=".js");let c=new zle(Zle(e)?e:vq(Xle,e),Object.assign({resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:$q=t.threadCount,name:t.name,restartNumber:Ns.exports.restartNumber,ticketKeys:Yq()},transferList:o},t));for(let{port1:l,existingPort:d}of i)d.postMessage({type:Gq,port:l,threadId:c.threadId},[l]);return _p(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>hO(e,t),c.on("error",l=>{ai.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{Mo.splice(Mo.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<oue?(t.unexpectedRestarts=c.unexpectedRestarts+1,hO(e,t)):ai.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{Kq[l.type]?.(l,c)}),Mo.push(c),bue(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(hO,"startWorker");var due=[kf.THREAD_TYPES.HTTP];async function RO(e=null,t=Math.max($q>3,1),r=!0){if(SO){if(r){let{loadRootComponents:o}=tO();await o()}Ns.exports.restartNumber++,t<1&&(t=t*Mo.length);let n=[],s=[];for(let o of Mo.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;ai.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Ns.exports.restartNumber,type:kf.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=due.indexOf(o.name)>-1,l=new Promise(d=>{let u=setTimeout(()=>{ai.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},TO*2).unref();o.on("exit",()=>{clearTimeout(u),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),d()})});if(n.push(l),c&&r){let d=o.startCopy(),u=new Promise(f=>{let E=a(_=>{_.type===iue.ITC_EVENT_TYPES.CHILD_STARTED&&(ai.trace("Worker has started",d.threadId),f(),s.splice(s.indexOf(u)),d.off("message",E))},"startListener");ai.trace("Waiting for worker to start",d.threadId),d.on("message",E)});s.push(u),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}=jd();r&&(e==="http"||!e)&&Bq.get(kf.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else ii.postMessage({type:aue,workerType:e})}a(RO,"restartWorkers");function fue(e,t){Kq[e]=t}a(fue,"setChildListenerByType");function _ue(e){return RO(e,1/0,!1)}a(_ue,"shutdownWorkers");var Wq=[];function Eue(e){Wq.push(e)}a(Eue,"onMessageFromWorkers");var mO=new Map;function Qq(e,t){let r=mO.get(e);r||mO.set(e,r=[]),r.push(t)}a(Qq,"onMessageByType");var hue=10;async function mue(e,t){let r=0;for(let n of ns)try{n.postMessage(e),r++>hue&&(r=0,await new Promise(setImmediate))}catch(s){ai.error("Unable to send message to worker",s)}t&&jq(e,null)}a(mue,"broadcast");var fp=new Map,pue=1;function Sue(e){return new Promise(t=>{let r=0;for(let n of ns)try{let s=pue++,i=a(()=>{fp.delete(s),--r===0&&t(),n!==ii&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,fp.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of fp)o.port===n&&o()})),n.postMessage(e),r++}catch(s){ai.error("Unable to send message to worker",s)}r===0&&t()})}a(Sue,"broadcastWithAcknowledgement");function Tue(e){e.postMessage({type:Fq,workers:zq()})}a(Tue,"sendThreadInfo");function zq(){let e=Date.now();return Mo.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(zq,"getChildWorkerInfo");function gue(e,t){e.resources=t,e.resources.updated=Date.now()}a(gue,"recordResourceReport");var pO;function Rue(e){pO=e}a(Rue,"setMonitorListener");var Aue=1e3,Uq=!1;function bue(){Uq||(Uq=!0,setInterval(()=>{for(let e of Mo){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}pO&&pO()},Aue).unref())}a(bue,"startMonitoring");var yue=1e3;if(ii&&oi.addPorts){_p(ii);for(let e=0,t=oi.addPorts.length;e<t;e++){let r=oi.addPorts[e];r.threadId=oi.addThreadIds[e],_p(r)}setInterval(()=>{let e=process.memoryUsage();ii.postMessage({type:kq,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},yue).unref(),EO=a(()=>new Promise((e,t)=>{ii.on("message",r),ii.postMessage({type:Hq});function r(n){n.type===Fq&&(ii.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else EO=zq;Ns.exports.getThreadInfo=EO;function _p(e,t){ns.push(e),e.on("message",r=>{if(r.type===Gq)r.port.threadId=r.threadId,_p(r.port);else if(r.type===cue){let n=fp.get(r.id);n&&n()}else jq(r,e)}).on("close",()=>{ns.splice(ns.indexOf(e),1)}).on("exit",()=>{ns.splice(ns.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(_p,"addPort");function jq(e,t){for(let n of Wq)n(e,t);let r=mO.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){ai.error(s)}}a(jq,"notifyMessageListeners");if(SO){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await rue(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(vq(s,o.name));try{for await(let{filename:o}of tue(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await RO(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");Ns.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else ii.on("message",async e=>{let{type:t}=e;t===kf.ITC_EVENT_TYPES.SHUTDOWN&&(Ns.exports.restartNumber=e.restartNumber,ii.unref(),setTimeout(()=>{ai.warn("Thread did not voluntarily terminate",Jle),process.exit(0)},TO).unref())})});var TP={};Ze(TP,{AUDIT_STORE_OPTIONS:()=>Kd,Decoder:()=>zc,HAS_CURRENT_RESIDENCY_ID:()=>Yo,HAS_EXPIRATION_EXTENDED_TYPE:()=>gu,HAS_ORIGINATING_OPERATION:()=>Tu,HAS_PREVIOUS_RESIDENCY_ID:()=>Ko,REMOTE_SEQUENCE_UPDATE:()=>dh,createAuditEntry:()=>uc,getLastRemoved:()=>cA,openAuditStore:()=>Sp,readAuditEntry:()=>Lt,setAuditRetention:()=>Nue,transactionKeyEncoder:()=>aV});function Sp(e){let t=e.auditStore=e.openDB(AO.AUDIT_STORE_NAME,Object.assign({create:!1},Kd));t||(t=e.auditStore=e.openDB(AO.AUDIT_STORE_NAME,Kd),Xq(t,1)),t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,{remove(){delete r[i]}}};let n=null;function s(i=Ep){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let o=0,c,l;try{for(let{key:d,value:u}of t.getRange({start:1,snapshot:!1,end:Date.now()-bO})){if((u[0]&15)===yO){let f=Lt(u),E=f.tableId;r[E]?.(f.recordId)}if(c=t.remove(d),l=d,await new Promise(setImmediate),++o>=Oue){i=10;break}}await c}finally{o===0?i=Math.min(i<<1,bO/10):Xq(t,l),s(i)}},i).unref()}if(a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,Gf.getWorkerIndex)()===(0,Gf.getWorkerCount)()-1&&s(Ep),(0,Gf.getWorkerIndex)()===0&&!Jq)for(let i of t.getKeys({reverse:!0,limit:1}))i>Date.now()&&(Jq=!0,pp.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function Xq(e,t){OO[0]=t,e.put(Symbol.for("last-removed"),cV)}function cA(e){let t=e.get(Symbol.for("last-removed"));if(t)return cV.set(t),OO[0]}function Nue(e,t=Ep){bO=e,Ep=t}function uc(e,t,r,n,s,i,o,c,l,d,u,f,E){let _=lV[o];if(!_)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?Uo.setFloat64(0,n):ss.set(HS),h=9),l){if(l&16761087)throw new Error("Illegal extended type");h++}g(s),g(t),S(r),Uo.setFloat64(h,e),h+=8,l&Yo&&g(d),l&Ko&&g(u),l&gu&&(Uo.setFloat64(h,f),h+=8),l&Tu&&g(uV[E]),i?S(i):ss[h++]=0,l?Uo.setUint16(n?8:0,_|l|32768):ss[n?8:0]=_;let p=ss.subarray(0,h);if(c)return Buffer.concat([p,c]);return p;function S(T){let A=h;h+=1,h=(0,Fl.writeKey)(T,ss,h);let N=h-A-1;N>127?N>16383?(pp.error("Key or username was too large for audit entry",T),h=A+1,ss[A]=0):(ss.copyWithin(A+2,A+1,h),Uo.setUint16(A,N|32768),h++):ss[A]=N}function g(T){T<128?ss[h++]=T:T<16384?(Uo.setUint16(h,T|32768),h+=2):T<1056964608?(Uo.setUint32(h,T|3221225472),h+=4):(ss[h]=255,Uo.setUint32(h+1,T),h+=5)}}function Lt(e){try{let t=e.dataView||(e.dataView=new zc(e.buffer,e.byteOffset,e.byteLength)),r;e[t.position]==66&&(r=t.readFloat64());let n=t.readInt(),s=t.readInt(),i=t.readInt(),o=t.readInt(),c=t.position,l=t.position+=o,d=t.readFloat64(),u,f,E,_;if(n&Yo&&(u=t.readInt()),n&Ko&&(f=t.readInt()),n&gu&&(E=t.readFloat64()),n&Tu){let S=t.readInt();_=uV[S]}o=t.readInt();let h=t.position,p=t.position+=o;return{type:lV[n&7],tableId:i,nodeId:s,get recordId(){return sV(e,c,l)},getBinaryRecordId(){return e.subarray(c,l)},version:d,previousLocalTime:r,get user(){return p>h?sV(e,h,p):void 0},encoded:e,getValue(S,g,T){if(n&hp||n&Ff&&!g)return S.decoder.decode(e.subarray(t.position));if(n&Ff&&T)return NO(S.getEntry(this.recordId),T,S)},getBinaryValue(){return n&(hp|Ff)?e.subarray(t.position):void 0},extendedType:n,residencyId:u,previousResidencyId:f,expiresAt:E,originatingOperation:_}}catch(t){return pp.error("Reading audit entry error",t,e),{}}}function sV(e,t,r){let n=e.subarray(t,r);return(0,Fl.readKey)(n,0,r-t)}var Fl,mp,AO,iV,Gf,oV,pp,ss,Uo,aV,Kd,bO,Oue,OO,cV,Ep,Jq,hp,Ff,Zq,yO,eV,tV,rV,nV,dh,Yo,Ko,Tu,gu,lV,uV,zc,Ei=Oe(()=>{Fl=require("ordered-binary"),mp=U(ie()),AO=U(Ft()),iV=U(B()),Gf=U(at()),oV=U(te());dc();pp=U(X());Tp();(0,mp.initSync)();ss=Buffer.alloc(1024),Uo=new DataView(ss.buffer,ss.byteOffset,1024),aV={writeKey(e,t,r){return e===Su?(t.set(Su,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Fl.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,Fl.readKey)(e,t,r)}},Kd={encoding:"binary",keyEncoder:aV},bO=(0,oV.convertToMS)((0,mp.get)(iV.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,Oue=1e3,OO=new Float64Array(1),cV=new Uint8Array(OO.buffer),Ep=1e4,Jq=!1;a(Sp,"openAuditStore");a(Xq,"updateLastRemoved");a(cA,"getLastRemoved");a(Nue,"setAuditRetention");hp=16,Ff=32,Zq=1,yO=2,eV=3,tV=4,rV=5,nV=6,dh=11,Yo=512,Ko=1024,Tu=2048,gu=4096,lV={put:Zq|hp,[Zq]:"put",delete:yO,[yO]:"delete",message:eV|hp,[eV]:"message",invalidate:tV|Ff,[tV]:"invalidate",patch:rV|Ff,[rV]:"patch",relocate:nV,[nV]:"relocate"},uV={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(uc,"createAuditEntry");a(Lt,"readAuditEntry");zc=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;try{t=this.getUint8(this.position++)}catch(r){throw r}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(sV,"readKeySafely")});var IO={};Ze(IO,{add:()=>gp,applyReverse:()=>dV,getRecordAtTime:()=>NO,rebuildUpdateBefore:()=>Rp});function gp(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function Rp(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,gp(r,n,s)}}else r||(r={}),r[n]=e[n];return r}function dV(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Iue[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=fV}}function NO(e,t,r){let n=r.rootStore.auditStore,s=Object.assign({},e.value),i=e.localTime;for(;i>t;){let l=n.get(i),d=Lt(l);switch(d.type){case"put":s=d.getValue(r);break;case"patch":dV(s,d.getValue(r));break;case"delete":s=null}i=d.previousLocalTime}let o={},c=0;for(let l in s)s[l]===fV&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),d=Lt(l),u;switch(d.type){case"put":u=d.getValue(r);break;case"patch":u=d.getValue(r);break}for(let f in u)o[f]&&(s[f]=u[f],o[f]=!1,c--);i=d.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var Iue,fV,Tp=Oe(()=>{Ei();a(gp,"add");gp.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};Iue={add:gp};a(Rp,"rebuildUpdateBefore");a(dV,"applyReverse");fV={};a(NO,"getRecordAtTime")});function Un(e){return e[tr]||(e[tr]=Object.create(null))}function Np(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,l,d;if(o.resolve)d={get(){return o.resolve(this,this[Me])},set(u){return o.set(this,u)},configurable:!0};else{switch(o.type){case"String":l=a(function(u){if(!(typeof u=="string"||u==null&&o.nullable!==!1))throw new is.ClientError(`${c} must be a string, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"ID":l=a(function(u){if(!(typeof u=="string"||u?.length>0&&u.every?.(f=>typeof f=="string")||u==null&&o.nullable!==!1))throw new is.ClientError(`${c} must be a string, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"Float":case"Number":l=a(function(u){let f=u?.__op__?u.value:u;if(!(typeof f=="number"||u==null&&o.nullable!==!1))throw new is.ClientError(`${c} must be a number, attempt to assign ${f}`);Un(this)[c]=u},"set");break;case"Int":l=a(function(u){let f=u?.__op__?u.value:u;if(!(f>>0===f||u==null&&o.nullable!==!1))if(typeof f=="number"&&Math.abs((f>>0)-f)<=1)f=Math.round(f),u?.__op__?u.value=f:u=f;else throw new is.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"Long":l=a(function(u){let f=u?.__op__?u.value:u;if(!(Math.round(f)===u&&Math.abs(f)<=9007199254740992||u==null&&o.nullable!==!1))if(typeof f=="number"&&Math.abs(f)<=9007199254740992)f=Math.round(f),u?.__op__?u.value=f:u=f;else throw new is.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"BigInt":l=a(function(u){let f=u?.__op__?u.value:u;if(!(typeof f=="bigint"||u==null&&o.nullable!==!1))if(typeof f=="string"||typeof f=="number")f=BigInt(f),u?.__op__?u.value=f:u=f;else throw new is.ClientError(`${c} must be a number, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"Boolean":l=a(function(u){if(!(typeof u=="boolean"||u==null&&o.nullable!==!1))throw new is.ClientError(`${c} must be a boolean, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"Date":l=a(function(u){if(!(u instanceof Date||u==null&&o.nullable!==!1))if(typeof u=="string"||typeof u=="number")u=new Date(u);else throw new is.ClientError(`${c} must be a Date, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"Bytes":l=a(function(u){if(!(u instanceof Uint8Array||u==null&&o.nullable!==!1))throw new is.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"Any":case void 0:l=a(function(u){Un(this)[c]=u},"set");break;default:l=a(function(u){if(!(typeof u=="object"||u==null&&o.nullable!==!1))throw new is.ClientError(`${c} must be an object, attempt to assign ${u}`);Un(this)[c]=u},"set")}d={get(){let u=this[tr];if(u&&c in u){let E=u[c];if(E?.__op__){let _=this[Ce]?.[c];return E.update(_)}return E}let f=this[Ce]?.[c];if(f&&typeof f=="object"){let E=EV(f,o);if(E)return u||(u=this[tr]=Object.create(null)),u[c]=E}return f},set:l,enumerable:!0,configurable:!0}}d.get.isAttribute=!0,n[c]=d,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,d)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let l=this[tr];return l?.[o]!==void 0?l[o]:this[Ce]?.[o]}),i("set",function(o,c){let l=n[o];if(l)return l.set.call(this,c);if(t.sealed)throw new is.ClientError("Can not add a property to a sealed table schema");Un(this)[o]=c}),i("deleteProperty",function(o){Un(this)[o]=void 0}),i("toJSON",function(){let o=this[tr],c;for(let d in o){c||(c=Object.assign({},this[Ce]));let u=o[d];if(u?.__op__){let f=c[d];u=u.update(f)}c[d]=u}return Object.keys(this).length>0&&(c||(c=Object.assign({},this[Ce])),Object.assign(c,this)),c||this[Ce]}),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 EV(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?.[Ce])throw new Error("Can not track an already tracked object, check for circular references");this[Ce]=s}},Np(r,t)),new r(e)):new Ap(e);case Array:let n=new yp(e.length);n[Ce]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=EV(o,t?.elements)),n[s]=o}return n;default:return e}}function SE(e){let t=e[tr],r;for(let s in t){r||(r=Object.assign({},e[Ce]));let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=SE(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=Object.assign({},e[Ce])),Object.assign(r,e)),r||e[Ce]}function za(e,t=e[tr]){let r;if(_V.call(e,Ce)&&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=za(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[Ce]));let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=IO[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=za(s);r[n]=s}return r?Object.freeze(r):_V.call(e,Ce)?e[Ce]:e}function bp(e){let t=e[Ce];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[Qa]||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?.[Ce]===s){if(bp(i))return!0}else return!0}}else{let r=e[tr];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[Ce]===i){if(bp(s))return!0}else return!0}else return!0}}return!1}var is,tr,Ap,_V,Qa,yp,Op,TE=Oe(()=>{us();is=U(ce());Tp();tr=Symbol("own-data");a(Un,"getChanges");a(Np,"assignTrackedAccessors");a(EV,"trackObject");Ap=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[Ce])throw new Error("Can not track an already tracked object, check for circular references");this[Ce]=t}};Np(Ap,{});a(SE,"collapseData");_V=Object.prototype.hasOwnProperty;a(za,"deepFreeze");a(bp,"hasChanges");Qa=Symbol.for("has-array-changes"),yp=class extends Array{static{a(this,"TrackedArray")}[Qa];constructor(t){super(t)}splice(...t){return this[Qa]=!0,super.splice(...t)}push(...t){return this[Qa]=!0,super.push(...t)}pop(){return this[Qa]=!0,super.pop()}unshift(...t){return this[Qa]=!0,super.unshift(...t)}shift(){return this[Qa]=!0,super.shift()}};yp.prototype.constructor=Array;Op=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var ng={};Ze(ng,{CONTEXT:()=>Me,ID_PROPERTY:()=>We,IS_COLLECTION:()=>Is,RECORD_PROPERTY:()=>Ce,Resource:()=>pr,snake_case:()=>Cue,transformForSelect:()=>wp});function Cue(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function hV(e,t){if(qf=!1,e==="")return null;if(e=e.slice(1),e.indexOf("/")===-1)return e===""?(qf=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new CO;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){qf=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}function vn(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,d,u;if(r?(o?(u=i,o=o[Me]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(u=s,c=u[this.primaryKey]??null,o=i[Me]||i):u=i:(u=s,s=void 0,c=u[We]??u[this.primaryKey]),c===null&&(d=!0)):i?o=i[Me]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string"){let _=c.indexOf("?");if(_>-1){let p=this.parseQuery(c.slice(_+1));l?l=Object.assign(p,l):l=p,c=c.slice(0,_)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),d=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],d=!0;for(let _ of s){if(typeof _=="object"&&_)break;c.push(_)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,d=!1)))}c===void 0&&(c=s.id??null,c==null&&(d=!0))}else c=s,l=new Fa(c),c===null&&(d=!0);o||(o={});let f;if(l?.ensureLoaded!=null||l?.async||d?(f=Object.assign({},t),l?.ensureLoaded!=null&&(f.ensureLoaded=l.ensureLoaded),l?.async&&(f.async=l.async),d&&(f.isCollection=!0)):f=t,o.transaction){let _=this.getResource(c,o,f);return _.then?_.then(E):E(_)}else return Tt(o,()=>{let _=this.getResource(c,o,f);return _.then?_.then(E):E(_)},f);function E(_){if(o.authorize){o.authorize=!1;let h=t.type==="read"?_.allowRead(o.user,l,o):t.type==="update"?_.doesExist?.()===!1?_.allowCreate(o.user,u,o):_.allowUpdate(o.user,u,o):t.type==="create"?_.allowCreate(o.user,u,o):_.allowDelete(o.user,l,o);if(h?.then)return h.then(p=>{if(!p)throw new Ip(o.user);return typeof u?.then=="function"?u.then(S=>e(_,l,o,S)):e(_,l,o,u)});if(!h)throw new Ip(o.user)}return typeof u?.then=="function"?u.then(h=>e(_,l,o,h)):e(_,l,o,u)}a(E,"authorizeActionOnResource")}}function xn(e,t){let r=new SV.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 wO(e,t,r){let n=e[Ce];if(n){let s=e[tr];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 wp(e,t){let r=t?.propertyResolvers,n=t[Me],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):wO(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let d=[],u=i(wO(l,r,n));for(let f of e)d.push(u(f));return d},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(E=>E&&typeof E=="object"?c(E):E);let d={},u=i(wO(l,r,n)),f;for(let E of e){let _=u(E);_===void 0&&o&&(_=null),_?.then?(f||(f=[]),f.push(_.then(h=>d[E.name||E]=h))):d[E.name||E]=_}return f?Promise.all(f).then(()=>d):d},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let u=r[c.name]?.definition?.tableClass;l=s[c.name]=wp(c.select||c,u)}let d=o(c.name);return l(d)}else return o(c);else return c}}a(i,"handleProperty")}var mV,pV,SV,Me,We,Is,Ce,wue,pr,Ip,qf,CO,us=Oe(()=>{mV=require("crypto");cc();pV=require("../../index"),SV=U(ce());TE();aa();Sf();Me=Symbol.for("context"),We=Symbol.for("primary-key"),Is=Symbol("is-collection"),Ce=Symbol("stored-record"),wue={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},pr=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[We]=t;let n=r?.[Me];this[Me]=n!==void 0?n:r||null}static get=vn(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let d=wp(l,t.constructor);return typeof c?.map=="function"?c.map(d):d(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=vn(function(t,r,n,s){if(Array.isArray(s)&&t[Is]){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,d=l.getResource(c[l.primaryKey],n,{async:!0});d.then?i.push(d.then(u=>u.put(c,n))):i.push(d.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):xn(t,"put")},{hasContent:!0,type:"update"});static patch=vn(function(t,r,n,s){return t.patch?t.patch(s,r):xn(t,"patch")},{hasContent:!0,type:"update"});static delete=vn(function(t,r,n,s){return t.delete?t.delete(r):xn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,mV.randomUUID)()}static create(t,r,n){let s;return t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),n||(n={}),Tt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):xn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=vn(function(t,r,n,s){return t.invalidate?t.invalidate(r):xn(t,"delete")},{hasContent:!1,type:"update"});static post=vn(function(t,r,n,s){return t[We]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=vn(function(t,r,n,s){return t.connect?t.connect(s,r):xn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=vn(function(t,r,n,s){return t.subscribe?t.subscribe(r):xn(t,"subscribe")},{type:"read"});static publish=vn(function(t,r,n,s){return t[We]!=null&&t.update?.(),t.publish?t.publish(s,r):xn(t,"publish")},{hasContent:!0,type:"create"});static search=vn(function(t,r,n,s){let i=t.search?t.search(r):xn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=wp(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=vn(function(t,r,n,s){return t.search?t.search(s,r):xn(t,"search")},{hasContent:!0,type:"read"});static copy=vn(function(t,r,n,s){return t.copy?t.copy(s,r):xn(t,"copy")},{hasContent:!0,type:"create"});static move=vn(function(t,r,n,s){return t.move?t.move(s,r):xn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this[Is])return(await this.constructor.create(this[We],t,this[Me]))[We];xn(this,"post")}static isCollection(t){return t?.[Is]}static coerceId(t){return t}static parseQuery(t){return Tm(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&&wue[o];if(c)r.headers.set("accept",c);else if(n)n.property=o;else return{query:{property:o},id:hV(t,this),isCollection:qf}}let i=hV(t,this);return qf?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[Me],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let d=l.asMap.get(t);if(s=d?.find(u=>u.constructor===c),s)return s;d||l.asMap.set(t,d=[]),d.push(s=new c(t,i))}else{if(s=l.find(d=>d[We]===t&&d.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let d=new Map;for(let u of l){let f=u[We],E=d.get(f);E?E.push(u):d.set(f,[u])}i.resourceCache.length=0,i.resourceCache.asMap=d}}}else s=new c(t,i);return o&&(s[Is]=!0),s}subscribe(t){return new Sn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Sn}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[We]}getContext(){return this[Me]}};pr.prototype[Me]=null;(0,pV._assignPackageExport)("Resource",pr);a(Cue,"snake_case");Ip=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(hV,"pathToId");CO=class extends Array{static{a(this,"MulitPartId")}toString(){return this.join("/")}};a(vn,"transactional");a(xn,"missingMethod");a(wO,"selectFromObject");a(wp,"transformForSelect")});var Ey={};Ze(Ey,{coerceType:()=>Cp,makeTable:()=>Pp,setServerUtilities:()=>Hue,updateResource:()=>Dp});function Pp(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:d,dbisDB:u,sealed:f,replicate:E}=e,{expirationMS:_,evictionMS:h,audit:p,trackDeletes:S}=e,{attributes:g}=e;g||(g=[]);let T=GS(i,n,l),A,N,V={},v=Promise.resolve(),J,$,F;for(let q of g)(q.assignCreatedTime||q.name==="__createdtime__")&&(J=q),(q.assignUpdatedTime||q.name==="__updatedtime__")&&($=q),q.expiresAt&&(F=q),q.isPrimaryKey&&(V=q);let ne,ee=[],Z=[],le=1,fe=2,je={},ye={},Ht=864e5,Bo,rc,Gr,Kl=!1,$i,Yi,Cs=new Map,Ds=new Map,Ct,Gp,dn=Gl.get(os.CONFIG_PARAMS.REPLICATION_DATABASES);if(Array.isArray(dn)){for(let q of dn)if(q.name===c&&q.replicateTo>=0){Gp=q.replicateTo;break}}let r_=i.getRange({start:!1,end:!1}).constructor,n_=10,Wl=6;p&&tt();class ve extends pr{static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=p;static databasePath=o;static databaseName=c;static attributes=g;static replicate=E;static sealed=f;static createdTimeProperty=J;static updatedTimeProperty=$;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return _}static dbisDB=u;static schemaDefined=d;static sourcedFrom(m,R){if(R&&(this.sourceOptions=R,(R.expiration||R.eviction||R.scanInterval)&&this.setTTLExpiration(R)),R?.intermediateSource)m.intermediateSource=!0,this.sources.unshift(m);else{if(this.sources.some(C=>!C.intermediateSource))throw new Error("Can not have multiple canonical (non-intermediate) sources");this.sources.push(m)}N=N||m.get&&(!m.get.reliesOnPrototype||m.prototype.get),A=A||m.load;let w=a(C=>{let O=this.sources;if(O=O.filter(P=>P.intermediateSource&&P[C]&&(!P[C].reliesOnPrototype||P.prototype[C])),O.length>0)if(O.length===1){let P=O[0];return(M,L,H)=>{if(M?.source!==P)return P[C](L,H,M)}}else return(P,M,L)=>{let H=[];for(let Y of O){if(P?.source===Y)break;H.push(Y[C](M,L,P))}return Promise.all(H)}},"getApplyToIntermediateSource"),b=this.sources[this.sources.length-1];b.intermediateSource&&(b={});let y=a(C=>{if(b[C]&&(!b[C].reliesOnPrototype||b.prototype[C]))return(O,P,M)=>{if(!O?.source)return b[C](P,M,O)}},"getApplyToCanonicalSource");return je={put:y("put"),patch:y("patch"),delete:y("delete"),publish:y("publish")},ye={put:w("put"),patch:w("patch"),delete:w("delete"),publish:w("publish"),invalidate:w("invalidate")},(async()=>{let C=!1,O,P=a(async(M,L)=>{let H=M.value,Y=M.table?Ve[c][M.table]:ve;if(c===os.SYSTEM_SCHEMA_NAME&&(M.table===os.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||M.table===os.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(C=!0),M.id===void 0&&(M.id=H[Y.primaryKey],M.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(M));M.source=m;let K={residencyId:Dt(M.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:M.nodeId},Te=await Y.getResource(M.id,L,K);switch(M.type){case"put":return Te._writeUpdate(H,!0,K);case"patch":return Te._writeUpdate(H,!1,K);case"delete":return Te._writeDelete(K);case"publish":return Te._writePublish(H,K);case"invalidate":return Te._writeInvalidate(K);case"relocate":return Te._writeRelocate(K);default:qe.default.error?.("Unknown operation",M.type,M.id)}},"writeUpdate");try{let M=m.subscribe;M&&S==null&&(S=!0);let L=m.subscribeOnThisThread?m.subscribeOnThisThread((0,Xa.getWorkerIndex)()):(0,Xa.getWorkerIndex)()===0,H=M&&L&&await m.subscribe?.({crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0});if(H){let Y;for await(let K of H)try{if(!(K.type==="transaction"?K.writes[0]:K)){qe.default.error?.("Bad subscription event",K);continue}if(K.source=m,K.type==="end_txn"){if(Y?.resolve(),K.localTime&&O!==K.localTime){if(K.remoteNodeIds?.length>0){let Ie=[Symbol.for("seq"),K.remoteNodeIds[0]],he=u.get(Ie),De=he?.nodes;De||(De=[]);for(let k of K.remoteNodeIds.slice(1)){let se=De.find(ue=>ue.name===k);se||(se={id:k,seqId:0},De.push(se)),se.seqId=Math.max(he?.seqId??1,K.localTime),k===K.nodeId&&(se.lastTxnTime=K.timestamp)}let x=Math.max(he?.seqId??1,K.localTime);u.put(Ie,{seqId:x,nodes:De})}O=K.localTime}K.onCommit&&Y?.committed.then(K.onCommit);continue}if(Y)if(K.beginTxn)Y.resolve();else{Y.write_promises.push(P(K,Y));continue}let j=Tt(K,()=>{if(K.type==="transaction"){let Ie=[];for(let he of K.writes)try{Ie.push(P(he,K))}catch(De){throw De.message+=" writing "+JSON.stringify(he)+" of event "+JSON.stringify(K),De}return Promise.all(Ie)}else if(K.type==="define_schema"){let Ie=this.attributes.slice(0),he;for(let De of K.attributes)Ie.find(x=>x.name===De.name)||(Ie.push(De),he=!0);he&&(dt({table:s,database:c,attributes:Ie,origin:"cluster"}),Qf.signalSchemaChange(new zf.SchemaEventMsg(process.pid,os.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return K.beginTxn?(Y=K,Y.write_promises=[P(K,K)],new Promise(Ie=>{Y.resolve=()=>Ie(Promise.all(Y.write_promises))})):P(K,K)});Y&&(Y.committed=j),C&&j&&!j?.waitingForUserChange&&(j.then(()=>Qf.signalUserChange(new zf.UserEventMsg(process.pid))),j.waitingForUserChange=!0),K.onCommit&&(j?j.then(K.onCommit):K.onCommit())}catch(Te){qe.default.error?.("error in subscription handler",Te)}}}catch(M){qe.default.error?.(M)}})(),this}static getResource(m,R,w){let b=super.getResource(m,R,w);if(m!=null){li(m);try{if(b.hasOwnProperty(Ce))return b;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let y=!w?.async||i.cache?.get(m),C=Dr(R),O=C.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return nc(m,R,{transaction:O,ensureLoaded:w?.ensureLoaded},y,P=>{if(P?Dp(b,P):b[Ce]=null,R.onlyIfCached&&R.noCacheStore){if(!b.doesExist())throw new Cr.ServerError("Entry is not cached",504)}else if(w?.ensureLoaded){let M=sc(m,P,R,b);if(M)return C?.disregardReadTxn(),b[DO]=!0,PO(M,L=>(Dp(b,L),b))}return b})}catch(y){throw y.message.includes("Unable to serialize object")&&(y.message+=": "+JSON.stringify(m)),y}}return b}ensureLoaded(){let m=sc(this[We],this[wr],this[Me]);if(m)return this[DO]=!0,PO(m,R=>{this[wr]=R,this[Ce]=R.value,this[Kf]=R.version})}static getNewId(){let m=V?.type;if(m==="String"||m==="ID")return super.getNewId();if(!Ct){let y=i.getEntry(Symbol.for("id_allocation")),C=y?.value,O;if(C&&C.nodeName===server.hostname&&(!Fue(i)||C.pid===process.pid)){let P=C.start,M=C.end;O=P;for(let L of i.getKeys({start:M,end:P,limit:1,reverse:!0}))O=L}else C=b(y?.version??null),O=C.start;Ct=new BigInt64Array([BigInt(O)+1n]),Ct=new BigInt64Array(i.getUserSharedBuffer("id",Ct.buffer)),Ct.maxSafeId=C.end}let R=Number(Atomics.add(Ct,0,1n)),w=m==="Int"?512:1048576;if(R+w>=Ct.maxSafeId){let y=a(C=>{Ct.maxSafeId=R+(m==="Int"?1023:4194303);let O=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,P=C?void 0:i.useReadTransaction(),M=Number(Ct[0]);for(let Y of i.getKeys({start:M+1,end:O,limit:1,transaction:P}))O=Y;P?.done();let{value:L,version:H}=i.getEntry(Symbol.for("id_allocation"));if(Ct.maxSafeId<O){if(L.end>Ct.maxSafeId-100)return;qe.default.info?.("New id allocation",R,Ct.maxSafeId,H),i.put(Symbol.for("id_allocation"),{start:L.start,end:Ct.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),H)}else{qe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${Ct.maxSafeId}, but id of ${O} detected`);let Y=b(H);Y.alreadyUpdated||Atomics.store(Ct,0,BigInt(Y.start+1)),Ct.maxSafeId=Y.end}},"updateEnd");R+w===Ct.maxSafeId?setImmediate(y):R+100>=Ct.maxSafeId&&(qe.default.warn?.(`Synchronous id allocation required on table ${s}${m=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>y(!0)))}return R;function b(y){let C=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,O=C/4,P,M,L=!1,H,Y;do{H=Math.floor(Math.random()*C),Y={start:H,end:H+(m==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},P=0;for(let K of i.getKeys({start:H,limit:1,reverse:!0}))P=K;M=C;for(let K of i.getKeys({start:H+1,end:C,limit:1}))M=K;O*=.875,O<1e3&&!L&&(L=!0,qe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${m==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,H,P,M,O))}while(!(O<M-H&&(O<H-P||P===0)));return i.transactionSync(()=>{let K=i.getEntry(Symbol.for("id_allocation"));return(K?.version??null)==y?(qe.default.info?.("Allocated new id range",Y),i.put(Symbol.for("id_allocation"),Y,Date.now()),Y):(qe.default.debug?.("Looks like ids were already allocated"),Object.assign({alreadyUpdated:!0},K.value))})}}static setTTLExpiration(m){if(typeof m=="number")_=m*1e3,h||(h=0);else if(m&&typeof m=="object")_=m.expiration*1e3,h=(m.eviction||0)*1e3,Ht=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(_<0)throw new Error("Expiration can not be negative");Ht=Ht||(_+h)/4,Fe()}static getResidencyRecord(m){return u.get([Symbol.for("residency_by_id"),m])}static setResidency(m){ve.getResidency=m}static setResidencyById(m){ve.getResidencyById=m}static getResidency(m,R,w){if(ve.getResidencyById)return ve.getResidencyById(m[t]);let b=Gp;if(R.replicateTo!=null){if(Array.isArray(R.replicateTo))return R.replicateTo.includes(server.hostname)?R.replicateTo:[server.hostname,...R.replicateTo];R.replicateTo>=0&&(b=R.replicateTo)}if(b>=0&&server.nodes){let y=[server.hostname];if(w)y.push(...w.slice(0,b));else{let C=Math.floor(server.nodes.length*Math.random());y.push(...server.nodes.slice(C,C+b));let O=C+b-server.nodes.length;O>0&&y.push(...server.nodes.slice(0,O))}return y}}static enableAuditing(m=!0){p=m,m&&tt(),ve.audit=m}static coerceId(m){return m===""?null:Cp(m,V)}static async dropTable(){if(delete Ve[c][s],c===o){for(let m of g)u.remove(ve.tableName+"/"+m.name),r[m.name]?.drop();u.remove(ve.tableName+"/"),i.drop(),await u.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));Qf.signalSchemaChange(new zf.SchemaEventMsg(process.pid,os.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this[Is])return this.search(m);if(this[We]===null){if(m?.conditions)return this.search(m);let R=ve.getRecordCount();return{recordCount:R.recordCount,estimatedRecordRange:R.estimatedRange,records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:g}}if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this[Me]?.returnNonexistent)return this}allowRead(m,R){let w=ui(m);if(w?.read){if(w.isSuperUser)return!0;let b=w.attribute_permissions,y=R?.select;if(b?.length>0||Kl&&y){if(R||(R={}),y){let C=b?.length>0&&LO(b,"read");R.select=y.map(O=>{let P=O.name||O;if(!C||C[P]){let M=Gr[P]?.definition?.tableClass;if(M){if(O.name||(O={name:O}),!M.prototype.allowRead.call(null,m,O))return!1;if(!O.select)return O.name}return O}}).filter(Boolean)}else R.select=b.filter(C=>C.read&&!Gr[C.attribute_name]).map(C=>C.attribute_name);return R}else return!0}}allowUpdate(m,R){let w=ui(m);if(w?.update){let b=w.attribute_permissions;if(b?.length>0){let y=LO(b,"update");for(let C in R)if(!y[C])return!1;for(let C of b){let O=C.attribute_name;!C.update&&!(O in R)&&(R[O]=this.getProperty(O))}}return Ae(this[Me])}}allowCreate(m,R){if(this[Is]){let w=ui(m);if(w?.insert){let b=w.attribute_permissions;if(b?.length>0){let y=LO(b,"insert");for(let C in R)if(!y[C])return!1;return Ae(this[Me])}else return Ae(this[Me])}}else return this.allowUpdate(m,{})}allowDelete(m){return ui(m)?.delete&&Ae(this[Me])}update(m,R){if(!Dr(this[Me]))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let b;return typeof m=="object"&&m&&(R?(Object.isFrozen(m)&&(m=Object.assign({},m)),this[Ce]={},this[tr]=m):(b=this[tr],b&&(m=Object.assign(b,m)),this[tr]=b=m)),this._writeUpdate(this[tr],R),this}addTo(m,R){if(typeof R=="number"||typeof R=="bigint")this[Vf]===gV?this.set(m,(+this.getProperty(m)||0)+R):(this[Vf]||this.update(),this.set(m,new Op(R)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,R){if(typeof R=="number")return this.addTo(m,-R);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this[wr]}invalidate(){this._writeInvalidate()}_writeInvalidate(m){let R=this[Me],w=this[We];li(w),Dr(this[Me]).addWrite({key:w,store:i,invalidated:!0,entry:this[wr],before:je.invalidate?.bind(this,R,w),beforeIntermediate:ye.invalidate?.bind(this,R,w),commit:(y,C)=>{if(me(y,C,m?.nodeId))return;let O=null;for(let P in r)O||(O={}),O[P]=this.getProperty(P);qe.default.trace?.(`Invalidating entry id: ${w}, timestamp: ${new Date(y).toISOString()}`),T(w,O,this[wr],y,ja,p,{user:R?.user,residencyId:m?.residencyId,nodeId:m?.nodeId},"invalidate")}})}_writeRelocate(m){let R=this[Me],w=this[We];li(w),Dr(this[Me]).addWrite({key:w,store:i,invalidated:!0,entry:this[wr],before:je.relocate?.bind(this,R,w),beforeIntermediate:ye.relocate?.bind(this,R,w),commit:(y,C)=>{if(me(y,C,m?.nodeId))return;let O=ve.getResidencyRecord(m.residencyId),P=0,M=null,L=C?.value;if(O&&!O.includes(server.hostname)){for(let H in r)M||(M={}),M[H]=L(H);P=ja}else M=L;qe.default.trace?.(`Relocating entry id: ${w}, timestamp: ${new Date(y).toISOString()}`),T(w,M,this[wr],y,P,p,{user:R.user,residencyId:m.residencyId,nodeId:m.nodeId,expiresAt:m.expiresAt},"relocate",!1,null)}})}static _recordRelocate(m,R){let w={previousResidency:this.getResidencyRecord(m.residencyId),isRelocation:!0},b=this.getResidency(R.value,w),y;if(b){if(!Array.isArray(b))throw new Error("Residency must be an array, but was: "+b);if(!b.includes(server.hostname))return;y=Dt(b)}let O=T(m.key,R.value,m,m.version,0,!0,{residencyId:y,expiresAt:R.expiresAt},"relocate",!1,null)}static evict(m,R,w){let b=this.Source,y;if(!((N||p)&&(!R||(y=i.getEntry(m),!y||!R)||y.version!==w))){if(N){if(i.hasLock(m,y.version))return;let C;for(let O in r)C||(C={}),C[O]=R[O];if(C)return T(m,C,y,w,$f,null,null,null,!0)}return i.ifVersion(m,w,()=>{Ki(m,R,null)}),p?T(m,null,y,w,$f,null,null,null,!0):i.remove(m,w)}}lock(){throw new Error("Not yet implemented")}static operation(m,R){return m.table||=s,m.schema||=c,NV.operation(m,R)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,R,w){let b=this[Me],y=Dr(b),C=this[We];li(C);let O=this[wr];this[Vf]=R?gV:vue;let P={key:C,store:i,entry:O,nodeName:b?.nodeName,validate:M=>{m||(m=this[tr]),R||m&&bp(this[tr]===m?this:m)?b?.source||(y.checkOverloaded(),this.validate(m,!R),$&&(m[$.name]=$.type==="Date"?new Date(M):$.type==="String"?new Date(M).toISOString():M),R&&(t&&m[t]!==C&&(m[t]=C),J&&(O?.value?m[J.name]=O?.value[J.name]:m[J.name]=J.type==="Date"?new Date(M):J.type==="String"?new Date(M).toISOString():M),m=za(m))):y.removeWrite(P)},before:R?je.put?()=>je.put(b,C,m):null:je.patch?()=>je.patch(b,C,m):je.put?()=>je.put(b,C,za(this)):null,beforeIntermediate:R?ye.put?()=>ye.put(b,C,m):null:ye.patch?()=>ye.patch(b,C,m):ye.put?()=>ye.put(b,C,za(this)):null,commit:(M,L,H)=>{if(H){if(b&&L?.version>(b.lastModified||0)&&(b.lastModified=L.version),this[wr]=L,L?.value?.[Ce])throw new Error("Can not assign a record to a record, check for circular references");R||(this[Ce]=L?.value??null)}this[tr]=void 0,this[Kf]=M;let Y=L?.value,K=m;if(this[Vf]=0,me(M,L,w?.nodeId))if(p){let k=L.localTime,se=L.version;for(;K&&(k>M||se>=M&&k>0);){let ue=l.get(k);if(!ue)break;let pe=Lt(ue);if(se=pe.version,se>M){if(pe.type==="patch"){let rt=pe.getValue(i);K=Rp(K,rt)}else if(pe.type==="put"||pe.type==="delete")return}else if(se===M)return;k=pe.previousLocalTime}}else{if(R)return;K=Rp(K,Y)}let j;if(R?j=K:(this[Ce]=Y,j=R?K:za(this,K)),this[Ce]=j,j?.[Ce])throw new Error("Can not assign a record to a record, check for circular references");let Ie,he;if(w?.residencyId!=null)he=w.residencyId;else{O?.residencyId&&(b.previousResidency=ve.getResidencyRecord(O.residencyId));let k=ve.getResidency(j,b);if(k){if(!Array.isArray(k))throw new Error("Residency must be an array, got: "+k);k.includes(server.hostname)||k.push(server.hostname)}he=Dt(k)}R||(Ie=m);let De=b?.expiresAt||(_?_+Date.now():0);qe.default.trace?.(`Saving record with id: ${C}, timestamp: ${new Date(M).toISOString()}${De?", expires at: "+new Date(De).toISOString():""}${L?", replaces entry from: "+new Date(L.version).toISOString():", new entry"}`),Ki(C,Y,j);let x=R?"put":"patch";T(C,j,L,M,0,p,{user:b?.user,residencyId:he,expiresAt:De,nodeId:w?.nodeId,originatingOperation:b?.originatingOperation},x,!1,Ie),b.expiresAt&&Fe()}};y.addWrite(P)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this[Is]){for await(let R of this.search(m))(await ve.getResource(R[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this[Ce]?this._writeDelete(m):!1}_writeDelete(m){let R=Dr(this[Me]),w=this[We];li(w);let b=this[Me];return R.addWrite({key:w,store:i,resource:this,nodeName:b?.nodeName,before:je.delete?.bind(this,b,w),beforeIntermediate:ye.delete?.bind(this,b,w),commit:(y,C,O)=>{let P=C?.value;O&&(b&&C?.version>(b.lastModified||0)&&(b.lastModified=C.version),Dp(this,C)),!me(y,C,m?.nodeId)&&(Ki(this[We],P),qe.default.trace?.(`Deleting record with id: ${w}, txn timestamp: ${new Date(y).toISOString()}`),p||S?(T(w,null,this[wr],y,0,p,{user:b?.user,nodeId:m?.nodeId},"delete"),p||Fe()):i.remove(this[We]))}}),!0}search(m){let R=this[Me],w=Dr(R);if(!m)throw new Error("No query provided");let b=m.conditions;b?b.length===void 0&&(b=b[Symbol.iterator]?Array.from(b):[b]):b=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this[We]&&(b=[{attribute:null,comparator:"prefix",value:this[We]}].concat(b));let y,C={};function O(k,se){let ue;switch(se){case"and":case void 0:if(k.length<1)throw new Error('An "and" operator requires at least one condition');ue=!0;break;case"or":if(k.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+se)}let pe=ue&&{},rt;for(let xe of k){if(xe.conditions){xe.conditions=O(xe.conditions,xe.operator);continue}let He=xe[0]??xe.attribute,nt=He==null?V:ti(g,He);if(nt){if(ue){let rr=As(He),kt=pe[rr];kt?(kt.push(xe),rt=!0):pe[rr]=[xe]}(nt.type||Fb[xe.comparator])&&(xe[1]===void 0?xe.value=M(xe.value,nt):xe[1]=M(xe[1],nt))}else if(He!=null)throw(0,Cr.handleHDBError)(new Error,`${He} is not a defined attribute`,404)}if(m.enforceExecutionOrder)return k;if(rt)for(let xe in pe){let He=pe[xe],nt=He.length;if(nt>1)for(let rr=0;rr<nt;rr++){let kt=He[rr];if(kt.comparator==="ge"||kt.comparator==="greater_than_equal")for(let fn=0;fn<nt;fn++){let di=He[fn];(di.comparator==="le"||di.comparator==="less_than_equal")&&(kt.comparator="between",kt.value=[kt.value,di.value],k.splice(k.indexOf(di),1))}if(kt.comparator==="equals"||!kt.comparator){for(let fn=0;fn<nt;fn++)if(fn!==rr){let di=He[fn];k.splice(k.indexOf(di),1)}break}}}return k}a(O,"prepareConditions");function P(k,se){if(m.enforceExecutionOrder)return k;for(let ue of k)ue.conditions&&(ue.conditions=P(ue.conditions,ue.operator));return k.length>1&&se!=="or"?(0,OV.sortBy)(k,Sm(ve)):k}a(P,"orderConditions");function M(k,se){return Array.isArray(k)?k.map(ue=>Cp(ue,se)):Cp(k,se)}a(M,"coerceTypedValues");let L=m.operator;(b.length>0||L)&&(b=O(b,L));let H=typeof m.sort=="object"&&m.sort,Y;if(H&&L!=="or"){let k=H.attribute;if(y=b.find(se=>As(se.attribute)===As(k)),!y){let se=ti(g,k);if(!se)throw(0,Cr.handleHDBError)(new Error,`${Array.isArray(k)?k.join("."):k} is not a defined attribute`,404);if(se.indexed)y={attribute:k,comparator:"sort"},b.push(y);else if(b.length===0&&!m.allowFullScan)throw(0,Cr.handleHDBError)(new Error,`${Array.isArray(k)?k.join("."):k} is not indexed and not combined with any other conditions`,404)}y&&(y.descending=!!H.descending)}b=P(b,L),H&&(y&&b[0]===y?H.next&&(Y={dbOrderedAttribute:H.attribute,attribute:H.next.attribute,descending:H.next.descending,next:H.next.next}):(y&&b.splice(b.indexOf(y),1),Y=H));let K=m.select;if(b.length===0&&(b=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:b,operator:L,postOrdering:Y,selectApplied:!!K};let Te=w.useReadTxn(),j=Gb(b,L,ve,Te,m,R,(k,se)=>re(k,K,R,Te,se),C),Ie=m.ensureLoaded!==!1;Y||(j=x(j));let he=ve.transformEntryForSelect(K,R,Te,C,Ie,!0),De=ve.transformToOrderedSelect(j,K,Y,Te,R,he);function x(k){return m.offset||m.limit!==void 0?k.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):k}return a(x,"applyOffset"),Y&&(De=x(De)),De.onDone=()=>{De.onDone=null,w.doneReadTxn()},De.selectApplied=!0,De.getColumns=()=>{if(K){let k=[];for(let se of K)se==="*"?k.push(...g.map(ue=>ue.name)):k.push(se.name||se);return k}return g.filter(k=>!k.computed&&!k.relationship).map(k=>k.name)},De}static transformToOrderedSelect(m,R,w,b,y,C){let O=new r_;if(w){m=re(m,R,b,y,null);let P;O.iterate=function(){let L,H=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),Y,K=w.dbOrderedAttribute,Te,j,Ie=!0;function he(x){let k=x.next&&he(x.next),se=x.descending;return(ue,pe)=>{let rt=Ho(ue,x.attribute,b),xe=Ho(pe,x.attribute,b),He=se?(0,Za.compareKeys)(xe,rt):(0,Za.compareKeys)(rt,xe);return He===0?k?.(ue,pe)||0:He}}a(he,"createComparator");let De=he(w);return{async next(){let x;if(L)if(x=L.next(),x.done){if(Y)return O.onDone&&O.onDone(),x}else return{value:await C.call(this,x.value)};P=[],Te&&P.push(Te);do if(x=await H.next(),x.done){if(Y=!0,P.length)break;return O.onDone&&O.onDone(),x}else{let k=x.value;if(k?.then&&(k=await k),K){let se=Ho(k,K,b);if(Ie)Ie=!1,j=se;else if(se!==j){j=se,Te=k;break}}P.push(k)}while(!0);return w.isGrouped,P.sort(De),L=P[Symbol.iterator](),x=L.next(),x.done?(O.onDone&&O.onDone(),x):{value:await C.call(this,x.value)}},return(){O.onDone&&O.onDone(),H.return()},throw(){O.onDone&&O.onDone(),H.throw()}}};let M=a(L=>{if(typeof R=="object"&&Array.isArray(L.attribute))for(let H=0;H<R.length;H++){let Y=R[H],K;if(Y.name===L.attribute[0]){for(K=Y.sort||(Y.sort={});K.next;)K=K.next;K.attribute=L.attribute.slice(1),K.descending=L.descending}else Y===L.attribute[0]&&(R[H]=K={name:Y,sort:{attribute:L.attribute.slice(1),descending:L.descending}})}L.next&&M(L.next)},"applySortingOnSelect");M(w)}else O.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),O=O.map(C);return O}static transformEntryForSelect(m,R,w,b,y,C){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let L=a(H=>(R?.transaction?.stale&&(R.transaction.stale=!1),H?.key??H),"transform");return m===t?L:m.asArray?H=>[L(H)]:H=>({[t]:L(H)})}let O;y&&N&&!(typeof m=="string"?[m]:m)?.every(L=>{let H;return typeof L=="object"?H=L.name:H=L,r[H]||H===t})&&(O=!0);let P,M=a(function(L){let H;if(R?.transaction?.stale&&(R.transaction.stale=!1),L!=null){if($i=L,H=L.value||L.deref?.(),!H&&(L.key===void 0||L.deref)){if(L=nc(L.key??L,R,{transaction:w,lazy:m?.length<4},this?.isSync,Y=>Y),L?.then)return L.then(M.bind(this));H=L?.value}if(O&&L?.metadataFlags&(ja|$f)||L?.expiresAt&&L?.expiresAt<Date.now()){let Y=sc(L.key??L,L,R);if(Y?.then)return Y.then(M)}}if(H==null)return C?Ja.SKIP:H;if(m&&!(m[0]==="*"&&m.length===1)){let Y,K=a((j,Ie)=>{let he;typeof j=="object"?he=j.name:he=j;let De=Gr?.[he],x;if(De){let k=b?.[he];if(k)if(k.hasMappings){let ue=De.from?H[De.from]:As(L.key);x=k.get(ue),x||(x=[])}else x=k.fromRecord?.(H);else x=De(H,R,L);let se=a(ue=>{if(ue&&typeof ue=="object"){let pe=De.definition?.tableClass||ve;P||(P={});let rt=P[he]||(P[he]=pe.transformEntryForSelect(he===j?null:j.select||(Array.isArray(j)?j:null),R,w,k,y));if(Array.isArray(ue)){let xe=[],He=pe.transformToOrderedSelect(ue,j.select,typeof j.sort=="object"&&j.sort,R,w,rt)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),nt=a(kt=>{for(;!kt.done;){if(kt?.then)return kt.then(nt);xe.push(kt.value),kt=He.next()}Ie(xe,he)},"nextValue"),rr=nt(He.next());rr&&(Y||(Y=[]),Y.push(rr));return}else if(ue=rt.call(this,ue),ue?.then){Y||(Y=[]),Y.push(ue.then(xe=>Ie(xe,he)));return}}Ie(ue,he)},"handleResolvedValue");x?.then?(Y||(Y=[]),Y.push(x.then(se))):se(x);return}else x=H[he],x&&typeof x=="object"&&he!==j&&(x=ve.transformEntryForSelect(j.select||j,R,w,null)({value:x}));Ie(x,he)},"selectAttribute"),Te;if(typeof m=="string")K(m,j=>{Te=j});else if(Array.isArray(m))if(m.asArray)Te=[],m.forEach((j,Ie)=>{j==="*"?m[Ie]=H:K(j,he=>Te[Ie]=he)});else{Te={};let j=m.forceNulls;for(let Ie of m)if(Ie==="*")for(let he in H)Te[he]=H[he];else K(Ie,(he,De)=>{he===void 0&&j&&(he=null),Te[De]=he})}else throw new Cr.ClientError("Invalid select"+m);return Y?Promise.all(Y).then(()=>Te):Te}return H},"transform");return M}async subscribe(m){if(!l)throw new Error("Can not subscribe to a table without an audit log");p||dt({table:s,database:c,schemaDefined:d,attributes:g,audit:!0}),m||(m={});let R=!m.rawEvents,w=XR(ve,this[We]??null,function(O,P,M,L){try{let H=P.getValue?.(i,R),Y=P.type;if(!H&&P.type==="patch"&&R){let K=i.getEntry(O);K?.version===P.version?H=K.value:H=P.getValue?.(i,!0,M),Y="put"}this.send({id:O,timestamp:M,value:H,version:P.version,type:Y,beginTxn:L})}catch(H){qe.default.error?.(H)}},m.startTime||0,m);this[Is]&&(w.includeDescendants=!0,m.onlyChildren&&(w.onlyChildren=!0)),m.supportsTransactions&&(w.supportsTransactions=!0);let b=this[We],y=m.previousCount;y>1e3&&(y=1e3);let C=m.startTime;if(this[Is]){if(C){if(y)throw new Cr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:O,value:P}of l.getRange({start:C,exclusiveStart:!0})){let M=Lt(P);if(M.tableId!==n)continue;let L=M.recordId;if(b==null||bV(b,L)){let H=M.getValue(i,R,O);w.send({id:L,timestamp:O,value:H,version:M.version,type:M.type})}w.startTime=O}}else if(y){let O=[];for(let{key:P,value:M}of l.getRange({start:"z",end:!1,reverse:!0}))try{let L=Lt(M);if(L.tableId!==n)continue;let H=L.recordId;if(b==null||bV(b,H)){let Y=L.getValue(i,R,P);if(O.push({id:H,timestamp:P,value:Y,version:L.version,type:L.type}),--y<=0)break}}catch(L){qe.default.error?.("Error getting history entry",P,L)}for(let P=O.length;P>0;)w.send(O[--P]);O[0]&&(w.startTime=O[0].timestamp)}else if(!m.omitCurrent)for(let{key:O,value:P,version:M,localTime:L}of i.getRange({start:b??!1,end:b==null?void 0:[b,Za.MAXIMUM_KEY],versions:!0}))P&&w.send({id:O,timestamp:L,value:P,version:M,type:"put"})}else{y&&!C&&(C=0);let O=this[wr]?.localTime;if(O===FS&&(i.cache?.delete(b),this[wr]=i.getEntry(b),qe.default.trace?.("re-retrieved record",O,this[wr]?.localTime),O=this[wr]?.localTime),qe.default.trace?.("Subscription from",C,"from",b,O),C<O){let P=[],M=O;do{let L=l.get(M);if(L){m.omitCurrent=!0;let H=Lt(L),Y=H.getValue(i,R,M);R&&(H.type="put"),P.push({id:b,value:Y,timestamp:M,...H}),M=H.previousLocalTime}else break;y&&y--}while(M>C&&y!==0);for(let L=P.length;L>0;)w.send(P[--L]);w.startTime=O}!m.omitCurrent&&this.doesExist()&&w.send({id:b,timestamp:O,value:this[Ce],version:this[Kf],type:"put"})}return m.listener&&w.on("data",m.listener),w}doesExist(){return!!(this[Ce]||this[Vf])}publish(m,R){this._writePublish(m,R)}_writePublish(m,R){let w=Dr(this[Me]),b=this[We]||null;b!=null&&li(b);let y=this[Me];w.addWrite({key:b,store:i,entry:this[wr],nodeName:y?.nodeName,validate:()=>{y?.source||(w.checkOverloaded(),this.validate(m))},before:je.publish?.bind(this,y,b,m),beforeIntermediate:ye.publish?.bind(this,y,b,m),commit:(C,O,P)=>{O===void 0&&S&&!p&&Fe(),qe.default.trace?.(`Publishing message to id: ${b}, timestamp: ${new Date(C).toISOString()}`),T(b,O?.value??null,O,O?.version||C,0,!0,{user:y?.user,residencyId:R?.residencyId,expiresAt:y?.expiresAt,nodeId:R?.nodeId},"message",!1,m)}})}validate(m,R){let w,b=a((y,C,O)=>{if(C.type&&y!=null)if(R&&y.__op__&&(y=y.value),C.properties){typeof y!="object"&&(w||(w=[])).push(`Value ${ws(y)} in property ${O} must be an object${C.type?" ("+C.type+")":""}`);let P=C.properties;for(let M=0,L=P.length;M<L;M++){let H=P[M],Y=b(y[H.name],H,O+"."+H.name);Y&&(y[H.name]=Y)}if(C.sealed&&y!=null&&typeof y=="object")for(let M in y)P.find(L=>L.name===M)||(w||(w=[])).push(`Property ${M} is not allowed within object in property ${O}`)}else switch(C.type){case"Int":(typeof y!="number"||y>>0!==y)&&(w||(w=[])).push(`Value ${ws(y)} in property ${O} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof y!="number"||!(Math.floor(y)===y&&Math.abs(y)<=9007199254740992))&&(w||(w=[])).push(`Value ${ws(y)} in property ${O} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof y!="number"&&(w||(w=[])).push(`Value ${ws(y)} in property ${O} must be a number`);break;case"ID":typeof y=="string"||y?.length>0&&y.every?.(P=>typeof P=="string")||(w||(w=[])).push(`Value ${ws(y)} in property ${O} must be a string, or an array of strings`);break;case"String":typeof y!="string"&&(w||(w=[])).push(`Value ${ws(y)} in property ${O} must be a string`);break;case"Boolean":typeof y!="boolean"&&(w||(w=[])).push(`Value ${ws(y)} in property ${O} must be a boolean`);break;case"Date":if(!(y instanceof Date)){if(typeof y=="string"||typeof y=="number")return new Date(y);(w||(w=[])).push(`Value ${ws(y)} in property ${O} must be a Date`)}break;case"BigInt":if(typeof y!="bigint"){if(typeof y=="string"||typeof y=="number")return BigInt(y);(w||(w=[])).push(`Value ${ws(y)} in property ${O} must be a bigint`)}break;case"Bytes":y instanceof Uint8Array||(w||(w=[])).push(`Value ${ws(y)} in property ${O} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(y)){if(C.elements)for(let P=0,M=y.length;P<M;P++){let L=y[P],H=b(L,C.elements,O+"[*]");H&&(y[P]=H)}}else(w||(w=[])).push(`Value ${ws(y)} in property ${O} must be a Buffer or Uint8Array`);break}C.nullable===!1&&y==null&&(w||(w=[])).push(`Property ${O} is required (and not does not allow null values)`)},"validateValue");for(let y=0,C=g.length;y<C;y++){let O=g[y];if(!(O.relationship||O.computed)&&(!R||O.name in m)){let P=b(m[O.name],O,O.name);P&&(m[O.name]=P)}}if(f)for(let y in m)g.find(C=>C.name===y)||(w||(w=[])).push(`Property ${y} is not allowed`);if(w)throw new Cr.ClientError(w.join(". "))}getUpdatedTime(){return this[Kf]}wasLoadedFromSource(){return N?!!this[DO]:void 0}static async addAttributes(m){let R=g.slice(0);for(let w of m){if(!w.name)throw new Cr.ClientError("Attribute name is required");if(w.name.match(/[`/]/))throw new Cr.ClientError("Attribute names cannot include backticks or forward slashes");R.push(w)}return dt({table:s,database:c,schemaDefined:d,attributes:R}),ve.indexingOperation}static async removeAttributes(m){let R=g.filter(w=>!m.includes(w.name));return dt({table:s,database:c,schemaDefined:d,attributes:R}),ve.indexingOperation}static getRecordCount(m){let R=i.getStats().entryCount,w=5e3,b=1e3,y;R>w&&!m?.exactCount&&(y=b);let C=0;for(let{value:O}of i.getRange({start:!0,lazy:!0,limit:y}))O!=null&&C++;if(y){let O=C;C=0;for(let{value:Ie}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:y}))Ie!=null&&C++;let P=y*2,M=(C+O)/P,L=Math.pow((C-O+1)/y/2,2)+M*(1-M)/P,H=Math.max(Math.sqrt(L)*R,1),Y=Math.round(M*R),K=Math.max(Y-1.96*H,0),Te=Math.min(Y+1.96*H,R),j=Math.pow(10,Math.round(Math.log10(H)));return j>Y&&(j=j/10),C=Math.round(Y/j)*j,{recordCount:C,estimatedRange:[Math.round(K),Math.round(Te)]}}return{recordCount:C}}static updatedAttributes(){Gr=this.propertyResolvers={$id:(m,R,w)=>({value:w.key}),$updatedtime:(m,R,w)=>w.version,$record:(m,R,w)=>w?{value:m}:m};for(let m of this.attributes){m.resolve=null;let R=m.relationship,w=m.computed;if(R)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),w&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),Kl=!0,R.to)m.elements?.definition?(Gr[m.name]=m.resolve=(b,y,C)=>{let O=b[R.from?R.from:t],P=m.elements.definition.tableClass;return C?Al({attribute:R.to,value:O},Dr(y).getReadTxn(),!1,P,!1).asArray:P.search([{attribute:R.to,value:O}],y).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,R.from&&(m.resolve.from=R.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(R.from){let b=m.definition||m.elements?.definition;b?(Gr[m.name]=m.resolve=(y,C,O)=>{let P=y[R.from];if(P!==void 0){if(m.elements){let M,L=P.map(H=>{let Y=O?b.tableClass.primaryStore.getEntry(H,{transaction:Dr(C).getReadTxn()}):b.tableClass.get(H,C);return Y?.then&&(M=!0),Y});return R.filterMissing?M?Promise.all(L).then(H=>H.filter(yV)):L.filter(yV):M?Promise.all(L):L}return O?b.tableClass.primaryStore.getEntry(P,{transaction:Dr(C).getReadTxn()}):b.tableClass.get(P,C)}},m.set=(y,C)=>{if(Array.isArray(C)){let O=C.map(P=>P[We]||P[b.tableClass.primaryKey]);y[R.from]=O}else{let O=C[We]||C[b.tableClass.primaryKey];y[R.from]=O}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=R.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`);else w&&(typeof w.from=="function"&&this.setComputedAttribute(m.name,w.from),Gr[m.name]=m.resolve=(b,y,C)=>{let O=typeof w.from=="string"?b[w.from]:b,P=this.userResolvers[m.name];if(P)return P(O,y,C);qe.default.warn(`Computed attribute "${m.name}" does not have a function assigned to it. Please use setComputedAttribute('${m.name}', resolver) to assign a resolver function.`),this.userResolvers[m.name]=()=>{}})}Np(this,this)}static setComputedAttribute(m,R){let w=ti(g,m);if(!w){console.error(`The attribute "${m}" does not exist in the table "${s}"`);return}if(!w.computed){console.error(`The attribute "${m}" is not defined as computed in the table "${s}"`);return}this.userResolvers[m]=R}static async deleteHistory(m=0){let R;for(let{key:w,value:b}of l.getRange({start:0,end:m}))await Yf(),Lt(b).tableId===n&&(R=l.remove(w));await R}static async*getHistory(m=0,R=1/0){for(let{key:w,value:b}of l.getRange({start:m,end:R})){await Yf();let y=Lt(b);y.tableId===n&&(yield{id:y.recordId,localTime:w,version:y.version,type:y.type,value:y.getValue(i,!0,w),user:y.user,operation:y.originatingOperation})}}static async getHistoryOfRecord(m){let R=[];if(m==null)throw new Error("An id is required");let w=i.getEntry(m);if(!w)return R;let b=w.localTime;if(!b)throw new Error("The entry does not have a local audit time");let y=0;do{await Yf();let C=l.get(b);if(C){let O=Lt(C);R.push({id:O.recordId,localTime:b,version:O.version,type:O.type,value:O.getValue(i,!0,b),user:O.user}),b=O.previousLocalTime}else break}while(y<1e3&&b);return R.reverse()}static cleanup(){ne?.remove()}}ve.updatedAttributes();let qp=ve.prototype;return qp[Uue]=!0,_&&ve.setTTLExpiration(_/1e3),F&&Ee(),ve;function Ki(q,m,R){let w;for(let b in r){let y=r[b],C=y.isIndexing,O=Gr[b],P=R&&(O?O(R):R[b]),M=m&&(O?O(m):m[b]);if(P===M&&!C)continue;w=!0;let L=y.indexNulls,H=(0,Wf.getIndexedValues)(P,L),Y=(0,Wf.getIndexedValues)(M,L);if(Y?.length>0){let K=new Set(Y);if(H=H?H.filter(Te=>{if(K.has(Te))K.delete(Te);else return!0}):[],Y=Array.from(K),(Y.length>0||H.length>0)&&TV){let Te=Y.concat(H).map(j=>({key:j,value:q}));y.prefetch(Te,AV)}for(let Te=0,j=Y.length;Te<j;Te++)y.remove(Y[Te],q)}else H?.length>0&&TV&&y.prefetch(H.map(K=>({key:K,value:q})),AV);if(H)for(let K=0,Te=H.length;K<Te;K++)y.put(H[K],q)}return w}a(Ki,"updateIndices");function li(q){switch(typeof q){case"number":return!0;case"string":if(q.length<659)return!0;if(q.length>RV)throw new Error("Primary key size is too large: "+q.length);break;case"object":if(q===null)throw new Error("Invalid primary key of null");break;case"bigint":if(q<2n**64n&&q>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof q)}if((0,Za.writeKey)(q,xue,0)>RV)throw new Error("Primary key size is too large: "+q.length);return!0}a(li,"checkValidId");function nc(q,m,R,w,b){if(ve.getResidencyById&&R.ensureLoaded){let C=ve.getResidencyById(q);if(C&&!C.includes(server.hostname))return A({key:q,residency:C}).then(b,O=>{qe.default.error?.("Unable to retrieve data",O)})}let y=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),R.transaction?.isDone)return b(null,q);let C=i.getEntry(q,R);return C?.residencyId&&C.metadataFlags&ja&&A&&R.ensureLoaded?A(C).then(O=>b(O,q)):(C&&m&&(C?.version>(m.lastModified||0)&&(m.lastModified=C.version),C?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=C.localTime)),b(C,q))},"whenPrefetched");return w?y():le>0?(le--,y()):new Promise((C,O)=>{le===0?(le--,i.prefetch([q],()=>{P(),M()})):(ee.push(q),Z.push(M),ee.length>Wl&&(le--,P()));function P(){if(ee.length>0){let L=Z;i.prefetch(ee,()=>{le===-1?P():le++;for(let H of L)H()}),ee=[],Z=[],fe>2&&fe--}else le=fe,fe<n_&&fe++}a(P,"prefetch");function M(){try{C(y())}catch(L){O(L)}}a(M,"load")})}a(nc,"loadLocalRecord");function ui(q){if(!q?.role)return;let m=q.role.permission;if(m.super_user)return Bue;let R=m[c],w,b=R?.tables;if(b)return b[s];if(c==="data"&&(w=m[s])&&!w.tables)return w}a(ui,"getTablePermissions");function sc(q,m,R,w){if(N){let b=!1;if(R.noCache?b=!0:(m?(!m.value||m.metadataFlags&(ja|$f)||m.expiresAt&&m.expiresAt<Date.now())&&(b=!0):b=!0,wn(!b,"cache-hit",s)),b){let y=Je(q,m,R).then(C=>(C?.value?.[Ce]&&qe.default.error?.("Can not assign a record with a record property"),R&&(C?.version>(R.lastModified||0)&&(R.lastModified=C.version),R.lastRefreshed=Date.now()),C));if(R?.onlyIfCached||m?.value&&w?.allowStaleWhileRevalidate?.(m,q)){if(y.catch(C=>qe.default.warn?.(C)),R?.onlyIfCached&&!w.doesExist())throw new Cr.ServerError("Entry is not cached",504);return}else return y}}else if(m?.value&&m.expiresAt&&m.expiresAt<Date.now())return ve.evict(m.key,m.value,m.version),m.value=null,{then(b){return b(m)}}}a(sc,"ensureLoadedFromSource");function Dr(q){let m=q?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let R=m.next;if(!R)return m=m.next=new oa,m.lmdbDb=i,m;m=R}while(!0)}else return new hE}a(Dr,"txnForContext");function Ho(q,m,R){if(!q)return;$i=q;let w=q.value||q.deref?.()||($i=i.getEntry(q.key))?.value;if(typeof m=="object"){let y=Gr,C=w;for(let O=0,P=m.length;O<P;O++){let M=m[O],L=y?.[M];C=L&&C?L(C,R,!0)?.value:C?.[M],y=L?.definition?.tableClass?.propertyResolvers}return C}let b=Gr[m];return b?b(w,R):w[m]}a(Ho,"getAttributeValue");function re(q,m,R,w,b){let y=b?.length,C={transaction:w,lazy:y>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},O;function P(M,L){let H=M?.value;if(!H)return Ja.SKIP;for(let Y=0;Y<y;Y++)if(!O?.includes(Y)&&!b[Y](H,M))return Ja.SKIP;return L!==void 0&&(M.key=L),M}if(a(P,"processEntry"),y>0||!q.hasEntries){let M=q.map(L=>{if(O=null,typeof L=="object"&&L?.key!==void 0)return y>0?P(L):L;if(L==null)return Ja.SKIP;for(let H=0;H<y;H++){let K=b[H].idFilter;if(K){if(!K(L))return Ja.SKIP;O||(O=[]),O.push(H)}}return nc(L,R,C,!1,P)});return Array.isArray(q)&&(M=M.filter(L=>L!==Ja.SKIP)),M.hasEntries=!0,M}return q}a(re,"transformToEntries");function me(q,m,R=server.replication?.getThisNodeId(l)){if(q<=m?.version){if(m?.version===q&&R!==void 0){let w=server.replication?.exportIdMapping(l),b=m.localTime,y=l.get(b);if(y){let C,O,P=Lt(y);for(let M in w)w[M]===R&&(C=M),w[M]===P.nodeId&&(O=M);if(C>O)return!1}}return!0}return!1}a(me,"precedesExistingVersion");async function Je(q,m,R){let w=m?.metadataFlags,b=m?.version,y,C;if(!i.attemptLock(q,b,()=>{clearTimeout(C);let L=i.getEntry(q);!L||!L.value||L.metadataFlags&(ja|$f)?y(Je(q,i.getEntry(q),R)):y(L)}))return new Promise(L=>{y=L,C=setTimeout(()=>{i.unlock(q,b)},Mue)});let O=m?.value,P={requestContext:R,replacingRecord:O,replacingEntry:m,replacingVersion:b,noCacheStore:!1,source:null,resourceCache:R?.resourceCache},M=R?.responseHeaders;return new Promise((L,H)=>{let Y;PO(Tt(P,async K=>{let Te=performance.now(),j,Ie,he;try{for(let se of ve.sources)if(se.get&&(!se.get.reliesOnPrototype||se.prototype.get)){if(se.available?.(m)===!1)continue;if(P.source=se,j=await se.get(q,P),j)break}he=w&ja;let x=P.lastModified||he&&b;Ie=he||x>b||!O,x||(x=(0,Wf.getNextMonotonicTime)());let k=performance.now()-Te;if(Qr(k,"cache-resolution",s),M&&ab(M,"Server-Timing",`cache-resolve;dur=${k.toFixed(2)}`,!0),K.timestamp=x,_&&!P.expiresAt&&(P.expiresAt=Date.now()+_),j){if(typeof j!="object")throw new Error("Only objects can be cached and stored in tables");if(j.status>0&&j.headers)if(j.status>=300)if(j.status===304)j=O,x=b;else throw new Cr.ServerError(j.body||"Error from source",j.status);else j=j.body;typeof j.toJSON=="function"&&(j=j.toJSON()),t&&j[t]!==q&&(j[t]=q)}Y=!0,L({key:q,version:x,value:j})}catch(x){x.message+=` while resolving record ${q} for ${s}`,O&&((x.code==="ECONNRESET"||x.code==="ECONNREFUSED"||x.code==="EAI_AGAIN")&&!R?.mustRevalidate||R?.staleIfError&&(x.statusCode===500||x.statusCode===502||x.statusCode===503||x.statusCode===504))?(L({key:q,version:b,value:O}),qe.default.trace?.(x.message,"(returned stale record)")):H(x),P.transaction.abort();return}if(R?.noCacheStore||P.noCacheStore){P.transaction.abort();return}Dr(P).addWrite({key:q,store:i,entry:m,nodeName:"source",commit:(x,k)=>{if(k?.version!==b)return;let se=Ki(q,O,j);j?(ye.put?.(P,q,j),qe.default.trace?.(`Writing resolved record from source with id: ${q}, timestamp: ${new Date(x).toISOString()}`),T(q,j,k,x,0,p&&Ie||null,{user:P?.user,expiresAt:P.expiresAt},"put",!!he)):k&&(ye.delete?.(P,q),qe.default.trace?.(`Deleting resolved record from source with id: ${q}, timestamp: ${new Date(x).toISOString()}`),p||S?T(q,null,k,x,0,p&&Ie||null,{user:P?.user},"delete",!!he):i.remove(q,b))}})}),()=>{i.unlock(q,b)},K=>{i.unlock(q,b),Y&&qe.default.error?.("Error committing cache update",K)})})}a(Je,"getFromSource");function Ae(q){if(!q||q.user?.role?.permission?.super_user)return!0;if(q.replicateTo)throw new Cr.ClientError("Can not specify replication parameters without super user permissions",403);if(q.replicatedConfirmation)throw new Cr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(Ae,"checkContextPermissions");function Fe(){if(Ht!==Bo&&(Bo=Ht,(0,Xa.getWorkerIndex)()===(0,Xa.getWorkerCount)()-1)){if(rc&&clearTimeout(rc),!Ht)return;let q=new Date;q.setMonth(0),q.setDate(1),q.setHours(0),q.setMinutes(0),q.setSeconds(0);let m=Math.ceil((Date.now()-q.getTime())/Ht)*Ht+q.getTime(),R=a(w=>{qe.default.trace?.(`Scheduled next cleanup scan at ${new Date(w)}ms`),rc=setTimeout(()=>v=v.then(async()=>{if(R(Math.max(w+Ht,Date.now())),i.rootStore.status!=="open"){clearTimeout(rc);return}let b=50,y=new Array(b),C=0;qe.default.info?.(`Starting cleanup scan for ${s}`);try{let O=0;for(let{key:P,value:M,version:L,expiresAt:H}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let Y;M===null&&!p&&L+Pue<Date.now()?Y=i.remove(P,L):H&&H+h<Date.now()&&(Y=ve.evict(P,M,L),O++),Y&&(await y[C],y[C]=Y.catch(K=>{qe.default.error?.("Cleanup error",K)}),++C>=b&&(C=0)),await Yf()}qe.default.info?.(`Finished cleanup scan for ${s}, evicted ${O} entries`)}catch(O){qe.default.warn?.(`Error in cleanup scan for ${s}:`,O)}}),Math.min(w-Date.now(),2147483647)).unref()},"startNextTimer");R(m)}}a(Fe,"scheduleCleanup");function tt(){ne=l?.addDeleteRemovalCallback(n,q=>{let m=i.getEntry(q);m?.value===null&&i.remove(q,m.version)})}a(tt,"addDeleteRemoval");function Ee(){(0,Xa.getWorkerIndex)()===0&&setInterval(async()=>{if(!Yi){Yi=!0;try{let q=F.name,m=r[q];if(!m)throw new Error(`expiresAt attribute ${F} must be indexed`);for(let R of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let w of m.getValues(R)){let b=i.getEntry(w);b?.value?b.value[q]<Date.now()&&ve.evict(w,b.value,b.version):i.ifVersion(w,b?.version,()=>m.remove(R,w))}await Yf()}}catch(q){qe.default.error?.("Error in evicting old records",q)}finally{Yi=!1}}},Lue).unref()}a(Ee,"runRecordExpirationEviction");function Dt(q){if(q){let m=q.join(","),R=u.get([Symbol.for("residency_by_set"),m]);return R||(u.put([Symbol.for("residency_by_set"),m],R=Math.floor(Math.random()*2147483647)),u.put([Symbol.for("residency_by_id"),R],q),R)}}a(Dt,"getResidencyId")}function LO(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 AV(){}function Hue(e){NV=e}function Cp(e,t){let r=t?.type;return e===null?e:e===""&&r&&r!=="String"&&r!=="Any"?null:r==="Int"||r==="Long"?e[0]==="$"?parseInt(e.slice(1),36):e==="null"?null:parseInt(e):r==="Float"?e==="null"?null:+e:r==="BigInt"?e==="null"?null:BigInt(e):r==="Boolean"?e==="true"?!0:e==="false"?!1:e:r==="Date"?isNaN(e)?e==="null"?null:(kue.test(e)||(e+="Z"),new Date(e)):new Date(+e):!r||r==="Any"?(0,Lp.autoCast)(e):e}function bV(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 PO(e,t,r){return e?.then?e.then(t,r):t(e)}function Dp(e,t){e[wr]=t,e[Ce]=t?.value??null,e[Kf]=t?.version}function yV(e){return e!=null}function ws(e){try{return JSON.stringify(e)}catch{return e}}function Fue(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var os,Ja,Wf,OV,Gl,Cr,Qf,zf,qe,Za,Xa,Lp,Due,NV,Lue,Pue,TV,Mue,Kf,Uue,wr,Vf,gV,vue,DO,ja,$f,xue,RV,Bue,_ye,kue,Yf,Mm=Oe(()=>{os=U(B()),Ja=require("lmdb"),Wf=U(pn()),OV=require("lodash");us();mE();Gl=U(ie());ZR();Cr=U(ce()),Qf=U(Ti()),zf=U(Es());Ne();Sf();qe=U(hd());TE();aa();Za=require("ordered-binary"),Xa=U(at());Ei();Lp=U(te());dc();bi();Tp();Xd();Due=new Uint8Array(9);Due[8]=192;Lue=6e4,Pue=864e5;Gl.initSync();TV=Gl.get(os.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),Mue=1e4,Kf=Symbol.for("version"),Uue=Symbol.for("incremental-update"),wr=Symbol("entry"),Vf=Symbol("is-saving"),gV=1,vue=2,DO=Symbol("loaded-from-source"),ja=1,$f=8,xue=Buffer.allocUnsafeSlow(8192),RV=1978,Bue={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},_ye=(0,Lp.convertToMS)(Gl.get(os.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(Pp,"makeTable");a(LO,"attributesAsObject");a(AV,"noop");a(Hue,"setServerUtilities");kue=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(Cp,"coerceType");a(bV,"isDescendantId");Yf=a(()=>new Promise(setImmediate),"rest");a(PO,"when");a(Dp,"updateResource");a(yV,"exists");a(ws,"stringify");a(Fue,"hasOtherProcesses")});var it={};Ze(it,{database:()=>Ic,databases:()=>Ve,dropDatabase:()=>Cg,dropTableMeta:()=>Yue,getDatabases:()=>ct,getDefaultCompression:()=>Gh,getTables:()=>Gue,onRemovedDB:()=>bd,onUpdatedTable:()=>Ra,readMetaDb:()=>jf,resetDatabases:()=>$d,table:()=>dt,tables:()=>Tn});function Gue(){return xp||ct(),Tn||{}}function ct(){if(xp)return Ve;xp=!0,$l=new Map;let e=(0,Kt.getHdbBasePath)()&&(0,wt.join)((0,Kt.getHdbBasePath)(),ur.DATABASES_DIR_NAME),t=(0,Kt.get)(ur.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Kt.get)(ur.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,Bn.existsSync)(e)?e:(0,wt.join)((0,Kt.getHdbBasePath)(),ur.LEGACY_DATABASES_DIR_NAME)),!e)return;if((0,Bn.existsSync)(e))for(let n of(0,Bn.readdirSync)(e,{withFileTypes:!0})){let s=(0,wt.basename)(n.name,".mdb");n.isFile()&&(0,wt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&jf((0,wt.join)(e,n.name),null,s)}if((0,Bn.existsSync)((0,Vl.getBaseSchemaPath)())){for(let n of(0,Bn.readdirSync)((0,Vl.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,wt.join)((0,Vl.getBaseSchemaPath)(),n.name),i=(0,wt.join)((0,Vl.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,Bn.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,wt.extname)(o.name).toLowerCase()===".mdb"){let c=(0,wt.join)(i,o.name);jf((0,wt.join)(s,o.name),(0,wt.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,Bn.existsSync)(i))for(let c of(0,Bn.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,wt.extname)(c.name).toLowerCase()===".mdb"&&jf((0,wt.join)(i,c.name),(0,wt.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],d=(0,wt.join)(l.path,(0,wt.basename)(c+".mdb"));(0,Bn.existsSync)(d)&&jf(d,c,n,null,!0)}}for(let n in Ve){let s=$l.get(n);if(s){let i=Ve[n];n.includes("delete")&&mr.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(mr.trace(`delete table class ${o}`),delete i[o])}else if(delete Ve[n],n==="data"){for(let i in Tn)delete Tn[i];delete Tn[Bp]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(Ve.system)for(let n of r)Ve.system[n]&&(Ve.system[n].replicate=!1);return $l=null,Ve}function $d(){xp=!1;for(let[,e]of vo)e.needsDeletion=!0;ct();for(let[e,t]of vo)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),vo.delete(e),delete Ve[t.databaseName],Xf.forEach(r=>r(t.databaseName)));return Ve}function jf(e,t,r=vO,n,s){let i=new MO.default(e,!1);try{let o=vo.get(e);o?o.needsDeletion=!1:(o=(0,Yl.open)(i),vo.set(e,o));let c=new ec.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(Mp.INTERNAL_DBIS_NAME,c)),d=o.auditStore;d||(n?(0,Bn.existsSync)(n)&&(i.path=n,d=(0,Yl.open)(i),d.isLegacy=!0):d=Sp(o));let u=DV(r),f=u[Bp],E=new Map;for(let{key:_,value:h}of l.getRange({start:!1})){let[p,S]=_.toString().split("/");S===""?S=h.name:S||(S=p,p=t,h.name||(h.name=S,h.indexed=!h.is_hash_attribute)),f?.add(p);let g=E.get(p);g||E.set(p,g={attributes:[]}),(S==null||h.is_hash_attribute)&&(g.primary=h),S!=null&&g.attributes.push(h),Object.defineProperty(h,"key",{value:_,configurable:!0})}for(let[_,h]of E){let{attributes:p,primary:S}=h;if(!S){for(let Z of p)if(Z.is_hash_attribute||Z.isPrimaryKey){S=Z;break}if(!S){mr.fatal(`Unable to find a primary key attribute on table ${_}, with attributes: ${JSON.stringify(p)}`);continue}}let g=u[_],T={},A=[],N,V,v=typeof S.audit=="boolean"?S.audit:(0,Kt.get)(ur.CONFIG_PARAMS.LOGGING_AUDITLOG),J=S.trackDeletes,$=S.expiration,F=S.eviction,ne=S.sealed,ee=S.replicate;if(g)T=g.indices,A=g.attributes,g.schemaVersion++;else{N=S.tableId,N?N>=(l.get(ql)||0)&&l.putSync(ql,N+1):(S.tableId=N=l.get(ql),N||(N=1),l.putSync(ql,N+1),l.putSync(S.key,S));let Z=new ec.default(!S.is_hash_attribute,S.is_hash_attribute);if(Z.compression=S.compression,Z.compression){let le=(0,Kt.get)(ur.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||CV;Z.compression.threshold=le}V=C_(o.openDB(S.key,Z)),o.databaseName=r,V.rootStore=o,V.tableId=N}for(let Z of p){Z.attribute=Z.name;try{if(!Z.is_hash_attribute&&(Z.indexed||Z.attribute&&!Z.name)){if(!T[Z.name]){let fe=new ec.default(!Z.is_hash_attribute,Z.is_hash_attribute);T[Z.name]=o.openDB(Z.key,fe),T[Z.name].indexNulls=Z.indexNulls}let le=A.find(fe=>fe.name===Z.name);le?A.splice(A.indexOf(le),1,Z):A.push(Z)}}catch(le){mr.error("Error trying to update attribute",Z,A,T,le)}}if(!g){g=LV(u,_,Pp({primaryStore:V,auditStore:d,audit:v,sealed:ne,replicate:ee,expirationMS:$&&$*1e3,evictionMS:F&&F*1e3,trackDeletes:J,tableName:_,tableId:N,primaryKey:S.name,databasePath:s?r+"/"+_:r,databaseName:r,indices:T,attributes:p,schemaDefined:S.schemaDefined,dbisDB:l})),g.schemaVersion=1;for(let Z of Jf)Z(g)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function DV(e){let t=Ve[e];if(t||(e==="data"?t=Ve[e]=Tn:e==="system"?Object.defineProperty(Ve,"system",{value:t=Object.create(null),configurable:!0}):t=Ve[e]=Object.create(null)),$l&&!$l.has(e)){let r=new Set;t[Bp]=r,$l.set(e,r)}return t}function LV(e,t,r){return e[t]=r,r}function Ic({database:e,table:t}){e||(e=vO),ct();let r=DV(e),n=(0,wt.join)((0,Kt.getHdbBasePath)(),ur.DATABASES_DIR_NAME),s=(0,Kt.get)(ur.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,Kt.get)(ur.CONFIG_PARAMS.STORAGE_PATH)||((0,Bn.existsSync)(n)?n:(0,wt.join)((0,Kt.getHdbBasePath)(),ur.LEGACY_DATABASES_DIR_NAME));let o=(0,wt.join)(n,(i?t:e)+".mdb"),c=vo.get(o);if(!c||c.status==="closed"){let l=new MO.default(o,!1);c=(0,Yl.open)(l),vo.set(o,c)}return c.auditStore||(c.auditStore=Sp(c)),c}async function Cg(e){if(!Ve[e])throw new Error("Schema does not exist");let t=Ve[e],r;for(let n in t)r=t[n].primaryStore.rootStore,vo.delete(r.path),r.status==="open"&&(await r.close(),await Zf.remove(r.path));if(r||(r=Ic({database:e,table:null}),r.status==="open"&&(await r.close(),await Zf.remove(r.path))),e==="data"){for(let n in Tn)delete Tn[n];delete Tn[Bp]}delete Ve[e],Xf.forEach(n=>n(e))}function dt({table:e,database:t,expiration:r,eviction:n,scanInterval:s,attributes:i,audit:o,sealed:c,replicate:l,trackDeletes:d,schemaDefined:u,origin:f}){t||(t=vO);let E=Ic({database:t,table:e}),_=Ve[t];mr.trace(`Defining ${e} in ${t}`);let h=_?.[e];if(E.status==="closed")throw new Error(`Can not use a closed data store for ${e}`);let p,S,g,T;u==null&&(u=!0);let A=new ec.default(!1);for(let F of i)F.attribute&&!F.name?(F.name=F.attribute,F.indexed=!0):F.attribute=F.name,F.expiresAt&&(F.indexed=!0);let N,V;if(h){if(p=h.primaryKey,h.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${e} class`);h.attributes.splice(0,h.attributes.length,...i)}else{let F=E.auditStore;S=i.find(le=>le.isPrimaryKey)||{},p=S.name,S.is_hash_attribute=!0,S.schemaDefined=u,S.compression=Gh(),d&&(S.trackDeletes=!0),o=S.audit=typeof o=="boolean"?o:(0,Kt.get)(ur.CONFIG_PARAMS.LOGGING_AUDITLOG),r&&(S.expiration=r),n&&(S.eviction=n),typeof c=="boolean"&&(S.sealed=c),typeof l=="boolean"&&(S.replicate=l),f&&(S.origins?S.origins.includes(f)||S.origins.push(f):S.origins=[f]),mr.trace(`${e} table loading, opening primary store`);let ne=new ec.default(!1,!0);ne.compression=S.compression;let ee=e+"/",Z=C_(E.openDB(ee,ne));E.databaseName=t,Z.rootStore=E,T=E.dbisDb=E.openDB(Mp.INTERNAL_DBIS_NAME,A),Z.tableId=T.get(ql),Z.tableId||(Z.tableId=1),T.putSync(ql,Z.tableId+1),S.tableId=Z.tableId,h=LV(_,e,Pp({primaryStore:Z,auditStore:F,audit:o,sealed:c,replicate:l,trackDeletes:d,expirationMS:r&&r*1e3,evictionMS:n&&n*1e3,primaryKey:p,tableName:e,tableId:Z.tableId,databasePath:t,databaseName:t,indices:{},attributes:i,schemaDefined:u,dbisDB:T})),h.schemaVersion=1,N=!0,$(),T.put(ee,S)}g=h.indices,T=T||(E.dbisDb=E.openDB(Mp.INTERNAL_DBIS_NAME,A)),h.dbisDB=T;let v=[];for(let{key:F,value:ne}of T.getRange({start:!0})){let[ee,Z]=F.toString().split("/");if(Z===""&&(Z=ne.name),Z){if(ee!==e)continue}else Z=ee;if(!i.find(fe=>fe.name===Z)?.indexed&&ne.indexed&&!ne.isPrimaryKey){$(),N=!0,T.remove(F);let fe=h.indices[ee];fe&&v.push(fe)}}let J=[];try{for(let F of i||[]){if(F.relationship)continue;let ne=e+"/"+(F.name||"");Object.defineProperty(F,"key",{value:ne,configurable:!0});let ee=T.get(ne);if(F.isPrimaryKey){if(ee=ee||T.get(ne=e+"/")||{},o!==void 0&&o!==h.audit||c!==void 0&&c!==h.sealed||l!==void 0&&l!==h.replicate||(+r||void 0)!==(+ee.expiration||void 0)||(+n||void 0)!==(+ee.eviction||void 0)){let le=Object.assign({},ee);typeof o=="boolean"&&(o&&h.enableAuditing(o),le.audit=o),r&&(le.expiration=+r),n&&(le.eviction=+n),c!==void 0&&(le.sealed=c),l!==void 0&&(le.replicate=l),N=!0,$(),T.put(ne,le)}continue}ee?.attribute&&!ee.name&&(ee.indexed=!0);let Z=!ee||ee.type!==F.type||ee.indexed!==F.indexed||ee.nullable!==F.nullable||ee.version!==F.version||JSON.stringify(ee.attributes)!==JSON.stringify(F.attributes)||JSON.stringify(ee.elements)!==JSON.stringify(F.elements);if(F.indexed){let le=new ec.default(!0,!1),fe=E.openDB(ne,le);(Z||ee.indexingPID&&ee.indexingPID!==process.pid||ee.restartNumber<e_.workerData?.restartNumber)&&(N=!0,$(),ee=T.get(ne),(Z||ee.indexingPID&&ee.indexingPID!==process.pid||ee.restartNumber<e_.workerData?.restartNumber)&&(N=!0,F.indexNulls===void 0&&(F.indexNulls=!0),h.primaryStore.getStats().entryCount>0&&(F.lastIndexedKey=ee?.lastIndexedKey??void 0,F.indexingPID=process.pid,fe.isIndexing=!0,Object.defineProperty(F,"dbi",{value:fe}),J.push(F))),T.put(ne,F)),ee?.indexNulls&&F.indexNulls===void 0&&(F.indexNulls=!0),fe.indexNulls=F.indexNulls,g[F.name]=fe}else Z&&(N=!0,$(),T.put(ne,F))}}finally{V&&V()}if(N&&(E.auditStore,h.schemaVersion++,h.updatedAttributes()),mr.trace(`${e} table loading, running index`),J.length>0||v.length>0?h.indexingOperation=$ue(h,J,v):N&&Up.signalSchemaChange(new vp.SchemaEventMsg(process.pid,"schema-change",h.databaseName,h.tableName)),h.origin=f,N)for(let F of Jf)F(h,f!=="cluster");return(r||n||s)&&h.setTTLExpiration({expiration:r,eviction:n,scanInterval:s}),mr.trace(`${e} table loaded`),h;function $(){V||E.transactionSync(()=>({then(F){V=F}}))}a($,"startTxn")}async function $ue(e,t,r){try{mr.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await Up.signalSchemaChange(new vp.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let d of r)s=d.drop();let i,o={},c=0,l=t.length;if(await new Promise(d=>setImmediate(d)),l>0){let d;for(let f of t)(0,Yl.compareKeys)(f.lastIndexedKey,d)<0&&(d=f.lastIndexedKey),f.lastIndexedKey==null&&f.dbi.clearAsync();let u=0;for(let{key:f,value:E,version:_}of e.primaryStore.getRange({start:d,lazy:l<4,versions:!0,snapshot:!1}))if(E){if(u++,s=e.primaryStore.ifVersion(f,_,()=>{for(let h=0;h<l;h++){let p=t[h],S=p.name;try{let g=p.resolve,T=E&&(g?g(E):E[S]),A=(0,IV.getIndexedValues)(T);if(A)for(let N=0,V=A.length;N<V;N++)p.dbi.put(A[N],f)}catch(g){o[S]||(o[S]=!0,mr.error(`Error indexing attribute ${S}`,g))}}}),s.then(()=>u--,h=>{u--,mr.error(h)}),e_.workerData&&e_.workerData.restartNumber!==wV.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=f,e.dbisDB.put(h.key,h);if(i)return}u>que?await s:u>Vue&&await new Promise(h=>setImmediate(h))}for(let f of t)delete f.lastIndexedKey,delete f.indexingPID,f.dbi.isIndexing=!1,s=e.dbisDB.put(f.key,f)}await s,await Up.signalSchemaChange(new vp.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),mr.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){mr.error("Error in indexing",n)}}function Yue({table:e,database:t}){let r=Ic({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 Ra(e){return Jf.push(e),{remove(){let t=Jf.indexOf(e);t>-1&&Jf.splice(t,1)}}}function bd(e){return Xf.push(e),{remove(){let t=Xf.indexOf(e);t>-1&&Xf.splice(t,1)}}}function Gh(){let e=(0,Kt.get)(ur.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,Kt.get)(ur.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,Kt.get)(ur.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||CV,n={startingOffset:32};return t&&(n.dictionary=Zf.readFileSync(t)),r&&(n.threshold=r),e&&n}var Kt,Mp,Yl,wt,Bn,Vl,ec,MO,ur,Zf,UO,IV,Up,vp,e_,mr,wV,vO,Bp,CV,Tn,Ve,ql,Jf,Xf,xp,vo,$l,que,Vue,Ne=Oe(()=>{Kt=U(ie()),Mp=U(Ft()),Yl=require("lmdb"),wt=require("path"),Bn=require("fs"),Vl=U(St());Mm();ec=U(Ru()),MO=U(Au()),ur=U(B()),Zf=U(require("fs-extra")),UO=require("../../index"),IV=U(pn()),Up=U(Ti()),vp=U(Es()),e_=require("worker_threads"),mr=U(X()),wV=U(at());Ei();dc();vO="data",Bp=Symbol("defined-tables"),CV=((0,Kt.get)(ur.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,Kt.initSync)();Tn=Object.create(null),Ve=Object.create(null);(0,UO._assignPackageExport)("databases",Ve);(0,UO._assignPackageExport)("tables",Tn);ql=Symbol.for("next-table-id"),Jf=[],Xf=[],vo=new Map;a(Gue,"getTables");a(ct,"getDatabases");a($d,"resetDatabases");a(jf,"readMetaDb");a(DV,"ensureDB");a(LV,"setTable");a(Ic,"database");a(Cg,"dropDatabase");a(dt,"table");que=1e3,Vue=10;a($ue,"runIndexing");a(Yue,"dropTableMeta");a(Ra,"onUpdatedTable");a(bd,"onRemovedDB");a(Gh,"getDefaultCompression")});var te=I((Aye,YV)=>{"use strict";var xo=require("path"),xV=require("fs-extra"),un=X(),PV=require("fs-extra"),Hp=require("os"),Kue=require("net"),Wue=require("recursive-iterator"),Bt=B(),Que=ON(),MV=require("papaparse"),kp=require("moment"),{inspect:zue}=require("util"),UV=require("is-number"),Rye=require("lodash"),jue=require("minimist"),Jue=require("https"),Xue=require("http"),{hdb_errors:Fp}=ce(),Zue=/^((\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)))$/,BV=require("util").promisify(setTimeout),ede=100,tde=5,rde="",nde=4,vV={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};YV.exports={isEmpty:Hn,isEmptyOrZeroLength:ci,arrayHasEmptyValues:ode,arrayHasEmptyOrZeroLengthValues:ade,buildFolderPath:cde,isBoolean:HV,errorizeMessage:sde,stripFileExtension:ude,autoCast:dde,autoCastJSON:kV,autoCastJSONDeep:BO,removeDir:fde,compareVersions:_de,isCompatibleDataVersion:Ede,escapeRawValue:hde,unescapeValue:mde,stringifyProps:pde,timeoutPromise:Tde,isClusterOperation:Rde,getClusterUser:bde,checkGlobalSchemaTable:Ade,getHomeDir:GV,getPropsFilePath:Sde,promisifyPapaParse:yde,removeBOM:qV,createEventPromise:Ode,checkProcessRunning:Nde,checkSchemaTableExist:Ide,checkSchemaExists:VV,checkTableExists:$V,getStartOfTomorrowInSeconds:wde,getLimitKey:Cde,isObject:lde,isNotEmptyAndHasValue:ide,autoCasterIsNumberCheck:FV,backtickASTSchemaItems:Dde,isPortTaken:gde,createForkArgs:Lde,autoCastBoolean:Pde,async_set_timeout:BV,getTableHashAttribute:Mde,doesSchemaExist:Ude,doesTableExist:vde,stringifyObj:xde,ms_to_time:Bde,changeExtension:Hde,getEnvCliRootPath:HO,noBootFile:kde,httpRequest:Fde,transformReq:Gde,convertToMS:qde,PACKAGE_ROOT:Bt.PACKAGE_ROOT};function sde(e){return e instanceof Error?e:new Error(e)}a(sde,"errorizeMessage");function Hn(e){return e==null}a(Hn,"isEmpty");function ide(e){return!Hn(e)&&(e||e===0||e===""||HV(e))}a(ide,"isNotEmptyAndHasValue");function ci(e){return Hn(e)||e.length===0||e.size===0}a(ci,"isEmptyOrZeroLength");function ode(e){if(Hn(e))return!0;for(let t=0;t<e.length;t++)if(Hn(e[t]))return!0;return!1}a(ode,"arrayHasEmptyValues");function ade(e){if(ci(e))return!0;for(let t=0;t<e.length;t++)if(ci(e[t]))return!0;return!1}a(ade,"arrayHasEmptyOrZeroLengthValues");function cde(...e){try{return e.join(xo.sep)}catch{console.error(e)}}a(cde,"buildFolderPath");function HV(e){return Hn(e)?!1:e===!0||e===!1}a(HV,"isBoolean");function lde(e){return Hn(e)?!1:typeof e=="object"}a(lde,"isObject");function ude(e){return ci(e)?rde:e.slice(0,-nde)}a(ude,"stripFileExtension");function dde(e){return Hn(e)||e===""||typeof e!="string"?e:vV[e]!==void 0?vV[e]:FV(e)===!0?Number(e):Zue.test(e)?new Date(e):e}a(dde,"autoCast");function kV(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(kV,"autoCastJSON");function BO(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=BO(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=BO(r);n!==r&&(e[t]=n)}return e}else return kV(e)}a(BO,"autoCastJSONDeep");function FV(e){if(e.startsWith("0.")&&UV(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&UV(e))}a(FV,"autoCasterIsNumberCheck");async function fde(e){if(ci(e))throw new Error(`Directory path: ${e} does not exist`);try{await PV.emptyDir(e),await PV.remove(e)}catch(t){throw un.error(`Error removing files in ${e} -- ${t}`),t}}a(fde,"removeDir");function _de(e,t){if(ci(e)){un.info("Invalid current version sent as parameter.");return}if(ci(t)){un.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let d=0;d<l;d++)if(r=parseInt(o[d],10)-parseInt(c[d],10),r)return r;return o.length-c.length}a(_de,"compareVersions");function Ede(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(Ede,"isCompatibleDataVersion");function hde(e){if(Hn(e))return e;let t=String(e);return t==="."?Bt.UNICODE_PERIOD:t===".."?Bt.UNICODE_PERIOD+Bt.UNICODE_PERIOD:t.replace(Bt.FORWARD_SLASH_REGEX,Bt.UNICODE_FORWARD_SLASH)}a(hde,"escapeRawValue");function mde(e){if(Hn(e))return e;let t=String(e);return t===Bt.UNICODE_PERIOD?".":t===Bt.UNICODE_PERIOD+Bt.UNICODE_PERIOD?"..":String(e).replace(Bt.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(mde,"unescapeValue");function pde(e,t){if(Hn(e))return un.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+Hp.EOL}!ci(n)&&n[0]===";"?r+=" "+n+s+Hp.EOL:ci(n)||(r+=n+"="+s+Hp.EOL)}catch{un.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(pde,"stringifyProps");function GV(){let e;try{e=Hp.homedir()}catch{e=process.env.HOME}return e}a(GV,"getHomeDir");function Sde(){let e=xo.join(GV(),Bt.HDB_HOME_DIR_NAME,Bt.BOOT_PROPS_FILE_NAME);return xV.existsSync(e)||(e=xo.join(__dirname,"../","hdb_boot_properties.file")),e}a(Sde,"getPropsFilePath");function Tde(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:function(){clearTimeout(r)}}}a(Tde,"timeoutPromise");async function gde(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=Kue.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(gde,"isPortTaken");function Rde(e){try{return Bt.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){un.error(`Error checking operation against cluster ops ${t}`)}return!1}a(Rde,"isClusterOperation");function Ade(e,t){let r=(Ne(),ae(it)).getDatabases();if(!r[e])return Fp.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return Fp.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Ade,"checkGlobalSchemaTable");function bde(e,t){if(Hn(t)){un.warn("No CLUSTERING_USER defined, clustering disabled");return}if(Hn(e)||ci(e)){un.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){un.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){un.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(bde,"getClusterUser");function yde(){MV.parsePromise=function(e,t,r){return new Promise(function(n,s){MV.parse(e,{header:!0,transformHeader:qV,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(yde,"promisifyPapaParse");function qV(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(qV,"removeBOM");function Ode(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;un.info(`Got cluster status event response: ${zue(s)}`);try{i.cancel()}catch{un.error("Error trying to cancel timeout.")}n(s)})})}a(Ode,"createEventPromise");async function Nde(e){let t=!0,r=0;do await BV(ede*r++),(await Que.findPs(e)).length>0&&(t=!1);while(t&&r<tde);if(t)throw new Error(`process ${e} was not started`)}a(Nde,"checkProcessRunning");function Ide(e,t){let r=VV(e);if(r)return r;let n=$V(e,t);if(n)return n}a(Ide,"checkSchemaTableExist");function VV(e){let{getDatabases:t}=(Ne(),ae(it));if(!t()[e])return Fp.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(VV,"checkSchemaExists");function $V(e,t){let{getDatabases:r}=(Ne(),ae(it));if(!r()[e][t])return Fp.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a($V,"checkTableExists");function wde(){let e=kp().utc().add(1,Bt.MOMENT_DAYS_TAG).startOf(Bt.MOMENT_DAYS_TAG).unix(),t=kp().utc().unix();return e-t}a(wde,"getStartOfTomorrowInSeconds");function Cde(){return kp().utc().format("DD-MM-YYYY")}a(Cde,"getLimitKey");function Dde(e){try{let t=new Wue(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){un.error("Got an error back ticking items."),un.error(t)}}a(Dde,"backtickASTSchemaItems");function Lde(e){return[e]}a(Lde,"createForkArgs");function Pde(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(Pde,"autoCastBoolean");function Mde(e,t){let{getDatabases:r}=(Ne(),ae(it)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(Mde,"getTableHashAttribute");function Ude(e){let{getDatabases:t}=(Ne(),ae(it));return t()[e]!==void 0}a(Ude,"doesSchemaExist");function vde(e,t){let{getDatabases:r}=(Ne(),ae(it));return r()[e]?.[t]!==void 0}a(vde,"doesTableExist");function xde(e){try{return JSON.stringify(e)}catch{return e}}a(xde,"stringifyObj");function Bde(e){let t=kp.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(Bde,"ms_to_time");function Hde(e,t){let r=xo.basename(e,xo.extname(e));return xo.join(xo.dirname(e),r+t)}a(Hde,"changeExtension");function HO(){if(process.env[Bt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Bt.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=jue(process.argv);if(e[Bt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Bt.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(HO,"getEnvCliRootPath");var xO;function kde(){if(xO)return xO;let e=HO();if(HO()&&xV.pathExistsSync(xo.join(e,Bt.HDB_CONFIG_FILE)))return xO=!0,!0}a(kde,"noBootFile");function Fde(e,t){let r;return e.protocol==="http:"?r=Xue:r=Jue,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8");let c={body:"",headers:o.headers};o.on("data",l=>{c.body+=l}),o.on("end",()=>{n(c)})});i.on("error",o=>{s(o)}),i.write(JSON.stringify(t)),i.end()})}a(Fde,"httpRequest");function Gde(e){if(!e.schema&&!e.database){e.schema=Bt.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(Gde,"transformReq");function qde(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(qde,"convertToMS")});var kO=B(),KV=te(),t_=X(),Vde=Si(),$de=yn(),Yde=Oy(),{start:Kde}=(Ky(),ae(Zm)),{closeConnection:Wde}=jt(),WV=require("moment"),QV=vm(),{cloneDeep:Qde}=require("lodash"),zde=process.env[kO.PROCESS_NAME_ENV_PROP],tc=zde.substring(4);a(async function(){let t={id:tc,request:void 0},r=0;try{t_.notify("Starting job:",tc),Kde(),Vde.setSchemaDataToGlobal(),await $de.setUsersToGlobal();let n=await QV.getJobById(tc);if(KV.isEmptyOrZeroLength(n))throw new Error(`Unable to find a record in hdb_job for job: ${tc}`);let{request:s}=n[0];if(KV.isEmptyOrZeroLength(s))throw new Error("Did not find job request in hdb_job table, unable to proceed");s=Qde(s);let i=Yde.getOperationFunction(s);t_.trace("Running operation:",s.operation,"for job",tc);let o=await i.job_operation_function(s);t_.trace("Result from job:",tc,o),t.status=kO.JOB_STATUS_ENUM.COMPLETE,t.message=o,t.end_datetime=WV().valueOf(),t_.notify("Successfully completed job:",tc)}catch(n){r=1,t_.error(n),t.status=kO.JOB_STATUS_ENUM.ERROR,t.message=n.message?n.message:n,t.end_datetime=WV().valueOf()}finally{await QV.updateJob(t),await Wde(),setTimeout(()=>{process.exit(r)},3e3).unref()}},"job")();