harperdb 4.3.36 → 4.3.38
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/bin/harperdb.js +25 -25
- package/bin/lite.js +18 -18
- package/launchServiceScripts/launchInstallNATSServer.js +1 -1
- package/launchServiceScripts/launchNatsIngestService.js +19 -19
- package/launchServiceScripts/launchNatsReplyService.js +19 -19
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +19 -19
- package/npm-shrinkwrap.json +1292 -518
- package/package.json +2 -2
- package/resources/RecordEncoder.d.ts +3 -3
- package/resources/Table.d.ts +32 -32
- package/resources/auditStore.d.ts +11 -4
- package/resources/databases.d.ts +32 -32
- package/server/jobs/jobProcess.js +19 -19
- package/server/threads/threadServer.js +19 -19
- package/studio/build-local/asset-manifest.json +2 -2
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/static/js/{main.10a18f39.js → main.3ae1052d.js} +2 -2
- package/utility/scripts/restartHdb.js +19 -19
- /package/studio/build-local/static/js/{main.10a18f39.js.LICENSE.txt → main.3ae1052d.js.LICENSE.txt} +0 -0
|
@@ -1,34 +1,34 @@
|
|
|
1
|
-
"use strict";var Hq=Object.create;var fc=Object.defineProperty;var Gq=Object.getOwnPropertyDescriptor;var qq=Object.getOwnPropertyNames;var Fq=Object.getPrototypeOf,kq=Object.prototype.hasOwnProperty;var a=(e,t)=>fc(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),Fe=(e,t)=>{for(var r in t)fc(e,r,{get:t[r],enumerable:!0})},hO=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of qq(t))!kq.call(e,s)&&s!==r&&fc(e,s,{get:()=>t[s],enumerable:!(n=Gq(t,s))||n.enumerable});return e};var H=(e,t,r)=>(r=e!=null?Hq(Fq(e)):{},hO(t||!e||!e.__esModule?fc(r,"default",{value:e,enumerable:!0}):r,e)),ie=e=>hO(fc({},"__esModule",{value:!0}),e);var SO=g((uce,pO)=>{var Vq=require("fast-glob"),{statSync:Bh,existsSync:xh,readFileSync:$q,writeFileSync:Yq}=require("fs"),{spawnSync:Kq,spawn:Wq,execFileSync:cce}=require("child_process"),{isMainThread:Qq}=require("worker_threads"),{join:ei,relative:mO}=require("path"),{PACKAGE_ROOT:Nn}=P(),{tmpdir:zq,platform:Jq}=require("os");require("source-map-support").install();var Xq=["resources","server","dataLayer","components"],Ec="ts-build",Hh,jq=__filename.endsWith("tsBuild.js");if(jq){if(Qq){let r;try{Bh(ei(Nn,Ec)),r=!0}catch{}if(r)for(let n of Vq.sync(Xq.map(s=>s+"/**/*.ts"),{cwd:Nn})){let s=0,i=0;try{s=Bh(ei(Nn,n)).mtimeMs-5e3,i=Bh(ei(Nn,Ec,n.replace(/.ts$/,".js"))).mtimeMs}catch{}if(s>i){console.warn(`TypeScript ${n} is not compiled`+(i?` (TS source file was modified at ${new Date(s)} and compiled file at ${new Date(i)})`:"")+", consider enabling auto-compilation of TypeScript in your IDE), compiling now."),Hh=!0;break}}else console.log("TypeScript modules are not compiled, compiling now"),Hh=!0;if(Hh){let n=ei(Nn,"node_modules/.bin/tsc");Jq()==="win32"&&(n+=".cmd");let s=Kq(n,{cwd:Nn});if(s.stdout?.length&&console.log(s.stdout.toString()),s.stderr?.length&&console.log(s.stderr.toString()),r){let i=ei(zq(),"harperdb-tsc.pid"),o;if(xh(i))try{process.kill(+$q(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=Wq(n,["--watch"],{cwd:Nn,detached:!0,stdio:"ignore"});Yq(i,c.pid.toString()),c.unref()}}}}let e=pO.constructor,t=e._findPath;e._findPath=function(r,n,s){if(r.startsWith(".")&&!s&&n.length===1&&n[0].startsWith(Nn)&&!n[0].includes("node_modules")){let i=mO(Nn,n[0]),o;i.startsWith(Ec)?o=ei(Nn,mO(Ec,i)):o=ei(Nn,Ec,i);let c=ei(o,r),u=c+".js";if(xh(u))return u;if(c.includes(".")&&xh(c))return c}return t(r,n,s)}}});var P=g((dce,MO)=>{"use strict";var an=require("path"),Zq=require("fs"),{relative:lce,join:_ce}=an,{existsSync:eF}=Zq;function tF(){let e=__dirname;for(;!eF(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(tF,"getHDBPackageRoot");var ti=tF(),TO="js",u_=TO,rF="harperdb-config.yaml",nF="defaultConfig.yaml",sF="hdb",gO=`harperdb.${u_}`,RO=`customFunctionsServer.${u_}`,iF=`restartHdb.${u_}`,qh="HarperDB",c_="Custom Functions",l_="Clustering Hub",__="Clustering Leaf",oF="Clustering Ingest Service",aF="Clustering Reply Service",cF="foreground.pid",uF="hdb.pid",lF="data",_F={HDB:qh,CLUSTERING_HUB:l_,CLUSTERING_LEAF:__,CLUSTERING_INGEST_SERVICE:oF,CLUSTERING_REPLY_SERVICE:aF,CUSTOM_FUNCTIONS:c_,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"},dF={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},fF={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},EF={harperdb:qh,"clustering hub":l_,"clustering leaf":__,"custom functions":c_,custom_functions:c_,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers"},hF={CLUSTERING_HUB_PROC_DESCRIPTOR:l_,CLUSTERING_LEAF_PROC_DESCRIPTOR:__},Gh={HDB:an.join(ti,"server/harperdb"),CUSTOM_FUNCTIONS:an.join(ti,"server/customFunctions"),CLUSTERING_HUB:an.join(ti,"server/nats"),CLUSTERING_LEAF:an.join(ti,"server/nats")},mF={HDB:an.join(Gh.HDB,gO),CUSTOM_FUNCTIONS:an.join(Gh.CUSTOM_FUNCTIONS,RO)},pF={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:an.join(ti,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:an.join(ti,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:an.join(ti,"launchServiceScripts/launchUpdateNodes4-0-0.js")},SF={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},AO="support@harperdb.io",TF="customer-success@harperdb.io",OO=1,gF=4141,bO="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",RF="https://www.harperdb.io/product",AF=`For support, please submit a request at ${bO} or contact ${AO}`,yO=`For license support, please contact ${TF}`,OF="None of the specified records were found.",bF="hash attribute not found",yF=`Your current license only supports ${OO} role. ${yO}`,NF="Your current license only supports 3 connections to a node.",IF="127.0.0.1",wF=1,CF=/^\.$/,DF=/^\.\.$/,LF="U+002E",MF=/\//g,PF="U+002F",UF=/U\+002F/g,vF=/^U\+002E$/,BF=/^U\+002EU\+002E$/,xF="d",HF=999999,GF="*",qF="--max-old-space-size=",FF="system",kF="__hdb_hash",VF=".harperdb",$F=".hdb",YF="keys",KF="hdb_boot_properties.file",WF=".updateConfig.json",QF="SIGTSTP",zF=24,JF=6e4,XF=448,jF="blob",ZF="trash",ek="database",tk="schema",rk="transactions",nk=".count",sk="id",ik="PROCESS_NAME",NO={SETTINGS_PATH_KEY:"settings_path"},IO=require("lodash"),ok={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"},ak={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},ck={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},uk={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"},lk={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"},Ur="hdb_internal:",_k={CREATE_SCHEMA:Ur+"create_schema",CREATE_TABLE:Ur+"create_table",CREATE_ATTRIBUTE:Ur+"create_attribute",ADD_USER:Ur+"add_user",ALTER_USER:Ur+"alter_user",DROP_USER:Ur+"drop_user",HDB_NODES:Ur+"hdb_nodes",HDB_USERS:Ur+"hdb_users",HDB_WORKERS:Ur+"hdb_workers",CATCHUP:Ur+"catchup",SCHEMA_CATCHUP:Ur+"schema_catchup",WORKER_ROOM:Ur+"cluster_workers"},dk={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"},fk="060493.ks",Ek=".license",hk={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},te={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"},mk={CSV:".csv",JSON:".json"},pk={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},Sk={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},hc={};hc[te.INSERT]=te.INSERT;hc[te.UPDATE]=te.UPDATE;hc[te.UPSERT]=te.UPSERT;hc[te.DELETE]=te.DELETE;var Ge=Object.create(null);Ge[te.DESCRIBE_ALL]=te.DESCRIBE_ALL;Ge[te.DESCRIBE_TABLE]=te.DESCRIBE_TABLE;Ge[te.DESCRIBE_SCHEMA]=te.DESCRIBE_SCHEMA;Ge[te.READ_LOG]=te.READ_LOG;Ge[te.ADD_NODE]=te.ADD_NODE;Ge[te.LIST_USERS]=te.LIST_USERS;Ge[te.LIST_ROLES]=te.LIST_ROLES;Ge[te.USER_INFO]=te.USER_INFO;Ge[te.SQL]=te.SQL;Ge[te.GET_JOB]=te.GET_JOB;Ge[te.SEARCH_JOBS_BY_START_DATE]=te.SEARCH_JOBS_BY_START_DATE;Ge[te.DELETE_FILES_BEFORE]=te.DELETE_FILES_BEFORE;Ge[te.EXPORT_LOCAL]=te.EXPORT_LOCAL;Ge[te.EXPORT_TO_S3]=te.EXPORT_TO_S3;Ge[te.CLUSTER_STATUS]=te.CLUSTER_STATUS;Ge[te.REMOVE_NODE]=te.REMOVE_NODE;Ge[te.RESTART]=te.RESTART;Ge[te.CUSTOM_FUNCTIONS_STATUS]=te.CUSTOM_FUNCTIONS_STATUS;Ge[te.GET_CUSTOM_FUNCTIONS]=te.GET_CUSTOM_FUNCTIONS;Ge[te.GET_CUSTOM_FUNCTION]=te.GET_CUSTOM_FUNCTION;Ge[te.SET_CUSTOM_FUNCTION]=te.SET_CUSTOM_FUNCTION;Ge[te.DROP_CUSTOM_FUNCTION]=te.DROP_CUSTOM_FUNCTION;Ge[te.ADD_CUSTOM_FUNCTION_PROJECT]=te.ADD_CUSTOM_FUNCTION_PROJECT;Ge[te.DROP_CUSTOM_FUNCTION_PROJECT]=te.DROP_CUSTOM_FUNCTION_PROJECT;Ge[te.PACKAGE_CUSTOM_FUNCTION_PROJECT]=te.PACKAGE_CUSTOM_FUNCTION_PROJECT;Ge[te.DEPLOY_CUSTOM_FUNCTION_PROJECT]=te.DEPLOY_CUSTOM_FUNCTION_PROJECT;var Tk={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"},gk={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},wO={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"},Rk=IO.invert(wO),Ak={CUSTOMFUNCTIONS_ENABLED:"customFunctions_enabled",CUSTOMFUNCTIONS_NETWORK_PORT:"customFunctions_network_port",CUSTOMFUNCTIONS_TLS_CERTIFICATE:"customFunctions_tls_certificate",CUSTOMFUNCTIONS_NETWORK_CORS:"customFunctions_network_cors",CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST:"customFunctions_network_corsAccessList",CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT:"customFunctions_network_headersTimeout",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT:"customFunctions_network_keepAliveTimeout",CUSTOMFUNCTIONS_TLS_PRIVATEKEY:"customFunctions_tls_privateKey",CUSTOMFUNCTIONS_TLS_CERT_AUTH:"customFunctions_tls_certificateAuthority",CUSTOMFUNCTIONS_NETWORK_TIMEOUT:"customFunctions_network_timeout",CUSTOMFUNCTIONS_NODEENV:"customFunctions_nodeEnv",CUSTOMFUNCTIONS_ROOT:"customFunctions_root"},w={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_MAXPARAMLENGTH:"http_maxParamLength",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_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"},CO={settings_path:NO.SETTINGS_PATH_KEY,hdb_root_key:w.ROOTPATH,hdb_root:w.ROOTPATH,rootpath:w.ROOTPATH,server_port_key:w.OPERATIONSAPI_NETWORK_PORT,server_port:w.OPERATIONSAPI_NETWORK_PORT,cert_key:w.TLS_CERTIFICATE,certificate:w.TLS_CERTIFICATE,private_key_key:w.TLS_PRIVATEKEY,private_key:w.TLS_PRIVATEKEY,http_secure_enabled_key:w.OPERATIONSAPI_NETWORK_HTTPS,https_on:w.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:w.OPERATIONSAPI_NETWORK_CORS,cors_on:w.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:w.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:w.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:w.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:w.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:w.LOGGING_LEVEL,log_level:w.LOGGING_LEVEL,log_path_key:w.LOGGING_ROOT,log_path:w.LOGGING_ROOT,clustering_node_name_key:w.CLUSTERING_NODENAME,node_name:w.CLUSTERING_NODENAME,clustering_enabled_key:w.CLUSTERING_ENABLED,clustering:w.CLUSTERING_ENABLED,max_http_threads:w.THREADS_COUNT,max_hdb_processes:w.THREADS_COUNT,server_timeout_key:w.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:w.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:w.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:w.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:w.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:w.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:w.LOGGING_AUDITLOG,disable_transaction_log:w.LOGGING_AUDITLOG,operation_token_timeout_key:w.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:w.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:w.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:w.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:w.HTTP_PORT,custom_functions_port:w.HTTP_PORT,custom_functions_directory_key:w.COMPONENTSROOT,custom_functions_directory:w.COMPONENTSROOT,max_custom_function_processes:w.THREADS_COUNT,log_to_file:w.LOGGING_FILE,log_to_stdstreams:w.LOGGING_STDSTREAMS,local_studio_on:w.LOCALSTUDIO_ENABLED,clustering_port:w.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:w.CLUSTERING_USER,clustering_enabled:w.CLUSTERING_ENABLED,clustering_hubserver_cluster_name:w.CLUSTERING_HUBSERVER_CLUSTER_NAME,clustering_hubserver_cluster_network_port:w.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_hubserver_cluster_network_routes:w.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,clustering_hubserver_leafnodes_network_port:w.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT,clustering_hubserver_network_port:w.CLUSTERING_HUBSERVER_NETWORK_PORT,clustering_leafserver_network_port:w.CLUSTERING_LEAFSERVER_NETWORK_PORT,clustering_leafserver_network_routes:w.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,clustering_leafserver_streams_maxage:w.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE,clustering_leafserver_streams_maxbytes:w.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES,clustering_leafserver_streams_maxconsumemsgs:w.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS,clustering_leafserver_streams_maxingestthreads:w.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS,clustering_leafserver_streams_maxmsgs:w.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS,clustering_leafserver_streams_path:w.CLUSTERING_LEAFSERVER_STREAMS_PATH,clustering_nodename:w.CLUSTERING_NODENAME,clustering_tls_certificate:w.CLUSTERING_TLS_CERTIFICATE,clustering_tls_privatekey:w.CLUSTERING_TLS_PRIVATEKEY,clustering_tls_certificateauthority:w.CLUSTERING_TLS_CERT_AUTH,clustering_tls_insecure:w.CLUSTERING_TLS_INSECURE,clustering_tls_verify:w.CLUSTERING_TLS_VERIFY,clustering_loglevel:w.CLUSTERING_LOGLEVEL,clustering_republishmessages:w.CLUSTERING_REPUBLISHMESSAGES,clustering_databaselevel:w.CLUSTERING_DATABASELEVEL,customfunctions_network_port:w.HTTP_PORT,customfunctions_tls_certificate:w.TLS_CERTIFICATE,customfunctions_network_cors:w.HTTP_CORS,customfunctions_network_corsaccesslist:w.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:w.HTTP_HEADERSTIMEOUT,customfunctions_network_https:w.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:w.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:w.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:w.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:w.HTTP_TIMEOUT,customfunctions_tls:w.TLS,http_threads:w.THREADS_COUNT,threads:w.THREADS_COUNT,threads_count:w.THREADS_COUNT,threads_debug:w.THREADS_DEBUG,threads_debug_startingport:w.THREADS_DEBUG_STARTINGPORT,threads_debug_port:w.THREADS_DEBUG_PORT,threads_debug_host:w.THREADS_DEBUG_HOST,threads_debug_waitfordebugger:w.THREADS_DEBUG_WAITFORDEBUGGER,threads_maxheapmemory:w.THREADS_MAXHEAPMEMORY,http_session_affinity:w.HTTP_SESSIONAFFINITY,http_compressionthreshold:w.HTTP_COMPRESSIONTHRESHOLD,http_cors:w.HTTP_CORS,http_corsaccesslist:w.HTTP_CORSACCESSLIST,http_headerstimeout:w.HTTP_HEADERSTIMEOUT,http_keepalivetimeout:w.HTTP_KEEPALIVETIMEOUT,http_maxparamlength:w.HTTP_MAXPARAMLENGTH,http_timeout:w.HTTP_TIMEOUT,http_port:w.HTTP_PORT,http_secureport:w.HTTP_SECUREPORT,http_mtls:w.HTTP_MTLS,http_mtls_user:w.HTTP_MTLS_USER,http_mtls_required:w.HTTP_MTLS_REQUIRED,http_maxheadersize:w.HTTP_MAXHEADERSIZE,http_threadrange:w.HTTP_THREADRANGE,customfunctions_processes:w.THREADS_COUNT,customfunctions_root:w.COMPONENTSROOT,localstudio_enabled:w.LOCALSTUDIO_ENABLED,logging_file:w.LOGGING_FILE,logging_level:w.LOGGING_LEVEL,logging_root:w.LOGGING_ROOT,logging_rotation_enabled:w.LOGGING_ROTATION_ENABLED,logging_rotation_compress:w.LOGGING_ROTATION_COMPRESS,logging_rotation_interval:w.LOGGING_ROTATION_INTERVAL,logging_rotation_maxsize:w.LOGGING_ROTATION_MAXSIZE,logging_rotation_path:w.LOGGING_ROTATION_PATH,logging_stdstreams:w.LOGGING_STDSTREAMS,logging_auditlog:w.LOGGING_AUDITLOG,logging_auditretention:w.LOGGING_AUDITRETENTION,logging_auditauthevents_logfailed:w.LOGGING_AUDITAUTHEVENTS_LOGFAILED,logging_auditauthevents_logsuccessful:w.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL,operationsapi_authentication_operationtokentimeout:w.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operationsapi_authentication_refreshtokentimeout:w.AUTHENTICATION_REFRESHTOKENTIMEOUT,operationsapi_network_cors:w.OPERATIONSAPI_NETWORK_CORS,operationsapi_network_corsaccesslist:w.OPERATIONSAPI_NETWORK_CORSACCESSLIST,operationsapi_network_headerstimeout:w.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,operationsapi_network_https:w.OPERATIONSAPI_NETWORK_HTTPS,operationsapi_network_keepalivetimeout:w.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,operationsapi_network_port:w.OPERATIONSAPI_NETWORK_PORT,operationsapi_network_domainsocket:w.OPERATIONSAPI_NETWORK_DOMAINSOCKET,operationsapi_network_secureport:w.OPERATIONSAPI_NETWORK_SECUREPORT,operationsapi_tls:w.OPERATIONSAPI_TLS,operationsapi_tls_certificate:w.OPERATIONSAPI_TLS_CERTIFICATE,operationsapi_tls_privatekey:w.OPERATIONSAPI_TLS_PRIVATEKEY,operationsapi_tls_certificateauthority:w.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY,operationsapi_network_timeout:w.OPERATIONSAPI_NETWORK_TIMEOUT,operationsapi_root:w.ROOTPATH,databases:w.DATABASES,storage_path:w.STORAGE_PATH,storage_maxtransactionqueuetime:w.STORAGE_MAXTRANSACTIONQUEUETIME,ignorescripts:w.IGNORE_SCRIPTS,mqtt_network_port:w.MQTT_NETWORK_PORT,mqtt_websocket:w.MQTT_WEBSOCKET,mqtt_network_secureport:w.MQTT_NETWORK_SECUREPORT,mqtt_network_mtls:w.MQTT_NETWORK_MTLS,mqtt_network_mtls_certificateAuthority:w.MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY,mqtt_network_mtls_user:w.MQTT_NETWORK_MTLS_USER,mqtt_network_mtls_required:w.MQTT_NETWORK_MTLS_REQUIRED,mqtt_requireauthentication:w.MQTT_REQUIREAUTHENTICATION,analytics_aggregatePeriod:w.ANALYTICS_AGGREGATEPERIOD,authentication_authorizelocal:w.AUTHENTICATION_AUTHORIZELOCAL,authentication_cachettl:w.AUTHENTICATION_CACHETTL,authentication_enablesessions:w.AUTHENTICATION_ENABLESESSIONS,authentication_operationtokentimeout:w.AUTHENTICATION_OPERATIONTOKENTIMEOUT,authentication_refreshtokentimeout:w.AUTHENTICATION_REFRESHTOKENTIMEOUT,componentsroot:w.COMPONENTSROOT,tls:w.TLS,tls_certificate:w.TLS_CERTIFICATE,tls_privatekey:w.TLS_PRIVATEKEY,tls_certificateauthority:w.TLS_CERTIFICATEAUTHORITY,tls_ciphers:w.TLS_CIPHERS};for(let e in w){let t=w[e];CO[t.toLowerCase()]=t}var Ok={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},bk={csv_file_load:"csv_file_load",csv_data_load:te.CSV_DATA_LOAD,csv_url_load:te.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"},yk={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"},Nk={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},Ik={VERSION_DEFAULT:"2.2.0"},wk={DEVELOPMENT:8192,DEFAULT:512},Ck={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"},Dk={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"},Lk={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},DO={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},Mk=Symbol("metadata"),Pk="__clustering__",Uk=Object.values(DO),vk=15984864e5,LO={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},Bk=IO.invert(LO),xk={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"},Hk=111,Gk=`\r
|
|
2
|
-
`,
|
|
1
|
+
"use strict";var Gq=Object.create;var Ec=Object.defineProperty;var qq=Object.getOwnPropertyDescriptor;var Fq=Object.getOwnPropertyNames;var kq=Object.getPrototypeOf,Vq=Object.prototype.hasOwnProperty;var a=(e,t)=>Ec(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),Fe=(e,t)=>{for(var r in t)Ec(e,r,{get:t[r],enumerable:!0})},mO=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Fq(t))!Vq.call(e,s)&&s!==r&&Ec(e,s,{get:()=>t[s],enumerable:!(n=qq(t,s))||n.enumerable});return e};var H=(e,t,r)=>(r=e!=null?Gq(kq(e)):{},mO(t||!e||!e.__esModule?Ec(r,"default",{value:e,enumerable:!0}):r,e)),ie=e=>mO(Ec({},"__esModule",{value:!0}),e);var TO=g((_ce,SO)=>{var $q=require("fast-glob"),{statSync:Hh,existsSync:Gh,readFileSync:Yq,writeFileSync:Kq}=require("fs"),{spawnSync:Wq,spawn:Qq,execFileSync:lce}=require("child_process"),{isMainThread:zq}=require("worker_threads"),{join:ei,relative:pO}=require("path"),{PACKAGE_ROOT:Nn}=P(),{tmpdir:Jq,platform:Xq}=require("os");require("source-map-support").install();var jq=["resources","server","dataLayer","components"],hc="ts-build",qh,Zq=__filename.endsWith("tsBuild.js");if(Zq){if(zq){let r;try{Hh(ei(Nn,hc)),r=!0}catch{}if(r)for(let n of $q.sync(jq.map(s=>s+"/**/*.ts"),{cwd:Nn})){let s=0,i=0;try{s=Hh(ei(Nn,n)).mtimeMs-5e3,i=Hh(ei(Nn,hc,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."),qh=!0;break}}else console.log("TypeScript modules are not compiled, compiling now"),qh=!0;if(qh){let n=ei(Nn,"node_modules/.bin/tsc");Xq()==="win32"&&(n+=".cmd");let s=Wq(n,{cwd:Nn});if(s.stdout?.length&&console.log(s.stdout.toString()),s.stderr?.length&&console.log(s.stderr.toString()),r){let i=ei(Jq(),"harperdb-tsc.pid"),o;if(Gh(i))try{process.kill(+Yq(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=Qq(n,["--watch"],{cwd:Nn,detached:!0,stdio:"ignore"});Kq(i,c.pid.toString()),c.unref()}}}}let e=SO.constructor,t=e._findPath;e._findPath=function(r,n,s){if(r.startsWith(".")&&!s&&n.length===1&&n[0].startsWith(Nn)&&!n[0].includes("node_modules")){let i=pO(Nn,n[0]),o;i.startsWith(hc)?o=ei(Nn,pO(hc,i)):o=ei(Nn,hc,i);let c=ei(o,r),u=c+".js";if(Gh(u))return u;if(c.includes(".")&&Gh(c))return c}return t(r,n,s)}}});var P=g((Ece,PO)=>{"use strict";var an=require("path"),eF=require("fs"),{relative:dce,join:fce}=an,{existsSync:tF}=eF;function rF(){let e=__dirname;for(;!tF(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(rF,"getHDBPackageRoot");var ti=rF(),gO="js",u_=gO,nF="harperdb-config.yaml",sF="defaultConfig.yaml",iF="hdb",RO=`harperdb.${u_}`,AO=`customFunctionsServer.${u_}`,oF=`restartHdb.${u_}`,kh="HarperDB",c_="Custom Functions",l_="Clustering Hub",__="Clustering Leaf",aF="Clustering Ingest Service",cF="Clustering Reply Service",uF="foreground.pid",lF="hdb.pid",_F="data",dF={HDB:kh,CLUSTERING_HUB:l_,CLUSTERING_LEAF:__,CLUSTERING_INGEST_SERVICE:aF,CLUSTERING_REPLY_SERVICE:cF,CUSTOM_FUNCTIONS:c_,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"},fF={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},EF={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},hF={harperdb:kh,"clustering hub":l_,"clustering leaf":__,"custom functions":c_,custom_functions:c_,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers"},mF={CLUSTERING_HUB_PROC_DESCRIPTOR:l_,CLUSTERING_LEAF_PROC_DESCRIPTOR:__},Fh={HDB:an.join(ti,"server/harperdb"),CUSTOM_FUNCTIONS:an.join(ti,"server/customFunctions"),CLUSTERING_HUB:an.join(ti,"server/nats"),CLUSTERING_LEAF:an.join(ti,"server/nats")},pF={HDB:an.join(Fh.HDB,RO),CUSTOM_FUNCTIONS:an.join(Fh.CUSTOM_FUNCTIONS,AO)},SF={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:an.join(ti,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:an.join(ti,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:an.join(ti,"launchServiceScripts/launchUpdateNodes4-0-0.js")},TF={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},OO="support@harperdb.io",gF="customer-success@harperdb.io",bO=1,RF=4141,yO="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",AF="https://www.harperdb.io/product",OF=`For support, please submit a request at ${yO} or contact ${OO}`,NO=`For license support, please contact ${gF}`,bF="None of the specified records were found.",yF="hash attribute not found",NF=`Your current license only supports ${bO} role. ${NO}`,IF="Your current license only supports 3 connections to a node.",wF="127.0.0.1",CF=1,DF=/^\.$/,LF=/^\.\.$/,MF="U+002E",PF=/\//g,UF="U+002F",vF=/U\+002F/g,BF=/^U\+002E$/,xF=/^U\+002EU\+002E$/,HF="d",GF=999999,qF="*",FF="--max-old-space-size=",kF="system",VF="__hdb_hash",$F=".harperdb",YF=".hdb",KF="keys",WF="hdb_boot_properties.file",QF=".updateConfig.json",zF="SIGTSTP",JF=24,XF=6e4,jF=448,ZF="blob",ek="trash",tk="database",rk="schema",nk="transactions",sk=".count",ik="id",ok="PROCESS_NAME",IO={SETTINGS_PATH_KEY:"settings_path"},wO=require("lodash"),ak={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"},ck={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},uk={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},lk={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"},_k={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"},Ur="hdb_internal:",dk={CREATE_SCHEMA:Ur+"create_schema",CREATE_TABLE:Ur+"create_table",CREATE_ATTRIBUTE:Ur+"create_attribute",ADD_USER:Ur+"add_user",ALTER_USER:Ur+"alter_user",DROP_USER:Ur+"drop_user",HDB_NODES:Ur+"hdb_nodes",HDB_USERS:Ur+"hdb_users",HDB_WORKERS:Ur+"hdb_workers",CATCHUP:Ur+"catchup",SCHEMA_CATCHUP:Ur+"schema_catchup",WORKER_ROOM:Ur+"cluster_workers"},fk={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"},Ek="060493.ks",hk=".license",mk={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},te={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"},pk={CSV:".csv",JSON:".json"},Sk={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},Tk={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},mc={};mc[te.INSERT]=te.INSERT;mc[te.UPDATE]=te.UPDATE;mc[te.UPSERT]=te.UPSERT;mc[te.DELETE]=te.DELETE;var Ge=Object.create(null);Ge[te.DESCRIBE_ALL]=te.DESCRIBE_ALL;Ge[te.DESCRIBE_TABLE]=te.DESCRIBE_TABLE;Ge[te.DESCRIBE_SCHEMA]=te.DESCRIBE_SCHEMA;Ge[te.READ_LOG]=te.READ_LOG;Ge[te.ADD_NODE]=te.ADD_NODE;Ge[te.LIST_USERS]=te.LIST_USERS;Ge[te.LIST_ROLES]=te.LIST_ROLES;Ge[te.USER_INFO]=te.USER_INFO;Ge[te.SQL]=te.SQL;Ge[te.GET_JOB]=te.GET_JOB;Ge[te.SEARCH_JOBS_BY_START_DATE]=te.SEARCH_JOBS_BY_START_DATE;Ge[te.DELETE_FILES_BEFORE]=te.DELETE_FILES_BEFORE;Ge[te.EXPORT_LOCAL]=te.EXPORT_LOCAL;Ge[te.EXPORT_TO_S3]=te.EXPORT_TO_S3;Ge[te.CLUSTER_STATUS]=te.CLUSTER_STATUS;Ge[te.REMOVE_NODE]=te.REMOVE_NODE;Ge[te.RESTART]=te.RESTART;Ge[te.CUSTOM_FUNCTIONS_STATUS]=te.CUSTOM_FUNCTIONS_STATUS;Ge[te.GET_CUSTOM_FUNCTIONS]=te.GET_CUSTOM_FUNCTIONS;Ge[te.GET_CUSTOM_FUNCTION]=te.GET_CUSTOM_FUNCTION;Ge[te.SET_CUSTOM_FUNCTION]=te.SET_CUSTOM_FUNCTION;Ge[te.DROP_CUSTOM_FUNCTION]=te.DROP_CUSTOM_FUNCTION;Ge[te.ADD_CUSTOM_FUNCTION_PROJECT]=te.ADD_CUSTOM_FUNCTION_PROJECT;Ge[te.DROP_CUSTOM_FUNCTION_PROJECT]=te.DROP_CUSTOM_FUNCTION_PROJECT;Ge[te.PACKAGE_CUSTOM_FUNCTION_PROJECT]=te.PACKAGE_CUSTOM_FUNCTION_PROJECT;Ge[te.DEPLOY_CUSTOM_FUNCTION_PROJECT]=te.DEPLOY_CUSTOM_FUNCTION_PROJECT;var gk={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"},Rk={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},CO={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"},Ak=wO.invert(CO),Ok={CUSTOMFUNCTIONS_ENABLED:"customFunctions_enabled",CUSTOMFUNCTIONS_NETWORK_PORT:"customFunctions_network_port",CUSTOMFUNCTIONS_TLS_CERTIFICATE:"customFunctions_tls_certificate",CUSTOMFUNCTIONS_NETWORK_CORS:"customFunctions_network_cors",CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST:"customFunctions_network_corsAccessList",CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT:"customFunctions_network_headersTimeout",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT:"customFunctions_network_keepAliveTimeout",CUSTOMFUNCTIONS_TLS_PRIVATEKEY:"customFunctions_tls_privateKey",CUSTOMFUNCTIONS_TLS_CERT_AUTH:"customFunctions_tls_certificateAuthority",CUSTOMFUNCTIONS_NETWORK_TIMEOUT:"customFunctions_network_timeout",CUSTOMFUNCTIONS_NODEENV:"customFunctions_nodeEnv",CUSTOMFUNCTIONS_ROOT:"customFunctions_root"},w={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_MAXPARAMLENGTH:"http_maxParamLength",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_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:IO.SETTINGS_PATH_KEY,hdb_root_key:w.ROOTPATH,hdb_root:w.ROOTPATH,rootpath:w.ROOTPATH,server_port_key:w.OPERATIONSAPI_NETWORK_PORT,server_port:w.OPERATIONSAPI_NETWORK_PORT,cert_key:w.TLS_CERTIFICATE,certificate:w.TLS_CERTIFICATE,private_key_key:w.TLS_PRIVATEKEY,private_key:w.TLS_PRIVATEKEY,http_secure_enabled_key:w.OPERATIONSAPI_NETWORK_HTTPS,https_on:w.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:w.OPERATIONSAPI_NETWORK_CORS,cors_on:w.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:w.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:w.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:w.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:w.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:w.LOGGING_LEVEL,log_level:w.LOGGING_LEVEL,log_path_key:w.LOGGING_ROOT,log_path:w.LOGGING_ROOT,clustering_node_name_key:w.CLUSTERING_NODENAME,node_name:w.CLUSTERING_NODENAME,clustering_enabled_key:w.CLUSTERING_ENABLED,clustering:w.CLUSTERING_ENABLED,max_http_threads:w.THREADS_COUNT,max_hdb_processes:w.THREADS_COUNT,server_timeout_key:w.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:w.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:w.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:w.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:w.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:w.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:w.LOGGING_AUDITLOG,disable_transaction_log:w.LOGGING_AUDITLOG,operation_token_timeout_key:w.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:w.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:w.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:w.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:w.HTTP_PORT,custom_functions_port:w.HTTP_PORT,custom_functions_directory_key:w.COMPONENTSROOT,custom_functions_directory:w.COMPONENTSROOT,max_custom_function_processes:w.THREADS_COUNT,log_to_file:w.LOGGING_FILE,log_to_stdstreams:w.LOGGING_STDSTREAMS,local_studio_on:w.LOCALSTUDIO_ENABLED,clustering_port:w.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:w.CLUSTERING_USER,clustering_enabled:w.CLUSTERING_ENABLED,clustering_hubserver_cluster_name:w.CLUSTERING_HUBSERVER_CLUSTER_NAME,clustering_hubserver_cluster_network_port:w.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_hubserver_cluster_network_routes:w.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,clustering_hubserver_leafnodes_network_port:w.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT,clustering_hubserver_network_port:w.CLUSTERING_HUBSERVER_NETWORK_PORT,clustering_leafserver_network_port:w.CLUSTERING_LEAFSERVER_NETWORK_PORT,clustering_leafserver_network_routes:w.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,clustering_leafserver_streams_maxage:w.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE,clustering_leafserver_streams_maxbytes:w.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES,clustering_leafserver_streams_maxconsumemsgs:w.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS,clustering_leafserver_streams_maxingestthreads:w.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS,clustering_leafserver_streams_maxmsgs:w.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS,clustering_leafserver_streams_path:w.CLUSTERING_LEAFSERVER_STREAMS_PATH,clustering_nodename:w.CLUSTERING_NODENAME,clustering_tls_certificate:w.CLUSTERING_TLS_CERTIFICATE,clustering_tls_privatekey:w.CLUSTERING_TLS_PRIVATEKEY,clustering_tls_certificateauthority:w.CLUSTERING_TLS_CERT_AUTH,clustering_tls_insecure:w.CLUSTERING_TLS_INSECURE,clustering_tls_verify:w.CLUSTERING_TLS_VERIFY,clustering_loglevel:w.CLUSTERING_LOGLEVEL,clustering_republishmessages:w.CLUSTERING_REPUBLISHMESSAGES,clustering_databaselevel:w.CLUSTERING_DATABASELEVEL,customfunctions_network_port:w.HTTP_PORT,customfunctions_tls_certificate:w.TLS_CERTIFICATE,customfunctions_network_cors:w.HTTP_CORS,customfunctions_network_corsaccesslist:w.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:w.HTTP_HEADERSTIMEOUT,customfunctions_network_https:w.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:w.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:w.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:w.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:w.HTTP_TIMEOUT,customfunctions_tls:w.TLS,http_threads:w.THREADS_COUNT,threads:w.THREADS_COUNT,threads_count:w.THREADS_COUNT,threads_debug:w.THREADS_DEBUG,threads_debug_startingport:w.THREADS_DEBUG_STARTINGPORT,threads_debug_port:w.THREADS_DEBUG_PORT,threads_debug_host:w.THREADS_DEBUG_HOST,threads_debug_waitfordebugger:w.THREADS_DEBUG_WAITFORDEBUGGER,threads_maxheapmemory:w.THREADS_MAXHEAPMEMORY,http_session_affinity:w.HTTP_SESSIONAFFINITY,http_compressionthreshold:w.HTTP_COMPRESSIONTHRESHOLD,http_cors:w.HTTP_CORS,http_corsaccesslist:w.HTTP_CORSACCESSLIST,http_headerstimeout:w.HTTP_HEADERSTIMEOUT,http_keepalivetimeout:w.HTTP_KEEPALIVETIMEOUT,http_maxparamlength:w.HTTP_MAXPARAMLENGTH,http_timeout:w.HTTP_TIMEOUT,http_port:w.HTTP_PORT,http_secureport:w.HTTP_SECUREPORT,http_mtls:w.HTTP_MTLS,http_mtls_user:w.HTTP_MTLS_USER,http_mtls_required:w.HTTP_MTLS_REQUIRED,http_maxheadersize:w.HTTP_MAXHEADERSIZE,http_threadrange:w.HTTP_THREADRANGE,customfunctions_processes:w.THREADS_COUNT,customfunctions_root:w.COMPONENTSROOT,localstudio_enabled:w.LOCALSTUDIO_ENABLED,logging_file:w.LOGGING_FILE,logging_level:w.LOGGING_LEVEL,logging_root:w.LOGGING_ROOT,logging_rotation_enabled:w.LOGGING_ROTATION_ENABLED,logging_rotation_compress:w.LOGGING_ROTATION_COMPRESS,logging_rotation_interval:w.LOGGING_ROTATION_INTERVAL,logging_rotation_maxsize:w.LOGGING_ROTATION_MAXSIZE,logging_rotation_path:w.LOGGING_ROTATION_PATH,logging_stdstreams:w.LOGGING_STDSTREAMS,logging_auditlog:w.LOGGING_AUDITLOG,logging_auditretention:w.LOGGING_AUDITRETENTION,logging_auditauthevents_logfailed:w.LOGGING_AUDITAUTHEVENTS_LOGFAILED,logging_auditauthevents_logsuccessful:w.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL,operationsapi_authentication_operationtokentimeout:w.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operationsapi_authentication_refreshtokentimeout:w.AUTHENTICATION_REFRESHTOKENTIMEOUT,operationsapi_network_cors:w.OPERATIONSAPI_NETWORK_CORS,operationsapi_network_corsaccesslist:w.OPERATIONSAPI_NETWORK_CORSACCESSLIST,operationsapi_network_headerstimeout:w.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,operationsapi_network_https:w.OPERATIONSAPI_NETWORK_HTTPS,operationsapi_network_keepalivetimeout:w.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,operationsapi_network_port:w.OPERATIONSAPI_NETWORK_PORT,operationsapi_network_domainsocket:w.OPERATIONSAPI_NETWORK_DOMAINSOCKET,operationsapi_network_secureport:w.OPERATIONSAPI_NETWORK_SECUREPORT,operationsapi_tls:w.OPERATIONSAPI_TLS,operationsapi_tls_certificate:w.OPERATIONSAPI_TLS_CERTIFICATE,operationsapi_tls_privatekey:w.OPERATIONSAPI_TLS_PRIVATEKEY,operationsapi_tls_certificateauthority:w.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY,operationsapi_network_timeout:w.OPERATIONSAPI_NETWORK_TIMEOUT,operationsapi_root:w.ROOTPATH,databases:w.DATABASES,storage_path:w.STORAGE_PATH,storage_maxtransactionqueuetime:w.STORAGE_MAXTRANSACTIONQUEUETIME,ignorescripts:w.IGNORE_SCRIPTS,mqtt_network_port:w.MQTT_NETWORK_PORT,mqtt_websocket:w.MQTT_WEBSOCKET,mqtt_network_secureport:w.MQTT_NETWORK_SECUREPORT,mqtt_network_mtls:w.MQTT_NETWORK_MTLS,mqtt_network_mtls_certificateAuthority:w.MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY,mqtt_network_mtls_user:w.MQTT_NETWORK_MTLS_USER,mqtt_network_mtls_required:w.MQTT_NETWORK_MTLS_REQUIRED,mqtt_requireauthentication:w.MQTT_REQUIREAUTHENTICATION,analytics_aggregatePeriod:w.ANALYTICS_AGGREGATEPERIOD,authentication_authorizelocal:w.AUTHENTICATION_AUTHORIZELOCAL,authentication_cachettl:w.AUTHENTICATION_CACHETTL,authentication_enablesessions:w.AUTHENTICATION_ENABLESESSIONS,authentication_operationtokentimeout:w.AUTHENTICATION_OPERATIONTOKENTIMEOUT,authentication_refreshtokentimeout:w.AUTHENTICATION_REFRESHTOKENTIMEOUT,componentsroot:w.COMPONENTSROOT,tls:w.TLS,tls_certificate:w.TLS_CERTIFICATE,tls_privatekey:w.TLS_PRIVATEKEY,tls_certificateauthority:w.TLS_CERTIFICATEAUTHORITY,tls_ciphers:w.TLS_CIPHERS};for(let e in w){let t=w[e];DO[t.toLowerCase()]=t}var bk={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},yk={csv_file_load:"csv_file_load",csv_data_load:te.CSV_DATA_LOAD,csv_url_load:te.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"},Nk={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"},Ik={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},wk={VERSION_DEFAULT:"2.2.0"},Ck={DEVELOPMENT:8192,DEFAULT:512},Dk={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"},Lk={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"},Mk={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},LO={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},Pk=Symbol("metadata"),Uk="__clustering__",vk=Object.values(LO),Bk=15984864e5,MO={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},xk=wO.invert(MO),Hk={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"},Gk=111,qk=`\r
|
|
2
|
+
`,Fk={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},kk=["*","%"],Vk="unauthorized_access",$k="func_val",Yk={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},Kk={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},Wk={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"},Qk={HDB_CORE:"hdb_core",CUSTOM_FUNCTIONS:"custom_functions"},zk={HTTP:"http"},Jk={STOPPED:"stopped",ONLINE:"online"},Xk="3.x.x",jk={SUCCESS:"success",FAILURE:"failure"},Zk={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"};PO.exports={LOCAL_HARPERDB_OPERATIONS:Ge,HDB_SUPPORT_ADDRESS:OO,HDB_SUPPORT_URL:yO,HDB_PRICING_URL:AF,SUPPORT_HELP_MSG:OF,LICENSE_HELP_MSG:NO,HDB_PROC_NAME:RO,HDB_PROC_DESCRIPTOR:kh,CLUSTERING_LEAF_PROC_DESCRIPTOR:__,CLUSTERING_HUB_PROC_DESCRIPTOR:l_,SYSTEM_SCHEMA_NAME:kF,HASH_FOLDER_NAME:VF,HDB_HOME_DIR_NAME:$F,UPDATE_FILE_NAME:QF,LICENSE_KEY_DIR_NAME:KF,BOOT_PROPS_FILE_NAME:WF,JOB_TYPE_ENUM:yk,JOB_STATUS_ENUM:mk,SYSTEM_TABLE_NAMES:lk,SYSTEM_TABLE_HASH_ATTRIBUTES:_k,OPERATIONS_ENUM:te,VALID_S3_FILE_TYPES:pk,S3_BUCKET_AUTH_KEYS:Sk,VALID_SQL_OPS_ENUM:Tk,GEO_CONVERSION_ENUM:Rk,HDB_SETTINGS_NAMES:CO,HDB_SETTINGS_NAMES_REVERSE_LOOKUP:Ak,SERVICE_ACTIONS_ENUM:gk,CLUSTER_MESSAGE_TYPE_ENUM:Nk,CLUSTER_CONNECTION_DIRECTION_ENUM:Ik,CLUSTER_EVENTS_DEFS_ENUM:Dk,PERIOD_REGEX:DF,DOUBLE_PERIOD_REGEX:LF,UNICODE_PERIOD:MF,FORWARD_SLASH_REGEX:PF,UNICODE_FORWARD_SLASH:UF,ESCAPED_FORWARD_SLASH_REGEX:vF,ESCAPED_PERIOD_REGEX:BF,ESCAPED_DOUBLE_PERIOD_REGEX:xF,REG_KEY_FILE_NAME:Ek,RESTART_TIMEOUT_MS:XF,HDB_FILE_PERMISSIONS:jF,DATABASES_DIR_NAME:tk,LEGACY_DATABASES_DIR_NAME:rk,TRANSACTIONS_DIR_NAME:nk,LIMIT_COUNT_NAME:sk,ID_ATTRIBUTE_STRING:ik,INSERT_MODULE_ENUM:ck,UPGRADE_JSON_FIELD_NAMES_ENUM:uk,RESTART_CODE:zF,RESTART_CODE_NUM:JF,CLUSTER_OPERATIONS:mc,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:fk,HDB_INTERNAL_SC_CHANNEL_PREFIX:Ur,INTERNAL_SC_CHANNELS:dk,CLUSTERING_MESSAGE_TYPES:Hk,HDB_FILE_SUFFIX:YF,BLOB_FOLDER_NAME:ZF,HDB_TRASH_DIR:ek,ORIGINATOR_SET_VALUE:Gk,LICENSE_VALUES:wk,RAM_ALLOCATION_ENUM:Ck,TIME_STAMP_NAMES_ENUM:LO,TIME_STAMP_NAMES:vk,PERMS_UPDATE_RELEASE_TIMESTAMP:Bk,SEARCH_NOT_FOUND_MESSAGE:bF,SEARCH_ATTRIBUTE_NOT_FOUND:yF,LICENSE_ROLE_DENIED_RESPONSE:NF,LICENSE_MAX_CONNS_REACHED:IF,BASIC_LICENSE_MAX_NON_CU_ROLES:bO,BASIC_LICENSE_CLUSTER_CONNECTION_LIMIT_WS_ERROR_CODE:RF,VALUE_SEARCH_COMPARATORS:MO,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:xk,LICENSE_FILE_NAME:hk,WEBSOCKET_CLOSE_CODE_DESCRIPTION_LOOKUP:Lk,NEW_LINE:qk,BASIC_LICENSE_MAX_CLUSTER_USER_ROLES:CF,MOMENT_DAYS_TAG:HF,API_TURNOVER_SEC:GF,LOOPBACK:wF,CODE_EXTENSION:u_,WILDCARD_SEARCH_VALUE:qF,NODE_ERROR_CODES:Mk,JAVASCRIPT_EXTENSION:gO,PERMS_CRUD_ENUM:Fk,UNAUTHORIZED_PERMISSION_NAME:Vk,SEARCH_WILDCARDS:kk,FUNC_VAL:$k,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:Yk,JWT_ENUM:Kk,CLUSTERING_FLAG:Uk,ITC_EVENT_TYPES:Wk,CUSTOM_FUNCTION_PROC_NAME:AO,CUSTOM_FUNCTION_PROC_DESCRIPTOR:c_,SERVICES:Qk,THREAD_TYPES:zk,MEM_SETTING_KEY:FF,HDB_RESTART_SCRIPT:oF,PROCESS_DESCRIPTORS:dF,SERVICE_SERVERS:pF,SERVICE_SERVERS_CWD:Fh,PROCESS_DESCRIPTORS_VALIDATE:hF,LAUNCH_SERVICE_SCRIPTS:SF,LOG_LEVELS:EF,PROCESS_NAME_ENV_PROP:ok,LOG_NAMES:fF,PM2_PROCESS_STATUSES:Jk,CONFIG_PARAM_MAP:DO,CONFIG_PARAMS:w,HDB_CONFIG_FILE:nF,HDB_DEFAULT_CONFIG_FILE:sF,ROLE_TYPES_ENUM:TF,BOOT_PROP_PARAMS:IO,INSTALL_PROMPTS:ak,HDB_ROOT_DIR_NAME:iF,CLUSTERING_PROCESSES:mF,FOREGROUND_PID_FILE:uF,PACKAGE_ROOT:ti,PRE_4_0_0_VERSION:Xk,DATABASES_PARAM_CONFIG:bk,METADATA_PROPERTY:Pk,AUTH_AUDIT_STATUS:jk,AUTH_AUDIT_TYPES:Zk,HDB_PID_FILE:lF,DEFAULT_DATABASE_NAME:_F,LEGACY_CONFIG_PARAMS:Ok};TO()});var Vh=g((mce,BO)=>{"use strict";var UO=require("minimist");BO.exports=eV;function eV(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=vO(process.env),n=vO(UO(process.argv))):(r=process.env,n=UO(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(eV,"assignCMDENVVariables");function vO(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(vO,"objKeysToLowerCase")});var $=g((Sce,Jh)=>{"use strict";var Hi=require("fs-extra"),{workerData:tV,threadId:rV}=require("worker_threads"),Ts=require("path"),GO=require("yaml"),qO=require("properties-reader"),Tt=P(),xO=Vh(),nV=require("os"),{PACKAGE_ROOT:Yh}=P(),{_assignPackageExport:sV}=require("../index"),Sc={};for(let e in console)Sc[e]||(Sc[e]=console[e]);var _r={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},FO={STDOUT:"stdOut",STDERR:"stdErr"},iV=Ts.join(Yh,"logs"),oV=Ts.join(Yh,"config/yaml/",Tt.HDB_DEFAULT_CONFIG_FILE),aV=1e4,Ss,zn,lr,d_,f_,Tc,Vo,pc;pc===void 0&&kO();Jh.exports={notify:YO,fatal:KO,error:gc,warn:zh,info:E_,debug:Qh,trace:Wh,setLogLevel:EV,log_level:lr,loggerWithTag:cV,suppressLogging:uV,initLogSettings:kO,setupConsoleLogging:VO,logCustomLevel:dV,closeLogFile:Kh,getLogFilePath:()=>Tc,OUTPUTS:FO,AuthAuditLog:pV};sV("logger",Jh.exports);function kO(e=!1){try{if(pc===void 0||e){Kh();let t=fV(),r=xO(["ROOTPATH"]);try{pc=qO(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!Hi.pathExistsSync(Ts.join(r.ROOTPATH,Tt.HDB_CONFIG_FILE)))throw n}({level:lr,config_log_path:f_,to_file:Ss,to_stream:zn}=hV(r.ROOTPATH?Ts.join(r.ROOTPATH,Tt.HDB_CONFIG_FILE):pc.get("settings_path"))),d_=Tt.LOG_NAMES.HDB,Tc=Ts.join(f_,d_)}}catch(t){if(pc=void 0,t.code===Tt.NODE_ERROR_CODES.ENOENT||t.code===Tt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=xO(Object.keys(Tt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Tt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let u=r[o];if(c===Tt.CONFIG_PARAMS.LOGGING_LEVEL){lr=u;continue}if(c===Tt.CONFIG_PARAMS.LOGGING_STDSTREAMS){zn=u;continue}c===Tt.CONFIG_PARAMS.LOGGING_FILE&&(Ss=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=mV();Ss=Ss===void 0?s:Ss,Ss=HO(Ss),zn=zn===void 0?i:zn,zn=HO(zn),lr=lr===void 0?n:lr,f_=iV,d_=Tt.LOG_NAMES.INSTALL,Tc=Ts.join(f_,d_);return}throw gc("Error initializing log settings"),gc(t),t}process.env.DEV_MODE&&(zn=!0),VO()}a(kO,"initLogSettings");var $h=!0;function VO(){ko("error",gc),ko("warn",zh),ko("log",E_),ko("info",E_),ko("debug",Qh),ko("trace",Wh)}a(VO,"setupConsoleLogging");function ko(e,t){console[e]=function(...r){if($h&&t(...r),!/PM2 log:|App \[/.test(r[0]))return Sc[e](...r)}}a(ko,"logConsole");function cV(e){let t={tagName:e.replace(/ /g,"-")};return{notify:r(YO),fatal:r(KO),error:r(gc),warn:r(zh),info:r(E_),debug:r(Qh),trace:r(Wh)};function r(n){return function(...s){return n(t,...s)}}}a(cV,"loggerWithTag");function uV(e){try{$h=!1,e()}finally{$h=!0}}a(uV,"suppressLogging");var lV=tV?.name?.replace(/ /g,"-")||"main";function gs(e,t){let r=new Date(Date.now()).toISOString(),n="",s=t.length,i=s-1,o=[e],c=0,u;for(typeof t[0]=="object"&&(t[0]?.tagName?(o.push(t[0]?.tagName),c++):t[0]?.serviceName&&(u=t[0]?.serviceName,c++)),o.unshift(u||lV+"/"+rV);c<s;c++){let _=t[c];if(_ instanceof Error&&_.stack)n+=_.stack,Object.keys(_).length>0&&(n+=`
|
|
3
3
|
`+JSON.stringify(_)),_.cause&&(t[c--]=_.cause,_&&(n+=`
|
|
4
4
|
Caused by:`));else if(typeof _=="object")try{n+=JSON.stringify(_)}catch{n+="Object ["+Object.keys(_)+"]"}else n+=_;c<i&&(n+=" ")}return`${r} [${o.join("] [")}]: ${n}
|
|
5
|
-
`}a(gs,"createLogRecord");function
|
|
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:SV.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(AV,"findPs")});var ft=g((gce,zO)=>{"use strict";var OV="__dbis__",bV="__txns__",yV="__environment_name__",NV="__dbi_defintion__",IV={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"},wV=["__createdtime__","__updatedtime__"],CV="\uFFFF",QO={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},DV=Object.values(QO);zO.exports={AUDIT_STORE_NAME:bV,INTERNAL_DBIS_NAME:OV,DBI_DEFINITION_NAME:NV,SEARCH_TYPES:IV,TIMESTAMP_NAMES:wV,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:yV,TRANSACTIONS_DBI_NAMES_ENUM:QO,TRANSACTIONS_DBIS:DV,OVERFLOW_MARKER:CV}});var vr=g((Rce,sb)=>{"use strict";var JO=P(),XO=ft(),jO={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},ZO=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),eb={500:ZO("There was an error processing your request."),400:"Invalid request"},LV=eb[jO.INTERNAL_SERVER_ERROR],MV={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.`},PV={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},UV={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"},vV={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 ${XO.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${XO.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"},BV={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${JO.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 ${JO.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"},tb={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"},xV={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."},HV={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`},GV={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"},qV={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},FV={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`},rb={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.`},nb={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}`},kV={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."},VV={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},$V={...tb,...UV,...MV,...xV,...HV,...GV,...qV,...FV,...BV,...rb,...nb,...kV,...VV,...PV};sb.exports={CHECK_LOGS_WRAPPER:ZO,HDB_ERROR_MSGS:$V,DEFAULT_ERROR_MSGS:eb,DEFAULT_ERROR_RESP:LV,HTTP_STATUS_CODES:jO,LMDB_ERRORS_ENUM:vV,AUTHENTICATION_ERROR_MSGS:tb,VALIDATION_ERROR_MSGS:rb,ITC_ERRORS:nb}});var se=g((Oce,ab)=>{"use strict";var $o=vr(),YV=$(),KV=P(),m_=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,ib),this.statusCode=n||$o.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||($o.DEFAULT_ERROR_MSGS[n]?$o.DEFAULT_ERROR_MSGS[n]:$o.DEFAULT_ERROR_MSGS[$o.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&&YV[s](i)}},zh=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}},Jh=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function ib(e,t,r,n=KV.LOG_LEVELS.ERROR,s=null,i=!1){if(ob(e))return e;let o=new m_(e,t,r,n,s);return i&&delete o.stack,o}a(ib,"handleHDBError");function ob(e){return e.__proto__.constructor.name===m_.name}a(ob,"isHDBError");ab.exports={isHDBError:ob,handleHDBError:ib,ClientError:zh,ServerError:Jh,hdb_errors:$o}});var Xe=g((yce,Eb)=>{"use strict";var yc=P(),WV=J(),dr=ee(),Nc=require("path"),QV=require("minimist"),cb=require("fs-extra"),ub=require("lodash");dr.initSync();var{CONFIG_PARAMS:ri,DATABASES_PARAM_CONFIG:Rc,SYSTEM_SCHEMA_NAME:p_}=yc,Ac,Oc,bc;function lb(){if(Ac!==void 0)return Ac;if(dr.getHdbBasePath()!==void 0)return Ac=dr.get(ri.STORAGE_PATH)||Nc.join(dr.getHdbBasePath(),yc.DATABASES_DIR_NAME),Ac}a(lb,"getBaseSchemaPath");function _b(){if(Oc!==void 0)return Oc;if(dr.getHdbBasePath()!==void 0)return Oc=fb(p_),Oc}a(_b,"getSystemSchemaPath");function db(){if(bc!==void 0)return bc;if(dr.getHdbBasePath()!==void 0)return bc=dr.get(yc.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Nc.join(dr.getHdbBasePath(),yc.TRANSACTIONS_DIR_NAME),bc}a(db,"getTransactionAuditStoreBasePath");function zV(e,t){let r=dr.get(ri.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Nc.join(db(),e.toString())}a(zV,"getTransactionAuditStorePath");function fb(e,t){e=e.toString(),t=t&&t.toString();let r=dr.get(yc.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Nc.join(lb(),e)}a(fb,"getSchemaPath");function JV(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,QV(process.argv));let n=r[ri.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!WV.isObject(n))throw o;i=n}for(let o of i){let c=o[p_];if(!c)continue;let u=dr.get(ri.DATABASES);u=u??{};let _=c?.tables?.[t]?.[Rc.PATH];if(_)return ub.set(u,[p_,Rc.TABLES,t,Rc.PATH],_),dr.setProperty(ri.DATABASES,u),_;let l=c?.[Rc.PATH];if(l)return ub.set(u,[p_,Rc.PATH],l),dr.setProperty(ri.DATABASES,u),l}}let s=r[ri.STORAGE_PATH.toUpperCase()];if(s){if(!cb.pathExistsSync(s))throw new Error(s+" does not exist");let i=Nc.join(s,e);return cb.mkdirsSync(i),dr.setProperty(ri.STORAGE_PATH,s),i}return _b()}a(JV,"initSystemSchemaPaths");function XV(){Ac=void 0,Oc=void 0,bc=void 0}a(XV,"resetPaths");Eb.exports={getBaseSchemaPath:lb,getSystemSchemaPath:_b,getTransactionAuditStorePath:zV,getTransactionAuditStoreBasePath:db,getSchemaPath:fb,initSystemSchemaPaths:JV,resetPaths:XV}});var Br=g((Cce,Tb)=>{"use strict";var jV=vr().LMDB_ERRORS_ENUM,Ice=require("lmdb"),ZV=ft(),wce=require("buffer").Buffer,{OVERFLOW_MARKER:hb,MAX_SEARCH_KEY_LENGTH:S_}=ZV,mb=["number","string","symbol","boolean","bigint"];function e$(e){if(e=e?.primaryStore||e,!e)throw new Error(jV.ENV_REQUIRED)}a(e$,"validateEnv");function t$(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(t$,"stringifyData");function r$(e){return e instanceof Date?e.valueOf():e}a(r$,"convertKeyValueToWrite");function n$(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(mb.includes(typeof e))return e.length>S_?[e.slice(0,S_)+hb]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(mb.includes(typeof i))i.length>S_?r.push(i.slice(0,S_)+hb):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(n$,"getIndexedValues");var T_=0,pb=0;function Sb(){pb=Date.now()-performance.now()}a(Sb,"adjustStartTime");Sb();var s$=6e4;setInterval(Sb,s$).unref();function i$(){let e=performance.now()+pb;return e>T_?(T_=e,e):(T_+=488e-6,T_)}a(i$,"getNextMonotonicTime");Tb.exports={validateEnv:e$,stringifyData:t$,convertKeyValueToWrite:r$,getNextMonotonicTime:i$,getIndexedValues:n$}});var Ic=g((Lce,gb)=>{"use strict";var o$=P().OPERATIONS_ENUM,Xh=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=o$.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};gb.exports=Xh});var wc=g((Uce,bb)=>{"use strict";var Pce=Ic(),g_=P(),jh=J(),Rb=$(),a$=require("uuid"),{handleHDBError:R_,hdb_errors:c$}=se(),{HDB_ERROR_MSGS:A_,HTTP_STATUS_CODES:O_}=c$;bb.exports=Ab;function Ab(e,t,r){for(let s=0;s<t.length;s++)Ob(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];u$(i,r,e.operation)}}a(Ab,"processRows");Ab.validateAttribute=Ob;function Ob(e){if(Buffer.byteLength(String(e))>g_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw R_(new Error,A_.ATTR_NAME_LENGTH_ERR(e),O_.BAD_REQUEST,void 0,void 0,!0);if(jh.isEmptyOrZeroLength(e)||jh.isEmpty(e.trim()))throw R_(new Error,A_.ATTR_NAME_NULLISH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}a(Ob,"validateAttribute");function u$(e,t,r){if(!e.hasOwnProperty(t)||jh.isEmptyOrZeroLength(e[t])){if(r===g_.OPERATIONS_ENUM.INSERT||r===g_.OPERATIONS_ENUM.UPSERT){e[t]=a$.v4();return}throw Rb.error("Update transaction aborted due to record with no hash value:",e),R_(new Error,A_.RECORD_MISSING_HASH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>g_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Rb.error(e),R_(new Error,A_.HASH_VAL_LENGTH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}a(u$,"validateHash")});var yb,In,Zh,Cc=Re(()=>{yb=require("events"),In=class extends yb.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new Zh;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){let t=this.queue?.shift();return t||this.emit("drained"),t}waitForDrain(){return new Promise(t=>{!this.queue||this.queue.length===0?t(!0):(this.once("drained",()=>t(!0)),this.currentDrainResolver=t,this.drainCloseListener||(this.drainCloseListener=!0,this.on("close",()=>{this.currentDrainResolver?.(!1)})))})}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},Zh=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 Gi={};Fe(Gi,{server:()=>at});var Nb,at,fr=Re(()=>{Nb=require("../index"),at={};(0,Nb._assignPackageExport)("server",at)});var rm={};Fe(rm,{loadGQLSchema:()=>d$,start:()=>tm,startOnMainThread:()=>_$});function tm({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:u,NamedTypeNode:_,StringValueNode:l}=await import("graphql"),d=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let S of d.definitions)switch(S.kind){case u.OBJECT_TYPE_DEFINITION:let B=function(U){if(U.kind==="NonNullType"){let Q=B(U.type);return Q.nullable=!1,Q}if(U.kind==="ListType")return{type:"array",elements:B(U.type)};let M={type:U.name?.value};return Object.defineProperty(M,"location",{value:U.loc.startToken}),M};a(B,"getProperty");let T=S.name.value,A=[],b={table:null,database:null,properties:A};E.set(T,b);for(let U of S.directives){if(U.name.value==="table"){for(let F of U.arguments)b[F.name.value]=F.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(U.name.value==="sealed"&&(b.sealed=!0),U.name.value==="export"){b.export=!0;for(let F of U.arguments)F.name.value==="name"&&(b.export={name:F.value.value})}}let I=!1;for(let U of S.fields){let F=B(U.type);F.name=U.name.value,A.push(F);for(let M of U.directives)if(M.name.value==="primaryKey")I?console.warn("Can not define two attributes as a primary key"):(F.isPrimaryKey=!0,I=!0);else if(M.name.value==="indexed")F.indexed=!0;else if(M.name.value==="relationship"){let Q={};for(let z of M.arguments)Q[z.name.value]=z.value.value;F.relationship=Q}else if(M.name.value==="createdTime")F.assignCreatedTime=!0;else if(M.name.value==="updatedTime")F.assignUpdatedTime=!0;else if(M.name.value==="expiresAt")F.expiresAt=!0;else if(M.name.value==="allow"){let Q=F.authorizedRoles=[];for(let z of M.arguments)z.name.value==="role"&&Q.push(z.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):l$.includes(S.type)||(0,Ib.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,em.dirname)(n),S.tableClass):i.set((0,em.dirname)(n)+"/"+(S.export.name||S.type),S.tableClass))}}var em,Ib,l$,_$,d$,wb=Re(()=>{em=require("path");Ae();Ib=H(Qe()),l$=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];a(tm,"start");_$=tm,d$=tm({ensureTable:Et}).handleFile});async function b_(e){let t=(0,Lb.pathToFileURL)(e).toString();return f$?(Dc||(Dc=E$(m$)),(await(await Dc).import(t)).namespace):import(t)}async function E$(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),Dc=new Compartment({console,Math,Date,fetch:h$,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,Db.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Yt,tables:xr,databases:ct})}};let n=await(0,Cb.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),Dc}function h$(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 m$(){return{Resource:Yt,tables:xr}}var Cb,Db,Lb,f$,Dc,nm=Re(()=>{cn();Ae();Cb=require("fs/promises"),Db=require("path"),Lb=require("url"),f$=!1;a(b_,"secureImport");a(E$,"getCompartment");a(h$,"secureOnlyFetch");a(m$,"getGlobalVars")});var im={};Fe(im,{handleFile:()=>p$});async function p$(e,t,r,n){let s=new Map,i=await b_(r);c(i.default)&&n.set((0,sm.dirname)(t),i.default),o(i,(0,sm.dirname)(t));function o(u,_){for(let l in u){let d=u[l];c(d)?n.set(_+"/"+l,d):typeof d=="object"&&o(d,_+"/"+l)}}a(o,"recurseForResources");function c(u){return typeof u=="function"&&(u.get||u.put||u.post||u.delete)}return a(c,"isResource"),s}var sm,Mb=Re(()=>{nm();sm=require("path");a(p$,"handleFile")});var am={};Fe(am,{start:()=>S$});function S$({resources:e}){e.set("login",om),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var om,Pb=Re(()=>{cn();a(S$,"start");om=class extends Yt{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={};Fe(qb,{parse:()=>um,streamAsJSON:()=>Lc,stringify:()=>qi});function Lc(e){return new cm({value:e})}function Ub(e){return console.error(e),JSON.stringify(e.toString())}function vb(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function qi(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===Hb)return Gb(e);if(t.resolution)return t.resolution.then(()=>qi(e));throw t}}function Gb(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+=Gb(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+qi(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function um(e){return R$.test(e)?T$.parse(e):JSON.parse(e)}var Bb,xb,T$,g$,Hb,cm,R$,lm=Re(()=>{Bb=require("stream"),xb=H(require("json-bigint-fixes")),T$=(0,xb.default)({useNativeBigInt:!0}),g$=1e4,Hb={};BigInt.prototype.toJSON=function(){throw Hb};a(Lc,"streamAsJSON");cm=class extends Bb.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),Ub)}catch(s){yield Ub(s)}else yield qi(t)}else yield qi(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);vb(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>g$?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 vb(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(Ub,"handleError");a(vb,"when");a(qi,"stringify");a(Gb,"jsStringify");R$=/[[,:]\s*-?\d{16,}/;a(um,"parse")});var Zb=g((Jce,jb)=>{"use strict";var _m=require("recursive-iterator"),A$=require("alasql"),dm=require("clone"),Fb=J(),{handleHDBError:kb,hdb_errors:O$}=se(),{HDB_ERROR_MSGS:Vb,HTTP_STATUS_CODES:$b}=O$,{getDatabases:b$}=(Ae(),ie(ke)),y$=["DISTINCT_ARRAY"],Yb=Symbol("validateTables"),fm=Symbol("validateTable"),zce=Symbol("getAllColumns"),Kb=Symbol("validateAllColumns"),y_=Symbol("findColumn"),Wb=Symbol("validateOrderBy"),Mc=Symbol("validateSegment"),Em=Symbol("validateColumn"),Qb=Symbol("setColumnsForTable"),zb=Symbol("checkColumnsForAsterisk"),Jb=Symbol("validateGroupBy"),Xb=Symbol("hasColumns"),hm=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[Yb](),this[zb](),this[Kb]()}[Yb](){if(this[Xb]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[fm](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[fm](t.table)})}}[Xb](){let t=!1,r=new _m(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[fm](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=b$();if(!r[t.databaseid])throw kb(new Error,Vb.SCHEMA_NOT_FOUND(t.databaseid),$b.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw kb(new Error,Vb.TABLE_NOT_FOUND(t.databaseid,t.tableid),$b.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=dm(s);i.table=dm(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)}[zb](){let t=new _m(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[Qb](r.tableid)}[Qb](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new A$.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[Kb](){this[Mc](this.statement.columns,!1),this[Mc](this.statement.joins,!1),this[Mc](this.statement.where,!1),this[Jb](this.statement.group,!1),this[Mc](this.statement.order,!0)}[Mc](t,r){if(!t)return;let n=new _m(t),s=[];for(let{node:i,path:o}of n)!Fb.isEmpty(i)&&!Fb.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[Wb](i):s.push(this[Em](i)));return s}[Jb](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&y$.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=dm(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`}[Wb](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[Em](t)}[Em](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]}};jb.exports=hm});var ty=g((jce,ey)=>{"use strict";var mm=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")}};ey.exports=mm});var ny=g((eue,ry)=>{"use strict";var pm=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};ry.exports=pm});var ay={};Fe(ay,{HAS_EXPIRATION:()=>bm,LAST_TIMESTAMP_PLACEHOLDER:()=>vc,LOCAL_TIMESTAMP:()=>N$,METADATA:()=>Pc,NO_TIMESTAMP:()=>Tm,PENDING_LOCAL_TIME:()=>ym,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>Om,RecordEncoder:()=>Am,TIMESTAMP_ASSIGN_LAST:()=>w$,TIMESTAMP_ASSIGN_NEW:()=>iy,TIMESTAMP_ASSIGN_PREVIOUS:()=>oy,TIMESTAMP_PLACEHOLDER:()=>N_,TIMESTAMP_RECORD_PREVIOUS:()=>gm,getUpdateRecord:()=>Nm,handleLocalTimeForGets:()=>D_});function D$(){return Uc[0]=Uc[0]^64,I$.getFloat64(0)}function D_(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),u=c?.value,_=u?.[Pc];return _>=0&&(c.metadataFlags=_,c.localTime=u.localTime,c.value=u.value,u.expiresAt>0&&(c.expiresAt=u.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[Pc]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let u=c.value,_=u[Pc];return _>=0&&(c.metadataFlags=_,c.localTime=u.localTime,c.value=u.value,u.expiresAt>0&&(c.expiresAt=u.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,Fi.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let u=0;u<Fi.length;u++){let _=Fi[u].deref();(!_||_.isDone||_.isCommitted)&&Fi.splice(u--,1)}},i.prototype.done.isTracked=!0}return e}function Nm(e,t,r){return function(n,s,i,o,c=-1,u,_,l,d="put",E,f){if(E||u==null?Yo=i?.localTime?gm|oy:Tm:Yo=u?i?.localTime?gm|16384:iy|16384:Tm,l>0&&(c|=bm),w_=c,Rm=l,i?.version===o&&u===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Yo>0},p;try{E&&(h.ifVersion=p=i?.version??null);let S=e.put(n,s,h);if(u){let T=_?.user?.username;if(f&&(I_=e.encoder.encode(f)),E&&i?.localTime){let A=i?.localTime,b=r.get(A);if(b){let I=Bt(b).previousLocalTime;return r.put(A,C_(o,t,n,I,T,d,I_),{ifVersion:p}),S}}r.put(vc,C_(o,t,n,i?.localTime?1:0,T,d,I_),{append:d!=="invalidate",instructedWrite:!0,ifVersion:p})}return S}catch(S){throw S.message+=" id: "+n+" options: "+h,S}}}var sy,Sm,N_,vc,Om,N$,Pc,Uc,I$,Tm,iy,w$,oy,gm,bm,ym,C$,I_,Yo,w_,Rm,Am,Fi,Bc=Re(()=>{sy=require("msgpackr");ni();Sm=H($()),N_=new Uint8Array([1,1,1,1,4,64,0,0]),vc=new Uint8Array([1,1,1,1,1,0,0,0]),Om=new Uint8Array([1,1,1,1,3,64,0,0]),N$=Symbol("local-timestamp"),Pc=Symbol("metadata"),Uc=new Uint8Array(8),I$=new DataView(Uc.buffer,0,8),Tm=0,iy=0,w$=1,oy=3,gm=4,bm=16,ym=1,Yo=0,w_=-1,Rm=0,Am=class extends sy.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(n,s){if(Yo||w_>=0){let i=0,o=Yo;o&&(i+=8,Yo=0);let c=w_,u=Rm;c>=0&&(i+=2,w_=-1,u&&(i+=8,Rm=0));let _=C$=r.call(this,n,s|2048|i);I_=_.subarray((_.start||0)+i,_.end);let l=_.start||0;return o&&(N_[4]=o,N_[5]=o>>8,_.set(N_,l),l+=8),c>=0&&(_[l++]=c,_[l++]=0,u&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(l,u)),_}else return r.call(this,n,s)}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,u;if(i===2){if(t.copy)t.copy(Uc,0,c),c+=8;else for(let d=0;d<8;d++)Uc[d]=t[c++];u=D$(),i=t[c]}let _;i<32&&(o=i,c+=2,o&bm&&(_=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8));let l=super.decode(t.subarray(c,s),s-c);return{localTime:u,value:l,[Pc]:o,expiresAt:_}}return super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(D$,"getTimestamp");a(D_,"handleLocalTimeForGets");Fi=[];setInterval(()=>{for(let e=0;e<Fi.length;e++){let t=Fi[e].deref();!t||t.isDone||t.isCommitted?Fi.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Sm.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Sm.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(Nm,"getUpdateRecord")});var xc=g((iue,uy)=>{"use strict";var cy=ee(),L$=P(),{RecordEncoder:M$}=(Bc(),ie(ay)),sue=require("fs");cy.initSync();var P$=cy.get(L$.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Im=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=P$&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:M$})}};uy.exports=Im});var Hc=g((aue,ly)=>{"use strict";var Hr=ee(),un=P();Hr.initSync();var L_=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Hr.get(un.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Hr.get(un.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Hr.get(un.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Hr.get(un.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Hr.get(un.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Hr.get(un.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Hr.get(un.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Hr.get(un.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Hr.get(un.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Hr.get(un.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Hr.get(un.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Hr.get(un.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};ly.exports=L_;L_.MAX_DBS=1e4});var ze=g((uue,gy)=>{"use strict";var Cm=require("lmdb"),wn=require("fs-extra"),Gr=require("path"),M_=Br(),fy=$(),Er=vr().LMDB_ERRORS_ENUM,P_=ny(),Dm=xc(),Ey=Hc(),si=ft(),_y=P(),{table:U$,resetDatabases:v$}=(Ae(),ie(ke)),dy=ee(),Cn=si.INTERNAL_DBIS_NAME,hy=si.DBI_DEFINITION_NAME,B$="data.mdb",x$="lock.mdb",Gc=".mdb",H$="-lock",wm=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ln(t,r),this.key_type=this.dbi[si.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[si.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new Cm.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function U_(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(U_,"pathEnvNameValidation");async function Lm(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=Gr.join(e,t+Gc);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(Gr.join(e,t,B$),wn.constants.R_OK|wn.constants.F_OK),Gr.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(Lm,"validateEnvironmentPath");function v_(e,t){if(M_.validateEnv(e),t===void 0)throw new Error(Er.DBI_NAME_REQUIRED)}a(v_,"validateEnvDBIName");async function G$(e,t,r=!1,n=!1){U_(e,t);let s=Gr.basename(e);t=t.toString();let i=dy.get(_y.CONFIG_PARAMS.DATABASES);i||dy.setProperty(_y.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await Lm(e,t,n),my(e,t,r)}catch(o){if(o.message===Er.INVALID_ENVIRONMENT){let c=Gr.join(e,t);await wn.mkdirp(n?c:e);let u=new Ey(n?c:c+Gc,!1),_=Cm.open(u);_.dbis=Object.create(null);let l=new Dm(!1);_.openDB(Cn,l),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=Mm(e,t,r);return _[si.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=_,_}throw o}}a(G$,"createEnvironment");async function q$(e,t,r,n=!0){U_(e,t),t=t.toString();let s=Gr.join(e,t);return U$({table:t,database:Gr.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(q$,"copyEnvironment");async function my(e,t,r=!1){U_(e,t),t=t.toString();let n=Mm(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 Lm(e,t),i=Gr.join(e,t+Gc),o=s!=i,c=new Ey(s,o),u=Cm.open(c);u.dbis=Object.create(null);let _=Sy(u);for(let l=0;l<_.length;l++)ln(u,_[l]);return u[si.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=u,u}a(my,"openEnvironment");async function F$(e,t,r=!1){U_(e,t),t=t.toString();let n=Gr.join(e,t+Gc),s=await Lm(e,t);if(global.lmdb_map!==void 0){let i=Mm(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await py(o),delete global.lmdb_map[i]}}await wn.remove(s),await wn.remove(s===n?s+H$:Gr.join(Gr.dirname(s),x$))}a(F$,"deleteEnvironment");async function py(e){M_.validateEnv(e);let t=e[si.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(py,"closeEnvironment");function Mm(e,t,r=!1){let s=`${Gr.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(Mm,"getCachedEnvironmentName");function k$(e){M_.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 P_,s)}catch{fy.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(k$,"listDBIDefinitions");function Sy(e){M_.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(Sy,"listDBIs");function V$(e,t){let n=ln(e,Cn).getEntry(t),s=new P_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{fy.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(V$,"getDBIDefinition");function Ty(e,t,r,n=!r){if(v_(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 Dm(r,n===!0),o=e.openDB(t,i),c=new P_(r===!0,n);return o[hy]=c,ln(e,Cn).putSync(t,c),e.dbis[t]=o,o}throw s}}a(Ty,"createDBI");function ln(e,t){if(v_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Cn?r=V$(e,t):r=new P_,r===void 0)throw new Error(Er.DBI_DOES_NOT_EXIST);let n;try{let s=new Dm(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[hy]=r,e.dbis[t]=n,n}a(ln,"openDBI");function $$(e,t){v_(e,t),t=t.toString();let r=ln(e,t),n=r.getStats();return r[si.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a($$,"statDBI");async function Y$(e,t){try{let r=Gr.join(e,t+Gc);return(await wn.stat(r)).size}catch{throw new Error(Er.INVALID_ENVIRONMENT)}}a(Y$,"environmentDataSize");function K$(e,t){if(v_(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(K$,"dropDBI");function W$(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)Ty(e,i,i!==t,i===t),n=!0;else throw o}}n&&v$()}a(W$,"initializeDBIs");gy.exports={openDBI:ln,openEnvironment:my,createEnvironment:G$,listDBIs:Sy,listDBIDefinitions:k$,createDBI:Ty,dropDBI:K$,statDBI:$$,deleteEnvironment:F$,initializeDBIs:W$,TransactionCursor:wm,environmentDataSize:Y$,copyEnvironment:q$,closeEnvironment:py}});var Ay=g((_ue,Ry)=>{"use strict";var Pm=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};Ry.exports=Pm});var by=g((fue,Oy)=>{"use strict";var Um=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}};Oy.exports=Um});var Ny=g((hue,yy)=>{"use strict";var vm=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};yy.exports=vm});var Ko=g((gue,Cy)=>{"use strict";var Q$=ze(),z$=Ay(),J$=by(),X$=Ny(),Jn=Br(),qc=vr().LMDB_ERRORS_ENUM,j$=ft(),Rs=P(),Z$=J(),e1=require("uuid"),pue=require("lmdb"),{handleHDBError:t1,hdb_errors:r1}=se(),{OVERFLOW_MARKER:Sue,MAX_SEARCH_KEY_LENGTH:Tue}=j$,Iy=ee();Iy.initSync();var B_=Iy.get(Rs.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),Bm=Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME,ki=Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function n1(e,t,r,n,s=Jn.getNextMonotonicTime()){qm(e,t,r,n),xm(e,t,r);let i=new z$,o=[],c=[];for(let u=0;u<n.length;u++){let _=n[u];wy(_,!0,s);let l=s1(e,t,r,_),d=_[t];o.push(l),c.push(d)}return Hm(o,c,n,i,s)}a(n1,"insertRecords");function s1(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let l=c([[{}]]);Array.isArray(l)&&(c=l[0][Rs.FUNC_VAL],n[o]=c)}let u=Jn.getIndexedValues(c),_=e.dbis[o];if(u){B_&&_.prefetch(u.map(l=>({key:l,value:s})),x_);for(let l=0,d=u.length;l<d;l++)_.put(u[l],s)}}B_&&e.dbis[t].prefetch([s],x_),e.dbis[t].put(s,n,n[ki])})}a(s1,"insertRecord");function i1(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(i1,"removeSkippedRecords");function wy(e,t,r){let n=r>0;(n||!Number.isInteger(e[ki]))&&(e[ki]=r||(r=Jn.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[Bm]))&&(e[Bm]=r||Jn.getNextMonotonicTime()):delete e[Bm]}a(wy,"setTimestamps");function xm(e,t,r){r.indexOf(Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),Q$.initializeDBIs(e,t,r)}a(xm,"initializeTransaction");async function o1(e,t,r,n,s=Jn.getNextMonotonicTime()){qm(e,t,r,n),xm(e,t,r);let i=new J$,o=[],c=[],u=[];for(let _=0;_<n.length;_++){let l=n[_],d=l[t],E;try{E=Gm(e,t,l,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(_);continue}c.push(E),u.push(d)}return Hm(c,u,n,i,s,o)}a(o1,"updateRecords");async function a1(e,t,r,n,s=Jn.getNextMonotonicTime()){try{qm(e,t,r,n)}catch(u){throw t1(u,u.message,r1.HTTP_STATUS_CODES.BAD_REQUEST)}xm(e,t,r);let i=new X$,o=[],c=[];for(let u=0;u<n.length;u++){let _=n[u],l;Z$.isEmpty(_[t])?(l=e1.v4(),_[t]=l):l=_[t];let d=Gm(e,t,_,l,i,!1,s);o.push(d),c.push(l)}return Hm(o,c,n,i,s)}a(a1,"upsertRecords");async function Hm(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,u=o.length;c<u;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||Jn.getNextMonotonicTime(),i1(r,i),n}a(Hm,"finalizeWrite");function Gm(e,t,r,n,s,i=!1,o){let c=e.dbis[t],u=c.getEntry(n),_=u?.value,l=_;if(!_){if(i)return!1;_={}}if(wy(r,!l,o),Number.isInteger(r[ki])&&_[ki]>r[ki])return!1;l&&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][Rs.FUNC_VAL],r[h]=p)}if(p===T)continue;let A=Jn.getIndexedValues(T);if(A){B_&&S.prefetch(A.map(b=>({key:b,value:n})),x_);for(let b=0,I=A.length;b<I;b++)S.remove(A[b],n)}if(A=Jn.getIndexedValues(p),A){B_&&S.prefetch(A.map(b=>({key:b,value:n})),x_);for(let b=0,I=A.length;b<I;b++)S.put(A[b],n)}}let f=Object.assign({},_,r);c.put(n,f,f[ki])},"do_put");return u?d=c.ifVersion(n,u.version,E):d=c.ifNoExists(n,E),d.then(f=>f?!0:Gm(e,t,r,n,s,i,o))}a(Gm,"updateUpsertRecord");function c1(e,t,r){if(Jn.validateEnv(e),t===void 0)throw new Error(qc.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(qc.WRITE_ATTRIBUTES_REQUIRED):new Error(qc.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(c1,"validateBasic");function qm(e,t,r,n){if(c1(e,t,r),!Array.isArray(n))throw n===void 0?new Error(qc.RECORDS_REQUIRED):new Error(qc.RECORDS_MUST_BE_ARRAY)}a(qm,"validateWrite");function x_(){}a(x_,"noop");Cy.exports={insertRecords:n1,updateRecords:o1,upsertRecords:a1}});var Vi=g((Aue,u1)=>{u1.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((Oue,My)=>{"use strict";var Ly=J(),Dy=P(),Wo=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Xn=require("joi"),ii={schema_format:{pattern:Wo,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},l1=Xn.alternatives(Xn.string().min(1).max(ii.schema_length.maximum).pattern(Wo).messages({"string.pattern.base":"{:#label} "+ii.schema_format.message}),Xn.number(),Xn.array()).required(),_1=Xn.alternatives(Xn.string().min(1).max(ii.schema_length.maximum).pattern(Wo).messages({"string.pattern.base":"{:#label} "+ii.schema_format.message}),Xn.number()),d1=Xn.alternatives(Xn.string().min(1).max(ii.schema_length.maximum).pattern(Wo).messages({"string.pattern.base":"{:#label} "+ii.schema_format.message}),Xn.number()).required();function f1(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ii.schema_length.maximum?`'${e}' maximum of 250 characters`:Wo.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(f1,"checkValidTable");function E1(e,t){return Ly.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(E1,"validateSchemaExists");function h1(e,t){let r=t.state.ancestors[0].schema;return Ly.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(h1,"validateTableExists");function m1(e,t){return e.toLowerCase()===Dy.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${Dy.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(m1,"validateSchemaName");My.exports={common_validators:ii,schema_regex:Wo,hdb_schema_table:l1,validateSchemaExists:E1,validateTableExists:h1,validateSchemaName:m1,checkValidTable:f1,hdb_database:_1,hdb_table:d1}});var je=g((yue,Py)=>{"use strict";var hr=require("validate.js");hr.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||hr.validators.type.checks[t](e)?null:` must be a '${t}' value`};hr.validators.type.checks={Object:function(e){return hr.isObject(e)&&!hr.isArray(e)},Array:hr.isArray,Integer:hr.isInteger,Number:hr.isNumber,String:hr.isString,Date:hr.isDate,Boolean:function(e){return typeof e=="boolean"}};hr.validators.hasValidFileExt=function(e,t){return hr.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};Py.exports={validateObject:p1,validateObjectAsync:S1,validateBySchema:T1};function p1(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=hr(e,t,{format:"flat"});return r?new Error(r):null}a(p1,"validateObject");async function S1(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await hr.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(S1,"validateObjectAsync");function T1(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(T1,"validateBySchema")});var H_=g((Iue,Uy)=>{var{common_validators:Zn}=jn(),kc=je(),Fc="is required",gt={database:{presence:!1,format:Zn.schema_format,length:Zn.schema_length},schema:{presence:!1,format:Zn.schema_format,length:Zn.schema_length},table:{presence:!0,format:Zn.schema_format,length:Zn.schema_length},attribute:{presence:!0,format:Zn.schema_format,length:Zn.schema_length},hash_attribute:{presence:!0,format:Zn.schema_format,length:Zn.schema_length}};function Vc(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(Vc,"makeAttributesStrings");function g1(e){return e=Vc(e),gt.table.presence=!1,gt.attribute.presence=!1,gt.hash_attribute.presence=!1,kc.validateObject(e,gt)}a(g1,"schema_object");function R1(e){return e=Vc(e),gt.table.presence={message:Fc},gt.attribute.presence=!1,gt.hash_attribute.presence=!1,kc.validateObject(e,gt)}a(R1,"table_object");function A1(e){return e=Vc(e),gt.table.presence={message:Fc},gt.attribute.presence=!1,kc.validateObject(e,gt)}a(A1,"create_table_object");function O1(e){return e=Vc(e),gt.table.presence={message:Fc},gt.attribute.presence={message:Fc},gt.hash_attribute.presence=!1,kc.validateObject(e,gt)}a(O1,"attribute_object");function b1(e){return e=Vc(e),gt.table.presence={message:Fc},gt.attribute.presence=!1,gt.hash_attribute.presence=!1,kc.validateObject(e,gt)}a(b1,"describe_table");function y1(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(y1,"validateTableResidence");Uy.exports={schema_object:g1,create_table_object:A1,table_object:R1,attribute_object:O1,describe_table:b1,validateTableResidence:y1}});var By=g((Cue,vy)=>{"use strict";var N1=require("uuid"),Fm=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||N1.v4(),this.schema_table=`${this.schema}.${this.table}`}};vy.exports=Fm});var G_=g((Lue,xy)=>{"use strict";var I1=By(),km=class extends I1{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}};xy.exports=km});var Gy=g((Pue,Hy)=>{"use strict";Hy.exports=C1;var w1="inserted";function C1(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===w1?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(C1,"returnObject")});var q_=g((vue,$y)=>{"use strict";var D1=P(),Vm=ze(),L1=Ko(),{getSystemSchemaPath:M1,getSchemaPath:P1}=Xe(),U1=Vi(),v1=H_(),B1=G_(),x1=Gy(),{handleHDBError:qy,hdb_errors:ky}=se(),Fy=J(),{HTTP_STATUS_CODES:H1}=ky,$m=U1.hdb_attribute,Vy=[];for(let e=0;e<$m.attributes.length;e++)Vy.push($m.attributes[e].attribute);var G1="inserted";$y.exports=q1;async function q1(e){let t=v1.attribute_object(e);if(t)throw qy(new Error,t.message,ky.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&Fy.checkGlobalSchemaTable(e.schema,e.table);if(r)throw qy(new Error,r,H1.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=Fy.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 B1(e.schema,e.table,e.attribute,e.id);try{let i=await Vm.openEnvironment(P1(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}`);Vm.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await Vm.openEnvironment(M1(),D1.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:u}=await L1.insertRecords(o,$m.hash_attribute,Vy,[s]);return x1(G1,c,{records:[s]},u)}catch(i){throw i}}a(q1,"lmdbCreateAttribute")});var Km=g((xue,Ky)=>{var{hdb_table:F1,hdb_database:Yy}=jn(),k1=je(),Ym=require("joi"),V1={undefined:"undefined",null:"null"},$1=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||V1[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"),Y1=Ym.object({database:Yy,schema:Yy,table:F1,records:Ym.array().items(Ym.object().custom($1)).required()});Ky.exports=function(e){return k1.validateBySchema(e,Y1)}});var $c=g((que,Qy)=>{"use strict";var As=J(),Wy=$(),Gue=Km(),{getDatabases:K1}=(Ae(),ie(ke)),{ClientError:$i}=se();Qy.exports=W1;function W1(e){if(As.isEmpty(e))throw new $i("invalid update parameters defined.");if(As.isEmptyOrZeroLength(e.schema))throw new $i("invalid schema specified.");if(As.isEmptyOrZeroLength(e.table))throw new $i("invalid table specified.");if(!Array.isArray(e.records))throw new $i("records must be an array");let t=K1()[e.schema]?.[e.table];if(As.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&&As.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(!As.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`);!As.isEmpty(o[r])&&o[r]!==""&&n.has(As.autoCast(o[r]))&&(o.skip=!0),n.add(As.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(W1,"insertUpdateValidate")});var Jy=g((kue,zy)=>{"use strict";var Wm=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};zy.exports=Wm});var Zy=g(($ue,jy)=>{"use strict";var Qm=ze(),Q1=$(),Xy=vr().LMDB_ERRORS_ENUM;jy.exports=z1;async function z1(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 Qm.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==Xy.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await Qm.closeEnvironment(global.lmdb_map[n]),await Qm.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==Xy.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){Q1.error(t)}}a(z1,"cleanLMDBMap")});var Os=g((Kue,nN)=>{"use strict";var Yc=require("crypto"),J1=ee(),{CONFIG_PARAMS:X1}=P(),tN="aes-256-cbc",j1=32,Z1=16,zm=64,rN=32,eY=zm+rN,eN=new Map;nN.exports={encrypt:tY,decrypt:rY,createNatsTableStreamName:nY};function tY(e){let t=Yc.randomBytes(j1),r=Yc.randomBytes(Z1),n=Yc.createCipheriv(tN,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(tY,"encrypt");function rY(e){let t=e.substr(0,zm),r=e.substr(zm,rN),n=e.substr(eY,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=Yc.createDecipheriv(tN,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(rY,"decrypt");function nY(e,t){let r=J1.get(X1.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=eN.get(r);return n||(n=Yc.createHash("md5").update(r).digest("hex"),eN.set(r,n)),n}a(nY,"createNatsTableStreamName")});var bs=g((zue,iN)=>{"use strict";var Que=qr(),Kc=$(),sN=H_(),sY=Os(),F_=J(),{handleHDBError:k_,hdb_errors:iY}=se(),{HDB_ERROR_MSGS:V_,HTTP_STATUS_CODES:Jm}=iY,oY=ee();oY.initSync();var{getDatabases:Xm}=(Ae(),ie(ke)),aY=require("fs-extra");iN.exports={describeAll:cY,describeTable:$_,describeSchema:uY};async function cY(e={}){try{let t=F_.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=Xm(),o={},c={},u=[],_=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let E=i[d];for(let f in E)try{let h;if(t||s||r)h=await $_({schema:d,table:f,exact_count:_});else if(n&&n[d].describe&&n[d].tables[f].describe){let p=n[d].tables[f].attribute_permissions;h=await $_({schema:d,table:f,exact_count:_},p)}h&&u.push(h)}catch(h){Kc.error(h)}}let l={};for(let d in u)t||s||r?(l[u[d].schema]==null&&(l[u[d].schema]={}),l[u[d].schema][u[d].name]=u[d],o[u[d].schema]&&delete o[u[d].schema]):c[u[d].schema]&&(l[u[d].schema]==null&&(l[u[d].schema]={}),l[u[d].schema][u[d].name]=u[d],o[u[d].schema]&&delete o[u[d].schema]);for(let d in o)t||s||r?l[d]={}:c[d]&&(l[d]={});return l}catch(t){return Kc.error("Got an error in describeAll"),Kc.error(t),k_(new Error,V_.DESCRIBE_ALL_ERR)}}a(cY,"describeAll");async function $_(e,t){F_.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=sN.describe_table(e);if(i)throw i;let c=Xm()[r];if(!c)throw k_(new Error,V_.SCHEMA_NOT_FOUND(e.schema),Jm.NOT_FOUND);let u=c[n];if(!u)throw k_(new Error,V_.TABLE_NOT_FOUND(e.schema,e.table),Jm.NOT_FOUND);function _(f){l.push(Object.assign({},{attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0}))}a(_,"pushAtt");let l=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),u.attributes.forEach(h=>{f[h.name]&&_(h)})}else u.attributes?.forEach(f=>_(f));let d;try{d=(await aY.stat(u.primaryStore.env.path)).size}catch(f){Kc.warn("unable to get database size",f)}let E={schema:r,name:u.tableName,hash_attribute:u.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:u.audit,schema_defined:u.schemaDefined,attributes:l,db_size:d};E.clustering_stream_name=sY.createNatsTableStreamName(E.schema,E.name);try{let f=u.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.estimated_record_range=f.estimatedRange;let h=u.auditStore;if(h)for(let p of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=p[0];if(!E.last_updated_record&&u.indices.__updatedtime__)for(let p of u.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=p}catch(f){Kc.warn(`unable to stat table dbi due to ${f}`)}return E}a($_,"descTable");async function uY(e){F_.transformReq(e);let t=sN.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=Xm()[n];if(!i)throw k_(new Error,V_.SCHEMA_NOT_FOUND(e.schema),Jm.NOT_FOUND);let o={};for(let c in i){let u;if(r&&r.tables[c]&&(u=r.tables[c]),F_.isEmpty(u)||u.describe){let _=await $_({schema:e.schema,table:c,exact_count:e.exact_count},u?u.attribute_permissions:null);_&&(o[_.name]=_)}}return o}a(uY,"describeSchema")});var ys=g((Zue,lN)=>{var lY=Vi(),{callbackify:aN,promisify:_Y}=require("util"),{getDatabases:cN}=(Ae(),ie(ke));lN.exports={setSchemaDataToGlobal:oN,getTableSchema:dY,getSystemSchema:fY,setSchemaDataToGlobalAsync:_Y(oN)};var uN=bs(),Xue=aN(uN.describeAll),jue=aN(uN.describeTable);function oN(e){global.hdb_schema=cN(),e&&e()}a(oN,"setSchemaDataToGlobal");function dY(e,t,r){let n=cN()[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(dY,"getTableSchema");function fY(){return lY}a(fY,"getSystemSchema")});var Fr=g((tle,EN)=>{"use strict";var K_=Km(),Kt=J(),EY=require("util"),W_=Dn(),hY=ys(),_N=$(),{handleHDBError:Yi,hdb_errors:mY}=se(),{HTTP_STATUS_CODES:Ki}=mY,pY=EY.promisify(hY.getTableSchema),SY="updated",dN="inserted",fN="upserted";EN.exports={insert:gY,update:RY,upsert:AY,validation:TY,flush:OY};async function TY(e){if(Kt.isEmpty(e))throw new Error("invalid update parameters defined.");if(Kt.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Kt.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await pY(e.schema,e.table),r=K_(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&&Kt.isEmptyOrZeroLength(c[n]))throw _N.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(!Kt.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw _N.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Kt.isEmpty(c[n])&&c[n]!==""&&s.has(Kt.autoCast(c[n]))&&(c.skip=!0),s.add(Kt.autoCast(c[n]));for(let u in c)i[u]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(TY,"validation");async function gY(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=K_(e);if(t)throw Yi(new Error,t.message,Ki.BAD_REQUEST);Kt.transformReq(e);let r=Kt.checkSchemaTableExist(e.schema,e.table);if(r)throw Yi(new Error,r,Ki.BAD_REQUEST);let n=await W_.createRecords(e);return Y_(dN,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(gY,"insertData");async function RY(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=K_(e);if(t)throw Yi(new Error,t.message,Ki.BAD_REQUEST);Kt.transformReq(e);let r=Kt.checkSchemaTableExist(e.schema,e.table);if(r)throw Yi(new Error,r,Ki.BAD_REQUEST);let n=await W_.updateRecords(e);return Kt.isEmpty(n.existing_rows)?Y_(SY,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Y_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(RY,"updateData");async function AY(e){if(e.operation!=="upsert")throw Yi(new Error,"invalid operation, must be upsert",Ki.INTERNAL_SERVER_ERROR);let t=K_(e);if(t)throw Yi(new Error,t.message,Ki.BAD_REQUEST);Kt.transformReq(e);let r=Kt.checkSchemaTableExist(e.schema,e.table);if(r)throw Yi(new Error,r,Ki.BAD_REQUEST);let n=await W_.upsertRecords(e);return Y_(fN,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(AY,"upsertData");function Y_(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===dN?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===fN?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Y_,"returnObject");function OY(e){return Kt.transformReq(e),W_.flush(e.schema,e.table)}a(OY,"flush")});var Zm=g((nle,pN)=>{var bY=je(),jm=require("joi"),{hdb_table:yY,hdb_database:hN}=jn(),mN={schema:hN,database:hN,table:yY},NY={date:jm.date().iso().required()},IY={timestamp:jm.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};pN.exports=function(e,t){let r=t==="timestamp"?{...mN,...IY}:{...mN,...NY},n=jm.object(r);return bY.validateBySchema(e,n)}});var gN=g((sle,TN)=>{var wY=je(),ep=require("joi"),{hdb_table:CY,hdb_database:SN}=jn(),DY=ep.object({schema:SN,database:SN,table:CY,hash_values:ep.array().required(),ids:ep.array()});TN.exports=function(e){return wY.validateBySchema(e,DY)}});var AN=g((ile,RN)=>{"use strict";var tp=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}},rp=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}},np=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};RN.exports={InsertObject:tp,NoSQLSeachObject:rp,DeleteResponseObject:np}});var ci=g((ale,IN)=>{"use strict";var bN=Zm(),LY=gN(),Wi=J(),ON=require("moment"),yN=$(),{promisify:MY,callbackify:PY}=require("util"),Qi=P(),UY=ys(),sp=MY(UY.getTableSchema),ip=Dn(),{DeleteResponseObject:vY}=AN(),{handleHDBError:oi,hdb_errors:BY}=se(),{HDB_ERROR_MSGS:Q_,HTTP_STATUS_CODES:ai}=BY,xY="records successfully deleted",HY=PY(NN);IN.exports={delete:HY,deleteRecord:NN,deleteFilesBefore:GY,deleteAuditLogsBefore:qY};async function GY(e){let t=bN(e,"date");if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);if(Wi.transformReq(e),!ON(e.date,ON.ISO_8601).isValid())throw oi(new Error,Q_.INVALID_DATE,ai.BAD_REQUEST,Qi.LOG_LEVELS.ERROR,Q_.INVALID_DATE,!0);let n=Wi.checkSchemaTableExist(e.schema,e.table);if(n)throw oi(new Error,n,ai.NOT_FOUND,Qi.LOG_LEVELS.ERROR,n,!0);let s=await ip.deleteRecordsBefore(e);if(await sp(e.schema,e.table),yN.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(GY,"deleteFilesBefore");async function qY(e){let t=bN(e,"timestamp");if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);if(Wi.transformReq(e),isNaN(e.timestamp))throw oi(new Error,Q_.INVALID_VALUE("Timestamp"),ai.BAD_REQUEST,Qi.LOG_LEVELS.ERROR,Q_.INVALID_VALUE("Timestamp"),!0);let r=Wi.checkSchemaTableExist(e.schema,e.table);if(r)throw oi(new Error,r,ai.NOT_FOUND,Qi.LOG_LEVELS.ERROR,r,!0);let n=await ip.deleteAuditLogsBefore(e);return await sp(e.schema,e.table),yN.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(qY,"deleteAuditLogsBefore");async function NN(e){e.ids&&(e.hash_values=e.ids);let t=LY(e);if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);Wi.transformReq(e);let r=Wi.checkSchemaTableExist(e.schema,e.table);if(r)throw oi(new Error,r,ai.NOT_FOUND,Qi.LOG_LEVELS.ERROR,r,!0);try{await sp(e.schema,e.table);let n=await ip.deleteRecords(e);return Wi.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${xY}`),n}catch(n){if(n.message===Qi.SEARCH_NOT_FOUND_MESSAGE){let s=new vY;return s.message=Qi.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(NN,"deleteRecord")});var z_=g((ule,DN)=>{var FY=require("crypto"),wN=9;function kY(e){let t=$Y(wN),r=CN(e+t);return t+r}a(kY,"createHash");function VY(e,t){let r=e?.substr(0,wN),n=r+CN(t+r);return e===n}a(VY,"validateHash");function $Y(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($Y,"generateSalt");function CN(e){return FY.createHash("md5").update(e).digest("hex")}a(CN,"md5");DN.exports={hash:kY,validate:VY}});var MN=g((_le,LN)=>{var op=je(),Zt={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 YY(e){return Zt.password.presence=!0,Zt.username.presence=!0,Zt.role.presence=!0,Zt.active.presence=!0,op.validateObject(e,Zt)}a(YY,"addUserValidation");function KY(e){return Zt.password.presence=!1,Zt.username.presence=!0,Zt.role.presence=!1,Zt.active.presence=!1,op.validateObject(e,Zt)}a(KY,"alterUserValidation");function WY(e){return Zt.password.presence=!1,Zt.username.presence=!0,Zt.role.presence=!1,Zt.active.presence=!1,op.validateObject(e,Zt)}a(WY,"dropUserValidation");LN.exports={addUserValidation:YY,alterUserValidation:KY,dropUserValidation:WY}});var Ve=g((Ele,UN)=>{"use strict";var{platform:fle}=require("os"),QY="nats-server.zip",ap="nats-server",zY=process.platform==="win32"?`${ap}.exe`:ap,JY=/^[^\s.,*>]+$/,PN="__request__",XY=a(e=>`${e}.${PN}`,"REQUEST_SUBJECT"),jY={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},ZY={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},eK={HUB:"hub.pid",LEAF:"leaf.pid"},tK={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},rK={SUCCESS:"success",ERROR:"error"},nK={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},sK={TXN:"txn",MSGID:"msgid"},Qo={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},iK={[Qo.ERR]:1,[Qo.WRN]:2,[Qo.INF]:3,[Qo.DBG]:4,[Qo.TRC]:5},oK={debug:"-D",trace:"-DVV"};UN.exports={NATS_SERVER_ZIP:QY,NATS_SERVER_NAME:ap,NATS_BINARY_NAME:zY,PID_FILES:eK,NATS_CONFIG_FILES:ZY,SERVER_SUFFIX:tK,NATS_TERM_CONSTRAINTS_RX:JY,REQUEST_SUFFIX:PN,UPDATE_REMOTE_RESPONSE_STATUSES:rK,CLUSTER_STATUS_STATUSES:nK,REQUEST_SUBJECT:XY,SUBJECT_PREFIXES:sK,MSG_HEADERS:jY,LOG_LEVELS:Qo,LOG_LEVEL_FLAGS:oK,LOG_LEVEL_HIERARCHY:iK}});var BN=g((mle,vN)=>{"use strict";var aK={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
|
+
`}a(gs,"createLogRecord");function Rc(e){Ss&&$O(e),zn&&process.stdout.write(e)}a(Rc,"logStdOut");function h_(e){Ss&&$O(e),zn&&process.stderr.write(e)}a(h_,"logStdErr");function $O(e){_V(),Vo?Hi.appendFileSync(Vo,e):Sc.log(e)}a($O,"logToFile");function Kh(){try{Hi.closeSync(Vo)}catch{}Vo=null}a(Kh,"closeLogFile");function _V(){if(!Vo){try{if(!Tc)debugger;Vo=Hi.openSync(Tc,"a")}catch(e){Sc.error(e)}setTimeout(()=>{Kh()},aV).unref()}}a(_V,"openLogFile");function E_(...e){_r[lr]<=_r.info&&Rc(gs("info",e))}a(E_,"info");function Wh(...e){_r[lr]<=_r.trace&&Rc(gs("trace",e))}a(Wh,"trace");function gc(...e){_r[lr]<=_r.error&&h_(gs("error",e))}a(gc,"error");function Qh(...e){_r[lr]<=_r.debug&&Rc(gs("debug",e))}a(Qh,"debug");function YO(...e){_r[lr]<=_r.notify&&Rc(gs("notify",e))}a(YO,"notify");function KO(...e){_r[lr]<=_r.fatal&&h_(gs("fatal",e))}a(KO,"fatal");function zh(...e){_r[lr]<=_r.warn&&h_(gs("warn",e))}a(zh,"warn");function dV(e,t,...r){t===FO.STDERR?h_(gs(e,r)):Rc(gs(e,r))}a(dV,"logCustomLevel");function fV(){let e;try{e=nV.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=Ts.join(e,Tt.HDB_HOME_DIR_NAME,Tt.BOOT_PROPS_FILE_NAME);return Hi.existsSync(t)||(t=Ts.join(Yh,"utility/hdb_boot_properties.file")),t}a(fV,"getPropsFilePath");function EV(e){lr=e}a(EV,"setLogLevel");function HO(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(HO,"autoCastBoolean");function hV(e){try{if(e.includes("config/settings.js")){let o=qO(e);return{level:o.get(Tt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:Ts.dirname(o.get(Tt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(Tt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(Tt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=GO.parseDocument(Hi.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===Tt.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(hV,"getLogConfig");function mV(){try{let e=GO.parseDocument(Hi.readFileSync(oV,"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(mV,"getDefaultConfig");function pV(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(pV,"AuthAuditLog")});var QO=g((gce,WO)=>{"use strict";var SV=require("util"),TV=require("path"),gV=require("child_process"),RV=SV.promisify(gV.execFile),AV=1e3*1e3*10;WO.exports={findPs:OV};async function OV(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await RV("ps",["wwxo",`pid,${r}`],{maxBuffer:AV});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:TV.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(OV,"findPs")});var ft=g((Ace,JO)=>{"use strict";var bV="__dbis__",yV="__txns__",NV="__environment_name__",IV="__dbi_defintion__",wV={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"},CV=["__createdtime__","__updatedtime__"],DV="\uFFFF",zO={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},LV=Object.values(zO);JO.exports={AUDIT_STORE_NAME:yV,INTERNAL_DBIS_NAME:bV,DBI_DEFINITION_NAME:IV,SEARCH_TYPES:wV,TIMESTAMP_NAMES:CV,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:NV,TRANSACTIONS_DBI_NAMES_ENUM:zO,TRANSACTIONS_DBIS:LV,OVERFLOW_MARKER:DV}});var vr=g((Oce,ib)=>{"use strict";var XO=P(),jO=ft(),ZO={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},eb=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),tb={500:eb("There was an error processing your request."),400:"Invalid request"},MV=tb[ZO.INTERNAL_SERVER_ERROR],PV={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.`},UV={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},vV={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"},BV={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 ${jO.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${jO.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"},xV={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${XO.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 ${XO.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"},rb={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"},HV={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."},GV={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`},qV={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"},FV={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},kV={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`},nb={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.`},sb={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}`},VV={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."},$V={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},YV={...rb,...vV,...PV,...HV,...GV,...qV,...FV,...kV,...xV,...nb,...sb,...VV,...$V,...UV};ib.exports={CHECK_LOGS_WRAPPER:eb,HDB_ERROR_MSGS:YV,DEFAULT_ERROR_MSGS:tb,DEFAULT_ERROR_RESP:MV,HTTP_STATUS_CODES:ZO,LMDB_ERRORS_ENUM:BV,AUTHENTICATION_ERROR_MSGS:rb,VALIDATION_ERROR_MSGS:nb,ITC_ERRORS:sb}});var se=g((yce,cb)=>{"use strict";var $o=vr(),KV=$(),WV=P(),m_=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,ob),this.statusCode=n||$o.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||($o.DEFAULT_ERROR_MSGS[n]?$o.DEFAULT_ERROR_MSGS[n]:$o.DEFAULT_ERROR_MSGS[$o.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&&KV[s](i)}},Xh=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}},jh=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function ob(e,t,r,n=WV.LOG_LEVELS.ERROR,s=null,i=!1){if(ab(e))return e;let o=new m_(e,t,r,n,s);return i&&delete o.stack,o}a(ob,"handleHDBError");function ab(e){return e.__proto__.constructor.name===m_.name}a(ab,"isHDBError");cb.exports={isHDBError:ab,handleHDBError:ob,ClientError:Xh,ServerError:jh,hdb_errors:$o}});var Xe=g((Ice,hb)=>{"use strict";var Nc=P(),QV=J(),dr=ee(),Ic=require("path"),zV=require("minimist"),ub=require("fs-extra"),lb=require("lodash");dr.initSync();var{CONFIG_PARAMS:ri,DATABASES_PARAM_CONFIG:Ac,SYSTEM_SCHEMA_NAME:p_}=Nc,Oc,bc,yc;function _b(){if(Oc!==void 0)return Oc;if(dr.getHdbBasePath()!==void 0)return Oc=dr.get(ri.STORAGE_PATH)||Ic.join(dr.getHdbBasePath(),Nc.DATABASES_DIR_NAME),Oc}a(_b,"getBaseSchemaPath");function db(){if(bc!==void 0)return bc;if(dr.getHdbBasePath()!==void 0)return bc=Eb(p_),bc}a(db,"getSystemSchemaPath");function fb(){if(yc!==void 0)return yc;if(dr.getHdbBasePath()!==void 0)return yc=dr.get(Nc.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Ic.join(dr.getHdbBasePath(),Nc.TRANSACTIONS_DIR_NAME),yc}a(fb,"getTransactionAuditStoreBasePath");function JV(e,t){let r=dr.get(ri.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Ic.join(fb(),e.toString())}a(JV,"getTransactionAuditStorePath");function Eb(e,t){e=e.toString(),t=t&&t.toString();let r=dr.get(Nc.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Ic.join(_b(),e)}a(Eb,"getSchemaPath");function XV(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,zV(process.argv));let n=r[ri.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!QV.isObject(n))throw o;i=n}for(let o of i){let c=o[p_];if(!c)continue;let u=dr.get(ri.DATABASES);u=u??{};let _=c?.tables?.[t]?.[Ac.PATH];if(_)return lb.set(u,[p_,Ac.TABLES,t,Ac.PATH],_),dr.setProperty(ri.DATABASES,u),_;let l=c?.[Ac.PATH];if(l)return lb.set(u,[p_,Ac.PATH],l),dr.setProperty(ri.DATABASES,u),l}}let s=r[ri.STORAGE_PATH.toUpperCase()];if(s){if(!ub.pathExistsSync(s))throw new Error(s+" does not exist");let i=Ic.join(s,e);return ub.mkdirsSync(i),dr.setProperty(ri.STORAGE_PATH,s),i}return db()}a(XV,"initSystemSchemaPaths");function jV(){Oc=void 0,bc=void 0,yc=void 0}a(jV,"resetPaths");hb.exports={getBaseSchemaPath:_b,getSystemSchemaPath:db,getTransactionAuditStorePath:JV,getTransactionAuditStoreBasePath:fb,getSchemaPath:Eb,initSystemSchemaPaths:XV,resetPaths:jV}});var Br=g((Lce,gb)=>{"use strict";var ZV=vr().LMDB_ERRORS_ENUM,Cce=require("lmdb"),e$=ft(),Dce=require("buffer").Buffer,{OVERFLOW_MARKER:mb,MAX_SEARCH_KEY_LENGTH:S_}=e$,pb=["number","string","symbol","boolean","bigint"];function t$(e){if(e=e?.primaryStore||e,!e)throw new Error(ZV.ENV_REQUIRED)}a(t$,"validateEnv");function r$(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(r$,"stringifyData");function n$(e){return e instanceof Date?e.valueOf():e}a(n$,"convertKeyValueToWrite");function s$(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(pb.includes(typeof e))return e.length>S_?[e.slice(0,S_)+mb]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(pb.includes(typeof i))i.length>S_?r.push(i.slice(0,S_)+mb):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(s$,"getIndexedValues");var T_=0,Sb=0;function Tb(){Sb=Date.now()-performance.now()}a(Tb,"adjustStartTime");Tb();var i$=6e4;setInterval(Tb,i$).unref();function o$(){let e=performance.now()+Sb;return e>T_?(T_=e,e):(T_+=488e-6,T_)}a(o$,"getNextMonotonicTime");gb.exports={validateEnv:t$,stringifyData:r$,convertKeyValueToWrite:n$,getNextMonotonicTime:o$,getIndexedValues:s$}});var wc=g((Pce,Rb)=>{"use strict";var a$=P().OPERATIONS_ENUM,Zh=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=a$.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};Rb.exports=Zh});var Cc=g((Bce,yb)=>{"use strict";var vce=wc(),g_=P(),em=J(),Ab=$(),c$=require("uuid"),{handleHDBError:R_,hdb_errors:u$}=se(),{HDB_ERROR_MSGS:A_,HTTP_STATUS_CODES:O_}=u$;yb.exports=Ob;function Ob(e,t,r){for(let s=0;s<t.length;s++)bb(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];l$(i,r,e.operation)}}a(Ob,"processRows");Ob.validateAttribute=bb;function bb(e){if(Buffer.byteLength(String(e))>g_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw R_(new Error,A_.ATTR_NAME_LENGTH_ERR(e),O_.BAD_REQUEST,void 0,void 0,!0);if(em.isEmptyOrZeroLength(e)||em.isEmpty(e.trim()))throw R_(new Error,A_.ATTR_NAME_NULLISH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}a(bb,"validateAttribute");function l$(e,t,r){if(!e.hasOwnProperty(t)||em.isEmptyOrZeroLength(e[t])){if(r===g_.OPERATIONS_ENUM.INSERT||r===g_.OPERATIONS_ENUM.UPSERT){e[t]=c$.v4();return}throw Ab.error("Update transaction aborted due to record with no hash value:",e),R_(new Error,A_.RECORD_MISSING_HASH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>g_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Ab.error(e),R_(new Error,A_.HASH_VAL_LENGTH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}a(l$,"validateHash")});var Nb,In,tm,Dc=Re(()=>{Nb=require("events"),In=class extends Nb.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new tm;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){let t=this.queue?.shift();return t||this.emit("drained"),t}waitForDrain(){return new Promise(t=>{!this.queue||this.queue.length===0?t(!0):(this.once("drained",()=>t(!0)),this.currentDrainResolver=t,this.drainCloseListener||(this.drainCloseListener=!0,this.on("close",()=>{this.currentDrainResolver?.(!1)})))})}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},tm=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 Gi={};Fe(Gi,{server:()=>at});var Ib,at,fr=Re(()=>{Ib=require("../index"),at={};(0,Ib._assignPackageExport)("server",at)});var sm={};Fe(sm,{loadGQLSchema:()=>f$,start:()=>nm,startOnMainThread:()=>d$});function nm({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:u,NamedTypeNode:_,StringValueNode:l}=await import("graphql"),d=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let S of d.definitions)switch(S.kind){case u.OBJECT_TYPE_DEFINITION:let B=function(U){if(U.kind==="NonNullType"){let Q=B(U.type);return Q.nullable=!1,Q}if(U.kind==="ListType")return{type:"array",elements:B(U.type)};let M={type:U.name?.value};return Object.defineProperty(M,"location",{value:U.loc.startToken}),M};a(B,"getProperty");let T=S.name.value,A=[],y={table:null,database:null,properties:A};E.set(T,y);for(let U of S.directives){if(U.name.value==="table"){for(let F of U.arguments)y[F.name.value]=F.value.value;y.schema&&(y.database=y.schema),y.table||(y.table=T),y.audit&&(y.audit=y.audit!=="false"),y.attributes=y.properties,f.push(y)}if(U.name.value==="sealed"&&(y.sealed=!0),U.name.value==="export"){y.export=!0;for(let F of U.arguments)F.name.value==="name"&&(y.export={name:F.value.value})}}let I=!1;for(let U of S.fields){let F=B(U.type);F.name=U.name.value,A.push(F);for(let M of U.directives)if(M.name.value==="primaryKey")I?console.warn("Can not define two attributes as a primary key"):(F.isPrimaryKey=!0,I=!0);else if(M.name.value==="indexed")F.indexed=!0;else if(M.name.value==="relationship"){let Q={};for(let z of M.arguments)Q[z.name.value]=z.value.value;F.relationship=Q}else if(M.name.value==="createdTime")F.assignCreatedTime=!0;else if(M.name.value==="updatedTime")F.assignUpdatedTime=!0;else if(M.name.value==="expiresAt")F.expiresAt=!0;else if(M.name.value==="allow"){let Q=F.authorizedRoles=[];for(let z of M.arguments)z.name.value==="role"&&Q.push(z.value.value)}}y.type=T,T==="Query"&&(h=y)}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):_$.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,rm.dirname)(n),S.tableClass):i.set((0,rm.dirname)(n)+"/"+(S.export.name||S.type),S.tableClass))}}var rm,wb,_$,d$,f$,Cb=Re(()=>{rm=require("path");Ae();wb=H(Qe()),_$=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];a(nm,"start");d$=nm,f$=nm({ensureTable:Et}).handleFile});async function b_(e){let t=(0,Mb.pathToFileURL)(e).toString();return E$?(Lc||(Lc=h$(p$)),(await(await Lc).import(t)).namespace):import(t)}async function h$(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),Lc=new Compartment({console,Math,Date,fetch:m$,...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:Yt,tables:xr,databases:ct})}};let n=await(0,Db.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),Lc}function m$(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 p$(){return{Resource:Yt,tables:xr}}var Db,Lb,Mb,E$,Lc,im=Re(()=>{cn();Ae();Db=require("fs/promises"),Lb=require("path"),Mb=require("url"),E$=!1;a(b_,"secureImport");a(h$,"getCompartment");a(m$,"secureOnlyFetch");a(p$,"getGlobalVars")});var am={};Fe(am,{handleFile:()=>S$});async function S$(e,t,r,n){let s=new Map,i=await b_(r);c(i.default)&&n.set((0,om.dirname)(t),i.default),o(i,(0,om.dirname)(t));function o(u,_){for(let l in u){let d=u[l];c(d)?n.set(_+"/"+l,d):typeof d=="object"&&o(d,_+"/"+l)}}a(o,"recurseForResources");function c(u){return typeof u=="function"&&(u.get||u.put||u.post||u.delete)}return a(c,"isResource"),s}var om,Pb=Re(()=>{im();om=require("path");a(S$,"handleFile")});var um={};Fe(um,{start:()=>T$});function T$({resources:e}){e.set("login",cm),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var cm,Ub=Re(()=>{cn();a(T$,"start");cm=class extends Yt{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 Fb={};Fe(Fb,{parse:()=>_m,streamAsJSON:()=>Mc,stringify:()=>qi});function Mc(e){return new lm({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 qi(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===Gb)return qb(e);if(t.resolution)return t.resolution.then(()=>qi(e));throw t}}function qb(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+=qb(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+qi(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function _m(e){return A$.test(e)?g$.parse(e):JSON.parse(e)}var xb,Hb,g$,R$,Gb,lm,A$,dm=Re(()=>{xb=require("stream"),Hb=H(require("json-bigint-fixes")),g$=(0,Hb.default)({useNativeBigInt:!0}),R$=1e4,Gb={};BigInt.prototype.toJSON=function(){throw Gb};a(Mc,"streamAsJSON");lm=class extends xb.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 qi(t)}else yield qi(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>R$?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(qi,"stringify");a(qb,"jsStringify");A$=/[[,:]\s*-?\d{16,}/;a(_m,"parse")});var ey=g((jce,Zb)=>{"use strict";var fm=require("recursive-iterator"),O$=require("alasql"),Em=require("clone"),kb=J(),{handleHDBError:Vb,hdb_errors:b$}=se(),{HDB_ERROR_MSGS:$b,HTTP_STATUS_CODES:Yb}=b$,{getDatabases:y$}=(Ae(),ie(ke)),N$=["DISTINCT_ARRAY"],Kb=Symbol("validateTables"),hm=Symbol("validateTable"),Xce=Symbol("getAllColumns"),Wb=Symbol("validateAllColumns"),y_=Symbol("findColumn"),Qb=Symbol("validateOrderBy"),Pc=Symbol("validateSegment"),mm=Symbol("validateColumn"),zb=Symbol("setColumnsForTable"),Jb=Symbol("checkColumnsForAsterisk"),Xb=Symbol("validateGroupBy"),jb=Symbol("hasColumns"),pm=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[jb]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[hm](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[hm](t.table)})}}[jb](){let t=!1,r=new fm(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[hm](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=y$();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=Em(s);i.table=Em(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)}[Jb](){let t=new fm(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 O$.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[Wb](){this[Pc](this.statement.columns,!1),this[Pc](this.statement.joins,!1),this[Pc](this.statement.where,!1),this[Xb](this.statement.group,!1),this[Pc](this.statement.order,!0)}[Pc](t,r){if(!t)return;let n=new fm(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[mm](i)));return s}[Xb](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&N$.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Em(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`}[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[mm](t)}[mm](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]}};Zb.exports=pm});var ry=g((eue,ty)=>{"use strict";var Sm=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=Sm});var sy=g((rue,ny)=>{"use strict";var Tm=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};ny.exports=Tm});var cy={};Fe(cy,{HAS_EXPIRATION:()=>Nm,LAST_TIMESTAMP_PLACEHOLDER:()=>Bc,LOCAL_TIMESTAMP:()=>I$,METADATA:()=>Uc,NO_TIMESTAMP:()=>Rm,PENDING_LOCAL_TIME:()=>Im,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>ym,RecordEncoder:()=>bm,TIMESTAMP_ASSIGN_LAST:()=>C$,TIMESTAMP_ASSIGN_NEW:()=>oy,TIMESTAMP_ASSIGN_PREVIOUS:()=>ay,TIMESTAMP_PLACEHOLDER:()=>N_,TIMESTAMP_RECORD_PREVIOUS:()=>Am,getUpdateRecord:()=>wm,handleLocalTimeForGets:()=>D_});function L$(){return vc[0]=vc[0]^64,w$.getFloat64(0)}function D_(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),u=c?.value,_=u?.[Uc];return _>=0&&(c.metadataFlags=_,c.localTime=u.localTime,c.value=u.value,u.expiresAt>0&&(c.expiresAt=u.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[Uc]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let u=c.value,_=u[Uc];return _>=0&&(c.metadataFlags=_,c.localTime=u.localTime,c.value=u.value,u.expiresAt>0&&(c.expiresAt=u.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,Fi.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let u=0;u<Fi.length;u++){let _=Fi[u].deref();(!_||_.isDone||_.isCommitted)&&Fi.splice(u--,1)}},i.prototype.done.isTracked=!0}return e}function wm(e,t,r){return function(n,s,i,o,c=-1,u,_,l,d="put",E,f){if(E||u==null?Yo=i?.localTime?Am|ay:Rm:Yo=u?i?.localTime?Am|16384:oy|16384:Rm,l>0&&(c|=Nm),w_=c,Om=l,i?.version===o&&u===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Yo>0},p;try{E&&(h.ifVersion=p=i?.version??null);let S=e.put(n,s,h);if(u){let T=_?.user?.username;if(f&&(I_=e.encoder.encode(f)),E&&i?.localTime){let A=i?.localTime,y=r.get(A);if(y){let I=Bt(y).previousLocalTime;return r.put(A,C_(o,t,n,I,T,d,I_),{ifVersion:p}),S}}r.put(Bc,C_(o,t,n,i?.localTime?1:0,T,d,I_),{append:d!=="invalidate",instructedWrite:!0,ifVersion:p})}return S}catch(S){throw S.message+=" id: "+n+" options: "+h,S}}}var iy,gm,N_,Bc,ym,I$,Uc,vc,w$,Rm,oy,C$,ay,Am,Nm,Im,D$,I_,Yo,w_,Om,bm,Fi,xc=Re(()=>{iy=require("msgpackr");ni();gm=H($()),N_=new Uint8Array([1,1,1,1,4,64,0,0]),Bc=new Uint8Array([1,1,1,1,1,0,0,0]),ym=new Uint8Array([1,1,1,1,3,64,0,0]),I$=Symbol("local-timestamp"),Uc=Symbol("metadata"),vc=new Uint8Array(8),w$=new DataView(vc.buffer,0,8),Rm=0,oy=0,C$=1,ay=3,Am=4,Nm=16,Im=1,Yo=0,w_=-1,Om=0,bm=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(Yo||w_>=0){let i=0,o=Yo;o&&(i+=8,Yo=0);let c=w_,u=Om;c>=0&&(i+=2,w_=-1,u&&(i+=8,Om=0));let _=D$=r.call(this,n,s|2048|i);I_=_.subarray((_.start||0)+i,_.end);let l=_.start||0;return o&&(N_[4]=o,N_[5]=o>>8,_.set(N_,l),l+=8),c>=0&&(_[l++]=c,_[l++]=0,u&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(l,u)),_}else return r.call(this,n,s)}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,u;if(i===2){if(t.copy)t.copy(vc,0,c),c+=8;else for(let d=0;d<8;d++)vc[d]=t[c++];u=L$(),i=t[c]}let _;i<32&&(o=i,c+=2,o&Nm&&(_=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8));let l=super.decode(t.subarray(c,s),s-c);return{localTime:u,value:l,[Uc]:o,expiresAt:_}}return super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(L$,"getTimestamp");a(D_,"handleLocalTimeForGets");Fi=[];setInterval(()=>{for(let e=0;e<Fi.length;e++){let t=Fi[e].deref();!t||t.isDone||t.isCommitted?Fi.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(gm.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):gm.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(wm,"getUpdateRecord")});var Hc=g((aue,ly)=>{"use strict";var uy=ee(),M$=P(),{RecordEncoder:P$}=(xc(),ie(cy)),oue=require("fs");uy.initSync();var U$=uy.get(M$.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Cm=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=U$&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:P$})}};ly.exports=Cm});var Gc=g((uue,_y)=>{"use strict";var Hr=ee(),un=P();Hr.initSync();var L_=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Hr.get(un.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Hr.get(un.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Hr.get(un.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Hr.get(un.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Hr.get(un.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Hr.get(un.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Hr.get(un.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Hr.get(un.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Hr.get(un.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Hr.get(un.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Hr.get(un.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Hr.get(un.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};_y.exports=L_;L_.MAX_DBS=1e4});var ze=g((_ue,Ry)=>{"use strict";var Lm=require("lmdb"),wn=require("fs-extra"),Gr=require("path"),M_=Br(),Ey=$(),Er=vr().LMDB_ERRORS_ENUM,P_=sy(),Mm=Hc(),hy=Gc(),si=ft(),dy=P(),{table:v$,resetDatabases:B$}=(Ae(),ie(ke)),fy=ee(),Cn=si.INTERNAL_DBIS_NAME,my=si.DBI_DEFINITION_NAME,x$="data.mdb",H$="lock.mdb",qc=".mdb",G$="-lock",Dm=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ln(t,r),this.key_type=this.dbi[si.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[si.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new Lm.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function U_(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(U_,"pathEnvNameValidation");async function Pm(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=Gr.join(e,t+qc);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(Gr.join(e,t,x$),wn.constants.R_OK|wn.constants.F_OK),Gr.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(Pm,"validateEnvironmentPath");function v_(e,t){if(M_.validateEnv(e),t===void 0)throw new Error(Er.DBI_NAME_REQUIRED)}a(v_,"validateEnvDBIName");async function q$(e,t,r=!1,n=!1){U_(e,t);let s=Gr.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 Pm(e,t,n),py(e,t,r)}catch(o){if(o.message===Er.INVALID_ENVIRONMENT){let c=Gr.join(e,t);await wn.mkdirp(n?c:e);let u=new hy(n?c:c+qc,!1),_=Lm.open(u);_.dbis=Object.create(null);let l=new Mm(!1);_.openDB(Cn,l),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=Um(e,t,r);return _[si.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=_,_}throw o}}a(q$,"createEnvironment");async function F$(e,t,r,n=!0){U_(e,t),t=t.toString();let s=Gr.join(e,t);return v$({table:t,database:Gr.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(F$,"copyEnvironment");async function py(e,t,r=!1){U_(e,t),t=t.toString();let n=Um(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 Pm(e,t),i=Gr.join(e,t+qc),o=s!=i,c=new hy(s,o),u=Lm.open(c);u.dbis=Object.create(null);let _=Ty(u);for(let l=0;l<_.length;l++)ln(u,_[l]);return u[si.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=u,u}a(py,"openEnvironment");async function k$(e,t,r=!1){U_(e,t),t=t.toString();let n=Gr.join(e,t+qc),s=await Pm(e,t);if(global.lmdb_map!==void 0){let i=Um(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+G$:Gr.join(Gr.dirname(s),H$))}a(k$,"deleteEnvironment");async function Sy(e){M_.validateEnv(e);let t=e[si.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(Sy,"closeEnvironment");function Um(e,t,r=!1){let s=`${Gr.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(Um,"getCachedEnvironmentName");function V$(e){M_.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 P_,s)}catch{Ey.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(V$,"listDBIDefinitions");function Ty(e){M_.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 $$(e,t){let n=ln(e,Cn).getEntry(t),s=new P_;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($$,"getDBIDefinition");function gy(e,t,r,n=!r){if(v_(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 Mm(r,n===!0),o=e.openDB(t,i),c=new P_(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(v_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Cn?r=$$(e,t):r=new P_,r===void 0)throw new Error(Er.DBI_DOES_NOT_EXIST);let n;try{let s=new Mm(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 Y$(e,t){v_(e,t),t=t.toString();let r=ln(e,t),n=r.getStats();return r[si.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(Y$,"statDBI");async function K$(e,t){try{let r=Gr.join(e,t+qc);return(await wn.stat(r)).size}catch{throw new Error(Er.INVALID_ENVIRONMENT)}}a(K$,"environmentDataSize");function W$(e,t){if(v_(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(W$,"dropDBI");function Q$(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&&B$()}a(Q$,"initializeDBIs");Ry.exports={openDBI:ln,openEnvironment:py,createEnvironment:q$,listDBIs:Ty,listDBIDefinitions:V$,createDBI:gy,dropDBI:W$,statDBI:Y$,deleteEnvironment:k$,initializeDBIs:Q$,TransactionCursor:Dm,environmentDataSize:K$,copyEnvironment:F$,closeEnvironment:Sy}});var Oy=g((fue,Ay)=>{"use strict";var vm=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=vm});var yy=g((hue,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((pue,Ny)=>{"use strict";var xm=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=xm});var Ko=g((Aue,Dy)=>{"use strict";var z$=ze(),J$=Oy(),X$=yy(),j$=Iy(),Jn=Br(),Fc=vr().LMDB_ERRORS_ENUM,Z$=ft(),Rs=P(),e1=J(),t1=require("uuid"),Tue=require("lmdb"),{handleHDBError:r1,hdb_errors:n1}=se(),{OVERFLOW_MARKER:gue,MAX_SEARCH_KEY_LENGTH:Rue}=Z$,wy=ee();wy.initSync();var B_=wy.get(Rs.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),Hm=Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME,ki=Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function s1(e,t,r,n,s=Jn.getNextMonotonicTime()){km(e,t,r,n),Gm(e,t,r);let i=new J$,o=[],c=[];for(let u=0;u<n.length;u++){let _=n[u];Cy(_,!0,s);let l=i1(e,t,r,_),d=_[t];o.push(l),c.push(d)}return qm(o,c,n,i,s)}a(s1,"insertRecords");function i1(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let l=c([[{}]]);Array.isArray(l)&&(c=l[0][Rs.FUNC_VAL],n[o]=c)}let u=Jn.getIndexedValues(c),_=e.dbis[o];if(u){B_&&_.prefetch(u.map(l=>({key:l,value:s})),x_);for(let l=0,d=u.length;l<d;l++)_.put(u[l],s)}}B_&&e.dbis[t].prefetch([s],x_),e.dbis[t].put(s,n,n[ki])})}a(i1,"insertRecord");function o1(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(o1,"removeSkippedRecords");function Cy(e,t,r){let n=r>0;(n||!Number.isInteger(e[ki]))&&(e[ki]=r||(r=Jn.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[Hm]))&&(e[Hm]=r||Jn.getNextMonotonicTime()):delete e[Hm]}a(Cy,"setTimestamps");function Gm(e,t,r){r.indexOf(Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),z$.initializeDBIs(e,t,r)}a(Gm,"initializeTransaction");async function a1(e,t,r,n,s=Jn.getNextMonotonicTime()){km(e,t,r,n),Gm(e,t,r);let i=new X$,o=[],c=[],u=[];for(let _=0;_<n.length;_++){let l=n[_],d=l[t],E;try{E=Fm(e,t,l,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(_);continue}c.push(E),u.push(d)}return qm(c,u,n,i,s,o)}a(a1,"updateRecords");async function c1(e,t,r,n,s=Jn.getNextMonotonicTime()){try{km(e,t,r,n)}catch(u){throw r1(u,u.message,n1.HTTP_STATUS_CODES.BAD_REQUEST)}Gm(e,t,r);let i=new j$,o=[],c=[];for(let u=0;u<n.length;u++){let _=n[u],l;e1.isEmpty(_[t])?(l=t1.v4(),_[t]=l):l=_[t];let d=Fm(e,t,_,l,i,!1,s);o.push(d),c.push(l)}return qm(o,c,n,i,s)}a(c1,"upsertRecords");async function qm(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,u=o.length;c<u;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||Jn.getNextMonotonicTime(),o1(r,i),n}a(qm,"finalizeWrite");function Fm(e,t,r,n,s,i=!1,o){let c=e.dbis[t],u=c.getEntry(n),_=u?.value,l=_;if(!_){if(i)return!1;_={}}if(Cy(r,!l,o),Number.isInteger(r[ki])&&_[ki]>r[ki])return!1;l&&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 y=p([[_]]);Array.isArray(y)&&(p=y[0][Rs.FUNC_VAL],r[h]=p)}if(p===T)continue;let A=Jn.getIndexedValues(T);if(A){B_&&S.prefetch(A.map(y=>({key:y,value:n})),x_);for(let y=0,I=A.length;y<I;y++)S.remove(A[y],n)}if(A=Jn.getIndexedValues(p),A){B_&&S.prefetch(A.map(y=>({key:y,value:n})),x_);for(let y=0,I=A.length;y<I;y++)S.put(A[y],n)}}let f=Object.assign({},_,r);c.put(n,f,f[ki])},"do_put");return u?d=c.ifVersion(n,u.version,E):d=c.ifNoExists(n,E),d.then(f=>f?!0:Fm(e,t,r,n,s,i,o))}a(Fm,"updateUpsertRecord");function u1(e,t,r){if(Jn.validateEnv(e),t===void 0)throw new Error(Fc.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Fc.WRITE_ATTRIBUTES_REQUIRED):new Error(Fc.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(u1,"validateBasic");function km(e,t,r,n){if(u1(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Fc.RECORDS_REQUIRED):new Error(Fc.RECORDS_MUST_BE_ARRAY)}a(km,"validateWrite");function x_(){}a(x_,"noop");Dy.exports={insertRecords:s1,updateRecords:a1,upsertRecords:c1}});var Vi=g((bue,l1)=>{l1.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((yue,Py)=>{"use strict";var My=J(),Ly=P(),Wo=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Xn=require("joi"),ii={schema_format:{pattern:Wo,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},_1=Xn.alternatives(Xn.string().min(1).max(ii.schema_length.maximum).pattern(Wo).messages({"string.pattern.base":"{:#label} "+ii.schema_format.message}),Xn.number(),Xn.array()).required(),d1=Xn.alternatives(Xn.string().min(1).max(ii.schema_length.maximum).pattern(Wo).messages({"string.pattern.base":"{:#label} "+ii.schema_format.message}),Xn.number()),f1=Xn.alternatives(Xn.string().min(1).max(ii.schema_length.maximum).pattern(Wo).messages({"string.pattern.base":"{:#label} "+ii.schema_format.message}),Xn.number()).required();function E1(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ii.schema_length.maximum?`'${e}' maximum of 250 characters`:Wo.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(E1,"checkValidTable");function h1(e,t){return My.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(h1,"validateSchemaExists");function m1(e,t){let r=t.state.ancestors[0].schema;return My.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(m1,"validateTableExists");function p1(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(p1,"validateSchemaName");Py.exports={common_validators:ii,schema_regex:Wo,hdb_schema_table:_1,validateSchemaExists:h1,validateTableExists:m1,validateSchemaName:p1,checkValidTable:E1,hdb_database:d1,hdb_table:f1}});var je=g((Iue,Uy)=>{"use strict";var hr=require("validate.js");hr.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||hr.validators.type.checks[t](e)?null:` must be a '${t}' value`};hr.validators.type.checks={Object:function(e){return hr.isObject(e)&&!hr.isArray(e)},Array:hr.isArray,Integer:hr.isInteger,Number:hr.isNumber,String:hr.isString,Date:hr.isDate,Boolean:function(e){return typeof e=="boolean"}};hr.validators.hasValidFileExt=function(e,t){return hr.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};Uy.exports={validateObject:S1,validateObjectAsync:T1,validateBySchema:g1};function S1(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=hr(e,t,{format:"flat"});return r?new Error(r):null}a(S1,"validateObject");async function T1(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await hr.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(T1,"validateObjectAsync");function g1(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(g1,"validateBySchema")});var H_=g((Cue,vy)=>{var{common_validators:Zn}=jn(),Vc=je(),kc="is required",gt={database:{presence:!1,format:Zn.schema_format,length:Zn.schema_length},schema:{presence:!1,format:Zn.schema_format,length:Zn.schema_length},table:{presence:!0,format:Zn.schema_format,length:Zn.schema_length},attribute:{presence:!0,format:Zn.schema_format,length:Zn.schema_length},hash_attribute:{presence:!0,format:Zn.schema_format,length:Zn.schema_length}};function $c(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($c,"makeAttributesStrings");function R1(e){return e=$c(e),gt.table.presence=!1,gt.attribute.presence=!1,gt.hash_attribute.presence=!1,Vc.validateObject(e,gt)}a(R1,"schema_object");function A1(e){return e=$c(e),gt.table.presence={message:kc},gt.attribute.presence=!1,gt.hash_attribute.presence=!1,Vc.validateObject(e,gt)}a(A1,"table_object");function O1(e){return e=$c(e),gt.table.presence={message:kc},gt.attribute.presence=!1,Vc.validateObject(e,gt)}a(O1,"create_table_object");function b1(e){return e=$c(e),gt.table.presence={message:kc},gt.attribute.presence={message:kc},gt.hash_attribute.presence=!1,Vc.validateObject(e,gt)}a(b1,"attribute_object");function y1(e){return e=$c(e),gt.table.presence={message:kc},gt.attribute.presence=!1,gt.hash_attribute.presence=!1,Vc.validateObject(e,gt)}a(y1,"describe_table");function N1(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(N1,"validateTableResidence");vy.exports={schema_object:R1,create_table_object:O1,table_object:A1,attribute_object:b1,describe_table:y1,validateTableResidence:N1}});var xy=g((Lue,By)=>{"use strict";var I1=require("uuid"),Vm=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||I1.v4(),this.schema_table=`${this.schema}.${this.table}`}};By.exports=Vm});var G_=g((Pue,Hy)=>{"use strict";var w1=xy(),$m=class extends w1{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=$m});var qy=g((vue,Gy)=>{"use strict";Gy.exports=D1;var C1="inserted";function D1(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===C1?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(D1,"returnObject")});var q_=g((xue,Yy)=>{"use strict";var L1=P(),Ym=ze(),M1=Ko(),{getSystemSchemaPath:P1,getSchemaPath:U1}=Xe(),v1=Vi(),B1=H_(),x1=G_(),H1=qy(),{handleHDBError:Fy,hdb_errors:Vy}=se(),ky=J(),{HTTP_STATUS_CODES:G1}=Vy,Km=v1.hdb_attribute,$y=[];for(let e=0;e<Km.attributes.length;e++)$y.push(Km.attributes[e].attribute);var q1="inserted";Yy.exports=F1;async function F1(e){let t=B1.attribute_object(e);if(t)throw Fy(new Error,t.message,Vy.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&ky.checkGlobalSchemaTable(e.schema,e.table);if(r)throw Fy(new Error,r,G1.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=ky.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 x1(e.schema,e.table,e.attribute,e.id);try{let i=await Ym.openEnvironment(U1(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}`);Ym.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await Ym.openEnvironment(P1(),L1.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:u}=await M1.insertRecords(o,Km.hash_attribute,$y,[s]);return H1(q1,c,{records:[s]},u)}catch(i){throw i}}a(F1,"lmdbCreateAttribute")});var Qm=g((Gue,Wy)=>{var{hdb_table:k1,hdb_database:Ky}=jn(),V1=je(),Wm=require("joi"),$1={undefined:"undefined",null:"null"},Y1=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||$1[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"),K1=Wm.object({database:Ky,schema:Ky,table:k1,records:Wm.array().items(Wm.object().custom(Y1)).required()});Wy.exports=function(e){return V1.validateBySchema(e,K1)}});var Yc=g((kue,zy)=>{"use strict";var As=J(),Qy=$(),Fue=Qm(),{getDatabases:W1}=(Ae(),ie(ke)),{ClientError:$i}=se();zy.exports=Q1;function Q1(e){if(As.isEmpty(e))throw new $i("invalid update parameters defined.");if(As.isEmptyOrZeroLength(e.schema))throw new $i("invalid schema specified.");if(As.isEmptyOrZeroLength(e.table))throw new $i("invalid table specified.");if(!Array.isArray(e.records))throw new $i("records must be an array");let t=W1()[e.schema]?.[e.table];if(As.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&&As.isEmptyOrZeroLength(o[r]))throw Qy.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(!As.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw Qy.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`);!As.isEmpty(o[r])&&o[r]!==""&&n.has(As.autoCast(o[r]))&&(o.skip=!0),n.add(As.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(Q1,"insertUpdateValidate")});var Xy=g(($ue,Jy)=>{"use strict";var zm=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};Jy.exports=zm});var eN=g((Kue,Zy)=>{"use strict";var Jm=ze(),z1=$(),jy=vr().LMDB_ERRORS_ENUM;Zy.exports=J1;async function J1(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 Jm.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==jy.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await Jm.closeEnvironment(global.lmdb_map[n]),await Jm.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==jy.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){z1.error(t)}}a(J1,"cleanLMDBMap")});var Os=g((Que,sN)=>{"use strict";var Kc=require("crypto"),X1=ee(),{CONFIG_PARAMS:j1}=P(),rN="aes-256-cbc",Z1=32,eY=16,Xm=64,nN=32,tY=Xm+nN,tN=new Map;sN.exports={encrypt:rY,decrypt:nY,createNatsTableStreamName:sY};function rY(e){let t=Kc.randomBytes(Z1),r=Kc.randomBytes(eY),n=Kc.createCipheriv(rN,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(rY,"encrypt");function nY(e){let t=e.substr(0,Xm),r=e.substr(Xm,nN),n=e.substr(tY,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=Kc.createDecipheriv(rN,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(nY,"decrypt");function sY(e,t){let r=X1.get(j1.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=tN.get(r);return n||(n=Kc.createHash("md5").update(r).digest("hex"),tN.set(r,n)),n}a(sY,"createNatsTableStreamName")});var bs=g((Xue,oN)=>{"use strict";var Jue=qr(),Wc=$(),iN=H_(),iY=Os(),F_=J(),{handleHDBError:k_,hdb_errors:oY}=se(),{HDB_ERROR_MSGS:V_,HTTP_STATUS_CODES:jm}=oY,aY=ee();aY.initSync();var{getDatabases:Zm}=(Ae(),ie(ke)),cY=require("fs-extra");oN.exports={describeAll:uY,describeTable:$_,describeSchema:lY};async function uY(e={}){try{let t=F_.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=Zm(),o={},c={},u=[],_=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let E=i[d];for(let f in E)try{let h;if(t||s||r)h=await $_({schema:d,table:f,exact_count:_});else if(n&&n[d].describe&&n[d].tables[f].describe){let p=n[d].tables[f].attribute_permissions;h=await $_({schema:d,table:f,exact_count:_},p)}h&&u.push(h)}catch(h){Wc.error(h)}}let l={};for(let d in u)t||s||r?(l[u[d].schema]==null&&(l[u[d].schema]={}),l[u[d].schema][u[d].name]=u[d],o[u[d].schema]&&delete o[u[d].schema]):c[u[d].schema]&&(l[u[d].schema]==null&&(l[u[d].schema]={}),l[u[d].schema][u[d].name]=u[d],o[u[d].schema]&&delete o[u[d].schema]);for(let d in o)t||s||r?l[d]={}:c[d]&&(l[d]={});return l}catch(t){return Wc.error("Got an error in describeAll"),Wc.error(t),k_(new Error,V_.DESCRIBE_ALL_ERR)}}a(uY,"describeAll");async function $_(e,t){F_.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=iN.describe_table(e);if(i)throw i;let c=Zm()[r];if(!c)throw k_(new Error,V_.SCHEMA_NOT_FOUND(e.schema),jm.NOT_FOUND);let u=c[n];if(!u)throw k_(new Error,V_.TABLE_NOT_FOUND(e.schema,e.table),jm.NOT_FOUND);function _(f){l.push(Object.assign({},{attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0}))}a(_,"pushAtt");let l=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),u.attributes.forEach(h=>{f[h.name]&&_(h)})}else u.attributes?.forEach(f=>_(f));let d;try{d=(await cY.stat(u.primaryStore.env.path)).size}catch(f){Wc.warn("unable to get database size",f)}let E={schema:r,name:u.tableName,hash_attribute:u.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:u.audit,schema_defined:u.schemaDefined,attributes:l,db_size:d};E.clustering_stream_name=iY.createNatsTableStreamName(E.schema,E.name);try{let f=u.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.estimated_record_range=f.estimatedRange;let h=u.auditStore;if(h)for(let p of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=p[0];if(!E.last_updated_record&&u.indices.__updatedtime__)for(let p of u.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=p}catch(f){Wc.warn(`unable to stat table dbi due to ${f}`)}return E}a($_,"descTable");async function lY(e){F_.transformReq(e);let t=iN.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=Zm()[n];if(!i)throw k_(new Error,V_.SCHEMA_NOT_FOUND(e.schema),jm.NOT_FOUND);let o={};for(let c in i){let u;if(r&&r.tables[c]&&(u=r.tables[c]),F_.isEmpty(u)||u.describe){let _=await $_({schema:e.schema,table:c,exact_count:e.exact_count},u?u.attribute_permissions:null);_&&(o[_.name]=_)}}return o}a(lY,"describeSchema")});var ys=g((tle,_N)=>{var _Y=Vi(),{callbackify:cN,promisify:dY}=require("util"),{getDatabases:uN}=(Ae(),ie(ke));_N.exports={setSchemaDataToGlobal:aN,getTableSchema:fY,getSystemSchema:EY,setSchemaDataToGlobalAsync:dY(aN)};var lN=bs(),Zue=cN(lN.describeAll),ele=cN(lN.describeTable);function aN(e){global.hdb_schema=uN(),e&&e()}a(aN,"setSchemaDataToGlobal");function fY(e,t,r){let n=uN()[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(fY,"getTableSchema");function EY(){return _Y}a(EY,"getSystemSchema")});var Fr=g((nle,hN)=>{"use strict";var K_=Qm(),Kt=J(),hY=require("util"),W_=Dn(),mY=ys(),dN=$(),{handleHDBError:Yi,hdb_errors:pY}=se(),{HTTP_STATUS_CODES:Ki}=pY,SY=hY.promisify(mY.getTableSchema),TY="updated",fN="inserted",EN="upserted";hN.exports={insert:RY,update:AY,upsert:OY,validation:gY,flush:bY};async function gY(e){if(Kt.isEmpty(e))throw new Error("invalid update parameters defined.");if(Kt.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Kt.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await SY(e.schema,e.table),r=K_(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&&Kt.isEmptyOrZeroLength(c[n]))throw dN.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(!Kt.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw dN.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Kt.isEmpty(c[n])&&c[n]!==""&&s.has(Kt.autoCast(c[n]))&&(c.skip=!0),s.add(Kt.autoCast(c[n]));for(let u in c)i[u]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(gY,"validation");async function RY(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=K_(e);if(t)throw Yi(new Error,t.message,Ki.BAD_REQUEST);Kt.transformReq(e);let r=Kt.checkSchemaTableExist(e.schema,e.table);if(r)throw Yi(new Error,r,Ki.BAD_REQUEST);let n=await W_.createRecords(e);return Y_(fN,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(RY,"insertData");async function AY(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=K_(e);if(t)throw Yi(new Error,t.message,Ki.BAD_REQUEST);Kt.transformReq(e);let r=Kt.checkSchemaTableExist(e.schema,e.table);if(r)throw Yi(new Error,r,Ki.BAD_REQUEST);let n=await W_.updateRecords(e);return Kt.isEmpty(n.existing_rows)?Y_(TY,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Y_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(AY,"updateData");async function OY(e){if(e.operation!=="upsert")throw Yi(new Error,"invalid operation, must be upsert",Ki.INTERNAL_SERVER_ERROR);let t=K_(e);if(t)throw Yi(new Error,t.message,Ki.BAD_REQUEST);Kt.transformReq(e);let r=Kt.checkSchemaTableExist(e.schema,e.table);if(r)throw Yi(new Error,r,Ki.BAD_REQUEST);let n=await W_.upsertRecords(e);return Y_(EN,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(OY,"upsertData");function Y_(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===fN?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===EN?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Y_,"returnObject");function bY(e){return Kt.transformReq(e),W_.flush(e.schema,e.table)}a(bY,"flush")});var tp=g((ile,SN)=>{var yY=je(),ep=require("joi"),{hdb_table:NY,hdb_database:mN}=jn(),pN={schema:mN,database:mN,table:NY},IY={date:ep.date().iso().required()},wY={timestamp:ep.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};SN.exports=function(e,t){let r=t==="timestamp"?{...pN,...wY}:{...pN,...IY},n=ep.object(r);return yY.validateBySchema(e,n)}});var RN=g((ole,gN)=>{var CY=je(),rp=require("joi"),{hdb_table:DY,hdb_database:TN}=jn(),LY=rp.object({schema:TN,database:TN,table:DY,hash_values:rp.array().required(),ids:rp.array()});gN.exports=function(e){return CY.validateBySchema(e,LY)}});var ON=g((ale,AN)=>{"use strict";var np=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}},sp=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}},ip=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};AN.exports={InsertObject:np,NoSQLSeachObject:sp,DeleteResponseObject:ip}});var ci=g((ule,wN)=>{"use strict";var yN=tp(),MY=RN(),Wi=J(),bN=require("moment"),NN=$(),{promisify:PY,callbackify:UY}=require("util"),Qi=P(),vY=ys(),op=PY(vY.getTableSchema),ap=Dn(),{DeleteResponseObject:BY}=ON(),{handleHDBError:oi,hdb_errors:xY}=se(),{HDB_ERROR_MSGS:Q_,HTTP_STATUS_CODES:ai}=xY,HY="records successfully deleted",GY=UY(IN);wN.exports={delete:GY,deleteRecord:IN,deleteFilesBefore:qY,deleteAuditLogsBefore:FY};async function qY(e){let t=yN(e,"date");if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);if(Wi.transformReq(e),!bN(e.date,bN.ISO_8601).isValid())throw oi(new Error,Q_.INVALID_DATE,ai.BAD_REQUEST,Qi.LOG_LEVELS.ERROR,Q_.INVALID_DATE,!0);let n=Wi.checkSchemaTableExist(e.schema,e.table);if(n)throw oi(new Error,n,ai.NOT_FOUND,Qi.LOG_LEVELS.ERROR,n,!0);let s=await ap.deleteRecordsBefore(e);if(await op(e.schema,e.table),NN.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(qY,"deleteFilesBefore");async function FY(e){let t=yN(e,"timestamp");if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);if(Wi.transformReq(e),isNaN(e.timestamp))throw oi(new Error,Q_.INVALID_VALUE("Timestamp"),ai.BAD_REQUEST,Qi.LOG_LEVELS.ERROR,Q_.INVALID_VALUE("Timestamp"),!0);let r=Wi.checkSchemaTableExist(e.schema,e.table);if(r)throw oi(new Error,r,ai.NOT_FOUND,Qi.LOG_LEVELS.ERROR,r,!0);let n=await ap.deleteAuditLogsBefore(e);return await op(e.schema,e.table),NN.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(FY,"deleteAuditLogsBefore");async function IN(e){e.ids&&(e.hash_values=e.ids);let t=MY(e);if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);Wi.transformReq(e);let r=Wi.checkSchemaTableExist(e.schema,e.table);if(r)throw oi(new Error,r,ai.NOT_FOUND,Qi.LOG_LEVELS.ERROR,r,!0);try{await op(e.schema,e.table);let n=await ap.deleteRecords(e);return Wi.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${HY}`),n}catch(n){if(n.message===Qi.SEARCH_NOT_FOUND_MESSAGE){let s=new BY;return s.message=Qi.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(IN,"deleteRecord")});var z_=g((_le,LN)=>{var kY=require("crypto"),CN=9;function VY(e){let t=YY(CN),r=DN(e+t);return t+r}a(VY,"createHash");function $Y(e,t){let r=e?.substr(0,CN),n=r+DN(t+r);return e===n}a($Y,"validateHash");function YY(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(YY,"generateSalt");function DN(e){return kY.createHash("md5").update(e).digest("hex")}a(DN,"md5");LN.exports={hash:VY,validate:$Y}});var PN=g((fle,MN)=>{var cp=je(),Zt={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 KY(e){return Zt.password.presence=!0,Zt.username.presence=!0,Zt.role.presence=!0,Zt.active.presence=!0,cp.validateObject(e,Zt)}a(KY,"addUserValidation");function WY(e){return Zt.password.presence=!1,Zt.username.presence=!0,Zt.role.presence=!1,Zt.active.presence=!1,cp.validateObject(e,Zt)}a(WY,"alterUserValidation");function QY(e){return Zt.password.presence=!1,Zt.username.presence=!0,Zt.role.presence=!1,Zt.active.presence=!1,cp.validateObject(e,Zt)}a(QY,"dropUserValidation");MN.exports={addUserValidation:KY,alterUserValidation:WY,dropUserValidation:QY}});var Ve=g((mle,vN)=>{"use strict";var{platform:hle}=require("os"),zY="nats-server.zip",up="nats-server",JY=process.platform==="win32"?`${up}.exe`:up,XY=/^[^\s.,*>]+$/,UN="__request__",jY=a(e=>`${e}.${UN}`,"REQUEST_SUBJECT"),ZY={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},eK={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},tK={HUB:"hub.pid",LEAF:"leaf.pid"},rK={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},nK={SUCCESS:"success",ERROR:"error"},sK={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},iK={TXN:"txn",MSGID:"msgid"},Qo={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},oK={[Qo.ERR]:1,[Qo.WRN]:2,[Qo.INF]:3,[Qo.DBG]:4,[Qo.TRC]:5},aK={debug:"-D",trace:"-DVV"};vN.exports={NATS_SERVER_ZIP:zY,NATS_SERVER_NAME:up,NATS_BINARY_NAME:JY,PID_FILES:tK,NATS_CONFIG_FILES:eK,SERVER_SUFFIX:rK,NATS_TERM_CONSTRAINTS_RX:XY,REQUEST_SUFFIX:UN,UPDATE_REMOTE_RESPONSE_STATUSES:nK,CLUSTER_STATUS_STATUSES:sK,REQUEST_SUBJECT:jY,SUBJECT_PREFIXES:iK,MSG_HEADERS:ZY,LOG_LEVELS:Qo,LOG_LEVEL_FLAGS:aK,LOG_LEVEL_HIERARCHY:oK}});var xN=g((Sle,BN)=>{"use strict";var cK={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
|
|
7
7
|
`),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
|
|
8
|
-
`)},cK="certificate.pem",uK="privateKey.pem",lK="ca.pem";vN.exports={CERTIFICATE_VALUES:aK,CERTIFICATE_PEM_NAME:cK,PRIVATEKEY_PEM_NAME:uK,CA_PEM_NAME:lK}});var cp=g((Sle,kN)=>{"use strict";var qN=require("fs-extra"),ae=require("joi"),_K=require("os"),{boolean:be,string:er,number:tt,array:J_}=ae.types(),{totalmem:xN}=require("os"),zi=require("path"),dK=$(),X_=J(),ple=BN(),HN=P(),fK=je(),GN="log",EK="components",hK="Invalid logging.rotation.maxSize unit. Available units are G, M or K",mK="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",pK="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",SK="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",TK="rootPath config parameter is undefined",gK="clustering.enabled config parameter is undefined",Ji=tt.min(0).required(),j_=J_.items({host:er.required(),port:Ji}).empty(null),es,FN=!1;kN.exports={configValidator:RK,routesValidator:IK,route_constraints:j_};function RK(e,t=!1){if(FN=t,es=e.rootPath,X_.isEmpty(es))throw TK;let r=be.required(),n=tt.min(0).max(1e3).empty(null).default(NK),s=er.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(Wc),i=er.optional().empty(null),o=er.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=ae.string().empty(null).default(Wc),u=ae.custom(OK).empty(null).default(Wc),_=e.clustering?.enabled;if(X_.isEmpty(_))throw gK;let l=ae.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return _===!0?d=ae.object({enabled:r,hubServer:ae.object({cluster:ae.object({name:ae.required().empty(null),network:ae.object({port:Ji,routes:j_}).required()}).required(),leafNodes:ae.object({network:ae.object({port:Ji}).required()}).required(),network:ae.object({port:Ji}).required()}).required(),leafServer:ae.object({network:ae.object({port:Ji,routes:j_}).required(),streams:ae.object({maxAge:tt.min(120).allow(null).optional(),maxBytes:tt.min(1).allow(null).optional(),maxMsgs:tt.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:ae.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:be.optional(),databaseLevel:be.optional(),tls:ae.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:be.required(),verify:be.optional()}),user:er.optional().empty(null)}).required():d=ae.object({enabled:r,tls:ae.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:be.required()})}).required(),ae.object({authentication:ae.object({authorizeLocal:be,cacheTTL:tt.required(),enableSessions:be}),analytics:ae.object({aggregatePeriod:tt}),componentsRoot:s.optional(),clustering:d,localStudio:ae.object({enabled:r}).required(),logging:ae.object({auditAuthEvents:ae.object({logFailed:be,logSuccessful:be}),file:be.required(),level:ae.valid("notify","fatal","error","warn","info","debug","trace"),rotation:ae.object({enabled:be.optional(),compress:be.optional(),interval:er.custom(yK).optional().empty(null),maxSize:er.custom(bK).optional().empty(null),path:er.optional().empty(null).default(Wc)}).required(),root:s,stdStreams:be.required(),auditLog:be.required()}).required(),operationsApi:ae.object({network:ae.object({cors:be.optional(),corsAccessList:J_.optional(),headersTimeout:tt.min(1).optional(),keepAliveTimeout:tt.min(1).optional(),port:tt.optional().empty(null),domainSocket:ae.optional().empty("hdb/operations-server").default(Wc),securePort:tt.optional().empty(null),timeout:tt.min(1).optional()}).optional(),tls:ae.alternatives([ae.array().items(l),l])}).required(),rootPath:er.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:ae.object({network:ae.object({port:Ji,securePort:Ji,mtls:ae.alternatives([be.optional(),ae.object({user:er.optional(),certificateAuthority:i,required:be.optional()})])}).required(),webSocket:be.optional(),requireAuthentication:be.optional()}),http:ae.object({compressionThreshold:tt.optional(),cors:be.optional(),corsAccessList:J_.optional(),headersTimeout:tt.min(1).optional(),port:tt.min(0).optional().empty(null),securePort:tt.min(0).optional().empty(null),maxHeaderSize:tt.optional(),mtls:ae.alternatives([be.optional(),ae.object({user:er.optional(),certificateAuthority:i,required:be.optional()})]),threadRange:ae.alternatives([J_.optional(),er.optional()])}).required(),threads:ae.alternatives(n.optional(),ae.object({count:n.optional(),debug:ae.alternatives(be.optional(),ae.object({startingPort:tt.min(1).optional(),host:er.optional(),waitForDebugger:be.optional()})),maxHeapMemory:tt.min(0).optional()})),storage:ae.object({writeAsync:be.required(),overlappingSync:be.optional(),caching:be.optional(),compression:ae.alternatives([be.optional(),ae.object({dictionary:er.optional(),threshold:tt.optional()})]),compactOnStart:be.optional(),compactOnStartKeepBackup:be.optional(),noReadAhead:be.optional(),path:u,prefetchWrites:be.optional(),maxFreeSpaceToLoad:tt.optional(),maxFreeSpaceToRetain:tt.optional()}).required(),ignoreScripts:be.optional(),tls:ae.alternatives([ae.array().items(l),l])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(RK,"configValidator");function AK(e){return FN||qN.existsSync(e)?null:`Specified path ${e} does not exist.`}a(AK,"doesPathExist");function OK(e,t){ae.assert(e,er.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=AK(e);if(r)return t.message(r)}a(OK,"validatePath");function bK(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(hK);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(pK):e}a(bK,"validateRotationMaxSize");function yK(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(mK);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(SK):e}a(yK,"validateRotationInterval");function NK(e,t){let r=t.state.path.join("."),n=_K.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||xN();return i=Math.round(Math.min(i,xN())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),dK.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(NK,"setDefaultThreads");function Wc(e,t){let r=t.state.path.join(".");if(!X_.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(X_.isEmpty(es))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return zi.join(es,EK);case"logging.root":return zi.join(es,GN);case"clustering.leafServer.streams.path":return zi.join(es,"clustering","leaf");case"storage.path":let n=zi.join(es,HN.LEGACY_DATABASES_DIR_NAME);return qN.existsSync(n)?n:zi.join(es,HN.DATABASES_DIR_NAME);case"logging.rotation.path":return zi.join(es,GN);case"operationsApi.network.domainSocket":return r==null?null:zi.join(es,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Wc,"setDefaultRoot");function IK(e){let t=ae.object({routes:j_});return fK.validateBySchema({routes:e},t)}a(IK,"routesValidator")});var pr=g((Rle,XN)=>{"use strict";var Vr=P(),xt=J(),It=$(),{configValidator:wK,routesValidator:VN}=cp(),mr=require("fs-extra"),CK=require("yaml"),Ln=require("path"),DK=require("is-number"),YN=require("properties-reader"),LK=require("lodash"),{handleHDBError:MK}=se(),{HTTP_STATUS_CODES:PK,HDB_ERROR_MSGS:Z_}=vr(),gle=require("minimist"),{server:UK}=(fr(),ie(Gi)),{DATABASES_PARAM_CONFIG:Qc,CONFIG_PARAMS:kr,CONFIG_PARAM_MAP:Mn}=Vr,vK="Unable to get config value because config is uninitialized",BK="Config successfully initialized",xK="Error backing up config file",HK="Empty parameter sent to getConfigValue",KN=Ln.join(Vr.PACKAGE_ROOT,"config","yaml",Vr.HDB_DEFAULT_CONFIG_FILE),GK="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",$N={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"},ed,wt,td;XN.exports={createConfigFile:qK,getDefaultConfig:FK,getConfigValue:QN,initConfig:lp,flattenConfig:zo,updateConfigValue:zN,updateConfigObject:VK,getConfiguration:KK,setConfiguration:WK,readConfigFile:dp,getClusteringRoutes:QK,initOldConfig:JN,getConfigFromFile:zK,getConfigFilePath:Xi,addConfig:JK,deleteConfigFromFile:XK,getConfigObj:jK};function qK(e,t=!1){let r=ui(KN);ed=zo(r.toJSON());let n;for(let c in e){let u=Mn[c.toLowerCase()];if(u===kr.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(_=>({[_]:e[c][_]}));continue}if(!u&&(c.endsWith("_package")||c.endsWith("_port"))&&(u=c),u!==void 0){let _=u.split("_"),l=up(u,e[c]);u==="rootPath"&&l?.endsWith("/")&&(l=l.slice(0,-1));try{r.setIn([..._],l)}catch(d){It.error(d)}}}n&&WN(r,n),_p(r,t);let s=r.toJSON();wt=zo(s);let i=r.getIn(["rootPath"]),o=Ln.join(i,Vr.HDB_CONFIG_FILE);mr.createFileSync(o),mr.writeFileSync(o,String(r)),It.trace(`Config file written to ${o}`)}a(qK,"createConfigFile");function WN(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!xt.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(Qc.TABLES))for(let i in n[s][Qc.TABLES])for(let o in n[s][Qc.TABLES][i]){let c=n[s][Qc.TABLES][i][o],u=[kr.DATABASES,s,Qc.TABLES,i,o];e.hasIn(u)?e.setIn(u,c):e.addIn(u,c)}else for(let i in n[s]){let o=n[s][i],c=[kr.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(WN,"setSchemasConfig");function FK(e){if(ed===void 0){let r=ui(KN);ed=zo(r.toJSON())}let t=Mn[e.toLowerCase()];if(t!==void 0)return ed[t.toLowerCase()]}a(FK,"getDefaultConfig");function QN(e){if(e==null){It.error(HK);return}if(wt===void 0){It.trace(vK);return}let t=Mn[e.toLowerCase()];if(t!==void 0)return wt[t.toLowerCase()]}a(QN,"getConfigValue");function Xi(e=xt.getPropsFilePath()){let t=xt.getEnvCliRootPath();return t?Ln.join(t,Vr.HDB_CONFIG_FILE):YN(e).get(Vr.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY)}a(Xi,"getConfigFilePath");function lp(e=!1){if(wt===void 0||e){let t;if(!xt.noBootFile()){t=xt.getPropsFilePath();try{mr.accessSync(t,mr.constants.F_OK|mr.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{JN(r);return}catch(i){if(i.code!==Vr.NODE_ERROR_CODES.ENOENT)throw i}try{n=ui(r)}catch(i){if(i.code===Vr.NODE_ERROR_CODES.ENOENT){It.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 It.error(i),new Error(`Error reading HarperDB config file at ${r}`)}kK(n,r),_p(n);let s=n.toJSON();if(UK.config=s,wt=zo(s),wt.logging_rotation_rotate)for(let i in $N)wt[i]&&It.error(`Config ${$N[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);It.trace(BK)}}a(lp,"initConfig");function kK(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Ln.join(r,"database")),n=!0),e.hasIn(["clustering","leafServer","streams","path"])||(e.setIn(["clustering","leafServer","streams","path"],Ln.join(r,"clustering","leaf")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Ln.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"),mr.writeFileSync(t,String(e)))}a(kK,"checkForUpdatedConfig");function _p(e,t=!1){let r=e.toJSON();r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads);let n=wK(r,t);if(n.error)throw Z_.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(_p,"validateConfig");function VK(e,t){wt===void 0&&(wt={});let r=Mn[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(VK,"updateConfigObject");function zN(e,t,r=void 0,n=!1,s=!1,i=!1){wt===void 0&&lp();let o=QN(Mn.hdb_root),c=Ln.join(o,Vr.HDB_CONFIG_FILE),u=ui(c),_;if(r===void 0&&e.toLowerCase()===kr.DATABASES)_=t;else if(r===void 0){let E;if(i)E=e;else if(E=Mn[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=up(E,t);u.setIn([...f],h)}else for(let E in r){let f=Mn[E.toLowerCase()];if(f===kr.HTTP_SECUREPORT&&r[E]===wt[kr.HTTP_PORT]?.toString()&&u.setIn(["http","port"],null),f===kr.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===wt[kr.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&u.setIn(["operationsApi","network","port"],null),f===kr.DATABASES){_=r[E];continue}if(f?.startsWith("threads_")){let h=u.getIn(["threads"]);h>=0&&(u.deleteIn(["threads"]),u.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),p=Vr.LEGACY_CONFIG_PARAMS[E.toUpperCase()];p&&p.startsWith("customFunctions")&&u.hasIn(p.split("_"))&&(f=p,h=p.split("_"));let S=up(f,r[E]);f==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof u.getIn(h.slice(0,-1))=="boolean"&&u.deleteIn(h.slice(0,-1)),u.setIn([...h],S)}catch(T){It.error(T)}}}_&&WN(u,_),_p(u);let l=u.getIn(["rootPath"]),d=Ln.join(l,Vr.HDB_CONFIG_FILE);n===!0&&$K(c,l),mr.writeFileSync(d,String(u)),s&&(wt=zo(u.toJSON())),It.trace(`Config parameter: ${e} updated with value: ${t}`)}a(zN,"updateConfigValue");function $K(e,t){try{let r=Ln.join(t,"backup",`${Vr.HDB_CONFIG_FILE}.bak`);mr.copySync(e,r),It.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){It.error(xK),It.error(r)}}a($K,"backupConfigFile");var YK=["databases"];function zo(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)),td=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])&&!YK.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let u=i+"_"+c;!kr[u.toUpperCase()]&&Mn[u]&&(s[Mn[u].toLowerCase()]=o[c]),s[u]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(zo,"flattenConfig");function up(e,t){if(e===kr.CLUSTERING_NODENAME||e===kr.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(DK(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||xt.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 xt.autoCast(t)}a(up,"castConfigValue");function KK(){let e=xt.getPropsFilePath(),t=Xi(e);return ui(t).toJSON()}a(KK,"getConfiguration");async function WK(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return zN(void 0,void 0,s,!0),GK}catch(i){throw typeof i=="string"||i instanceof String?MK(i,i,PK.BAD_REQUEST,void 0,void 0,!0):i}}a(WK,"setConfiguration");function dp(){let e=xt.getPropsFilePath();try{mr.accessSync(e,mr.constants.F_OK|mr.constants.R_OK)}catch(n){if(!xt.noBootFile())throw It.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Xi(e);return ui(t).toJSON()}a(dp,"readConfigFile");function ui(e){return CK.parseDocument(mr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(ui,"parseYamlDoc");function QK(){let e=dp(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=xt.isEmptyOrZeroLength(t)?[]:t;let r=VN(t);if(r)throw Z_.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=xt.isEmptyOrZeroLength(n)?[]:n;let s=VN(n);if(s)throw Z_.CONFIG_VALIDATION(s.message);if(!xt.isEmptyOrZeroLength(n)&&!xt.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!xt.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Z_.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(QK,"getClusteringRoutes");function JN(e){let t=YN(e);wt={};for(let r in Mn){let n=t.get(r.toUpperCase());if(xt.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=Mn[r].toLowerCase();s===kr.LOGGING_ROOT?wt[s]=Ln.dirname(n):wt[s]=n}return wt}a(JN,"initOldConfig");function zK(e){let t=dp();return LK.get(t,e.replaceAll("_","."))}a(zK,"getConfigFromFile");async function JK(e,t){let r=ui(Xi());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await mr.writeFile(Xi(),String(r))}a(JK,"addConfig");function XK(e){let t=Xi(xt.getPropsFilePath()),r=ui(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Ln.join(n,Vr.HDB_CONFIG_FILE);mr.writeFileSync(s,String(r))}a(XK,"deleteConfigFromFile");function jK(){return td||(lp(),td)}a(jK,"getConfigObj")});var ZN=g((Ole,jN)=>{"use strict";var rd=P(),nd=class{static{a(this,"BaseLicense")}constructor(t=0,r=rd.RAM_ALLOCATION_ENUM.DEFAULT,n=rd.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},fp=class extends nd{static{a(this,"ExtendedLicense")}constructor(t=0,r=rd.RAM_ALLOCATION_ENUM.DEFAULT,n=rd.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};jN.exports={BaseLicense:nd,ExtendedLicense:fp}});var ji=g((yle,iI)=>{"use strict";var Xo=require("fs-extra"),tI=z_(),rI=require("crypto"),ZK=require("moment"),eW=require("uuid").v4,tr=$(),hp=require("path"),tW=J(),li=P(),{totalmem:eI}=require("os"),rW=ZN().ExtendedLicense,Jo="invalid license key format",nW="061183",sW="mofi25",iW="aes-256-cbc",oW=16,aW=32,nI=ee();nI.initSync();var Ep;iI.exports={validateLicense:sI,generateFingerPrint:uW,licenseSearch:Sp,getLicense:dW,checkMemoryLimit:fW};function mp(){return hp.join(nI.getHdbBasePath(),li.LICENSE_KEY_DIR_NAME,li.LICENSE_FILE_NAME)}a(mp,"getLicenseDirPath");function cW(){let e=mp();return hp.join(e,li.LICENSE_FILE_NAME)}a(cW,"getLicenseFilePath");function pp(){let e=mp();return hp.join(e,li.REG_KEY_FILE_NAME)}a(pp,"getFingerPrintFilePath");async function uW(){let e=pp();try{return await Xo.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await lW();throw tr.error(`Error writing fingerprint file to ${e}`),tr.error(t),new Error("There was an error generating the fingerprint")}}a(uW,"generateFingerPrint");async function lW(){let e=eW(),t=tI.hash(e),r=pp();try{await Xo.mkdirp(mp()),await Xo.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(lW,"writeFingerprint");function sI(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:li.RAM_ALLOCATION_ENUM.DEFAULT,version:li.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return tr.error("empty license key passed to validate."),r;let n=pp(),s=!1;try{s=Xo.statSync(n)}catch(i){tr.error(i)}if(s){let i;try{i=Xo.readFileSync(n,"utf8")}catch{tr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(sW),c=o[1];c=Buffer.concat([Buffer.from(c)],oW);let u=Buffer.concat([Buffer.from(i)],aW),_=rI.createDecipheriv(iW,u,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let l=null;try{l=_.update(o[0],"hex","utf8"),l.trim(),l+=_.final("utf8")}catch{let f=_W(o[0],i);if(f)l=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Jo),tr.error(Jo),new Error(Jo)}let d;if(isNaN(l))try{d=JSON.parse(l),r.version=d.version,r.exp_date=d.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),d.ram_allocation&&(r.ram_allocation=d.ram_allocation)}catch{throw console.error(Jo),tr.error(Jo),new Error(Jo)}else r.exp_date=l;r.exp_date<ZK().valueOf()&&(r.valid_date=!1),tI.validate(o[1],`${nW}${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(sI,"validateLicense");function _W(e,t){try{let r=rI.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(_W,"checkOldLicense");function Sp(){let e=new rW,t=[];try{t=Xo.readFileSync(cW(),"utf-8").split(li.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(tW.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=sI(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=li.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return Ep=e,e}a(Sp,"licenseSearch");async function dW(){return Ep||await Sp(),Ep}a(dW,"getLicense");function fW(){let e=Sp().ram_allocation,t=process.constrainedMemory?.()||eI();if(t=Math.round(Math.min(t,eI())/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(fW,"checkMemoryLimit")});var _n=g((Dle,RI)=>{"use strict";var uI="username is required",lI="nothing to update, must supply active, role or password to update",_I="password cannot be an empty string",dI="If role is specified, it cannot be empty.",fI="active must be true or false";RI.exports={addUser:AW,alterUser:OW,dropUser:yW,getSuperUser:CW,userInfo:NW,listUsers:id,listUsersExternal:IW,setUsersToGlobal:Zo,findAndValidateUser:TI,getClusterUser:DW,USERNAME_REQUIRED:uI,ALTERUSER_NOTHING_TO_UPDATE:lI,EMPTY_PASSWORD:_I,EMPTY_ROLE:dI,ACTIVE_BOOLEAN:fI};var EI=Fr(),EW=ci(),Rp=z_(),hI=MN(),mI=qr(),Ap=Ns(),$r=J(),pI=require("validate.js"),Oe=$(),{promisify:hW}=require("util"),Op=Os(),oI=P(),aI=Ve(),mW=pr(),Ile=ee(),wle=ji(),pW=Vi(),{table:Cle}=(Ae(),ie(ke)),{handleHDBError:ts,hdb_errors:SW}=se(),{HTTP_STATUS_CODES:rs,AUTHENTICATION_ERROR_MSGS:Tp,HDB_ERROR_MSGS:jo}=SW,{UserEventMsg:bp}=Pn(),gp=require("lodash"),{server:yp}=(fr(),ie(Gi)),TW=$();yp.getUser=(e,t)=>TI(e,t,t!=null);var SI={username:!0,active:!0,role:!0,password:!0},cI=new Map,sd=mI.searchByValue,gW=mI.searchByHash,RW=hW(EW.delete);async function AW(e){let t=pI.cleanAttributes(e,SI),r=hI.addUserValidation(t);if(r)throw ts(new Error,r.message,rs.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 sd(n),s=s&&Array.from(s)}catch(u){throw Oe.error("There was an error searching for a role in add user"),Oe.error(u),u}if(!s||s.length<1)throw ts(new Error,jo.ROLE_NAME_NOT_FOUND(t.role),rs.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw ts(new Error,jo.DUP_ROLES_FOUND(t.role),rs.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=Op.encrypt(t.password)),t.password=Rp.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(u){throw Oe.error("There was an error searching for a user."),Oe.error(u),u}Oe.debug(o);try{await Zo()}catch(u){throw Oe.error("Got an error setting users to global"),Oe.error(u),u}if(o.skipped_hashes.length===1)throw ts(new Error,jo.USER_ALREADY_EXISTS(t.username),rs.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],Ap.signalUserChange(new bp(process.pid)),`${c.username} successfully added`}a(AW,"addUser");async function OW(e){let t=pI.cleanAttributes(e,SI);if($r.isEmptyOrZeroLength(t.username))throw new Error(uI);if($r.isEmptyOrZeroLength(t.password)&&$r.isEmptyOrZeroLength(t.role)&&$r.isEmptyOrZeroLength(t.active))throw new Error(lI);if(!$r.isEmpty(t.password)&&$r.isEmptyOrZeroLength(t.password.trim()))throw new Error(_I);if(!$r.isEmpty(t.active)&&!$r.isBoolean(t.active))throw new Error(fI);let r=bW(t.username);if(!$r.isEmpty(t.password)&&!$r.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=Op.encrypt(t.password)),t.password=Rp.hash(t.password)),t.role==="")throw new Error(dI);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 sd(i)||[])}catch(c){throw Oe.error("Got an error searching for a role."),Oe.error(c),c}if(!o||o.length===0){let c=jo.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Oe.error(c),ts(new Error,c,rs.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=jo.ALTER_USER_DUP_ROLES(t.role);throw Oe.error(c),ts(new Error,c,rs.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 Zo()}catch(i){throw Oe.error("Got an error setting users to global"),Oe.error(i),i}return Ap.signalUserChange(new bp(process.pid)),s}a(OW,"alterUser");function bW(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(bW,"isClusterUser");async function yW(e){try{let t=hI.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if($r.isEmpty(global.hdb_users.get(e.username)))throw ts(new Error,jo.USER_NOT_EXIST(e.username),rs.NOT_FOUND,void 0,void 0,!0);let n;try{n=await RW(r)}catch(s){throw Oe.error("Got an error deleting a user."),Oe.error(s),s}Oe.debug(n);try{await Zo()}catch(s){throw Oe.error("Got an error setting users to global."),Oe.error(s),s}return Ap.signalUserChange(new bp(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(yW,"dropUser");async function NW(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=gp.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await gW(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(NW,"userInfo");async function IW(){let e;try{e=await id()}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(IW,"listUsersExternal");async function id(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await sd(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]=gp.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 sd(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=gp.cloneDeep(o),o.role=r[o.role],wW(o.role),i.set(o.username,o);return i}catch(e){throw Oe.error("got an error listing users"),Oe.error(e),$r.errorizeMessage(e)}return null}a(id,"listUsers");function wW(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(pW)){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(wW,"appendSystemTablesToRole");async function Zo(){try{let e=await id();global.hdb_users=e}catch(e){throw Oe.error(e),e}}a(Zo,"setUsersToGlobal");async function TI(e,t,r=!0){global.hdb_users||await Zo();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw ts(new Error,Tp.GENERIC_AUTH_FAIL,rs.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw ts(new Error,Tp.USER_INACTIVE,rs.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(cI.get(t)===n.password)return s;if(Rp.validate(n.password,t))cI.set(t,n.password);else throw ts(new Error,Tp.GENERIC_AUTH_FAIL,rs.UNAUTHORIZED,void 0,void 0,!0)}return s}a(TI,"findAndValidateUser");async function CW(){global.hdb_users||await Zo();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(CW,"getSuperUser");async function DW(){let e=await id(),t=mW.getConfigFromFile(oI.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!$r.isEmpty(r)&&r?.role?.role===oI.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=Op.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+aI.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+aI.SERVER_SUFFIX.ADMIN,r}a(DW,"getClusterUser");var gI=[];yp.invalidateUser=function(e){for(let t of gI)try{t(e)}catch(r){TW.error("Error invalidating user",r)}};yp.onInvalidatedUser=function(e){gI.push(e)}});var Jc=g((Ule,yI)=>{"use strict";var Zi=$(),Yr=P(),LW=Zy(),Mle=ys(),Ple=bs(),MW=_n(),{validateEvent:AI}=Pn(),zc=Dn(),PW=require("process"),{resetDatabases:UW}=(Ae(),ie(ke)),vW={[Yr.ITC_EVENT_TYPES.SCHEMA]:BW,[Yr.ITC_EVENT_TYPES.USER]:bI};async function BW(e){let t=AI(e);if(t){Zi.error(t);return}Zi.trace("ITC schemaHandler received schema event:",e),await LW(e.message),await xW(e.message)}a(BW,"schemaHandler");async function xW(e){try{zc.resetReadTxn(Yr.SYSTEM_SCHEMA_NAME,Yr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),zc.resetReadTxn(Yr.SYSTEM_SCHEMA_NAME,Yr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),zc.resetReadTxn(Yr.SYSTEM_SCHEMA_NAME,Yr.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=UW();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Zi.error(t)}}a(xW,"syncSchemaMetadata");var OI=[];async function bI(e){try{try{zc.resetReadTxn(Yr.SYSTEM_SCHEMA_NAME,Yr.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),zc.resetReadTxn(Yr.SYSTEM_SCHEMA_NAME,Yr.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Zi.warn(r)}let t=AI(e);if(t){Zi.error(t);return}Zi.trace(`ITC userHandler ${Yr.HDB_ITC_CLIENT_PREFIX}${PW.pid} received user event:`,e),await MW.setUsersToGlobal();for(let r of OI)r()}catch(t){Zi.error(t)}}a(bI,"userHandler");bI.addListener=function(e){OI.push(e)};yI.exports=vW});var Pn=g((qle,II)=>{"use strict";var Ble=$(),Np=J(),HW=P(),{ITC_ERRORS:Xc}=vr(),{parentPort:xle,threadId:GW,isMainThread:qW,workerData:Hle}=require("worker_threads"),{onMessageFromWorkers:FW,broadcast:Gle,broadcastWithAcknowledgement:kW}=Qe();II.exports={sendItcEvent:VW,validateEvent:NI,SchemaEventMsg:$W,UserEventMsg:YW};var od;FW(async(e,t)=>{od=od||Jc(),NI(e),od[e.type]&&await od[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function VW(e){return!qW&&e.message&&(e.message.originator=GW),kW(e)}a(VW,"sendItcEvent");function NI(e){if(typeof e!="object")return Xc.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||Np.isEmpty(e.type))return Xc.MISSING_TYPE;if(!e.hasOwnProperty("message")||Np.isEmpty(e.message))return Xc.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||Np.isEmpty(e.message.originator))return Xc.MISSING_ORIGIN;if(HW.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Xc.INVALID_EVENT(e.type)}a(NI,"validateEvent");function $W(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($W,"SchemaEventMsg");function YW(e){this.originator=e}a(YW,"UserEventMsg")});var Ns=g((Vle,LI)=>{"use strict";var wI=P(),kle=J(),ad=$(),CI=Jy(),ea,{sendItcEvent:DI}=Pn();function KW(e){try{ad.trace("signalSchemaChange called with message:",e),ea=ea||Jc();let t=new CI(wI.ITC_EVENT_TYPES.SCHEMA,e);return ea.schema(t),DI(t)}catch(t){ad.error(t)}}a(KW,"signalSchemaChange");function WW(e){try{ad.trace("signalUserChange called with message:",e),ea=ea||Jc();let t=new CI(wI.ITC_EVENT_TYPES.USER,e);return ea.user(t),DI(t)}catch(t){ad.error(t)}}a(WW,"signalUserChange");LI.exports={signalSchemaChange:KW,signalUserChange:WW}});var cd=g((Yle,PI)=>{"use strict";var MI=J(),QW=P(),zW=$(),JW=q_(),XW=G_(),jW=Ns(),{SchemaEventMsg:ZW}=Pn(),eQ="already exists in";PI.exports=tQ;async function tQ(e,t,r){if(MI.isEmptyOrZeroLength(r))return r;let n=[];MI.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 rQ(e,t.schema,t.name,i)})),s}a(tQ,"lmdbCheckForNewAttributes");async function rQ(e,t,r,n){let s=new XW(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await nQ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(eQ))zW.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(rQ,"createNewAttribute");async function nQ(e){let t;return t=await JW(e),jW.signalSchemaChange(new ZW(process.pid,QW.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(nQ,"createAttribute")});var ta=g((Wle,UI)=>{"use strict";var Ip=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}};UI.exports=Ip});var BI=g((zle,vI)=>{"use strict";var sQ=ta(),iQ=P().OPERATIONS_ENUM,wp=class extends sQ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(iQ.INSERT,r,n,s,i),this.records=t}};vI.exports=wp});var HI=g((Xle,xI)=>{"use strict";var oQ=ta(),aQ=P().OPERATIONS_ENUM,Cp=class extends oQ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(aQ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};xI.exports=Cp});var qI=g((Zle,GI)=>{"use strict";var cQ=ta(),uQ=P().OPERATIONS_ENUM,Dp=class extends cQ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(uQ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};GI.exports=Dp});var kI=g((t_e,FI)=>{"use strict";var lQ=ta(),_Q=P().OPERATIONS_ENUM,Lp=class extends lQ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(_Q.DELETE,n,s,t,i),this.original_records=r}};FI.exports=Lp});var jc=g((s_e,KI)=>{"use strict";var n_e=require("path"),VI=ze(),dQ=BI(),fQ=HI(),EQ=qI(),hQ=kI(),ra=ft(),$I=J(),{CONFIG_PARAMS:mQ}=P(),YI=ee();YI.initSync();var ud=P().OPERATIONS_ENUM,{getTransactionAuditStorePath:pQ}=Xe();KI.exports=SQ;async function SQ(e,t){if(YI.get(mQ.LOGGING_AUDITLOG)===!1)return;let r=pQ(e.schema,e.table),n=await VI.openEnvironment(r,e.table,!0),s=TQ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){VI.initializeDBIs(n,ra.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ra.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[ra.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[ra.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),$I.isEmpty(s.user_name)||n.dbis[ra.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[ra.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(SQ,"writeTransaction");function TQ(e,t){let r=$I.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===ud.INSERT)return new dQ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===ud.UPDATE)return new fQ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===ud.UPSERT)return new EQ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===ud.DELETE)return new hQ(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(TQ,"createTransactionObject")});var Mp=g((a_e,WI)=>{"use strict";var gQ=$c(),o_e=Ic(),Zc=P(),RQ=wc(),AQ=Ko().insertRecords,OQ=ze(),bQ=$(),yQ=cd(),{getSchemaPath:NQ}=Xe(),IQ=jc();WI.exports=wQ;async function wQ(e){try{let{schema_table:t,attributes:r}=gQ(e);RQ(e,r,t.hash_attribute),e.schema!==Zc.SYSTEM_SCHEMA_NAME&&(r.includes(Zc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Zc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Zc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Zc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await yQ(e.hdb_auth_header,t,r),s=NQ(e.schema,e.table),i=await OQ.openEnvironment(s,e.table),o=await AQ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await IQ(e,o)}catch(c){bQ.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(wQ,"lmdbCreateRecords")});var JI=g((u_e,zI)=>{"use strict";var QI=P(),CQ=Mp(),DQ=Ic(),LQ=require("fs-extra"),{getSchemaPath:MQ}=Xe();zI.exports=PQ;async function PQ(e){let t=[{name:e.schema,createddate:Date.now()}],r=new DQ(QI.SYSTEM_SCHEMA_NAME,QI.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await CQ(r),await LQ.mkdirp(MQ(e.schema))}a(PQ,"lmdbCreateSchema")});var jI=g((__e,XI)=>{"use strict";var Pp=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}};XI.exports=Pp});var rw=g((m_e,tw)=>{"use strict";var ZI=ze(),Up=Br(),vp=vr().LMDB_ERRORS_ENUM,UQ=ft(),ew=$(),f_e=J(),vQ=require("lmdb"),BQ=jI(),xQ=P(),{OVERFLOW_MARKER:E_e,MAX_SEARCH_KEY_LENGTH:h_e}=UQ,HQ=xQ.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function GQ(e,t,r,n){if(Up.validateEnv(e),t===void 0)throw new Error(vp.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(vp.IDS_REQUIRED):new Error(vp.IDS_MUST_BE_ITERABLE);try{let s=ZI.listDBIs(e);ZI.initializeDBIs(e,t,s);let i=new BQ,o,c=[],u=[];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[HQ]>n){i.skipped.push(o);continue}let p=e.dbis[t].ifVersion(o,vQ.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 A=e.dbis[T],b=h[T];if(b!=null)try{let I=Up.getIndexedValues(b);if(I)for(let B=0,U=I.length;B<U;B++)A.remove(I[B],o)}catch{ew.warn(`cannot delete from attribute: ${T}, ${b}:${o}`)}}});c.push(p),u.push(o),i.original_records.push(h)}catch(h){ew.warn(h),i.skipped.push(o)}let _=[],l=await Promise.all(c);for(let E=0,f=l.length;E<f;E++)l[E]===!0?i.deleted.push(u[E]):(i.skipped.push(u[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=Up.getNextMonotonicTime(),i}catch(s){throw s}}a(GQ,"deleteRecords");tw.exports={deleteRecords:GQ}});var eu=g((S_e,sw)=>{"use strict";var na=J(),qQ=rw(),FQ=ze(),{getSchemaPath:kQ}=Xe(),VQ=jc(),$Q=$();sw.exports=YQ;async function YQ(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(na.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(na.isEmptyOrZeroLength(e.hash_values)&&!na.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let u=e.records[c][n];na.isEmpty(u)||e.hash_values.push(u)}}if(na.isEmptyOrZeroLength(e.hash_values))return nw([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(na.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=kQ(e.schema,e.table),i=await FQ.openEnvironment(s,e.table),o=await qQ.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await VQ(e,o)}catch(c){$Q.error(`unable to write transaction due to ${c.message}`)}return nw(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(YQ,"lmdbDeleteRecords");function nw(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(nw,"createDeleteResponse")});var xp=g((R_e,iw)=>{"use strict";var KQ=P(),g_e=Br();function Bp(e,t){let r=Object.create(null);if(t.length===1&&KQ.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(Bp,"parseRow");function WQ(e,t,r,n){let s=Bp(r,e);n.push(s)}a(WQ,"searchAll");function QQ(e,t,r,n){let s=Bp(r,e);n[t]=s}a(QQ,"searchAllToMap");function zQ(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(zQ,"iterateDBI");function eo(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(eo,"pushResults");function JQ(e,t,r,n,s,i){t.toString().endsWith(e)&&eo(t,r,n,s,i)}a(JQ,"endsWith");function XQ(e,t,r,n,s,i){t.toString().includes(e)&&eo(t,r,n,s,i)}a(XQ,"contains");function jQ(e,t,r,n,s,i){t>e&&eo(t,r,n,s,i)}a(jQ,"greaterThanCompare");function ZQ(e,t,r,n,s,i){t>=e&&eo(t,r,n,s,i)}a(ZQ,"greaterThanEqualCompare");function ez(e,t,r,n,s,i){t<e&&eo(t,r,n,s,i)}a(ez,"lessThanCompare");function tz(e,t,r,n,s,i){t<=e&&eo(t,r,n,s,i)}a(tz,"lessThanEqualCompare");iw.exports={parseRow:Bp,searchAll:WQ,searchAllToMap:QQ,iterateDBI:zQ,endsWith:JQ,contains:XQ,greaterThanCompare:jQ,greaterThanEqualCompare:ZQ,lessThanCompare:ez,lessThanEqualCompare:tz,pushResults:eo}});var sa=g((N_e,dw)=>{"use strict";var _i=ze(),O_e=$(),Kr=Br(),ld=ft(),ht=vr().LMDB_ERRORS_ENUM,b_e=J(),rz=P(),_d=xp(),{parseRow:nz}=_d,y_e=require("lmdb"),{OVERFLOW_MARKER:ow,MAX_SEARCH_KEY_LENGTH:sz}=ld;function aw(e,t,r,n=!1,s=void 0,i=void 0){return to(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(aw,"iterateFullIndex");function tu(e,t,r,n,s,i=!1,o=void 0,c=void 0,u=!1,_=!1){return to(e,t,r,(l,d,E,f)=>{let A={transaction:l,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!u:!_,exclusiveStart:i===!0?_:u};return f===r?(A.values=!1,d.getRange(A).map(b=>({value:b}))):d.getRange(A)})}a(tu,"iterateRangeBetween");function to(e,t,r,n){let s=e.database||e,i=_i.openDBI(s,r);i[ld.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&_i.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(to,"setupTransaction");function cw(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(ow)){if(!s)if(r)s=_i.openDBI(e,r);else{let u=_i.listDBIs(e);for(let _=0,l=u.length;_<l&&(s=_i.openDBI(e,u[_]),!s[ld.DBI_DEFINITION_NAME].is_hash_attribute);_++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(cw,"getOverflowCheck");function iz(e,t,r,n=!1,s=void 0,i=void 0){if(Kr.validateEnv(e),t===void 0)throw new Error(ht.HASH_ATTRIBUTE_REQUIRED);return to(e,t,t,(o,c,u)=>(dd(r),r=ru(u,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(_=>nz(_.value,r))))}a(iz,"searchAll");function oz(e,t,r,n=!1,s=void 0,i=void 0){if(Kr.validateEnv(e),t===void 0)throw new Error(ht.HASH_ATTRIBUTE_REQUIRED);dd(r),r=ru(e.database||e,r);let o=new Map;for(let{key:c,value:u}of aw(e,t,t,n,s,i))o.set(c,_d.parseRow(u,r));return o}a(oz,"searchAllToMap");function az(e,t,r=!1,n=void 0,s=void 0){if(Kr.validateEnv(e),t===void 0)throw new Error(ht.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=aw(e,void 0,t,r,n,s),c=o.transaction,u=cw(c.database,c,void 0,t);for(let{key:_,value:l}of o){let d=u(_,l);i[d]===void 0&&(i[d]=[]),i[d].push(l)}return i}a(az,"iterateDBI");function cz(e,t){if(Kr.validateEnv(e),t===void 0)throw new Error(ht.HASH_ATTRIBUTE_REQUIRED);return _i.statDBI(e,t).entryCount}a(cz,"countAll");function uz(e,t,r,n,s=!1,i=void 0,o=void 0){return di(e,r,n),to(e,t,r,(c,u,_,l)=>(n=Kr.convertKeyValueToWrite(n),l===r?u.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:u.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(uz,"equals");function lz(e,t,r){return di(e,t,r),_i.openDBI(e,t).getValuesCount(r)}a(lz,"count");function _z(e,t,r,n,s=!1,i=void 0,o=void 0){return di(e,r,n),to(e,null,r,(c,u)=>{n=Kr.convertKeyValueToWrite(n);let _=!0;typeof n=="number"&&(_=!1);let l;if(s===!0){let d;for(let E of u.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){d=E;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),l=u.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==d){if(f.toString().startsWith(n))return E;if(_===!0)return l.DONE}}),l.filter(E=>E)}else return l=u.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(_===!0)return l.DONE}),_?l:l.filter(d=>d)})}a(_z,"startsWith");function dz(e,t,r,n,s=!1,i=void 0,o=void 0){return uw(e,t,r,n,s,i,o,!0)}a(dz,"endsWith");function uw(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return di(e,r,n),to(e,null,r,(u,_,l,d)=>{let E=cw(l,u,d,r);return o=Number.isInteger(o)?o:0,_.getKeys({transaction:u,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(ow)?_.getValues(f,{transaction:u}).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))?_[ld.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:_.getValues(f,{transaction:u}).map(p=>({key:f,value:p})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(uw,"contains");function fz(e,t,r,n,s=!1,i=void 0,o=void 0){di(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),tu(e,t,r,n,u,s,i,o,!0,!1)}a(fz,"greaterThan");function Ez(e,t,r,n,s=!1,i=void 0,o=void 0){di(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),tu(e,t,r,n,u,s,i,o,!1,!1)}a(Ez,"greaterThanEqual");function hz(e,t,r,n,s=!1,i=void 0,o=void 0){di(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),tu(e,t,r,u,n,s,i,o,!1,!0)}a(hz,"lessThan");function mz(e,t,r,n,s=!1,i=void 0,o=void 0){di(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),tu(e,t,r,u,n,s,i,o,!1,!1)}a(mz,"lessThanEqual");function pz(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Kr.validateEnv(e),r===void 0)throw new Error(ht.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(ht.START_VALUE_REQUIRED);if(s===void 0)throw new Error(ht.END_VALUE_REQUIRED);if(n=Kr.convertKeyValueToWrite(n),s=Kr.convertKeyValueToWrite(s),n>s)throw new Error(ht.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return tu(e,t,r,n,s,i,o,c)}a(pz,"between");function Sz(e,t,r,n){Kr.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(ht.HASH_ATTRIBUTE_REQUIRED);if(dd(r),r=ru(s,r),n===void 0)throw new Error(ht.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=_d.parseRow(c,r)),o}a(Sz,"searchByHash");function Tz(e,t,r){Kr.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(ht.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ht.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(Tz,"checkHashExists");function gz(e,t,r,n,s=[]){return _w(e,t,r,n,s),lw(e,t,r,n,s).map(i=>i[1])}a(gz,"batchSearchByHash");function Rz(e,t,r,n,s=[]){_w(e,t,r,n,s);let i=new Map;for(let[o,c]of lw(e,t,r,n,s))i.set(o,c);return i}a(Rz,"batchSearchByHashToMap");function lw(e,t,r,n,s=[]){return to(e,t,t,(i,o,c)=>{r=ru(c,r);let u=r.length<3;return n.map(_=>{let l=c.dbis[t].get(_,{transaction:i,lazy:u});if(l)return[_,_d.parseRow(l,r)];s.push(_)}).filter(_=>_)})}a(lw,"batchHashSearch");function _w(e,t,r,n,s){if(Kr.validateEnv(e),t===void 0)throw new Error(ht.HASH_ATTRIBUTE_REQUIRED);if(dd(r),n==null)throw new Error(ht.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(ht.IDS_MUST_BE_ITERABLE)}a(_w,"initializeBatchSearchByHash");function dd(e){if(!Array.isArray(e))throw e===void 0?new Error(ht.FETCH_ATTRIBUTES_REQUIRED):new Error(ht.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(dd,"validateFetchAttributes");function di(e,t,r){if(Kr.validateEnv(e),t===void 0)throw new Error(ht.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ht.SEARCH_VALUE_REQUIRED);if(r?.length>sz)throw new Error(ht.SEARCH_VALUE_TOO_LARGE)}a(di,"validateComparisonFunctions");function ru(e,t){return t.length===1&&rz.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=_i.listDBIs(e)),t}a(ru,"setGetWholeRowAttributes");dw.exports={searchAll:iz,searchAllToMap:oz,count:lz,countAll:cz,equals:uz,startsWith:_z,endsWith:dz,contains:uw,searchByHash:Sz,setGetWholeRowAttributes:ru,batchSearchByHash:gz,batchSearchByHashToMap:Rz,checkHashExists:Tz,iterateDBI:az,greaterThan:fz,greaterThanEqual:Ez,lessThan:hz,lessThanEqual:mz,between:pz}});var ia=g((w_e,pw)=>{var fw=require("lodash"),Ew=je(),he=require("joi"),Az=J(),{hdb_schema_table:nu,checkValidTable:hw,hdb_table:mw,hdb_database:fd}=jn(),{handleHDBError:Oz,hdb_errors:bz}=se(),{getDatabases:yz}=(Ae(),ie(ke)),{HTTP_STATUS_CODES:Nz}=bz,Iz=he.object({database:fd,schema:fd,table:mw,search_attribute:nu,search_value:he.any().required(),get_attributes:he.array().min(1).items(he.alternatives(nu,he.object())).optional(),desc:he.bool(),limit:he.number().integer().min(1),offset:he.number().integer().min(0)}),wz=he.object({database:fd,schema:fd,table:mw,operator:he.string().valid("and","or").default("and").lowercase(),offset:he.number().integer().min(0),limit:he.number().integer().min(1),get_attributes:he.array().min(1).items(he.alternatives(nu,he.object())).optional(),sort:he.object({attribute:he.alternatives(nu,he.array().min(1)),descending:he.bool().optional()}).optional(),conditions:he.array().min(1).items(he.alternatives(he.object({operator:he.string().valid("and","or").default("and").lowercase(),conditions:he.array()}),he.object({search_attribute:he.alternatives(nu,he.array().min(1)),search_type:he.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:he.when("search_type",{switch:[{is:"equals",then:he.any()},{is:"between",then:he.array().items(he.alternatives([he.string(),he.number()])).length(2)}],otherwise:he.alternatives(he.string(),he.number())}).required()}))).required()});pw.exports=function(e,t){let r=null;switch(t){case"value":r=Ew.validateBySchema(e,Iz);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(hw("database",e.schema)),i(hw("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,wz);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=Az.checkGlobalSchemaTable(e.schema,e.table);if(s)return Oz(new Error,s,Nz.NOT_FOUND);let o=yz()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let u=a(l=>{for(let d=0,E=l.conditions.length;d<E;d++){let f=l.conditions[d];f.conditions?u(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&u(e);let _=fw.filter(c,l=>l!=="*"&&!l.startsWith?.("$")&&l.attribute!=="*"&&!Array.isArray(l)&&!l.name&&!fw.some(o,d=>d===l||d.attribute===l||d.attribute===l.attribute));if(_&&_.length>0){let l=_.join(", ");return l=l.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${l}'`)}}return r}});var Hp=g((D_e,Sw)=>{"use strict";var Cz=ze(),Dz=ia(),{getSchemaPath:Lz}=Xe();Sw.exports=Mz;function Mz(e){let t=Dz(e,"hashes");if(t)throw t;let r=Lz(e.schema,e.table);return Cz.openEnvironment(r,e.table)}a(Mz,"initialize")});var Gp=g((M_e,Tw)=>{"use strict";var Pz=sa(),Uz=Hp();Tw.exports=vz;async function vz(e){let t=await Uz(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return Pz.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(vz,"lmdbGetDataByHash")});var oa=g((U_e,gw)=>{"use strict";var qp=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};gw.exports=qp});var Aw=g((x_e,Rw)=>{"use strict";var B_e=oa(),Bz=sa(),xz=Hp();Rw.exports=Hz;async function Hz(e){let t=await xz(e),r=global.hdb_schema[e.schema][e.table];return Bz.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(Hz,"lmdbSearchByHash")});var ns=g((G_e,Ow)=>{"use strict";var Fp=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,u=!1,_=void 0,l=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=u,this.limit=_,this.offset=l}};Ow.exports=Fp});var Ed=g((F_e,Cw)=>{"use strict";var rr=sa(),Gz=ze(),qz=J(),me=ft(),ro=P(),Fz=Vi(),bw=vr().LMDB_ERRORS_ENUM,{getSchemaPath:kz}=Xe(),Is=ro.SEARCH_WILDCARDS;async function Vz(e,t,r){let n;e.schema===ro.SYSTEM_SCHEMA_NAME?n=Fz[e.table]:n=global.hdb_schema[e.schema][e.table];let s=ww(e,n.hash_attribute,r,t);return Nw(e,s,n.hash_attribute,r)}a(Vz,"prepSearch");async function Nw(e,t,r,n){let s=kz(e.schema,e.table),i=await Gz.openEnvironment(s,e.table),o=Iw(i,e,t,r),c=o.transaction||i;if([me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,me.SEARCH_TYPES.SEARCH_ALL,me.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if($z(e,r)===!1){let l=e.search_attribute;if(l===r)return n?yw(o,()=>!0):o.map(E=>({[r]:E.key}));let d=a(E=>({[r]:E.value,[l]:E.key}),"toObject");return n?yw(o,d):o.map(d)}let _=e.search_attribute===r?o.map(l=>l.key):o.map(l=>l.value);return n===!0?rr.batchSearchByHashToMap(c,r,e.get_attributes,_):rr.batchSearchByHash(c,r,e.get_attributes,_)}a(Nw,"executeSearch");function Iw(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:u}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,u=Number.isInteger(u)?u:void 0,r){case me.SEARCH_TYPES.EQUALS:s=rr.equals(e,i,t.search_attribute,t.search_value,o,c,u);break;case me.SEARCH_TYPES.CONTAINS:s=rr.contains(e,i,t.search_attribute,t.search_value,o,c,u);break;case me.SEARCH_TYPES.ENDS_WITH:case me.SEARCH_TYPES._ENDS_WITH:s=rr.endsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case me.SEARCH_TYPES.STARTS_WITH:case me.SEARCH_TYPES._STARTS_WITH:s=rr.startsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return rr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return rr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.SEARCH_ALL:return rr.searchAll(e,n,t.get_attributes,o,c,u);case me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return rr.searchAllToMap(e,n,t.get_attributes,o,c,u);case me.SEARCH_TYPES.BETWEEN:s=rr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,u);break;case me.SEARCH_TYPES.GREATER_THAN:case me.SEARCH_TYPES._GREATER_THAN:s=rr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case me.SEARCH_TYPES.GREATER_THAN_EQUAL:case me.SEARCH_TYPES._GREATER_THAN_EQUAL:s=rr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;case me.SEARCH_TYPES.LESS_THAN:case me.SEARCH_TYPES._LESS_THAN:s=rr.lessThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case me.SEARCH_TYPES.LESS_THAN_EQUAL:case me.SEARCH_TYPES._LESS_THAN_EQUAL:s=rr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;default:return Object.create(null)}return s}a(Iw,"searchByType");function yw(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(yw,"createMapFromIterable");function $z(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($z,"checkToFetchMore");function ww(e,t,r,n){if(qz.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),Is.indexOf(s)>-1)return r===!0?me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:me.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Is[0])<0&&s.indexOf(Is[1])<0)return c===!0?r===!0?me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:me.SEARCH_TYPES.EQUALS;if(Is.indexOf(i)>=0&&Is.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),me.SEARCH_TYPES.CONTAINS;if(Is.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),me.SEARCH_TYPES.ENDS_WITH;if(Is.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),me.SEARCH_TYPES.STARTS_WITH;if(s.includes(Is[0])||s.includes(Is[1]))return me.SEARCH_TYPES.EQUALS;throw new Error(bw.UNKNOWN_SEARCH_TYPE)}else switch(n){case ro.VALUE_SEARCH_COMPARATORS.BETWEEN:return me.SEARCH_TYPES.BETWEEN;case ro.VALUE_SEARCH_COMPARATORS.GREATER:return me.SEARCH_TYPES.GREATER_THAN;case ro.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return me.SEARCH_TYPES.GREATER_THAN_EQUAL;case ro.VALUE_SEARCH_COMPARATORS.LESS:return me.SEARCH_TYPES.LESS_THAN;case ro.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return me.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(bw.UNKNOWN_SEARCH_TYPE)}}a(ww,"createSearchTypeFromSearchObject");Cw.exports={executeSearch:Nw,createSearchTypeFromSearchObject:ww,prepSearch:Vz,searchByType:Iw}});var Lw=g(($_e,Dw)=>{"use strict";var V_e=ns(),Yz=ia(),Kz=J(),Wz=P(),Qz=Ed();Dw.exports=zz;function zz(e,t){if(!Kz.isEmpty(t)&&Wz.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=Yz(e,"value");if(n)throw n;return Qz.prepSearch(e,t,!0)}a(zz,"lmdbGetDataByValue")});var su=g((W_e,Mw)=>{"use strict";var K_e=ns(),Jz=ia(),Xz=J(),jz=P(),Zz=Ed();Mw.exports=e2;async function e2(e,t){if(!Xz.isEmpty(t)&&jz.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=Jz(e,"value");if(n)throw n;return Zz.prepSearch(e,t,!1)}a(e2,"lmdbSearchByValue")});var Uw=g((J_e,Pw)=>{"use strict";var z_e=ft(),kp=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}},Vp=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},$p=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};Pw.exports={SearchByConditionsObject:kp,SearchCondition:Vp,SortAttribute:$p}});var Gw=g((ede,Hw)=>{"use strict";var j_e=Uw().SearchByConditionsObject,t2=ns(),r2=ia(),Yp=sa(),hd=ft(),{Resource:Z_e}=(cn(),ie(Kp)),xw=Ed(),n2=xp(),s2=require("lodash"),{getSchemaPath:i2}=Xe(),vw=ze(),{handleHDBError:o2,hdb_errors:a2}=se(),{HTTP_STATUS_CODES:c2}=a2,u2=1e8;Hw.exports=l2;async function l2(e){let t=r2(e,"conditions");if(t)throw o2(t,t.message,c2.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=i2(e.schema,e.table),n=await vw.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let _ of e.conditions)vw.openDBI(n,_.search_attribute);let i=s2.sortBy(e.conditions,_=>{if(_.estimated_count===void 0){let l=_.search_type;l===hd.SEARCH_TYPES.EQUALS?_.estimated_count=Yp.count(n,_.search_attribute,_.search_value):l===hd.SEARCH_TYPES.CONTAINS||l===hd.SEARCH_TYPES.ENDS_WITH?_.estimated_count=1/0:_.estimated_count=u2}return _.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await Bw(o,e,i[0],s.hash_attribute),u;if(!e.operator||e.operator.toLowerCase()==="and"){let _=n.dbis[s.hash_attribute],l=i.slice(1).map(xw.filterByType),d=l.length,E=Yp.setGetWholeRowAttributes(n,e.get_attributes);u=c.map(f=>_.get(f,{transaction:o,lazy:!0})),d>0&&(u=u.filter(f=>{for(let h=0;h<d;h++)if(!l[h](f))return!1;return!0})),(e.offset||e.limit!==void 0)&&(u=u.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),u=u.map(f=>n2.parseRow(f,E))}else{for(let d=1;d<i.length;d++){let E=i[d],f=await Bw(o,e,E,s.hash_attribute);c=c.concat(f)}let _=new Set,l=e.offset||0;c=c.filter(d=>_.has(d)?!1:(_.add(d),!0)).slice(l,e.limit&&e.limit+l),u=Yp.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return u.onDone=()=>{o.done()},u}a(l2,"lmdbSearchByConditions");async function Bw(e,t,r,n){let s=new t2(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===hd.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,xw.searchByType(e,s,i,n).map(o=>o.value)}a(Bw,"executeConditionSearch")});var aa=g((rde,qw)=>{"use strict";var _2=P().OPERATIONS_ENUM,Wp=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=_2.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};qw.exports=Wp});var Qp=g((sde,Qw)=>{"use strict";var $w=ns(),Yw=aa(),Kw=su(),Ww=eu(),Sr=P(),Fw=J(),kw=ze(),{getTransactionAuditStorePath:d2,getSchemaPath:f2}=Xe(),Vw=$();Qw.exports=E2;async function E2(e){try{if(Fw.isEmpty(global.hdb_schema[e.schema])||Fw.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await h2(e),await m2(e);let t=f2(e.schema,e.table);try{await kw.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Vw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=d2(e.schema,e.table);await kw.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Vw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(E2,"lmdbDropTable");async function h2(e){let t=new $w(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Kw(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 Yw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await Ww(s)}a(h2,"deleteAttributesFromSystem");async function m2(e){let t=new $w(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Kw(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 Yw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await Ww(s)}catch(i){throw i}}a(m2,"dropTableFromSystem")});var Jw=g((ode,zw)=>{"use strict";var p2=require("fs-extra"),S2=ns(),T2=oa(),g2=aa(),R2=Qp(),A2=eu(),O2=Gp(),b2=su(),ws=P(),{getSchemaPath:y2}=Xe(),{handleHDBError:N2,hdb_errors:I2}=se(),{HDB_ERROR_MSGS:w2,HTTP_STATUS_CODES:C2}=I2;zw.exports=D2;async function D2(e){let t;try{t=await L2(e.schema);let r=new S2(ws.SYSTEM_SCHEMA_NAME,ws.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,ws.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[ws.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await b2(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await R2(c)}catch(u){if(u.message!=="invalid environment")throw u}}let s=new g2(ws.SYSTEM_SCHEMA_NAME,ws.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await A2(s);let i=y2(t);await p2.remove(i)}catch(r){throw r}}a(D2,"lmdbDropSchema");async function L2(e){let t=new T2(ws.SYSTEM_SCHEMA_NAME,ws.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[ws.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await O2(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw N2(new Error,w2.SCHEMA_NOT_FOUND(e),C2.NOT_FOUND,void 0,void 0,!0);return n}a(L2,"validateDropSchema")});var md=g((cde,Xw)=>{"use strict";var zp=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Xw.exports=zp});var Zw=g((_de,jw)=>{"use strict";var M2=require("fs-extra"),pd=ze(),{getTransactionAuditStorePath:P2}=Xe(),Jp=ft(),lde=md();jw.exports=U2;async function U2(e){let t;try{let r=P2(e.schema,e.table);await M2.mkdirp(r),t=await pd.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{pd.createDBI(t,Jp.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),pd.createDBI(t,Jp.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),pd.createDBI(t,Jp.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(U2,"createTransactionsAuditEnvironment")});var nC=g((fde,rC)=>{"use strict";var Xp=P(),eC=ze(),v2=Ko(),{getSystemSchemaPath:B2,getSchemaPath:x2}=Xe(),H2=Vi(),G2=q_(),jp=G_(),q2=$(),F2=Zw(),eS=H2.hdb_table,tC=[];for(let e=0;e<eS.attributes.length;e++)tC.push(eS.attributes[e].attribute);rC.exports=k2;async function k2(e,t){let r=x2(t.schema,t.table),n=new jp(t.schema,t.table,Xp.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new jp(t.schema,t.table,Xp.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new jp(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await eC.createEnvironment(r,t.table),e!==void 0){let o=await eC.openEnvironment(B2(),Xp.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await v2.insertRecords(o,eS.hash_attribute,tC,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await Zp(n),await Zp(s),await Zp(i)}await F2(t)}catch(o){throw o}}a(k2,"lmdbCreateTable");async function Zp(e){try{await G2(e)}catch(t){q2.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Zp,"createAttribute")});var iC=g((hde,sC)=>{"use strict";var V2=$c(),$2=wc(),Y2=cd(),iu=P(),K2=Ko().updateRecords,W2=ze(),{getSchemaPath:Q2}=Xe(),z2=jc(),J2=$();sC.exports=X2;async function X2(e){try{let{schema_table:t,attributes:r}=V2(e);$2(e,r,t.hash_attribute),e.schema!==iu.SYSTEM_SCHEMA_NAME&&(r.includes(iu.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(iu.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(iu.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(iu.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await Y2(e.hdb_auth_header,t,r),s=Q2(e.schema,e.table),i=await W2.openEnvironment(s,e.table),o=await K2(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await z2(e,o)}catch(c){J2.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(X2,"lmdbUpdateRecords")});var aC=g((pde,oC)=>{"use strict";var j2=P().OPERATIONS_ENUM,tS=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=j2.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};oC.exports=tS});var uC=g((gde,cC)=>{"use strict";var Tde=aC(),Z2=$c(),eJ=wc(),tJ=cd(),ou=P(),rJ=Ko().upsertRecords,nJ=ze(),{getSchemaPath:sJ}=Xe(),iJ=jc(),oJ=$(),{handleHDBError:aJ,hdb_errors:cJ}=se();cC.exports=uJ;async function uJ(e){let t;try{t=Z2(e)}catch(u){throw aJ(u,u.message,cJ.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;eJ(e,n,r.hash_attribute),e.schema!==ou.SYSTEM_SCHEMA_NAME&&(n.includes(ou.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(ou.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(ou.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(ou.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await tJ(e.hdb_auth_header,r,n),i=sJ(e.schema,e.table),o=await nJ.openEnvironment(i,e.table),c=await rJ(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await iJ(e,c)}catch(u){oJ.error(`unable to write transaction due to ${u.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(uJ,"lmdbUpsertRecords")});var _C=g((Ade,lC)=>{"use strict";var rS=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};lC.exports=rS});var fC=g((bde,dC)=>{"use strict";var nS=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}};dC.exports=nS});var mC=g((Ide,hC)=>{"use strict";var sS=ze(),{getTransactionAuditStorePath:lJ}=Xe(),Nde=_C(),au=ft(),_J=J(),EC=fC(),dJ=require("util").promisify,fJ=dJ(setTimeout),EJ=1e4,hJ=100;hC.exports=mJ;async function mJ(e){let t=lJ(e.schema,e.table),r=await sS.openEnvironment(t,e.table,!0),n=sS.listDBIs(r);sS.initializeDBIs(r,au.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new EC;do s=await pJ(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 fJ(hJ);while(s.transactions_deleted>0);return i}a(mJ,"deleteAuditLogsBefore");async function pJ(e,t){let r=new EC;try{let n=e.dbis[au.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[au.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];_J.isEmpty(c)||(s=e.dbis[au.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let u=0;u<o.hash_values.length;u++)s=e.dbis[au.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[u],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>EJ)break}return await s,r}catch(n){throw n}}a(pJ,"deleteTransactions")});var SC=g((Cde,pC)=>{"use strict";var iS=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};pC.exports=iS});var gC=g((Mde,TC)=>{"use strict";var SJ=ns(),TJ=aa(),Lde=SC(),ss=P(),gJ=J(),oS=ze(),RJ=Vi(),AJ=su(),OJ=eu(),{getSchemaPath:bJ}=Xe();TC.exports=yJ;async function yJ(e,t=!0){let r;e.schema===ss.SYSTEM_SCHEMA_NAME?r=RJ[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await IJ(e),s=bJ(e.schema,e.table),i=await oS.openEnvironment(s,e.table);return t===!0&&await NJ(e,i,r.hash_attribute),oS.dropDBI(i,e.attribute),n}a(yJ,"lmdbDropAttribute");async function NJ(e,t,r){let n=oS.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:u}of n.getRange({start:!1,versions:!0})){let _={};for(let l in c)l!==i&&(_[l]=c[l]);s=t.dbis[r].put(o,_,u)}await s}a(NJ,"removeAttributeFromAllObjects");async function IJ(e){let t=new SJ(ss.SYSTEM_SCHEMA_NAME,ss.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,ss.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[ss.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,ss.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await AJ(t)).filter(o=>o[ss.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(gJ.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[ss.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new TJ(ss.SYSTEM_SCHEMA_NAME,ss.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return OJ(i)}a(IJ,"dropAttributeFromSystem")});var NC=g((vde,yC)=>{"use strict";var aS=ze(),ca=ft(),Ude=Br(),cS=P(),RC=J(),{getTransactionAuditStorePath:wJ}=Xe(),CJ=sa(),Sd=ta(),DJ=$();yC.exports=LJ;async function LJ(e){let t=wJ(e.schema,e.table),r=await aS.openEnvironment(t,e.table,!0),n=aS.listDBIs(r);aS.initializeDBIs(r,ca.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case cS.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return AC(r,e.search_values);case cS.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,PJ(r,e.search_values,s);case cS.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return MJ(r,e.search_values);default:return AC(r)}}a(LJ,"readAuditLog");function AC(e,t=[0,Date.now()]){RC.isEmpty(t[0])&&(t[0]=0),RC.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[ca.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 Sd,s))}a(AC,"searchTransactionsByTimestamp");function MJ(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[ca.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,bC(e,i))}return Object.fromEntries(r)}a(MJ,"searchTransactionsByUsername");function PJ(e,t,r){let n=new Map;for(let c=0,u=t.length;c<u;c++){let _=t[c],l=CJ.equals(e,ca.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ca.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,_);for(let{value:d}of l){let E=Number(d);n.has(E)?n.get(E).push(_.toString()):n.set(E,[_.toString()])}}let s=Array.from(n.keys()),i=bC(e,s),o=new Map;for(let c=0;c<i.length;c++){let u=i[c],_=u.timestamp,l=n.get(_);OC(u,"records",r,l,o),OC(u,"original_records",r,l,o)}return Object.fromEntries(o)}a(PJ,"searchTransactionsByHashValues");function OC(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],u=c[r].toString();if(n.indexOf(u)>=0)if(s.has(u)){let _=s.get(u),l=_[_.length-1];if(l.timestamp===i)l[t]=[c];else{let d=new Sd(e.operation,e.user_name,i,void 0);d[t]=[c],_.push(d)}}else{let _=new Sd(e.operation,e.user_name,i,void 0);_[t]=[c],s.set(u,[_])}}}a(OC,"loopRecords");function bC(e,t){let r=[];try{let n=e.dbis[ca.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 Sd,i);r.push(o)}}catch(i){DJ.warn(i)}return r}catch(n){throw n}}a(bC,"batchSearchTransactions")});var wC=g((Gde,IC)=>{"use strict";var{getSchemaPath:xde}=Xe(),Hde=ze(),{database:UJ}=(Ae(),ie(ke));IC.exports={writeTransaction:vJ};async function vJ(e,t,r){return UJ({database:e,table:t}).transaction(r)}a(vJ,"writeTransaction")});var MC=g((Fde,LC)=>{"use strict";var{getSchemaPath:CC}=Xe(),DC=ze();LC.exports={flush:BJ,resetReadTxn:xJ};async function BJ(e,t){return(await DC.openEnvironment(CC(e,t),t.toString())).flushed}a(BJ,"flush");async function xJ(e,t){try{(await DC.openEnvironment(CC(e,t),t.toString())).resetReadTxn()}catch{}}a(xJ,"resetReadTxn")});var BC=g((Vde,vC)=>{"use strict";var{Readable:HJ}=require("stream"),{getDatabases:GJ}=(Ae(),ie(ke)),{readSync:qJ,openSync:FJ,createReadStream:PC}=require("fs"),{open:kJ}=require("lmdb"),UC=xc(),VJ=Hc(),{AUDIT_STORE_OPTIONS:$J}=(ni(),ie(xC)),{INTERNAL_DBIS_NAME:YJ,AUDIT_STORE_NAME:KJ}=ft();vC.exports=QJ;var uS=32768,WJ=100;async function QJ(e){let t=e.database||e.schema||"data",r=GJ()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let _=r[s[0]];if(!_)throw new Error(`Can not find table ${s[0]}`);let l=_.dbisDB,d=kJ({noSync:!0,maxDbs:VJ.MAX_DBS}),E,f=d.openDB(YJ,new UC(!1)),h=l.useReadTransaction(),p=0,S=a(async function(A,b){b.encoding="binary",b.encoder=void 0;let I=d.openDB(A,b),B=l.openDB(A,b);for(let{key:U,version:F,value:M}of B.getRange({start:null,transaction:h,versions:B.useVersions}))E=I.put(U,M,F),p++%WJ===0&&(await new Promise(Q=>setTimeout(Q,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:A,value:b}of l.getRange({transaction:h,start:!1}))if(s.some(I=>A.startsWith?.(I+"/"))){f.put(A,b);let[,I]=A.split("/"),B=!I,U=new UC(!B,B);await S(A,U)}e.include_audit&&await S(KJ,Object.assign({},$J)),await E;let T=PC(d.path);return T.headers=u(),T.on("close",()=>{h.done(),d.close()}),T}let o=r[Object.keys(r)[0]].primaryStore,c=FJ(o.path);return o.transaction(()=>{let _=Buffer.alloc(uS);qJ(c,_,0,uS),o.resetReadTxn();let l=o.useReadTransaction();l.renew();let d=PC(null,{fd:c,start:uS}),E=new HJ.from(async function*(){yield _;for await(let f of d)l.openTimer&&(l.openTimer=0),yield f;l.done()}());return E.headers=u(),E});function u(){let _=new Map;return _.set("content-type","application/octet-stream"),_.set("content-disposition",`attachment; filename="${t}"`),_.set("date",n),_}}a(QJ,"getBackup")});var qC=g((Yde,GC)=>{"use strict";var zJ=$(),{handleHDBError:JJ}=se(),XJ=ty(),jJ=q_(),ZJ=Mp(),e4=JI(),t4=eu(),r4=Gp(),n4=Aw(),s4=Lw(),i4=su(),o4=Gw(),a4=Jw(),c4=nC(),u4=iC(),l4=uC(),_4=mC(),d4=Qp(),f4=gC(),E4=NC(),h4=wC(),HC=MC(),m4=BC(),lS=class extends XJ{static{a(this,"LMDBBridge")}async searchByConditions(t){return o4(t)}async getDataByHash(t){return await r4(t)}async searchByHash(t){return await n4(t)}async getDataByValue(t,r){return await s4(t,r)}async searchByValue(t){return await i4(t)}async createSchema(t){return await e4(t)}async dropSchema(t){return await a4(t)}async createTable(t,r){return await c4(t,r)}async dropTable(t){return await d4(t)}async createAttribute(t){return await jJ(t)}async createRecords(t){return await ZJ(t)}async updateRecords(t){return await u4(t)}async upsertRecords(t){try{return await l4(t)}catch(r){throw JJ(r,null,null,zJ.ERR,r)}}async deleteRecords(t){return await t4(t)}async dropAttribute(t){return await f4(t)}async deleteAuditLogsBefore(t){return await _4(t)}async readAuditLog(t){return await E4(t)}writeTransaction(t,r,n){return h4.writeTransaction(t,r,n)}flush(t,r){return HC.flush(t,r)}resetReadTxn(t,r){return HC.resetReadTxn(t,r)}getBackup(t){return m4(t)}};GC.exports=lS});function g4(){T4=setInterval(function(){for(let e of _S)if(e.stale){let t=e[ye]?.url;$C.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},S4).unref()}var dS,VC,$C,YC,KC,WC,FC,_S,p4,cu,kC,no,Td,S4,T4,fS=Re(()=>{dS=H(Br()),VC=H(se()),$C=H($());cn();YC=H(ee()),KC=H(P()),WC=H(J()),FC=100,_S=new Set,p4=(0,WC.convertToMS)(YC.get(KC.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3,no=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),_S.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(_S.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(cu&&!this.overloadChecked&&performance.now()-kC>p4)throw new VC.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp||(0,dS.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let 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 A=T();h?h.push?h.push(A):h=[h,A]:h=A}}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"),u=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,u);s=s||E}else u();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)<FC>>n?u():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 cu||(cu=s,kC=performance.now(),cu.then(()=>{cu=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)+FC/2),t?t.retries=n+1:t={retries:1},this.commit(t)));let l={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(E=>({txnTime:r,next:E}));l.next=d}return l}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},Td=class extends no{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,dS.getNextMonotonicTime)())}getReadTxn(){}},S4=3e4;a(g4,"startMonitoringTxns");g4()});function rt(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 no;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 u=n.commit({letItLinger:r?.letItLinger});return u.then?u.then(()=>c):c}function o(c){throw n.abort({}),c}}var QC,so=Re(()=>{QC=require("../index");cn();fS();a(rt,"transaction");(0,QC._assignPackageExport)("transaction",rt);rt.commit=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};rt.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 rD={};Fe(rD,{ResourceBridge:()=>mS});function pS({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 JC(e,t){let r=is(e),n=pS(e,r);if(!r)throw new Un.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache},o;rt(i,()=>new Promise(_=>o=_));let c=e.ids||e.hash_values,u=0;return{[Symbol.asyncIterator](){return{async next(){if(u<c.length){let _=c[u++],l;try{l=await r.get({id:_,lazy:s,select:n},i),l=l&&Rd(l)}catch(d){l={message:d.toString()}}return t?{value:{key:_,value:l}}:{value:l}}else return o(),{done:!0}},return(_){return o(),{value:_,done:!0}},throw(_){return o(),{done:!0}}}}}}function is(e){let t=e.database||e.schema||A4,r=Tr()[t];if(!r)throw(0,Un.handleHDBError)(new Error,R4.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function XC(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*jC(e,t,r){let n;for await(let s of e.getHistory(t,r)){let i=s.type;i==="put"&&(i="upsert");let{id:o,version:c,value:u}=s;n?.timestamp===c?(n.hash_values.push(o),n.records.push(u)):(n&&(yield n),n={operation:i,user_name:s.user,timestamp:c,hash_values:[o],records:[u]})}n&&(yield n)}var ZC,gd,Un,eD,vn,ES,hS,tD,R4,A4,O4,b4,zC,mS,nD=Re(()=>{"use strict";ZC=H(qC()),gd=H(ia()),Un=H(se());Ae();eD=H($c()),vn=H(P()),ES=H(Ns()),hS=H(Pn()),tD=H(J());so();Ad();({HDB_ERROR_MSGS:R4}=Un.hdb_errors),A4="data",O4=1e4,b4=10,mS=class extends ZC.default{static{a(this,"ResourceBridge")}constructor(t){super(t),zC=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,gd.default)(t,"conditions");if(r)throw(0,Un.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=is(t);if(!n)throw new Un.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:pS(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}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 Un.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}Et({database:r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await is(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=is(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,u)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,u,()=>r.primaryStore.put(o,c,u)).then(_=>{if(!_){let{value:l,version:d}=r.primaryStore.getEntry(o);return i(o,l,d)}})),"deleteRecord");for(let{key:o,value:c,version:u}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,u),await new Promise(_=>setImmediate(_));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){is(t).dropTable()}createSchema(t){return ua({database:t.schema,table:null}),ES.signalSchemaChange(new hS.SchemaEventMsg(process.pid,vn.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await SS(t.schema),ES.signalSchemaChange(new hS.SchemaEventMsg(process.pid,vn.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,zC.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,eD.default)(t),s,i=Tr()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt};return rt(o,async c=>{if(!i.schemaDefined){s=[];for(let l of n)i.attributes.find(E=>E.name==l)||s.push(l);s.length>0&&await i.addAttributes(s.map(l=>({name:l,indexed:!0})))}let u=[],_=[];for(let l of t.records){let d=l[i.primaryKey],E=d!=null&&await i.get(d,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){_.push(l[i.primaryKey]);continue}E&&(E=Rd(E));for(let f in l)if(Object.prototype.hasOwnProperty.call(l,f)){let h=l[f];if(typeof h=="function")try{let p=h([[E]]);Array.isArray(p)&&(h=p[0].func_val,l[f]=h)}catch(p){throw p.message+="Trying to set key "+f+" on object"+JSON.stringify(l),p}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(l,f)||(l[f]=E[f]);await(d==null?i.create(l,o):i.put(l,o)),u.push(l[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:u,new_attributes:s,skipped_hashes:_}})}async deleteRecords(t){let r=Tr()[t.schema][t.table],n={user:t.hdb_user};return rt(n,async s=>{let i=t.hash_values||t.records.map(u=>u[r.primaryKey]),o=[],c=[];for(let u of i)await r.delete(u,n)?o.push(u):c.push(u);return XC(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Tr()[t.schema][t.table];if(!r.createdTimeProperty)throw new Un.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:vn.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,u=[],_=a(async()=>{let l=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:u});i.push(...l.deleted_hashes),o.push(...l.skipped_hashes),await(0,tD.async_set_timeout)(b4),u=[],s=!0},"chunkDelete");for await(let l of n)u.push(l[r.primaryKey]),c++,c%O4===0&&await _();return u.length>0&&await _(),s?XC(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,gd.default)(t,"hashes");if(r)throw r;return JC(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of JC(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&vn.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,gd.default)(t,"value");if(n)throw n;let s=is(t);if(!s)throw new Un.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===vn.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:pS(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async getDataByValue(t,r){let n=new Map,s=is(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){is({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return is(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=is(t),n={};switch(t.search_type){case vn.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 vn.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of jC(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return jC(r,t.search_values?.[0],t.search_values?.[1])}}};a(pS,"getSelect");a(JC,"getRecords");a(is,"getTable");a(XC,"createDeleteResponse");a(jC,"groupRecordsInHistory")});var Dn=g((ofe,sD)=>{"use strict";var{ResourceBridge:y4}=(nD(),ie(rD)),N4=ee();N4.initSync();var Od;function I4(){return Od||(Od=new y4,Od)}a(I4,"getBridge");sD.exports=I4()});var cD=g((cfe,aD)=>{"use strict";var iD=require("lodash"),uu=require("mathjs"),w4=require("jsonata"),oD=J();aD.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?iD.uniqWith(e,iD.isEqual):e,searchJSON:C4,mad:lu.bind(null,uu.mad),mean:lu.bind(null,uu.mean),mode:lu.bind(null,uu.mode),prod:lu.bind(null,uu.prod),median:lu.bind(null,uu.median)};function lu(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(lu,"aggregateFunction");function C4(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(oD.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),oD.isEmpty(this.__ala__.res[r])){let n=w4(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(C4,"searchJSON")});var lD=g((lfe,uD)=>{"use strict";var Rt=require("moment"),TS="YYYY-MM-DDTHH:mm:ss.SSSZZ";Rt.suppressDeprecationWarnings=!0;uD.exports={current_date:()=>Rt().utc().format("YYYY-MM-DD"),current_time:()=>Rt().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return Rt(e).utc().format("YYYY");case"month":return Rt(e).utc().format("MM");case"day":return Rt(e).utc().format("DD");case"hour":return Rt(e).utc().format("HH");case"minute":return Rt(e).utc().format("mm");case"second":return Rt(e).utc().format("ss");case"millisecond":return Rt(e).utc().format("SSS");default:break}},date:e=>Rt(e).utc().format(TS),date_format:(e,t)=>Rt(e).utc().format(t),date_add:(e,t,r)=>Rt(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>Rt(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=Rt(e).utc(),s=Rt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>Rt().utc().valueOf(),get_server_time:()=>Rt().format(TS),offset_utc:(e,t)=>Rt(e).utc().utcOffset(t).format(TS)}});var ED=g((_fe,fD)=>{"use strict";var D4=require("@turf/area"),L4=require("@turf/length"),M4=require("@turf/circle"),P4=require("@turf/difference"),U4=require("@turf/distance"),v4=require("@turf/boolean-contains"),B4=require("@turf/boolean-equal"),x4=require("@turf/boolean-disjoint"),H4=require("@turf/helpers"),_D=P(),Te=J(),Cs=$();fD.exports={geoArea:G4,geoLength:q4,geoCircle:F4,geoDifference:k4,geoDistance:dD,geoNear:V4,geoContains:$4,geoEqual:Y4,geoCrosses:K4,geoConvert:W4};function G4(e){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return D4.default(e)}catch(t){return Cs.trace(t,e),NaN}}a(G4,"geoArea");function q4(e,t){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return L4.default(e,{units:t||"kilometers"})}catch(r){return Cs.trace(r,e),NaN}}a(q4,"geoLength");function F4(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return M4.default(e,t,{units:r||"kilometers"})}catch(n){return Cs.trace(n,e,t),NaN}}a(F4,"geoCircle");function k4(e,t){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return P4(e,t)}catch(r){return Cs.trace(r,e,t),NaN}}a(k4,"geoDifference");function dD(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return U4.default(e,t,{units:r||"kilometers"})}catch(n){return Cs.trace(n,e,t),NaN}}a(dD,"geoDistance");function V4(e,t,r,n){if(Te.isEmpty(e)||Te.isEmpty(t))return!1;if(Te.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return dD(e,t,n)<=r}catch(s){return Cs.trace(s,e,t),!1}}a(V4,"geoNear");function $4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return v4.default(e,t)}catch(r){return Cs.trace(r,e,t),!1}}a($4,"geoContains");function Y4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return B4.default(e,t)}catch(r){return Cs.trace(r,e,t),!1}}a(Y4,"geoEqual");function K4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return!x4.default(e,t)}catch(r){return Cs.trace(r,e,t),!1}}a(K4,"geoCrosses");function W4(e,t,r){if(Te.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Te.isEmpty(t))throw new Error("geo_type is required");if(Te.isEmpty(_D.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(_D.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Te.autoCastJSON(e)),H4[t](e,r)}a(W4,"geoConvert")});var bd=g((ffe,hD)=>{var io=cD(),Wr=lD(),os=ED();hD.exports=e=>{e.aggr.mad=e.aggr.MAD=io.mad,e.aggr.mean=e.aggr.MEAN=io.mean,e.aggr.mode=e.aggr.MODE=io.mode,e.aggr.prod=e.aggr.PROD=io.prod,e.aggr.median=e.aggr.MEDIAN=io.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=io.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=io.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Wr.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Wr.current_time,e.fn.extract=e.fn.EXTRACT=Wr.extract,e.fn.date=e.fn.DATE=Wr.date,e.fn.date_format=e.fn.DATE_FORMAT=Wr.date_format,e.fn.date_add=e.fn.DATE_ADD=Wr.date_add,e.fn.date_sub=e.fn.DATE_SUB=Wr.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Wr.date_diff,e.fn.now=e.fn.NOW=Wr.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Wr.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Wr.get_server_time,e.fn.getdate=e.fn.GETDATE=Wr.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Wr.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=os.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=os.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=os.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=os.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=os.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=os.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=os.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=os.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=os.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=os.geoNear}});var TD=g((Efe,SD)=>{"use strict";var _u=require("lodash"),gr=require("alasql");gr.options.cache=!1;var Q4=bd(),mD=require("clone"),yd=require("recursive-iterator"),fe=$(),Le=J(),la=Dn(),z4=P(),{hdb_errors:J4}=se(),{getDatabases:pD}=(Ae(),ie(ke)),X4="IS NULL",Bn="There was a problem performing this search. Please check the logs and try again.";Q4(gr);var gS=class{static{a(this,"SQLSearch")}constructor(t,r){if(Le.isEmpty(t))throw fe.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(),Le.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Le.isEmptyOrZeroLength(n))return fe.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw fe.error("Error thrown from checkEmptySQL in SQLSearch class method search."),fe.error(n),new Error(Bn)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw fe.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),fe.error(n),new Error(Bn)}if(Object.keys(this.data).length===0)return fe.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw fe.error("Error thrown from processJoins in SQLSearch class method search."),fe.error(n),new Error(Bn)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw fe.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),fe.error(n),new Error(Bn)}try{return t=await this._finalSQL(),t}catch(n){throw fe.error("Error thrown from finalSQL in SQLSearch class method search."),fe.error(n),new Error(Bn)}}_getColumns(){let t=new yd(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(mD(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=_u.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let n=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[n]={},this.data[n].__hash_name=pD()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Le.isEmpty(this.statement.where)){fe.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new yd(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Le.isEmpty(r)&&r.right)if(Le.isNotEmptyAndHasValue(r.right.value)){let n=Le.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new gr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Le.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new gr.yy.LogicValue({value:i}):n instanceof gr.yy.StringValue&&Le.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new gr.yy.NumValue({value:i}))});if(t){fe.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new yd(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(!Le.isEmpty(z4.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Le.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Le.isEmptyOrZeroLength(r.left.columnid)||Le.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(Le.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"=":!Le.isEmpty(r.right.value)||!Le.isEmpty(r.left.value)?n.add(Le.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let u=Array.isArray(r.right)?r.right:r.left;for(let _=0;_<u.length;_++)if(u[_].value)n.add(u[_].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from)&&Le.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&_u.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(Le.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Le.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(Le.isEmptyOrZeroLength(this.all_table_attributes)&&!Le.isEmptyOrZeroLength(this.columns.columns))return t;if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await gr.promise(r)}catch(r){throw fe.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),fe.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(mD(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(Le.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(X4)>-1&&this.tables.forEach(s=>{let i={columnid:pD()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=_u.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},u=!1,_=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(u=!0),!Le.isEmpty(this.exact_search_values[_])&&!this.exact_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.exact_search_values[_].values))if(u)try{c.hash_values=Array.from(this.exact_search_values[_].values);let l=await la.getDataByHash(c);for(let d of c.hash_values)l.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(l){throw fe.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(l),new Error(Bn)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[_].values).map(async l=>{let d=Object.assign({},c);d.search_value=l;let E=await la.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(l){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(l),new Error(Bn)}else if(!Le.isEmpty(this.comparator_search_values[_])&&!this.comparator_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.comparator_search_values[_].comparators))try{let l=this.comparator_search_values[_].comparators;for(let d=0,E=l.length;d<E;d++){let f=l[d];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await la.getDataByValue(c,f.operation);if(u)for(let[p]of h)this.data[i].__merged_data[p]||(this.data[i].__merged_data[p]=[...n[i]],this._setMergedHashAttribute(i,p));else for(let[p,S]of h)this.data[i].__merged_data[p]?this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]):(this.data[i].__merged_data[p]=[...n[i]],this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]),this._setMergedHashAttribute(i,p))}}catch(l){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),fe.error(l),new Error(Bn)}else try{c.search_attribute=s.attribute,c.search_value="*";let l=await la.getDataByValue(c);if(u)for(let[d]of l)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,E]of l)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(l){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),fe.error(l),new Error(Bn)}}}_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 gr.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 gr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new gr.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 gr.yy.FuncValue:new gr.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 u=this.statement.where?"WHERE "+this.statement.where:"";u=u.replace(/NOT\(NULL\)/g,"NOT NULL");let _="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(_="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(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 l="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(l=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${u} ${_} ${l} ${d}`,h=this._convertColumnsToIndexes(f,s);E=await gr.promise(h,t),t=null}catch(f){throw fe.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),fe.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=_u.difference(h,[...f.keys].map(S=>S.toString()));for(let S=0,T=p.length;S<T;S++){let A=p[S];delete this.data[`${f.schema}_${f.table}`].__merged_data[A]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new yd(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=_u.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw fe.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),fe.error(i),new Error(Bn)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let l in i)o.push(i[l][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},u=await la.getDataByHash(c),_=s.columns.length;for(let l=0,d=o.length;l<d;l++){let E=o[l],f=u.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 fe.error("Error thrown from getDataByHash function in SQLSearch class method getData."),fe.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,u=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===u}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();fe.trace(`Final SQL: ${s}`),n=await gr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),fe.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw fe.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),fe.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 fe.error(J4.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),fe.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let u=s[i],_=new RegExp(`${u}.\`${o}\``,"g"),l=`${u}.[${c}]`;n=n.replace(_,l)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let u=new RegExp(`\`${o}\``,"g"),_=`[${c}]`;n=n.replace(u,_)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await la.getDataByValue(i);for(let[c,u]of o)this.data[s].__merged_data[c]||(u[n.attribute]===void 0&&(u[n.attribute]=null),this.data[s].__merged_data[c]=Object.assign({},r[s])),this.data[s].__merged_data[c][t[n.attribute]]=u[n.attribute]??null}catch(o){throw fe.error("There was an error when processing this SQL operation. Check your logs"),fe.error(o),new Error(Bn)}}return Object.values(Object.values(this.data)[0].__merged_data)}};SD.exports=gS});var qr=g((mfe,gD)=>{"use strict";var j4=Zb();gD.exports={searchByConditions:e3,searchByHash:t3,searchByValue:r3,search:n3};var RS=Dn(),{transformReq:AS}=J(),Z4=TD();async function e3(e){return AS(e),RS.searchByConditions(e)}a(e3,"searchByConditions");async function t3(e){AS(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of RS.searchByHash(e))r&&t.push(r);return t}a(t3,"searchByHash");async function r3(e){AS(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of RS.searchByValue(e))t.push(r);return t}a(r3,"searchByValue");function n3(e,t){try{let r=new j4(e);r.validate(),new Z4(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(n3,"search")});var Nd=g((Sfe,RD)=>{"use strict";var s3=Dn();RD.exports={writeTransaction:i3};function i3(e,t,r){return s3.writeTransaction(e,t,r)}a(i3,"writeTransaction")});var yD=g((Rfe,bD)=>{"use strict";var o3=qr(),a3=ys(),AD=$(),c3=Fr(),gfe=Nd(),u3=require("clone"),bS=require("alasql"),l3=bd(),OD=require("util"),_3=OD.promisify(a3.getTableSchema),d3=OD.promisify(o3.search),f3=P(),OS=J();l3(bS);bD.exports={update:h3};var E3="There was a problem performing this update. Please check the logs and try again.";async function h3({statement:e,hdb_user:t}){let r=await _3(e.table.databaseid,e.table.tableid),n=m3(e.columns);OS.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=u3(s),c=OS.isEmpty(i)?"":` WHERE ${i.toString()}`,u=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,_=bS.parse(u).statements[0],l=await d3(_),d=p3(n,l);return S3(o,d,t)}a(h3,"update");function m3(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=bS.compile(`SELECT ${r.expression.toString()} AS [${f3.FUNC_VAL}] FROM ?`)}),t}catch(t){throw AD.error(t),new Error(E3)}}a(m3,"createUpdateRecord");function p3(e,t){return OS.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(p3,"buildUpdateRecords");async function S3(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await c3.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){AD.error(`Error delete new_attributes from update response: ${i}`)}return s}a(S3,"updateRecords")});var ID=g((yfe,ND)=>{var T3=require("alasql"),g3=qr(),R3=$(),A3=Dn(),NS=require("util"),yS=J(),O3=P(),b3=ys(),Ofe=Nd(),bfe=Fr(),y3="record",N3="successfully deleted",I3=NS.callbackify(L3),w3=NS.promisify(g3.search),C3=NS.promisify(b3.getTableSchema);ND.exports={convertDelete:I3};function D3(e){return`${e.deleted_hashes.length} ${y3}${e.deleted_hashes.length===1?"":"s"} ${N3}`}a(D3,"generateReturnMessage");async function L3({statement:e,hdb_user:t}){let r=await C3(e.table.databaseid,e.table.tableid);yS.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=yS.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=T3.parse(o).statements[0],u={operation:O3.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{u.records=await w3(c);let _=await A3.deleteRecords(u);return yS.isEmptyOrZeroLength(_.message)&&(_.message=D3(_)),delete _.txn_time,_}catch(_){throw R3.error(_),_.hdb_code?_.message:_}}a(L3,"convertDelete")});var MD=g((Ife,LD)=>{"use strict";var M3=bs(),{hdb_errors:wD}=se(),{getDatabases:CD}=(Ae(),ie(ke));LD.exports={checkSchemaExists:DD,checkSchemaTableExists:P3,schema_describe:M3};async function DD(e){if(!CD()[e])return wD.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(DD,"checkSchemaExists");async function P3(e,t){let r=await DD(e);if(r)return r;if(!CD()[e][t])return wD.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(P3,"checkSchemaTableExists")});var du=g((Cfe,U3)=>{U3.exports={name:"harperdb",version:"4.3.36",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.1.6",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.11.2",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.3",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^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 pu={};Fe(pu,{addAnalyticsListener:()=>mu,recordAction:()=>nr,recordActionBinary:()=>Qr,setAnalyticsEnabled:()=>v3});function v3(e){FD=e}function nr(e,t,r,n,s){if(!FD)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=Cd.get(i);if(o)if(typeof e=="number"){let c=o.values,u=c.index++;if(u>=c.length){let _=c;o.values=c=new Float32Array(u*2),c.set(_),c.index=u+1}c[u]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},Cd.set(i,o)}Id||B3()}function Qr(e,t,r,n,s){nr(!!e,t,r,n,s)}function mu(e){$D.push(e)}function B3(){Id=performance.now(),setTimeout(async()=>{let e=performance.now()-Id;Id=0;let t=[],r={time:Date.now(),period:e,threadId:oo.threadId,metrics:t};for(let[s,i]of Cd){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,u=0,_=[],l;for(let d of YD){let E=Math.floor(c*d),f=o[E-1];if(E>u){let h=E-u;if(f===l){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),l=f;u=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 KD()}let n=process.memoryUsage();t.push({metric:"memory",threadId:oo.threadId,byThread:!0,...n});for(let s of $D)s(t);Cd=new Map,oo.parentPort?oo.parentPort.postMessage({type:VD,report:r}):zD({report:r})},kD).unref()}async function x3(e,t=6e4){let r=CS(),n=WD(),s=new Promise(p=>{let S=performance.now();setImmediate(()=>{let T=performance.now();T-S>5e3&&(0,fu.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,fu.warn)("Unusually high task queue latency on the main thread of "+Math.round(T-S)+"ms"),p(T-S)})}),i;for(let p of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(p.value?.time){i=p.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,u=new Map,_=[],l;for(let{key:p,value:S}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!S)continue;if(o){if(p>o+t)break}else o=p;l=p;let{metrics:T,threadId:A}=S;for(let b of T||[]){let{path:I,method:B,type:U,metric:F,count:M,total:Q,distribution:z,threads:j,...oe}=b;M||(M=1);let ue=F+(I?"-"+I:"");B!==void 0&&(ue+="-"+B),U!==void 0&&(ue+="-"+U);let le=c.get(ue);if(le){if(le.threads){let Ne=le.threads[A];if(Ne)le=Ne;else{le.threads[A]=Object.assign({},oe);continue}}le.count||(le.count=1);let Be=le.count;for(let Ne in oe){let xe=oe[Ne];typeof xe=="number"&&(le[Ne]=(le[Ne]*Be+xe*M)/(Be+M))}le.count+=M,Q>=0&&(le.total+=Q,le.ratio=le.total/le.count)}else le=Object.assign({period:t},b),delete le.distribution,c.set(ue,le),le.byThread&&(le.threads=[],le.threads[A]=Object.assign({},oe),_.push(le));if(z){z=z.map(Ne=>typeof Ne=="number"?{value:Ne,count:1}:Ne);let Be=u.get(ue);Be?Be.push(...z):u.set(ue,z)}}await KD()}for(let p of _){let{path:S,method:T,type:A,metric:b,count:I,total:B,distribution:U,threads:F,...M}=p;F=F.filter(Q=>Q);for(let Q in M){if(typeof p[Q]!="number")continue;let z=0;for(let j of F){let oe=j[Q];typeof oe=="number"&&(z+=oe)}p[Q]=z}p.count=F.length,delete p.threads,delete p.byThread}for(let[p,S]of u){let T=c.get(p);S.sort((Ne,xe)=>Ne.value>xe.value?1:-1);let A=T.count-1,b=[],I=0,B=0,U;for(let Ne of YD){let xe=A*Ne;for(;I<xe;)U=S[B++],I+=U.count,B===1&&I--;let n_=S[B>1?B-2:0];U||(U=S[0]),b.push(U.value-(U.value-n_.value)*(I-xe)/U.count)}let[F,M,Q,z,j,oe,ue,le,Be]=b;Object.assign(T,{p1:F,p10:M,p25:Q,median:z,p75:j,p90:oe,p95:ue,p99:le,p999:Be})}let d;for(let[p,S]of c)S.id=(0,wd.getNextMonotonicTime)(),S.time=l,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,wd.getNextMonotonicTime)(),S={id:p,metric:"main-thread-utilization",idle:f-PD,active:h-UD,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(p,S,{append:!0}).then(T=>{T||n.primaryStore.put(p,S)})}PD=f,UD=h}async function vD(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function CS(){return BD||(BD=Et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function WD(){return xD||(xD=Et({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function q3(){QD=!0;let e=(0,hu.get)(wS.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await x3(kD,e),await vD(CS(),H3),await vD(WD(),G3)},Math.min(e/2,2147483647)).unref()}function zD(e,t){let r=e.report;r.threadId=t?.threadId||oo.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(HD+=n.mean*n.count);r.totalBytesProcessed=HD,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(GD.get(t))}),GD.set(t,t.performance.eventLoopUtilization())),r.id=(0,wd.getNextMonotonicTime)(),CS().primaryStore.put(r.id,r),QD||q3(),F3&&(JD=V3(r))}async function V3(e){if(await JD,!fi){let r=(0,Eu.dirname)((0,fu.getLogFilePath)());try{fi=await(0,IS.open)((0,Eu.join)(r,"analytics.log"),"r+")}catch{fi=await(0,IS.open)((0,Eu.join)(r,"analytics.log"),"w+")}}let t=(await fi.stat()).size;if(t>k3){let r=Buffer.alloc(t);await fi.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await fi.write(r,{position:0}),await fi.truncate(r.length),t=r.length}await fi.write(JSON.stringify(e)+`
|
|
10
|
-
`,t)}var oo,
|
|
8
|
+
`)},uK="certificate.pem",lK="privateKey.pem",_K="ca.pem";BN.exports={CERTIFICATE_VALUES:cK,CERTIFICATE_PEM_NAME:uK,PRIVATEKEY_PEM_NAME:lK,CA_PEM_NAME:_K}});var lp=g((gle,VN)=>{"use strict";var FN=require("fs-extra"),ae=require("joi"),dK=require("os"),{boolean:be,string:er,number:tt,array:J_}=ae.types(),{totalmem:HN}=require("os"),zi=require("path"),fK=$(),X_=J(),Tle=xN(),GN=P(),EK=je(),qN="log",hK="components",mK="Invalid logging.rotation.maxSize unit. Available units are G, M or K",pK="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",SK="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",TK="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",gK="rootPath config parameter is undefined",RK="clustering.enabled config parameter is undefined",Ji=tt.min(0).required(),j_=J_.items({host:er.required(),port:Ji}).empty(null),es,kN=!1;VN.exports={configValidator:AK,routesValidator:wK,route_constraints:j_};function AK(e,t=!1){if(kN=t,es=e.rootPath,X_.isEmpty(es))throw gK;let r=be.required(),n=tt.min(0).max(1e3).empty(null).default(IK),s=er.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(Qc),i=er.optional().empty(null),o=er.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=ae.string().empty(null).default(Qc),u=ae.custom(bK).empty(null).default(Qc),_=e.clustering?.enabled;if(X_.isEmpty(_))throw RK;let l=ae.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return _===!0?d=ae.object({enabled:r,hubServer:ae.object({cluster:ae.object({name:ae.required().empty(null),network:ae.object({port:Ji,routes:j_}).required()}).required(),leafNodes:ae.object({network:ae.object({port:Ji}).required()}).required(),network:ae.object({port:Ji}).required()}).required(),leafServer:ae.object({network:ae.object({port:Ji,routes:j_}).required(),streams:ae.object({maxAge:tt.min(120).allow(null).optional(),maxBytes:tt.min(1).allow(null).optional(),maxMsgs:tt.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:ae.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:be.optional(),databaseLevel:be.optional(),tls:ae.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:be.required(),verify:be.optional()}),user:er.optional().empty(null)}).required():d=ae.object({enabled:r,tls:ae.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:be.required()})}).required(),ae.object({authentication:ae.object({authorizeLocal:be,cacheTTL:tt.required(),enableSessions:be}),analytics:ae.object({aggregatePeriod:tt}),componentsRoot:s.optional(),clustering:d,localStudio:ae.object({enabled:r}).required(),logging:ae.object({auditAuthEvents:ae.object({logFailed:be,logSuccessful:be}),file:be.required(),level:ae.valid("notify","fatal","error","warn","info","debug","trace"),rotation:ae.object({enabled:be.optional(),compress:be.optional(),interval:er.custom(NK).optional().empty(null),maxSize:er.custom(yK).optional().empty(null),path:er.optional().empty(null).default(Qc)}).required(),root:s,stdStreams:be.required(),auditLog:be.required()}).required(),operationsApi:ae.object({network:ae.object({cors:be.optional(),corsAccessList:J_.optional(),headersTimeout:tt.min(1).optional(),keepAliveTimeout:tt.min(1).optional(),port:tt.optional().empty(null),domainSocket:ae.optional().empty("hdb/operations-server").default(Qc),securePort:tt.optional().empty(null),timeout:tt.min(1).optional()}).optional(),tls:ae.alternatives([ae.array().items(l),l])}).required(),rootPath:er.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:ae.object({network:ae.object({port:Ji,securePort:Ji,mtls:ae.alternatives([be.optional(),ae.object({user:er.optional(),certificateAuthority:i,required:be.optional()})])}).required(),webSocket:be.optional(),requireAuthentication:be.optional()}),http:ae.object({compressionThreshold:tt.optional(),cors:be.optional(),corsAccessList:J_.optional(),headersTimeout:tt.min(1).optional(),port:tt.min(0).optional().empty(null),securePort:tt.min(0).optional().empty(null),maxHeaderSize:tt.optional(),mtls:ae.alternatives([be.optional(),ae.object({user:er.optional(),certificateAuthority:i,required:be.optional()})]),threadRange:ae.alternatives([J_.optional(),er.optional()])}).required(),threads:ae.alternatives(n.optional(),ae.object({count:n.optional(),debug:ae.alternatives(be.optional(),ae.object({startingPort:tt.min(1).optional(),host:er.optional(),waitForDebugger:be.optional()})),maxHeapMemory:tt.min(0).optional()})),storage:ae.object({writeAsync:be.required(),overlappingSync:be.optional(),caching:be.optional(),compression:ae.alternatives([be.optional(),ae.object({dictionary:er.optional(),threshold:tt.optional()})]),compactOnStart:be.optional(),compactOnStartKeepBackup:be.optional(),noReadAhead:be.optional(),path:u,prefetchWrites:be.optional(),maxFreeSpaceToLoad:tt.optional(),maxFreeSpaceToRetain:tt.optional()}).required(),ignoreScripts:be.optional(),tls:ae.alternatives([ae.array().items(l),l])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(AK,"configValidator");function OK(e){return kN||FN.existsSync(e)?null:`Specified path ${e} does not exist.`}a(OK,"doesPathExist");function bK(e,t){ae.assert(e,er.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=OK(e);if(r)return t.message(r)}a(bK,"validatePath");function yK(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(mK);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(SK):e}a(yK,"validateRotationMaxSize");function NK(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(pK);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(TK):e}a(NK,"validateRotationInterval");function IK(e,t){let r=t.state.path.join("."),n=dK.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||HN();return i=Math.round(Math.min(i,HN())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),fK.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(IK,"setDefaultThreads");function Qc(e,t){let r=t.state.path.join(".");if(!X_.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(X_.isEmpty(es))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return zi.join(es,hK);case"logging.root":return zi.join(es,qN);case"clustering.leafServer.streams.path":return zi.join(es,"clustering","leaf");case"storage.path":let n=zi.join(es,GN.LEGACY_DATABASES_DIR_NAME);return FN.existsSync(n)?n:zi.join(es,GN.DATABASES_DIR_NAME);case"logging.rotation.path":return zi.join(es,qN);case"operationsApi.network.domainSocket":return r==null?null:zi.join(es,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Qc,"setDefaultRoot");function wK(e){let t=ae.object({routes:j_});return EK.validateBySchema({routes:e},t)}a(wK,"routesValidator")});var pr=g((Ole,jN)=>{"use strict";var Vr=P(),xt=J(),It=$(),{configValidator:CK,routesValidator:$N}=lp(),mr=require("fs-extra"),DK=require("yaml"),Ln=require("path"),LK=require("is-number"),KN=require("properties-reader"),MK=require("lodash"),{handleHDBError:PK}=se(),{HTTP_STATUS_CODES:UK,HDB_ERROR_MSGS:Z_}=vr(),Ale=require("minimist"),{server:vK}=(fr(),ie(Gi)),{DATABASES_PARAM_CONFIG:zc,CONFIG_PARAMS:kr,CONFIG_PARAM_MAP:Mn}=Vr,BK="Unable to get config value because config is uninitialized",xK="Config successfully initialized",HK="Error backing up config file",GK="Empty parameter sent to getConfigValue",WN=Ln.join(Vr.PACKAGE_ROOT,"config","yaml",Vr.HDB_DEFAULT_CONFIG_FILE),qK="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",YN={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"},ed,wt,td;jN.exports={createConfigFile:FK,getDefaultConfig:kK,getConfigValue:zN,initConfig:dp,flattenConfig:zo,updateConfigValue:JN,updateConfigObject:$K,getConfiguration:WK,setConfiguration:QK,readConfigFile:Ep,getClusteringRoutes:zK,initOldConfig:XN,getConfigFromFile:JK,getConfigFilePath:Xi,addConfig:XK,deleteConfigFromFile:jK,getConfigObj:ZK};function FK(e,t=!1){let r=ui(WN);ed=zo(r.toJSON());let n;for(let c in e){let u=Mn[c.toLowerCase()];if(u===kr.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(_=>({[_]:e[c][_]}));continue}if(!u&&(c.endsWith("_package")||c.endsWith("_port"))&&(u=c),u!==void 0){let _=u.split("_"),l=_p(u,e[c]);u==="rootPath"&&l?.endsWith("/")&&(l=l.slice(0,-1));try{r.setIn([..._],l)}catch(d){It.error(d)}}}n&&QN(r,n),fp(r,t);let s=r.toJSON();wt=zo(s);let i=r.getIn(["rootPath"]),o=Ln.join(i,Vr.HDB_CONFIG_FILE);mr.createFileSync(o),mr.writeFileSync(o,String(r)),It.trace(`Config file written to ${o}`)}a(FK,"createConfigFile");function QN(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!xt.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(zc.TABLES))for(let i in n[s][zc.TABLES])for(let o in n[s][zc.TABLES][i]){let c=n[s][zc.TABLES][i][o],u=[kr.DATABASES,s,zc.TABLES,i,o];e.hasIn(u)?e.setIn(u,c):e.addIn(u,c)}else for(let i in n[s]){let o=n[s][i],c=[kr.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(QN,"setSchemasConfig");function kK(e){if(ed===void 0){let r=ui(WN);ed=zo(r.toJSON())}let t=Mn[e.toLowerCase()];if(t!==void 0)return ed[t.toLowerCase()]}a(kK,"getDefaultConfig");function zN(e){if(e==null){It.error(GK);return}if(wt===void 0){It.trace(BK);return}let t=Mn[e.toLowerCase()];if(t!==void 0)return wt[t.toLowerCase()]}a(zN,"getConfigValue");function Xi(e=xt.getPropsFilePath()){let t=xt.getEnvCliRootPath();return t?Ln.join(t,Vr.HDB_CONFIG_FILE):KN(e).get(Vr.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY)}a(Xi,"getConfigFilePath");function dp(e=!1){if(wt===void 0||e){let t;if(!xt.noBootFile()){t=xt.getPropsFilePath();try{mr.accessSync(t,mr.constants.F_OK|mr.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{XN(r);return}catch(i){if(i.code!==Vr.NODE_ERROR_CODES.ENOENT)throw i}try{n=ui(r)}catch(i){if(i.code===Vr.NODE_ERROR_CODES.ENOENT){It.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 It.error(i),new Error(`Error reading HarperDB config file at ${r}`)}VK(n,r),fp(n);let s=n.toJSON();if(vK.config=s,wt=zo(s),wt.logging_rotation_rotate)for(let i in YN)wt[i]&&It.error(`Config ${YN[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);It.trace(xK)}}a(dp,"initConfig");function VK(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Ln.join(r,"database")),n=!0),e.hasIn(["clustering","leafServer","streams","path"])||(e.setIn(["clustering","leafServer","streams","path"],Ln.join(r,"clustering","leaf")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Ln.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"),mr.writeFileSync(t,String(e)))}a(VK,"checkForUpdatedConfig");function fp(e,t=!1){let r=e.toJSON();r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads);let n=CK(r,t);if(n.error)throw Z_.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(fp,"validateConfig");function $K(e,t){wt===void 0&&(wt={});let r=Mn[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($K,"updateConfigObject");function JN(e,t,r=void 0,n=!1,s=!1,i=!1){wt===void 0&&dp();let o=zN(Mn.hdb_root),c=Ln.join(o,Vr.HDB_CONFIG_FILE),u=ui(c),_;if(r===void 0&&e.toLowerCase()===kr.DATABASES)_=t;else if(r===void 0){let E;if(i)E=e;else if(E=Mn[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=_p(E,t);u.setIn([...f],h)}else for(let E in r){let f=Mn[E.toLowerCase()];if(f===kr.HTTP_SECUREPORT&&r[E]===wt[kr.HTTP_PORT]?.toString()&&u.setIn(["http","port"],null),f===kr.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===wt[kr.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&u.setIn(["operationsApi","network","port"],null),f===kr.DATABASES){_=r[E];continue}if(f?.startsWith("threads_")){let h=u.getIn(["threads"]);h>=0&&(u.deleteIn(["threads"]),u.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),p=Vr.LEGACY_CONFIG_PARAMS[E.toUpperCase()];p&&p.startsWith("customFunctions")&&u.hasIn(p.split("_"))&&(f=p,h=p.split("_"));let S=_p(f,r[E]);f==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof u.getIn(h.slice(0,-1))=="boolean"&&u.deleteIn(h.slice(0,-1)),u.setIn([...h],S)}catch(T){It.error(T)}}}_&&QN(u,_),fp(u);let l=u.getIn(["rootPath"]),d=Ln.join(l,Vr.HDB_CONFIG_FILE);n===!0&&YK(c,l),mr.writeFileSync(d,String(u)),s&&(wt=zo(u.toJSON())),It.trace(`Config parameter: ${e} updated with value: ${t}`)}a(JN,"updateConfigValue");function YK(e,t){try{let r=Ln.join(t,"backup",`${Vr.HDB_CONFIG_FILE}.bak`);mr.copySync(e,r),It.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){It.error(HK),It.error(r)}}a(YK,"backupConfigFile");var KK=["databases"];function zo(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)),td=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])&&!KK.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let u=i+"_"+c;!kr[u.toUpperCase()]&&Mn[u]&&(s[Mn[u].toLowerCase()]=o[c]),s[u]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(zo,"flattenConfig");function _p(e,t){if(e===kr.CLUSTERING_NODENAME||e===kr.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(LK(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||xt.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 xt.autoCast(t)}a(_p,"castConfigValue");function WK(){let e=xt.getPropsFilePath(),t=Xi(e);return ui(t).toJSON()}a(WK,"getConfiguration");async function QK(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return JN(void 0,void 0,s,!0),qK}catch(i){throw typeof i=="string"||i instanceof String?PK(i,i,UK.BAD_REQUEST,void 0,void 0,!0):i}}a(QK,"setConfiguration");function Ep(){let e=xt.getPropsFilePath();try{mr.accessSync(e,mr.constants.F_OK|mr.constants.R_OK)}catch(n){if(!xt.noBootFile())throw It.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Xi(e);return ui(t).toJSON()}a(Ep,"readConfigFile");function ui(e){return DK.parseDocument(mr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(ui,"parseYamlDoc");function zK(){let e=Ep(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=xt.isEmptyOrZeroLength(t)?[]:t;let r=$N(t);if(r)throw Z_.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=xt.isEmptyOrZeroLength(n)?[]:n;let s=$N(n);if(s)throw Z_.CONFIG_VALIDATION(s.message);if(!xt.isEmptyOrZeroLength(n)&&!xt.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!xt.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Z_.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(zK,"getClusteringRoutes");function XN(e){let t=KN(e);wt={};for(let r in Mn){let n=t.get(r.toUpperCase());if(xt.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=Mn[r].toLowerCase();s===kr.LOGGING_ROOT?wt[s]=Ln.dirname(n):wt[s]=n}return wt}a(XN,"initOldConfig");function JK(e){let t=Ep();return MK.get(t,e.replaceAll("_","."))}a(JK,"getConfigFromFile");async function XK(e,t){let r=ui(Xi());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await mr.writeFile(Xi(),String(r))}a(XK,"addConfig");function jK(e){let t=Xi(xt.getPropsFilePath()),r=ui(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Ln.join(n,Vr.HDB_CONFIG_FILE);mr.writeFileSync(s,String(r))}a(jK,"deleteConfigFromFile");function ZK(){return td||(dp(),td)}a(ZK,"getConfigObj")});var eI=g((yle,ZN)=>{"use strict";var rd=P(),nd=class{static{a(this,"BaseLicense")}constructor(t=0,r=rd.RAM_ALLOCATION_ENUM.DEFAULT,n=rd.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},hp=class extends nd{static{a(this,"ExtendedLicense")}constructor(t=0,r=rd.RAM_ALLOCATION_ENUM.DEFAULT,n=rd.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};ZN.exports={BaseLicense:nd,ExtendedLicense:hp}});var ji=g((Ile,oI)=>{"use strict";var Xo=require("fs-extra"),rI=z_(),nI=require("crypto"),eW=require("moment"),tW=require("uuid").v4,tr=$(),pp=require("path"),rW=J(),li=P(),{totalmem:tI}=require("os"),nW=eI().ExtendedLicense,Jo="invalid license key format",sW="061183",iW="mofi25",oW="aes-256-cbc",aW=16,cW=32,sI=ee();sI.initSync();var mp;oI.exports={validateLicense:iI,generateFingerPrint:lW,licenseSearch:gp,getLicense:fW,checkMemoryLimit:EW};function Sp(){return pp.join(sI.getHdbBasePath(),li.LICENSE_KEY_DIR_NAME,li.LICENSE_FILE_NAME)}a(Sp,"getLicenseDirPath");function uW(){let e=Sp();return pp.join(e,li.LICENSE_FILE_NAME)}a(uW,"getLicenseFilePath");function Tp(){let e=Sp();return pp.join(e,li.REG_KEY_FILE_NAME)}a(Tp,"getFingerPrintFilePath");async function lW(){let e=Tp();try{return await Xo.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await _W();throw tr.error(`Error writing fingerprint file to ${e}`),tr.error(t),new Error("There was an error generating the fingerprint")}}a(lW,"generateFingerPrint");async function _W(){let e=tW(),t=rI.hash(e),r=Tp();try{await Xo.mkdirp(Sp()),await Xo.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(_W,"writeFingerprint");function iI(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:li.RAM_ALLOCATION_ENUM.DEFAULT,version:li.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return tr.error("empty license key passed to validate."),r;let n=Tp(),s=!1;try{s=Xo.statSync(n)}catch(i){tr.error(i)}if(s){let i;try{i=Xo.readFileSync(n,"utf8")}catch{tr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(iW),c=o[1];c=Buffer.concat([Buffer.from(c)],aW);let u=Buffer.concat([Buffer.from(i)],cW),_=nI.createDecipheriv(oW,u,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let l=null;try{l=_.update(o[0],"hex","utf8"),l.trim(),l+=_.final("utf8")}catch{let f=dW(o[0],i);if(f)l=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Jo),tr.error(Jo),new Error(Jo)}let d;if(isNaN(l))try{d=JSON.parse(l),r.version=d.version,r.exp_date=d.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),d.ram_allocation&&(r.ram_allocation=d.ram_allocation)}catch{throw console.error(Jo),tr.error(Jo),new Error(Jo)}else r.exp_date=l;r.exp_date<eW().valueOf()&&(r.valid_date=!1),rI.validate(o[1],`${sW}${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(iI,"validateLicense");function dW(e,t){try{let r=nI.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(dW,"checkOldLicense");function gp(){let e=new nW,t=[];try{t=Xo.readFileSync(uW(),"utf-8").split(li.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(rW.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=iI(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=li.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return mp=e,e}a(gp,"licenseSearch");async function fW(){return mp||await gp(),mp}a(fW,"getLicense");function EW(){let e=gp().ram_allocation,t=process.constrainedMemory?.()||tI();if(t=Math.round(Math.min(t,tI())/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(EW,"checkMemoryLimit")});var _n=g((Mle,AI)=>{"use strict";var lI="username is required",_I="nothing to update, must supply active, role or password to update",dI="password cannot be an empty string",fI="If role is specified, it cannot be empty.",EI="active must be true or false";AI.exports={addUser:OW,alterUser:bW,dropUser:NW,getSuperUser:DW,userInfo:IW,listUsers:id,listUsersExternal:wW,setUsersToGlobal:Zo,findAndValidateUser:gI,getClusterUser:LW,USERNAME_REQUIRED:lI,ALTERUSER_NOTHING_TO_UPDATE:_I,EMPTY_PASSWORD:dI,EMPTY_ROLE:fI,ACTIVE_BOOLEAN:EI};var hI=Fr(),hW=ci(),Op=z_(),mI=PN(),pI=qr(),bp=Ns(),$r=J(),SI=require("validate.js"),Oe=$(),{promisify:mW}=require("util"),yp=Os(),aI=P(),cI=Ve(),pW=pr(),Cle=ee(),Dle=ji(),SW=Vi(),{table:Lle}=(Ae(),ie(ke)),{handleHDBError:ts,hdb_errors:TW}=se(),{HTTP_STATUS_CODES:rs,AUTHENTICATION_ERROR_MSGS:Rp,HDB_ERROR_MSGS:jo}=TW,{UserEventMsg:Np}=Pn(),Ap=require("lodash"),{server:Ip}=(fr(),ie(Gi)),gW=$();Ip.getUser=(e,t)=>gI(e,t,t!=null);var TI={username:!0,active:!0,role:!0,password:!0},uI=new Map,sd=pI.searchByValue,RW=pI.searchByHash,AW=mW(hW.delete);async function OW(e){let t=SI.cleanAttributes(e,TI),r=mI.addUserValidation(t);if(r)throw ts(new Error,r.message,rs.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 sd(n),s=s&&Array.from(s)}catch(u){throw Oe.error("There was an error searching for a role in add user"),Oe.error(u),u}if(!s||s.length<1)throw ts(new Error,jo.ROLE_NAME_NOT_FOUND(t.role),rs.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw ts(new Error,jo.DUP_ROLES_FOUND(t.role),rs.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=yp.encrypt(t.password)),t.password=Op.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await hI.insert(i)}catch(u){throw Oe.error("There was an error searching for a user."),Oe.error(u),u}Oe.debug(o);try{await Zo()}catch(u){throw Oe.error("Got an error setting users to global"),Oe.error(u),u}if(o.skipped_hashes.length===1)throw ts(new Error,jo.USER_ALREADY_EXISTS(t.username),rs.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],bp.signalUserChange(new Np(process.pid)),`${c.username} successfully added`}a(OW,"addUser");async function bW(e){let t=SI.cleanAttributes(e,TI);if($r.isEmptyOrZeroLength(t.username))throw new Error(lI);if($r.isEmptyOrZeroLength(t.password)&&$r.isEmptyOrZeroLength(t.role)&&$r.isEmptyOrZeroLength(t.active))throw new Error(_I);if(!$r.isEmpty(t.password)&&$r.isEmptyOrZeroLength(t.password.trim()))throw new Error(dI);if(!$r.isEmpty(t.active)&&!$r.isBoolean(t.active))throw new Error(EI);let r=yW(t.username);if(!$r.isEmpty(t.password)&&!$r.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=yp.encrypt(t.password)),t.password=Op.hash(t.password)),t.role==="")throw new Error(fI);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 sd(i)||[])}catch(c){throw Oe.error("Got an error searching for a role."),Oe.error(c),c}if(!o||o.length===0){let c=jo.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Oe.error(c),ts(new Error,c,rs.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=jo.ALTER_USER_DUP_ROLES(t.role);throw Oe.error(c),ts(new Error,c,rs.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 hI.update(n)}catch(i){throw Oe.error("Error during update."),Oe.error(i),i}try{await Zo()}catch(i){throw Oe.error("Got an error setting users to global"),Oe.error(i),i}return bp.signalUserChange(new Np(process.pid)),s}a(bW,"alterUser");function yW(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(yW,"isClusterUser");async function NW(e){try{let t=mI.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if($r.isEmpty(global.hdb_users.get(e.username)))throw ts(new Error,jo.USER_NOT_EXIST(e.username),rs.NOT_FOUND,void 0,void 0,!0);let n;try{n=await AW(r)}catch(s){throw Oe.error("Got an error deleting a user."),Oe.error(s),s}Oe.debug(n);try{await Zo()}catch(s){throw Oe.error("Got an error setting users to global."),Oe.error(s),s}return bp.signalUserChange(new Np(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(NW,"dropUser");async function IW(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 RW(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(IW,"userInfo");async function wW(){let e;try{e=await id()}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(wW,"listUsersExternal");async function id(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await sd(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 sd(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],CW(o.role),i.set(o.username,o);return i}catch(e){throw Oe.error("got an error listing users"),Oe.error(e),$r.errorizeMessage(e)}return null}a(id,"listUsers");function CW(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(SW)){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(CW,"appendSystemTablesToRole");async function Zo(){try{let e=await id();global.hdb_users=e}catch(e){throw Oe.error(e),e}}a(Zo,"setUsersToGlobal");async function gI(e,t,r=!0){global.hdb_users||await Zo();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw ts(new Error,Rp.GENERIC_AUTH_FAIL,rs.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw ts(new Error,Rp.USER_INACTIVE,rs.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(uI.get(t)===n.password)return s;if(Op.validate(n.password,t))uI.set(t,n.password);else throw ts(new Error,Rp.GENERIC_AUTH_FAIL,rs.UNAUTHORIZED,void 0,void 0,!0)}return s}a(gI,"findAndValidateUser");async function DW(){global.hdb_users||await Zo();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(DW,"getSuperUser");async function LW(){let e=await id(),t=pW.getConfigFromFile(aI.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!$r.isEmpty(r)&&r?.role?.role===aI.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=yp.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+cI.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+cI.SERVER_SUFFIX.ADMIN,r}a(LW,"getClusterUser");var RI=[];Ip.invalidateUser=function(e){for(let t of RI)try{t(e)}catch(r){gW.error("Error invalidating user",r)}};Ip.onInvalidatedUser=function(e){RI.push(e)}});var Xc=g((Ble,NI)=>{"use strict";var Zi=$(),Yr=P(),MW=eN(),Ule=ys(),vle=bs(),PW=_n(),{validateEvent:OI}=Pn(),Jc=Dn(),UW=require("process"),{resetDatabases:vW}=(Ae(),ie(ke)),BW={[Yr.ITC_EVENT_TYPES.SCHEMA]:xW,[Yr.ITC_EVENT_TYPES.USER]:yI};async function xW(e){let t=OI(e);if(t){Zi.error(t);return}Zi.trace("ITC schemaHandler received schema event:",e),await MW(e.message),await HW(e.message)}a(xW,"schemaHandler");async function HW(e){try{Jc.resetReadTxn(Yr.SYSTEM_SCHEMA_NAME,Yr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Jc.resetReadTxn(Yr.SYSTEM_SCHEMA_NAME,Yr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Jc.resetReadTxn(Yr.SYSTEM_SCHEMA_NAME,Yr.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=vW();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Zi.error(t)}}a(HW,"syncSchemaMetadata");var bI=[];async function yI(e){try{try{Jc.resetReadTxn(Yr.SYSTEM_SCHEMA_NAME,Yr.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Jc.resetReadTxn(Yr.SYSTEM_SCHEMA_NAME,Yr.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Zi.warn(r)}let t=OI(e);if(t){Zi.error(t);return}Zi.trace(`ITC userHandler ${Yr.HDB_ITC_CLIENT_PREFIX}${UW.pid} received user event:`,e),await PW.setUsersToGlobal();for(let r of bI)r()}catch(t){Zi.error(t)}}a(yI,"userHandler");yI.addListener=function(e){bI.push(e)};NI.exports=BW});var Pn=g((kle,wI)=>{"use strict";var Hle=$(),wp=J(),GW=P(),{ITC_ERRORS:jc}=vr(),{parentPort:Gle,threadId:qW,isMainThread:FW,workerData:qle}=require("worker_threads"),{onMessageFromWorkers:kW,broadcast:Fle,broadcastWithAcknowledgement:VW}=Qe();wI.exports={sendItcEvent:$W,validateEvent:II,SchemaEventMsg:YW,UserEventMsg:KW};var od;kW(async(e,t)=>{od=od||Xc(),II(e),od[e.type]&&await od[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function $W(e){return!FW&&e.message&&(e.message.originator=qW),VW(e)}a($W,"sendItcEvent");function II(e){if(typeof e!="object")return jc.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||wp.isEmpty(e.type))return jc.MISSING_TYPE;if(!e.hasOwnProperty("message")||wp.isEmpty(e.message))return jc.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||wp.isEmpty(e.message.originator))return jc.MISSING_ORIGIN;if(GW.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return jc.INVALID_EVENT(e.type)}a(II,"validateEvent");function YW(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(YW,"SchemaEventMsg");function KW(e){this.originator=e}a(KW,"UserEventMsg")});var Ns=g((Yle,MI)=>{"use strict";var CI=P(),$le=J(),ad=$(),DI=Xy(),ea,{sendItcEvent:LI}=Pn();function WW(e){try{ad.trace("signalSchemaChange called with message:",e),ea=ea||Xc();let t=new DI(CI.ITC_EVENT_TYPES.SCHEMA,e);return ea.schema(t),LI(t)}catch(t){ad.error(t)}}a(WW,"signalSchemaChange");function QW(e){try{ad.trace("signalUserChange called with message:",e),ea=ea||Xc();let t=new DI(CI.ITC_EVENT_TYPES.USER,e);return ea.user(t),LI(t)}catch(t){ad.error(t)}}a(QW,"signalUserChange");MI.exports={signalSchemaChange:WW,signalUserChange:QW}});var cd=g((Wle,UI)=>{"use strict";var PI=J(),zW=P(),JW=$(),XW=q_(),jW=G_(),ZW=Ns(),{SchemaEventMsg:eQ}=Pn(),tQ="already exists in";UI.exports=rQ;async function rQ(e,t,r){if(PI.isEmptyOrZeroLength(r))return r;let n=[];PI.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 nQ(e,t.schema,t.name,i)})),s}a(rQ,"lmdbCheckForNewAttributes");async function nQ(e,t,r,n){let s=new jW(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await sQ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(tQ))JW.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(nQ,"createNewAttribute");async function sQ(e){let t;return t=await XW(e),ZW.signalSchemaChange(new eQ(process.pid,zW.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(sQ,"createAttribute")});var ta=g((zle,vI)=>{"use strict";var Cp=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}};vI.exports=Cp});var xI=g((Xle,BI)=>{"use strict";var iQ=ta(),oQ=P().OPERATIONS_ENUM,Dp=class extends iQ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(oQ.INSERT,r,n,s,i),this.records=t}};BI.exports=Dp});var GI=g((Zle,HI)=>{"use strict";var aQ=ta(),cQ=P().OPERATIONS_ENUM,Lp=class extends aQ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(cQ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};HI.exports=Lp});var FI=g((t_e,qI)=>{"use strict";var uQ=ta(),lQ=P().OPERATIONS_ENUM,Mp=class extends uQ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(lQ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};qI.exports=Mp});var VI=g((n_e,kI)=>{"use strict";var _Q=ta(),dQ=P().OPERATIONS_ENUM,Pp=class extends _Q{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(dQ.DELETE,n,s,t,i),this.original_records=r}};kI.exports=Pp});var Zc=g((o_e,WI)=>{"use strict";var i_e=require("path"),$I=ze(),fQ=xI(),EQ=GI(),hQ=FI(),mQ=VI(),ra=ft(),YI=J(),{CONFIG_PARAMS:pQ}=P(),KI=ee();KI.initSync();var ud=P().OPERATIONS_ENUM,{getTransactionAuditStorePath:SQ}=Xe();WI.exports=TQ;async function TQ(e,t){if(KI.get(pQ.LOGGING_AUDITLOG)===!1)return;let r=SQ(e.schema,e.table),n=await $I.openEnvironment(r,e.table,!0),s=gQ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){$I.initializeDBIs(n,ra.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ra.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[ra.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[ra.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),YI.isEmpty(s.user_name)||n.dbis[ra.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[ra.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(TQ,"writeTransaction");function gQ(e,t){let r=YI.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===ud.INSERT)return new fQ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===ud.UPDATE)return new EQ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===ud.UPSERT)return new hQ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===ud.DELETE)return new mQ(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(gQ,"createTransactionObject")});var Up=g((u_e,QI)=>{"use strict";var RQ=Yc(),c_e=wc(),eu=P(),AQ=Cc(),OQ=Ko().insertRecords,bQ=ze(),yQ=$(),NQ=cd(),{getSchemaPath:IQ}=Xe(),wQ=Zc();QI.exports=CQ;async function CQ(e){try{let{schema_table:t,attributes:r}=RQ(e);AQ(e,r,t.hash_attribute),e.schema!==eu.SYSTEM_SCHEMA_NAME&&(r.includes(eu.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(eu.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(eu.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(eu.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await NQ(e.hdb_auth_header,t,r),s=IQ(e.schema,e.table),i=await bQ.openEnvironment(s,e.table),o=await OQ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await wQ(e,o)}catch(c){yQ.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(CQ,"lmdbCreateRecords")});var XI=g((__e,JI)=>{"use strict";var zI=P(),DQ=Up(),LQ=wc(),MQ=require("fs-extra"),{getSchemaPath:PQ}=Xe();JI.exports=UQ;async function UQ(e){let t=[{name:e.schema,createddate:Date.now()}],r=new LQ(zI.SYSTEM_SCHEMA_NAME,zI.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await DQ(r),await MQ.mkdirp(PQ(e.schema))}a(UQ,"lmdbCreateSchema")});var ZI=g((f_e,jI)=>{"use strict";var vp=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}};jI.exports=vp});var nw=g((S_e,rw)=>{"use strict";var ew=ze(),Bp=Br(),xp=vr().LMDB_ERRORS_ENUM,vQ=ft(),tw=$(),h_e=J(),BQ=require("lmdb"),xQ=ZI(),HQ=P(),{OVERFLOW_MARKER:m_e,MAX_SEARCH_KEY_LENGTH:p_e}=vQ,GQ=HQ.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function qQ(e,t,r,n){if(Bp.validateEnv(e),t===void 0)throw new Error(xp.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(xp.IDS_REQUIRED):new Error(xp.IDS_MUST_BE_ITERABLE);try{let s=ew.listDBIs(e);ew.initializeDBIs(e,t,s);let i=new xQ,o,c=[],u=[];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[GQ]>n){i.skipped.push(o);continue}let p=e.dbis[t].ifVersion(o,BQ.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 A=e.dbis[T],y=h[T];if(y!=null)try{let I=Bp.getIndexedValues(y);if(I)for(let B=0,U=I.length;B<U;B++)A.remove(I[B],o)}catch{tw.warn(`cannot delete from attribute: ${T}, ${y}:${o}`)}}});c.push(p),u.push(o),i.original_records.push(h)}catch(h){tw.warn(h),i.skipped.push(o)}let _=[],l=await Promise.all(c);for(let E=0,f=l.length;E<f;E++)l[E]===!0?i.deleted.push(u[E]):(i.skipped.push(u[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=Bp.getNextMonotonicTime(),i}catch(s){throw s}}a(qQ,"deleteRecords");rw.exports={deleteRecords:qQ}});var tu=g((g_e,iw)=>{"use strict";var na=J(),FQ=nw(),kQ=ze(),{getSchemaPath:VQ}=Xe(),$Q=Zc(),YQ=$();iw.exports=KQ;async function KQ(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(na.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(na.isEmptyOrZeroLength(e.hash_values)&&!na.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let u=e.records[c][n];na.isEmpty(u)||e.hash_values.push(u)}}if(na.isEmptyOrZeroLength(e.hash_values))return sw([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(na.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=VQ(e.schema,e.table),i=await kQ.openEnvironment(s,e.table),o=await FQ.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await $Q(e,o)}catch(c){YQ.error(`unable to write transaction due to ${c.message}`)}return sw(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(KQ,"lmdbDeleteRecords");function sw(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(sw,"createDeleteResponse")});var Gp=g((O_e,ow)=>{"use strict";var WQ=P(),A_e=Br();function Hp(e,t){let r=Object.create(null);if(t.length===1&&WQ.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(Hp,"parseRow");function QQ(e,t,r,n){let s=Hp(r,e);n.push(s)}a(QQ,"searchAll");function zQ(e,t,r,n){let s=Hp(r,e);n[t]=s}a(zQ,"searchAllToMap");function JQ(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(JQ,"iterateDBI");function eo(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(eo,"pushResults");function XQ(e,t,r,n,s,i){t.toString().endsWith(e)&&eo(t,r,n,s,i)}a(XQ,"endsWith");function jQ(e,t,r,n,s,i){t.toString().includes(e)&&eo(t,r,n,s,i)}a(jQ,"contains");function ZQ(e,t,r,n,s,i){t>e&&eo(t,r,n,s,i)}a(ZQ,"greaterThanCompare");function ez(e,t,r,n,s,i){t>=e&&eo(t,r,n,s,i)}a(ez,"greaterThanEqualCompare");function tz(e,t,r,n,s,i){t<e&&eo(t,r,n,s,i)}a(tz,"lessThanCompare");function rz(e,t,r,n,s,i){t<=e&&eo(t,r,n,s,i)}a(rz,"lessThanEqualCompare");ow.exports={parseRow:Hp,searchAll:QQ,searchAllToMap:zQ,iterateDBI:JQ,endsWith:XQ,contains:jQ,greaterThanCompare:ZQ,greaterThanEqualCompare:ez,lessThanCompare:tz,lessThanEqualCompare:rz,pushResults:eo}});var sa=g((w_e,fw)=>{"use strict";var _i=ze(),y_e=$(),Kr=Br(),ld=ft(),ht=vr().LMDB_ERRORS_ENUM,N_e=J(),nz=P(),_d=Gp(),{parseRow:sz}=_d,I_e=require("lmdb"),{OVERFLOW_MARKER:aw,MAX_SEARCH_KEY_LENGTH:iz}=ld;function cw(e,t,r,n=!1,s=void 0,i=void 0){return to(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(cw,"iterateFullIndex");function ru(e,t,r,n,s,i=!1,o=void 0,c=void 0,u=!1,_=!1){return to(e,t,r,(l,d,E,f)=>{let A={transaction:l,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!u:!_,exclusiveStart:i===!0?_:u};return f===r?(A.values=!1,d.getRange(A).map(y=>({value:y}))):d.getRange(A)})}a(ru,"iterateRangeBetween");function to(e,t,r,n){let s=e.database||e,i=_i.openDBI(s,r);i[ld.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&_i.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(to,"setupTransaction");function uw(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(aw)){if(!s)if(r)s=_i.openDBI(e,r);else{let u=_i.listDBIs(e);for(let _=0,l=u.length;_<l&&(s=_i.openDBI(e,u[_]),!s[ld.DBI_DEFINITION_NAME].is_hash_attribute);_++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(uw,"getOverflowCheck");function oz(e,t,r,n=!1,s=void 0,i=void 0){if(Kr.validateEnv(e),t===void 0)throw new Error(ht.HASH_ATTRIBUTE_REQUIRED);return to(e,t,t,(o,c,u)=>(dd(r),r=nu(u,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(_=>sz(_.value,r))))}a(oz,"searchAll");function az(e,t,r,n=!1,s=void 0,i=void 0){if(Kr.validateEnv(e),t===void 0)throw new Error(ht.HASH_ATTRIBUTE_REQUIRED);dd(r),r=nu(e.database||e,r);let o=new Map;for(let{key:c,value:u}of cw(e,t,t,n,s,i))o.set(c,_d.parseRow(u,r));return o}a(az,"searchAllToMap");function cz(e,t,r=!1,n=void 0,s=void 0){if(Kr.validateEnv(e),t===void 0)throw new Error(ht.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=cw(e,void 0,t,r,n,s),c=o.transaction,u=uw(c.database,c,void 0,t);for(let{key:_,value:l}of o){let d=u(_,l);i[d]===void 0&&(i[d]=[]),i[d].push(l)}return i}a(cz,"iterateDBI");function uz(e,t){if(Kr.validateEnv(e),t===void 0)throw new Error(ht.HASH_ATTRIBUTE_REQUIRED);return _i.statDBI(e,t).entryCount}a(uz,"countAll");function lz(e,t,r,n,s=!1,i=void 0,o=void 0){return di(e,r,n),to(e,t,r,(c,u,_,l)=>(n=Kr.convertKeyValueToWrite(n),l===r?u.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:u.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(lz,"equals");function _z(e,t,r){return di(e,t,r),_i.openDBI(e,t).getValuesCount(r)}a(_z,"count");function dz(e,t,r,n,s=!1,i=void 0,o=void 0){return di(e,r,n),to(e,null,r,(c,u)=>{n=Kr.convertKeyValueToWrite(n);let _=!0;typeof n=="number"&&(_=!1);let l;if(s===!0){let d;for(let E of u.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){d=E;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),l=u.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==d){if(f.toString().startsWith(n))return E;if(_===!0)return l.DONE}}),l.filter(E=>E)}else return l=u.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(_===!0)return l.DONE}),_?l:l.filter(d=>d)})}a(dz,"startsWith");function fz(e,t,r,n,s=!1,i=void 0,o=void 0){return lw(e,t,r,n,s,i,o,!0)}a(fz,"endsWith");function lw(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return di(e,r,n),to(e,null,r,(u,_,l,d)=>{let E=uw(l,u,d,r);return o=Number.isInteger(o)?o:0,_.getKeys({transaction:u,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(aw)?_.getValues(f,{transaction:u}).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))?_[ld.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:_.getValues(f,{transaction:u}).map(p=>({key:f,value:p})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(lw,"contains");function Ez(e,t,r,n,s=!1,i=void 0,o=void 0){di(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),ru(e,t,r,n,u,s,i,o,!0,!1)}a(Ez,"greaterThan");function hz(e,t,r,n,s=!1,i=void 0,o=void 0){di(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),ru(e,t,r,n,u,s,i,o,!1,!1)}a(hz,"greaterThanEqual");function mz(e,t,r,n,s=!1,i=void 0,o=void 0){di(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),ru(e,t,r,u,n,s,i,o,!1,!0)}a(mz,"lessThan");function pz(e,t,r,n,s=!1,i=void 0,o=void 0){di(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),ru(e,t,r,u,n,s,i,o,!1,!1)}a(pz,"lessThanEqual");function Sz(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Kr.validateEnv(e),r===void 0)throw new Error(ht.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(ht.START_VALUE_REQUIRED);if(s===void 0)throw new Error(ht.END_VALUE_REQUIRED);if(n=Kr.convertKeyValueToWrite(n),s=Kr.convertKeyValueToWrite(s),n>s)throw new Error(ht.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return ru(e,t,r,n,s,i,o,c)}a(Sz,"between");function Tz(e,t,r,n){Kr.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(ht.HASH_ATTRIBUTE_REQUIRED);if(dd(r),r=nu(s,r),n===void 0)throw new Error(ht.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=_d.parseRow(c,r)),o}a(Tz,"searchByHash");function gz(e,t,r){Kr.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(ht.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ht.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(gz,"checkHashExists");function Rz(e,t,r,n,s=[]){return dw(e,t,r,n,s),_w(e,t,r,n,s).map(i=>i[1])}a(Rz,"batchSearchByHash");function Az(e,t,r,n,s=[]){dw(e,t,r,n,s);let i=new Map;for(let[o,c]of _w(e,t,r,n,s))i.set(o,c);return i}a(Az,"batchSearchByHashToMap");function _w(e,t,r,n,s=[]){return to(e,t,t,(i,o,c)=>{r=nu(c,r);let u=r.length<3;return n.map(_=>{let l=c.dbis[t].get(_,{transaction:i,lazy:u});if(l)return[_,_d.parseRow(l,r)];s.push(_)}).filter(_=>_)})}a(_w,"batchHashSearch");function dw(e,t,r,n,s){if(Kr.validateEnv(e),t===void 0)throw new Error(ht.HASH_ATTRIBUTE_REQUIRED);if(dd(r),n==null)throw new Error(ht.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(ht.IDS_MUST_BE_ITERABLE)}a(dw,"initializeBatchSearchByHash");function dd(e){if(!Array.isArray(e))throw e===void 0?new Error(ht.FETCH_ATTRIBUTES_REQUIRED):new Error(ht.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(dd,"validateFetchAttributes");function di(e,t,r){if(Kr.validateEnv(e),t===void 0)throw new Error(ht.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ht.SEARCH_VALUE_REQUIRED);if(r?.length>iz)throw new Error(ht.SEARCH_VALUE_TOO_LARGE)}a(di,"validateComparisonFunctions");function nu(e,t){return t.length===1&&nz.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=_i.listDBIs(e)),t}a(nu,"setGetWholeRowAttributes");fw.exports={searchAll:oz,searchAllToMap:az,count:_z,countAll:uz,equals:lz,startsWith:dz,endsWith:fz,contains:lw,searchByHash:Tz,setGetWholeRowAttributes:nu,batchSearchByHash:Rz,batchSearchByHashToMap:Az,checkHashExists:gz,iterateDBI:cz,greaterThan:Ez,greaterThanEqual:hz,lessThan:mz,lessThanEqual:pz,between:Sz}});var ia=g((D_e,Sw)=>{var Ew=require("lodash"),hw=je(),he=require("joi"),Oz=J(),{hdb_schema_table:su,checkValidTable:mw,hdb_table:pw,hdb_database:fd}=jn(),{handleHDBError:bz,hdb_errors:yz}=se(),{getDatabases:Nz}=(Ae(),ie(ke)),{HTTP_STATUS_CODES:Iz}=yz,wz=he.object({database:fd,schema:fd,table:pw,search_attribute:su,search_value:he.any().required(),get_attributes:he.array().min(1).items(he.alternatives(su,he.object())).optional(),desc:he.bool(),limit:he.number().integer().min(1),offset:he.number().integer().min(0)}),Cz=he.object({database:fd,schema:fd,table:pw,operator:he.string().valid("and","or").default("and").lowercase(),offset:he.number().integer().min(0),limit:he.number().integer().min(1),get_attributes:he.array().min(1).items(he.alternatives(su,he.object())).optional(),sort:he.object({attribute:he.alternatives(su,he.array().min(1)),descending:he.bool().optional()}).optional(),conditions:he.array().min(1).items(he.alternatives(he.object({operator:he.string().valid("and","or").default("and").lowercase(),conditions:he.array()}),he.object({search_attribute:he.alternatives(su,he.array().min(1)),search_type:he.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:he.when("search_type",{switch:[{is:"equals",then:he.any()},{is:"between",then:he.array().items(he.alternatives([he.string(),he.number()])).length(2)}],otherwise:he.alternatives(he.string(),he.number())}).required()}))).required()});Sw.exports=function(e,t){let r=null;switch(t){case"value":r=hw.validateBySchema(e,wz);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(mw("database",e.schema)),i(mw("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=hw.validateBySchema(e,Cz);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=Oz.checkGlobalSchemaTable(e.schema,e.table);if(s)return bz(new Error,s,Iz.NOT_FOUND);let o=Nz()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let u=a(l=>{for(let d=0,E=l.conditions.length;d<E;d++){let f=l.conditions[d];f.conditions?u(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&u(e);let _=Ew.filter(c,l=>l!=="*"&&!l.startsWith?.("$")&&l.attribute!=="*"&&!Array.isArray(l)&&!l.name&&!Ew.some(o,d=>d===l||d.attribute===l||d.attribute===l.attribute));if(_&&_.length>0){let l=_.join(", ");return l=l.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${l}'`)}}return r}});var qp=g((M_e,Tw)=>{"use strict";var Dz=ze(),Lz=ia(),{getSchemaPath:Mz}=Xe();Tw.exports=Pz;function Pz(e){let t=Lz(e,"hashes");if(t)throw t;let r=Mz(e.schema,e.table);return Dz.openEnvironment(r,e.table)}a(Pz,"initialize")});var Fp=g((U_e,gw)=>{"use strict";var Uz=sa(),vz=qp();gw.exports=Bz;async function Bz(e){let t=await vz(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return Uz.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(Bz,"lmdbGetDataByHash")});var oa=g((B_e,Rw)=>{"use strict";var kp=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};Rw.exports=kp});var Ow=g((G_e,Aw)=>{"use strict";var H_e=oa(),xz=sa(),Hz=qp();Aw.exports=Gz;async function Gz(e){let t=await Hz(e),r=global.hdb_schema[e.schema][e.table];return xz.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(Gz,"lmdbSearchByHash")});var ns=g((F_e,bw)=>{"use strict";var Vp=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,u=!1,_=void 0,l=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=u,this.limit=_,this.offset=l}};bw.exports=Vp});var Ed=g((V_e,Dw)=>{"use strict";var rr=sa(),qz=ze(),Fz=J(),me=ft(),ro=P(),kz=Vi(),yw=vr().LMDB_ERRORS_ENUM,{getSchemaPath:Vz}=Xe(),Is=ro.SEARCH_WILDCARDS;async function $z(e,t,r){let n;e.schema===ro.SYSTEM_SCHEMA_NAME?n=kz[e.table]:n=global.hdb_schema[e.schema][e.table];let s=Cw(e,n.hash_attribute,r,t);return Iw(e,s,n.hash_attribute,r)}a($z,"prepSearch");async function Iw(e,t,r,n){let s=Vz(e.schema,e.table),i=await qz.openEnvironment(s,e.table),o=ww(i,e,t,r),c=o.transaction||i;if([me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,me.SEARCH_TYPES.SEARCH_ALL,me.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(Yz(e,r)===!1){let l=e.search_attribute;if(l===r)return n?Nw(o,()=>!0):o.map(E=>({[r]:E.key}));let d=a(E=>({[r]:E.value,[l]:E.key}),"toObject");return n?Nw(o,d):o.map(d)}let _=e.search_attribute===r?o.map(l=>l.key):o.map(l=>l.value);return n===!0?rr.batchSearchByHashToMap(c,r,e.get_attributes,_):rr.batchSearchByHash(c,r,e.get_attributes,_)}a(Iw,"executeSearch");function ww(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:u}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,u=Number.isInteger(u)?u:void 0,r){case me.SEARCH_TYPES.EQUALS:s=rr.equals(e,i,t.search_attribute,t.search_value,o,c,u);break;case me.SEARCH_TYPES.CONTAINS:s=rr.contains(e,i,t.search_attribute,t.search_value,o,c,u);break;case me.SEARCH_TYPES.ENDS_WITH:case me.SEARCH_TYPES._ENDS_WITH:s=rr.endsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case me.SEARCH_TYPES.STARTS_WITH:case me.SEARCH_TYPES._STARTS_WITH:s=rr.startsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return rr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return rr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.SEARCH_ALL:return rr.searchAll(e,n,t.get_attributes,o,c,u);case me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return rr.searchAllToMap(e,n,t.get_attributes,o,c,u);case me.SEARCH_TYPES.BETWEEN:s=rr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,u);break;case me.SEARCH_TYPES.GREATER_THAN:case me.SEARCH_TYPES._GREATER_THAN:s=rr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case me.SEARCH_TYPES.GREATER_THAN_EQUAL:case me.SEARCH_TYPES._GREATER_THAN_EQUAL:s=rr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;case me.SEARCH_TYPES.LESS_THAN:case me.SEARCH_TYPES._LESS_THAN:s=rr.lessThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case me.SEARCH_TYPES.LESS_THAN_EQUAL:case me.SEARCH_TYPES._LESS_THAN_EQUAL:s=rr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;default:return Object.create(null)}return s}a(ww,"searchByType");function Nw(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(Nw,"createMapFromIterable");function Yz(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(Yz,"checkToFetchMore");function Cw(e,t,r,n){if(Fz.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),Is.indexOf(s)>-1)return r===!0?me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:me.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Is[0])<0&&s.indexOf(Is[1])<0)return c===!0?r===!0?me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:me.SEARCH_TYPES.EQUALS;if(Is.indexOf(i)>=0&&Is.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),me.SEARCH_TYPES.CONTAINS;if(Is.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),me.SEARCH_TYPES.ENDS_WITH;if(Is.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),me.SEARCH_TYPES.STARTS_WITH;if(s.includes(Is[0])||s.includes(Is[1]))return me.SEARCH_TYPES.EQUALS;throw new Error(yw.UNKNOWN_SEARCH_TYPE)}else switch(n){case ro.VALUE_SEARCH_COMPARATORS.BETWEEN:return me.SEARCH_TYPES.BETWEEN;case ro.VALUE_SEARCH_COMPARATORS.GREATER:return me.SEARCH_TYPES.GREATER_THAN;case ro.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return me.SEARCH_TYPES.GREATER_THAN_EQUAL;case ro.VALUE_SEARCH_COMPARATORS.LESS:return me.SEARCH_TYPES.LESS_THAN;case ro.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return me.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(yw.UNKNOWN_SEARCH_TYPE)}}a(Cw,"createSearchTypeFromSearchObject");Dw.exports={executeSearch:Iw,createSearchTypeFromSearchObject:Cw,prepSearch:$z,searchByType:ww}});var Mw=g((K_e,Lw)=>{"use strict";var Y_e=ns(),Kz=ia(),Wz=J(),Qz=P(),zz=Ed();Lw.exports=Jz;function Jz(e,t){if(!Wz.isEmpty(t)&&Qz.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=Kz(e,"value");if(n)throw n;return zz.prepSearch(e,t,!0)}a(Jz,"lmdbGetDataByValue")});var iu=g((z_e,Pw)=>{"use strict";var Q_e=ns(),Xz=ia(),jz=J(),Zz=P(),e2=Ed();Pw.exports=t2;async function t2(e,t){if(!jz.isEmpty(t)&&Zz.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=Xz(e,"value");if(n)throw n;return e2.prepSearch(e,t,!1)}a(t2,"lmdbSearchByValue")});var vw=g((j_e,Uw)=>{"use strict";var X_e=ft(),$p=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}},Yp=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Kp=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};Uw.exports={SearchByConditionsObject:$p,SearchCondition:Yp,SortAttribute:Kp}});var qw=g((rde,Gw)=>{"use strict";var ede=vw().SearchByConditionsObject,r2=ns(),n2=ia(),Wp=sa(),hd=ft(),{Resource:tde}=(cn(),ie(Qp)),Hw=Ed(),s2=Gp(),i2=require("lodash"),{getSchemaPath:o2}=Xe(),Bw=ze(),{handleHDBError:a2,hdb_errors:c2}=se(),{HTTP_STATUS_CODES:u2}=c2,l2=1e8;Gw.exports=_2;async function _2(e){let t=n2(e,"conditions");if(t)throw a2(t,t.message,u2.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=o2(e.schema,e.table),n=await Bw.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let _ of e.conditions)Bw.openDBI(n,_.search_attribute);let i=i2.sortBy(e.conditions,_=>{if(_.estimated_count===void 0){let l=_.search_type;l===hd.SEARCH_TYPES.EQUALS?_.estimated_count=Wp.count(n,_.search_attribute,_.search_value):l===hd.SEARCH_TYPES.CONTAINS||l===hd.SEARCH_TYPES.ENDS_WITH?_.estimated_count=1/0:_.estimated_count=l2}return _.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await xw(o,e,i[0],s.hash_attribute),u;if(!e.operator||e.operator.toLowerCase()==="and"){let _=n.dbis[s.hash_attribute],l=i.slice(1).map(Hw.filterByType),d=l.length,E=Wp.setGetWholeRowAttributes(n,e.get_attributes);u=c.map(f=>_.get(f,{transaction:o,lazy:!0})),d>0&&(u=u.filter(f=>{for(let h=0;h<d;h++)if(!l[h](f))return!1;return!0})),(e.offset||e.limit!==void 0)&&(u=u.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),u=u.map(f=>s2.parseRow(f,E))}else{for(let d=1;d<i.length;d++){let E=i[d],f=await xw(o,e,E,s.hash_attribute);c=c.concat(f)}let _=new Set,l=e.offset||0;c=c.filter(d=>_.has(d)?!1:(_.add(d),!0)).slice(l,e.limit&&e.limit+l),u=Wp.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return u.onDone=()=>{o.done()},u}a(_2,"lmdbSearchByConditions");async function xw(e,t,r,n){let s=new r2(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===hd.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,Hw.searchByType(e,s,i,n).map(o=>o.value)}a(xw,"executeConditionSearch")});var aa=g((sde,Fw)=>{"use strict";var d2=P().OPERATIONS_ENUM,zp=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=d2.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Fw.exports=zp});var Jp=g((ode,zw)=>{"use strict";var Yw=ns(),Kw=aa(),Ww=iu(),Qw=tu(),Sr=P(),kw=J(),Vw=ze(),{getTransactionAuditStorePath:f2,getSchemaPath:E2}=Xe(),$w=$();zw.exports=h2;async function h2(e){try{if(kw.isEmpty(global.hdb_schema[e.schema])||kw.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await m2(e),await p2(e);let t=E2(e.schema,e.table);try{await Vw.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")$w.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=f2(e.schema,e.table);await Vw.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")$w.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(h2,"lmdbDropTable");async function m2(e){let t=new Yw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Ww(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 Kw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await Qw(s)}a(m2,"deleteAttributesFromSystem");async function p2(e){let t=new Yw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Ww(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 Kw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await Qw(s)}catch(i){throw i}}a(p2,"dropTableFromSystem")});var Xw=g((cde,Jw)=>{"use strict";var S2=require("fs-extra"),T2=ns(),g2=oa(),R2=aa(),A2=Jp(),O2=tu(),b2=Fp(),y2=iu(),ws=P(),{getSchemaPath:N2}=Xe(),{handleHDBError:I2,hdb_errors:w2}=se(),{HDB_ERROR_MSGS:C2,HTTP_STATUS_CODES:D2}=w2;Jw.exports=L2;async function L2(e){let t;try{t=await M2(e.schema);let r=new T2(ws.SYSTEM_SCHEMA_NAME,ws.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,ws.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[ws.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await y2(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await A2(c)}catch(u){if(u.message!=="invalid environment")throw u}}let s=new R2(ws.SYSTEM_SCHEMA_NAME,ws.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await O2(s);let i=N2(t);await S2.remove(i)}catch(r){throw r}}a(L2,"lmdbDropSchema");async function M2(e){let t=new g2(ws.SYSTEM_SCHEMA_NAME,ws.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[ws.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await b2(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw I2(new Error,C2.SCHEMA_NOT_FOUND(e),D2.NOT_FOUND,void 0,void 0,!0);return n}a(M2,"validateDropSchema")});var md=g((lde,jw)=>{"use strict";var Xp=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};jw.exports=Xp});var eC=g((fde,Zw)=>{"use strict";var P2=require("fs-extra"),pd=ze(),{getTransactionAuditStorePath:U2}=Xe(),jp=ft(),dde=md();Zw.exports=v2;async function v2(e){let t;try{let r=U2(e.schema,e.table);await P2.mkdirp(r),t=await pd.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{pd.createDBI(t,jp.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),pd.createDBI(t,jp.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),pd.createDBI(t,jp.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(v2,"createTransactionsAuditEnvironment")});var sC=g((hde,nC)=>{"use strict";var Zp=P(),tC=ze(),B2=Ko(),{getSystemSchemaPath:x2,getSchemaPath:H2}=Xe(),G2=Vi(),q2=q_(),eS=G_(),F2=$(),k2=eC(),rS=G2.hdb_table,rC=[];for(let e=0;e<rS.attributes.length;e++)rC.push(rS.attributes[e].attribute);nC.exports=V2;async function V2(e,t){let r=H2(t.schema,t.table),n=new eS(t.schema,t.table,Zp.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new eS(t.schema,t.table,Zp.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new eS(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await tC.createEnvironment(r,t.table),e!==void 0){let o=await tC.openEnvironment(x2(),Zp.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await B2.insertRecords(o,rS.hash_attribute,rC,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await tS(n),await tS(s),await tS(i)}await k2(t)}catch(o){throw o}}a(V2,"lmdbCreateTable");async function tS(e){try{await q2(e)}catch(t){F2.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(tS,"createAttribute")});var oC=g((pde,iC)=>{"use strict";var $2=Yc(),Y2=Cc(),K2=cd(),ou=P(),W2=Ko().updateRecords,Q2=ze(),{getSchemaPath:z2}=Xe(),J2=Zc(),X2=$();iC.exports=j2;async function j2(e){try{let{schema_table:t,attributes:r}=$2(e);Y2(e,r,t.hash_attribute),e.schema!==ou.SYSTEM_SCHEMA_NAME&&(r.includes(ou.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(ou.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(ou.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(ou.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await K2(e.hdb_auth_header,t,r),s=z2(e.schema,e.table),i=await Q2.openEnvironment(s,e.table),o=await W2(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await J2(e,o)}catch(c){X2.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(j2,"lmdbUpdateRecords")});var cC=g((Tde,aC)=>{"use strict";var Z2=P().OPERATIONS_ENUM,nS=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Z2.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};aC.exports=nS});var lC=g((Ade,uC)=>{"use strict";var Rde=cC(),eJ=Yc(),tJ=Cc(),rJ=cd(),au=P(),nJ=Ko().upsertRecords,sJ=ze(),{getSchemaPath:iJ}=Xe(),oJ=Zc(),aJ=$(),{handleHDBError:cJ,hdb_errors:uJ}=se();uC.exports=lJ;async function lJ(e){let t;try{t=eJ(e)}catch(u){throw cJ(u,u.message,uJ.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;tJ(e,n,r.hash_attribute),e.schema!==au.SYSTEM_SCHEMA_NAME&&(n.includes(au.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(au.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(au.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(au.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await rJ(e.hdb_auth_header,r,n),i=iJ(e.schema,e.table),o=await sJ.openEnvironment(i,e.table),c=await nJ(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await oJ(e,c)}catch(u){aJ.error(`unable to write transaction due to ${u.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(lJ,"lmdbUpsertRecords")});var dC=g((bde,_C)=>{"use strict";var sS=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};_C.exports=sS});var EC=g((Nde,fC)=>{"use strict";var iS=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}};fC.exports=iS});var pC=g((Cde,mC)=>{"use strict";var oS=ze(),{getTransactionAuditStorePath:_J}=Xe(),wde=dC(),cu=ft(),dJ=J(),hC=EC(),fJ=require("util").promisify,EJ=fJ(setTimeout),hJ=1e4,mJ=100;mC.exports=pJ;async function pJ(e){let t=_J(e.schema,e.table),r=await oS.openEnvironment(t,e.table,!0),n=oS.listDBIs(r);oS.initializeDBIs(r,cu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new hC;do s=await SJ(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 EJ(mJ);while(s.transactions_deleted>0);return i}a(pJ,"deleteAuditLogsBefore");async function SJ(e,t){let r=new hC;try{let n=e.dbis[cu.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[cu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];dJ.isEmpty(c)||(s=e.dbis[cu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let u=0;u<o.hash_values.length;u++)s=e.dbis[cu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[u],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>hJ)break}return await s,r}catch(n){throw n}}a(SJ,"deleteTransactions")});var TC=g((Lde,SC)=>{"use strict";var aS=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};SC.exports=aS});var RC=g((Ude,gC)=>{"use strict";var TJ=ns(),gJ=aa(),Pde=TC(),ss=P(),RJ=J(),cS=ze(),AJ=Vi(),OJ=iu(),bJ=tu(),{getSchemaPath:yJ}=Xe();gC.exports=NJ;async function NJ(e,t=!0){let r;e.schema===ss.SYSTEM_SCHEMA_NAME?r=AJ[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await wJ(e),s=yJ(e.schema,e.table),i=await cS.openEnvironment(s,e.table);return t===!0&&await IJ(e,i,r.hash_attribute),cS.dropDBI(i,e.attribute),n}a(NJ,"lmdbDropAttribute");async function IJ(e,t,r){let n=cS.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:u}of n.getRange({start:!1,versions:!0})){let _={};for(let l in c)l!==i&&(_[l]=c[l]);s=t.dbis[r].put(o,_,u)}await s}a(IJ,"removeAttributeFromAllObjects");async function wJ(e){let t=new TJ(ss.SYSTEM_SCHEMA_NAME,ss.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,ss.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[ss.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,ss.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await OJ(t)).filter(o=>o[ss.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(RJ.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[ss.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new gJ(ss.SYSTEM_SCHEMA_NAME,ss.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return bJ(i)}a(wJ,"dropAttributeFromSystem")});var IC=g((xde,NC)=>{"use strict";var uS=ze(),ca=ft(),Bde=Br(),lS=P(),AC=J(),{getTransactionAuditStorePath:CJ}=Xe(),DJ=sa(),Sd=ta(),LJ=$();NC.exports=MJ;async function MJ(e){let t=CJ(e.schema,e.table),r=await uS.openEnvironment(t,e.table,!0),n=uS.listDBIs(r);uS.initializeDBIs(r,ca.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case lS.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return OC(r,e.search_values);case lS.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,UJ(r,e.search_values,s);case lS.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return PJ(r,e.search_values);default:return OC(r)}}a(MJ,"readAuditLog");function OC(e,t=[0,Date.now()]){AC.isEmpty(t[0])&&(t[0]=0),AC.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[ca.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 Sd,s))}a(OC,"searchTransactionsByTimestamp");function PJ(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[ca.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,yC(e,i))}return Object.fromEntries(r)}a(PJ,"searchTransactionsByUsername");function UJ(e,t,r){let n=new Map;for(let c=0,u=t.length;c<u;c++){let _=t[c],l=DJ.equals(e,ca.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ca.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,_);for(let{value:d}of l){let E=Number(d);n.has(E)?n.get(E).push(_.toString()):n.set(E,[_.toString()])}}let s=Array.from(n.keys()),i=yC(e,s),o=new Map;for(let c=0;c<i.length;c++){let u=i[c],_=u.timestamp,l=n.get(_);bC(u,"records",r,l,o),bC(u,"original_records",r,l,o)}return Object.fromEntries(o)}a(UJ,"searchTransactionsByHashValues");function bC(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],u=c[r].toString();if(n.indexOf(u)>=0)if(s.has(u)){let _=s.get(u),l=_[_.length-1];if(l.timestamp===i)l[t]=[c];else{let d=new Sd(e.operation,e.user_name,i,void 0);d[t]=[c],_.push(d)}}else{let _=new Sd(e.operation,e.user_name,i,void 0);_[t]=[c],s.set(u,[_])}}}a(bC,"loopRecords");function yC(e,t){let r=[];try{let n=e.dbis[ca.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 Sd,i);r.push(o)}}catch(i){LJ.warn(i)}return r}catch(n){throw n}}a(yC,"batchSearchTransactions")});var CC=g((Fde,wC)=>{"use strict";var{getSchemaPath:Gde}=Xe(),qde=ze(),{database:vJ}=(Ae(),ie(ke));wC.exports={writeTransaction:BJ};async function BJ(e,t,r){return vJ({database:e,table:t}).transaction(r)}a(BJ,"writeTransaction")});var PC=g((Vde,MC)=>{"use strict";var{getSchemaPath:DC}=Xe(),LC=ze();MC.exports={flush:xJ,resetReadTxn:HJ};async function xJ(e,t){return(await LC.openEnvironment(DC(e,t),t.toString())).flushed}a(xJ,"flush");async function HJ(e,t){try{(await LC.openEnvironment(DC(e,t),t.toString())).resetReadTxn()}catch{}}a(HJ,"resetReadTxn")});var xC=g((Yde,BC)=>{"use strict";var{Readable:GJ}=require("stream"),{getDatabases:qJ}=(Ae(),ie(ke)),{readSync:FJ,openSync:kJ,createReadStream:UC}=require("fs"),{open:VJ}=require("lmdb"),vC=Hc(),$J=Gc(),{AUDIT_STORE_OPTIONS:YJ}=(ni(),ie(HC)),{INTERNAL_DBIS_NAME:KJ,AUDIT_STORE_NAME:WJ}=ft();BC.exports=zJ;var _S=32768,QJ=100;async function zJ(e){let t=e.database||e.schema||"data",r=qJ()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let _=r[s[0]];if(!_)throw new Error(`Can not find table ${s[0]}`);let l=_.dbisDB,d=VJ({noSync:!0,maxDbs:$J.MAX_DBS}),E,f=d.openDB(KJ,new vC(!1)),h=l.useReadTransaction(),p=0,S=a(async function(A,y){y.encoding="binary",y.encoder=void 0;let I=d.openDB(A,y),B=l.openDB(A,y);for(let{key:U,version:F,value:M}of B.getRange({start:null,transaction:h,versions:B.useVersions}))E=I.put(U,M,F),p++%QJ===0&&(await new Promise(Q=>setTimeout(Q,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:A,value:y}of l.getRange({transaction:h,start:!1}))if(s.some(I=>A.startsWith?.(I+"/"))){f.put(A,y);let[,I]=A.split("/"),B=!I,U=new vC(!B,B);await S(A,U)}e.include_audit&&await S(WJ,Object.assign({},YJ)),await E;let T=UC(d.path);return T.headers=u(),T.on("close",()=>{h.done(),d.close()}),T}let o=r[Object.keys(r)[0]].primaryStore,c=kJ(o.path);return o.transaction(()=>{let _=Buffer.alloc(_S);FJ(c,_,0,_S),o.resetReadTxn();let l=o.useReadTransaction();l.renew();let d=UC(null,{fd:c,start:_S}),E=new GJ.from(async function*(){yield _;for await(let f of d)l.openTimer&&(l.openTimer=0),yield f;l.done()}());return E.headers=u(),E});function u(){let _=new Map;return _.set("content-type","application/octet-stream"),_.set("content-disposition",`attachment; filename="${t}"`),_.set("date",n),_}}a(zJ,"getBackup")});var FC=g((Wde,qC)=>{"use strict";var JJ=$(),{handleHDBError:XJ}=se(),jJ=ry(),ZJ=q_(),e4=Up(),t4=XI(),r4=tu(),n4=Fp(),s4=Ow(),i4=Mw(),o4=iu(),a4=qw(),c4=Xw(),u4=sC(),l4=oC(),_4=lC(),d4=pC(),f4=Jp(),E4=RC(),h4=IC(),m4=CC(),GC=PC(),p4=xC(),dS=class extends jJ{static{a(this,"LMDBBridge")}async searchByConditions(t){return a4(t)}async getDataByHash(t){return await n4(t)}async searchByHash(t){return await s4(t)}async getDataByValue(t,r){return await i4(t,r)}async searchByValue(t){return await o4(t)}async createSchema(t){return await t4(t)}async dropSchema(t){return await c4(t)}async createTable(t,r){return await u4(t,r)}async dropTable(t){return await f4(t)}async createAttribute(t){return await ZJ(t)}async createRecords(t){return await e4(t)}async updateRecords(t){return await l4(t)}async upsertRecords(t){try{return await _4(t)}catch(r){throw XJ(r,null,null,JJ.ERR,r)}}async deleteRecords(t){return await r4(t)}async dropAttribute(t){return await E4(t)}async deleteAuditLogsBefore(t){return await d4(t)}async readAuditLog(t){return await h4(t)}writeTransaction(t,r,n){return m4.writeTransaction(t,r,n)}flush(t,r){return GC.flush(t,r)}resetReadTxn(t,r){return GC.resetReadTxn(t,r)}getBackup(t){return p4(t)}};qC.exports=dS});function R4(){g4=setInterval(function(){for(let e of fS)if(e.stale){let t=e[ye]?.url;YC.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},T4).unref()}var ES,$C,YC,KC,WC,QC,kC,fS,S4,uu,VC,no,Td,T4,g4,hS=Re(()=>{ES=H(Br()),$C=H(se()),YC=H($());cn();KC=H(ee()),WC=H(P()),QC=H(J()),kC=100,fS=new Set,S4=(0,QC.convertToMS)(KC.get(WC.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3,no=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),fS.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(fS.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(uu&&!this.overloadChecked&&performance.now()-VC>S4)throw new $C.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp||(0,ES.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let 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 A=T();h?h.push?h.push(A):h=[h,A]:h=A}}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"),u=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,u);s=s||E}else u();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)<kC>>n?u():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 uu||(uu=s,VC=performance.now(),uu.then(()=>{uu=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)+kC/2),t?t.retries=n+1:t={retries:1},this.commit(t)));let l={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(E=>({txnTime:r,next:E}));l.next=d}return l}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},Td=class extends no{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,ES.getNextMonotonicTime)())}getReadTxn(){}},T4=3e4;a(R4,"startMonitoringTxns");R4()});function rt(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 no;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 u=n.commit({letItLinger:r?.letItLinger});return u.then?u.then(()=>c):c}function o(c){throw n.abort({}),c}}var zC,so=Re(()=>{zC=require("../index");cn();hS();a(rt,"transaction");(0,zC._assignPackageExport)("transaction",rt);rt.commit=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};rt.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 nD={};Fe(nD,{ResourceBridge:()=>SS});function TS({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 XC(e,t){let r=is(e),n=TS(e,r);if(!r)throw new Un.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache},o;rt(i,()=>new Promise(_=>o=_));let c=e.ids||e.hash_values,u=0;return{[Symbol.asyncIterator](){return{async next(){if(u<c.length){let _=c[u++],l;try{l=await r.get({id:_,lazy:s,select:n},i),l=l&&Rd(l)}catch(d){l={message:d.toString()}}return t?{value:{key:_,value:l}}:{value:l}}else return o(),{done:!0}},return(_){return o(),{value:_,done:!0}},throw(_){return o(),{done:!0}}}}}}function is(e){let t=e.database||e.schema||O4,r=Tr()[t];if(!r)throw(0,Un.handleHDBError)(new Error,A4.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function jC(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*ZC(e,t,r){let n;for await(let s of e.getHistory(t,r)){let i=s.type;i==="put"&&(i="upsert");let{id:o,version:c,value:u}=s;n?.timestamp===c?(n.hash_values.push(o),n.records.push(u)):(n&&(yield n),n={operation:i,user_name:s.user,timestamp:c,hash_values:[o],records:[u]})}n&&(yield n)}var eD,gd,Un,tD,vn,mS,pS,rD,A4,O4,b4,y4,JC,SS,sD=Re(()=>{"use strict";eD=H(FC()),gd=H(ia()),Un=H(se());Ae();tD=H(Yc()),vn=H(P()),mS=H(Ns()),pS=H(Pn()),rD=H(J());so();Ad();({HDB_ERROR_MSGS:A4}=Un.hdb_errors),O4="data",b4=1e4,y4=10,SS=class extends eD.default{static{a(this,"ResourceBridge")}constructor(t){super(t),JC=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,gd.default)(t,"conditions");if(r)throw(0,Un.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=is(t);if(!n)throw new Un.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:TS(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}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 Un.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}Et({database:r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await is(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=is(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,u)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,u,()=>r.primaryStore.put(o,c,u)).then(_=>{if(!_){let{value:l,version:d}=r.primaryStore.getEntry(o);return i(o,l,d)}})),"deleteRecord");for(let{key:o,value:c,version:u}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,u),await new Promise(_=>setImmediate(_));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){is(t).dropTable()}createSchema(t){return ua({database:t.schema,table:null}),mS.signalSchemaChange(new pS.SchemaEventMsg(process.pid,vn.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await gS(t.schema),mS.signalSchemaChange(new pS.SchemaEventMsg(process.pid,vn.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,JC.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,tD.default)(t),s,i=Tr()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt};return rt(o,async c=>{if(!i.schemaDefined){s=[];for(let l of n)i.attributes.find(E=>E.name==l)||s.push(l);s.length>0&&await i.addAttributes(s.map(l=>({name:l,indexed:!0})))}let u=[],_=[];for(let l of t.records){let d=l[i.primaryKey],E=d!=null&&await i.get(d,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){_.push(l[i.primaryKey]);continue}E&&(E=Rd(E));for(let f in l)if(Object.prototype.hasOwnProperty.call(l,f)){let h=l[f];if(typeof h=="function")try{let p=h([[E]]);Array.isArray(p)&&(h=p[0].func_val,l[f]=h)}catch(p){throw p.message+="Trying to set key "+f+" on object"+JSON.stringify(l),p}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(l,f)||(l[f]=E[f]);await(d==null?i.create(l,o):i.put(l,o)),u.push(l[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:u,new_attributes:s,skipped_hashes:_}})}async deleteRecords(t){let r=Tr()[t.schema][t.table],n={user:t.hdb_user};return rt(n,async s=>{let i=t.hash_values||t.records.map(u=>u[r.primaryKey]),o=[],c=[];for(let u of i)await r.delete(u,n)?o.push(u):c.push(u);return jC(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Tr()[t.schema][t.table];if(!r.createdTimeProperty)throw new Un.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:vn.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,u=[],_=a(async()=>{let l=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:u});i.push(...l.deleted_hashes),o.push(...l.skipped_hashes),await(0,rD.async_set_timeout)(y4),u=[],s=!0},"chunkDelete");for await(let l of n)u.push(l[r.primaryKey]),c++,c%b4===0&&await _();return u.length>0&&await _(),s?jC(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,gd.default)(t,"hashes");if(r)throw r;return XC(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of XC(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&vn.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,gd.default)(t,"value");if(n)throw n;let s=is(t);if(!s)throw new Un.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===vn.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:TS(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async getDataByValue(t,r){let n=new Map,s=is(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){is({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return is(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=is(t),n={};switch(t.search_type){case vn.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 vn.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of ZC(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return ZC(r,t.search_values?.[0],t.search_values?.[1])}}};a(TS,"getSelect");a(XC,"getRecords");a(is,"getTable");a(jC,"createDeleteResponse");a(ZC,"groupRecordsInHistory")});var Dn=g((cfe,iD)=>{"use strict";var{ResourceBridge:N4}=(sD(),ie(nD)),I4=ee();I4.initSync();var Od;function w4(){return Od||(Od=new N4,Od)}a(w4,"getBridge");iD.exports=w4()});var uD=g((lfe,cD)=>{"use strict";var oD=require("lodash"),lu=require("mathjs"),C4=require("jsonata"),aD=J();cD.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?oD.uniqWith(e,oD.isEqual):e,searchJSON:D4,mad:_u.bind(null,lu.mad),mean:_u.bind(null,lu.mean),mode:_u.bind(null,lu.mode),prod:_u.bind(null,lu.prod),median:_u.bind(null,lu.median)};function _u(e,t,r,n){return n===1?t==null?[]:[t]:n===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(_u,"aggregateFunction");function D4(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(aD.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),aD.isEmpty(this.__ala__.res[r])){let n=C4(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(D4,"searchJSON")});var _D=g((dfe,lD)=>{"use strict";var Rt=require("moment"),RS="YYYY-MM-DDTHH:mm:ss.SSSZZ";Rt.suppressDeprecationWarnings=!0;lD.exports={current_date:()=>Rt().utc().format("YYYY-MM-DD"),current_time:()=>Rt().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return Rt(e).utc().format("YYYY");case"month":return Rt(e).utc().format("MM");case"day":return Rt(e).utc().format("DD");case"hour":return Rt(e).utc().format("HH");case"minute":return Rt(e).utc().format("mm");case"second":return Rt(e).utc().format("ss");case"millisecond":return Rt(e).utc().format("SSS");default:break}},date:e=>Rt(e).utc().format(RS),date_format:(e,t)=>Rt(e).utc().format(t),date_add:(e,t,r)=>Rt(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>Rt(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=Rt(e).utc(),s=Rt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>Rt().utc().valueOf(),get_server_time:()=>Rt().format(RS),offset_utc:(e,t)=>Rt(e).utc().utcOffset(t).format(RS)}});var hD=g((ffe,ED)=>{"use strict";var L4=require("@turf/area"),M4=require("@turf/length"),P4=require("@turf/circle"),U4=require("@turf/difference"),v4=require("@turf/distance"),B4=require("@turf/boolean-contains"),x4=require("@turf/boolean-equal"),H4=require("@turf/boolean-disjoint"),G4=require("@turf/helpers"),dD=P(),Te=J(),Cs=$();ED.exports={geoArea:q4,geoLength:F4,geoCircle:k4,geoDifference:V4,geoDistance:fD,geoNear:$4,geoContains:Y4,geoEqual:K4,geoCrosses:W4,geoConvert:Q4};function q4(e){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return L4.default(e)}catch(t){return Cs.trace(t,e),NaN}}a(q4,"geoArea");function F4(e,t){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return M4.default(e,{units:t||"kilometers"})}catch(r){return Cs.trace(r,e),NaN}}a(F4,"geoLength");function k4(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return P4.default(e,t,{units:r||"kilometers"})}catch(n){return Cs.trace(n,e,t),NaN}}a(k4,"geoCircle");function V4(e,t){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return U4(e,t)}catch(r){return Cs.trace(r,e,t),NaN}}a(V4,"geoDifference");function fD(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return v4.default(e,t,{units:r||"kilometers"})}catch(n){return Cs.trace(n,e,t),NaN}}a(fD,"geoDistance");function $4(e,t,r,n){if(Te.isEmpty(e)||Te.isEmpty(t))return!1;if(Te.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return fD(e,t,n)<=r}catch(s){return Cs.trace(s,e,t),!1}}a($4,"geoNear");function Y4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return B4.default(e,t)}catch(r){return Cs.trace(r,e,t),!1}}a(Y4,"geoContains");function K4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return x4.default(e,t)}catch(r){return Cs.trace(r,e,t),!1}}a(K4,"geoEqual");function W4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return!H4.default(e,t)}catch(r){return Cs.trace(r,e,t),!1}}a(W4,"geoCrosses");function Q4(e,t,r){if(Te.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Te.isEmpty(t))throw new Error("geo_type is required");if(Te.isEmpty(dD.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(dD.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Te.autoCastJSON(e)),G4[t](e,r)}a(Q4,"geoConvert")});var bd=g((hfe,mD)=>{var io=uD(),Wr=_D(),os=hD();mD.exports=e=>{e.aggr.mad=e.aggr.MAD=io.mad,e.aggr.mean=e.aggr.MEAN=io.mean,e.aggr.mode=e.aggr.MODE=io.mode,e.aggr.prod=e.aggr.PROD=io.prod,e.aggr.median=e.aggr.MEDIAN=io.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=io.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=io.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Wr.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Wr.current_time,e.fn.extract=e.fn.EXTRACT=Wr.extract,e.fn.date=e.fn.DATE=Wr.date,e.fn.date_format=e.fn.DATE_FORMAT=Wr.date_format,e.fn.date_add=e.fn.DATE_ADD=Wr.date_add,e.fn.date_sub=e.fn.DATE_SUB=Wr.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Wr.date_diff,e.fn.now=e.fn.NOW=Wr.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Wr.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Wr.get_server_time,e.fn.getdate=e.fn.GETDATE=Wr.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Wr.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=os.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=os.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=os.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=os.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=os.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=os.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=os.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=os.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=os.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=os.geoNear}});var gD=g((mfe,TD)=>{"use strict";var du=require("lodash"),gr=require("alasql");gr.options.cache=!1;var z4=bd(),pD=require("clone"),yd=require("recursive-iterator"),fe=$(),Le=J(),la=Dn(),J4=P(),{hdb_errors:X4}=se(),{getDatabases:SD}=(Ae(),ie(ke)),j4="IS NULL",Bn="There was a problem performing this search. Please check the logs and try again.";z4(gr);var AS=class{static{a(this,"SQLSearch")}constructor(t,r){if(Le.isEmpty(t))throw fe.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(),Le.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Le.isEmptyOrZeroLength(n))return fe.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw fe.error("Error thrown from checkEmptySQL in SQLSearch class method search."),fe.error(n),new Error(Bn)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw fe.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),fe.error(n),new Error(Bn)}if(Object.keys(this.data).length===0)return fe.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw fe.error("Error thrown from processJoins in SQLSearch class method search."),fe.error(n),new Error(Bn)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw fe.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),fe.error(n),new Error(Bn)}try{return t=await this._finalSQL(),t}catch(n){throw fe.error("Error thrown from finalSQL in SQLSearch class method search."),fe.error(n),new Error(Bn)}}_getColumns(){let t=new yd(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(pD(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=du.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(Le.isEmpty(this.statement.where)){fe.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new yd(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Le.isEmpty(r)&&r.right)if(Le.isNotEmptyAndHasValue(r.right.value)){let n=Le.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new gr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Le.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new gr.yy.LogicValue({value:i}):n instanceof gr.yy.StringValue&&Le.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new gr.yy.NumValue({value:i}))});if(t){fe.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new yd(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(!Le.isEmpty(J4.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Le.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Le.isEmptyOrZeroLength(r.left.columnid)||Le.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(Le.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"=":!Le.isEmpty(r.right.value)||!Le.isEmpty(r.left.value)?n.add(Le.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let u=Array.isArray(r.right)?r.right:r.left;for(let _=0;_<u.length;_++)if(u[_].value)n.add(u[_].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from)&&Le.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&&du.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(Le.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Le.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(Le.isEmptyOrZeroLength(this.all_table_attributes)&&!Le.isEmptyOrZeroLength(this.columns.columns))return t;if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await gr.promise(r)}catch(r){throw fe.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),fe.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(pD(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(Le.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(j4)>-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=du.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},u=!1,_=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(u=!0),!Le.isEmpty(this.exact_search_values[_])&&!this.exact_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.exact_search_values[_].values))if(u)try{c.hash_values=Array.from(this.exact_search_values[_].values);let l=await la.getDataByHash(c);for(let d of c.hash_values)l.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(l){throw fe.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(l),new Error(Bn)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[_].values).map(async l=>{let d=Object.assign({},c);d.search_value=l;let E=await la.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(l){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(l),new Error(Bn)}else if(!Le.isEmpty(this.comparator_search_values[_])&&!this.comparator_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.comparator_search_values[_].comparators))try{let l=this.comparator_search_values[_].comparators;for(let d=0,E=l.length;d<E;d++){let f=l[d];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await la.getDataByValue(c,f.operation);if(u)for(let[p]of h)this.data[i].__merged_data[p]||(this.data[i].__merged_data[p]=[...n[i]],this._setMergedHashAttribute(i,p));else for(let[p,S]of h)this.data[i].__merged_data[p]?this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]):(this.data[i].__merged_data[p]=[...n[i]],this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]),this._setMergedHashAttribute(i,p))}}catch(l){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),fe.error(l),new Error(Bn)}else try{c.search_attribute=s.attribute,c.search_value="*";let l=await la.getDataByValue(c);if(u)for(let[d]of l)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,E]of l)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(l){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),fe.error(l),new Error(Bn)}}}_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 gr.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 gr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new gr.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 gr.yy.FuncValue:new gr.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 u=this.statement.where?"WHERE "+this.statement.where:"";u=u.replace(/NOT\(NULL\)/g,"NOT NULL");let _="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(_="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(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 l="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(l=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${u} ${_} ${l} ${d}`,h=this._convertColumnsToIndexes(f,s);E=await gr.promise(h,t),t=null}catch(f){throw fe.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),fe.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=du.difference(h,[...f.keys].map(S=>S.toString()));for(let S=0,T=p.length;S<T;S++){let A=p[S];delete this.data[`${f.schema}_${f.table}`].__merged_data[A]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new yd(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=du.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 fe.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),fe.error(i),new Error(Bn)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let l in i)o.push(i[l][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},u=await la.getDataByHash(c),_=s.columns.length;for(let l=0,d=o.length;l<d;l++){let E=o[l],f=u.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 fe.error("Error thrown from getDataByHash function in SQLSearch class method getData."),fe.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,u=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===u}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();fe.trace(`Final SQL: ${s}`),n=await gr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),fe.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw fe.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),fe.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 fe.error(X4.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),fe.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let u=s[i],_=new RegExp(`${u}.\`${o}\``,"g"),l=`${u}.[${c}]`;n=n.replace(_,l)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let u=new RegExp(`\`${o}\``,"g"),_=`[${c}]`;n=n.replace(u,_)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await la.getDataByValue(i);for(let[c,u]of o)this.data[s].__merged_data[c]||(u[n.attribute]===void 0&&(u[n.attribute]=null),this.data[s].__merged_data[c]=Object.assign({},r[s])),this.data[s].__merged_data[c][t[n.attribute]]=u[n.attribute]??null}catch(o){throw fe.error("There was an error when processing this SQL operation. Check your logs"),fe.error(o),new Error(Bn)}}return Object.values(Object.values(this.data)[0].__merged_data)}};TD.exports=AS});var qr=g((Sfe,RD)=>{"use strict";var Z4=ey();RD.exports={searchByConditions:t3,searchByHash:r3,searchByValue:n3,search:s3};var OS=Dn(),{transformReq:bS}=J(),e3=gD();async function t3(e){return bS(e),OS.searchByConditions(e)}a(t3,"searchByConditions");async function r3(e){bS(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of OS.searchByHash(e))r&&t.push(r);return t}a(r3,"searchByHash");async function n3(e){bS(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of OS.searchByValue(e))t.push(r);return t}a(n3,"searchByValue");function s3(e,t){try{let r=new Z4(e);r.validate(),new e3(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(s3,"search")});var Nd=g((gfe,AD)=>{"use strict";var i3=Dn();AD.exports={writeTransaction:o3};function o3(e,t,r){return i3.writeTransaction(e,t,r)}a(o3,"writeTransaction")});var ND=g((Ofe,yD)=>{"use strict";var a3=qr(),c3=ys(),OD=$(),u3=Fr(),Afe=Nd(),l3=require("clone"),NS=require("alasql"),_3=bd(),bD=require("util"),d3=bD.promisify(c3.getTableSchema),f3=bD.promisify(a3.search),E3=P(),yS=J();_3(NS);yD.exports={update:m3};var h3="There was a problem performing this update. Please check the logs and try again.";async function m3({statement:e,hdb_user:t}){let r=await d3(e.table.databaseid,e.table.tableid),n=p3(e.columns);yS.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=l3(s),c=yS.isEmpty(i)?"":` WHERE ${i.toString()}`,u=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,_=NS.parse(u).statements[0],l=await f3(_),d=S3(n,l);return T3(o,d,t)}a(m3,"update");function p3(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=NS.compile(`SELECT ${r.expression.toString()} AS [${E3.FUNC_VAL}] FROM ?`)}),t}catch(t){throw OD.error(t),new Error(h3)}}a(p3,"createUpdateRecord");function S3(e,t){return yS.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(S3,"buildUpdateRecords");async function T3(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await u3.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){OD.error(`Error delete new_attributes from update response: ${i}`)}return s}a(T3,"updateRecords")});var wD=g((Ife,ID)=>{var g3=require("alasql"),R3=qr(),A3=$(),O3=Dn(),wS=require("util"),IS=J(),b3=P(),y3=ys(),yfe=Nd(),Nfe=Fr(),N3="record",I3="successfully deleted",w3=wS.callbackify(M3),C3=wS.promisify(R3.search),D3=wS.promisify(y3.getTableSchema);ID.exports={convertDelete:w3};function L3(e){return`${e.deleted_hashes.length} ${N3}${e.deleted_hashes.length===1?"":"s"} ${I3}`}a(L3,"generateReturnMessage");async function M3({statement:e,hdb_user:t}){let r=await D3(e.table.databaseid,e.table.tableid);IS.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=IS.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=g3.parse(o).statements[0],u={operation:b3.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{u.records=await C3(c);let _=await O3.deleteRecords(u);return IS.isEmptyOrZeroLength(_.message)&&(_.message=L3(_)),delete _.txn_time,_}catch(_){throw A3.error(_),_.hdb_code?_.message:_}}a(M3,"convertDelete")});var PD=g((Cfe,MD)=>{"use strict";var P3=bs(),{hdb_errors:CD}=se(),{getDatabases:DD}=(Ae(),ie(ke));MD.exports={checkSchemaExists:LD,checkSchemaTableExists:U3,schema_describe:P3};async function LD(e){if(!DD()[e])return CD.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(LD,"checkSchemaExists");async function U3(e,t){let r=await LD(e);if(r)return r;if(!DD()[e][t])return CD.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(U3,"checkSchemaTableExists")});var fu=g((Lfe,v3)=>{v3.exports={name:"harperdb",version:"4.3.38",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.2.0",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.11.2",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.3",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^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 Su={};Fe(Su,{addAnalyticsListener:()=>pu,recordAction:()=>nr,recordActionBinary:()=>Qr,setAnalyticsEnabled:()=>B3});function B3(e){kD=e}function nr(e,t,r,n,s){if(!kD)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=Cd.get(i);if(o)if(typeof e=="number"){let c=o.values,u=c.index++;if(u>=c.length){let _=c;o.values=c=new Float32Array(u*2),c.set(_),c.index=u+1}c[u]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},Cd.set(i,o)}Id||x3()}function Qr(e,t,r,n,s){nr(!!e,t,r,n,s)}function pu(e){YD.push(e)}function x3(){Id=performance.now(),setTimeout(async()=>{let e=performance.now()-Id;Id=0;let t=[],r={time:Date.now(),period:e,threadId:oo.threadId,metrics:t};for(let[s,i]of Cd){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,u=0,_=[],l;for(let d of KD){let E=Math.floor(c*d),f=o[E-1];if(E>u){let h=E-u;if(f===l){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),l=f;u=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 WD()}let n=process.memoryUsage();t.push({metric:"memory",threadId:oo.threadId,byThread:!0,...n});for(let s of YD)s(t);Cd=new Map,oo.parentPort?oo.parentPort.postMessage({type:$D,report:r}):JD({report:r})},VD).unref()}async function H3(e,t=6e4){let r=LS(),n=QD(),s=new Promise(p=>{let S=performance.now();setImmediate(()=>{let T=performance.now();T-S>5e3&&(0,Eu.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,Eu.warn)("Unusually high task queue latency on the main thread of "+Math.round(T-S)+"ms"),p(T-S)})}),i;for(let p of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(p.value?.time){i=p.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,u=new Map,_=[],l;for(let{key:p,value:S}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!S)continue;if(o){if(p>o+t)break}else o=p;l=p;let{metrics:T,threadId:A}=S;for(let y of T||[]){let{path:I,method:B,type:U,metric:F,count:M,total:Q,distribution:z,threads:j,...oe}=y;M||(M=1);let ue=F+(I?"-"+I:"");B!==void 0&&(ue+="-"+B),U!==void 0&&(ue+="-"+U);let le=c.get(ue);if(le){if(le.threads){let Ne=le.threads[A];if(Ne)le=Ne;else{le.threads[A]=Object.assign({},oe);continue}}le.count||(le.count=1);let Be=le.count;for(let Ne in oe){let xe=oe[Ne];typeof xe=="number"&&(le[Ne]=(le[Ne]*Be+xe*M)/(Be+M))}le.count+=M,Q>=0&&(le.total+=Q,le.ratio=le.total/le.count)}else le=Object.assign({period:t},y),delete le.distribution,c.set(ue,le),le.byThread&&(le.threads=[],le.threads[A]=Object.assign({},oe),_.push(le));if(z){z=z.map(Ne=>typeof Ne=="number"?{value:Ne,count:1}:Ne);let Be=u.get(ue);Be?Be.push(...z):u.set(ue,z)}}await WD()}for(let p of _){let{path:S,method:T,type:A,metric:y,count:I,total:B,distribution:U,threads:F,...M}=p;F=F.filter(Q=>Q);for(let Q in M){if(typeof p[Q]!="number")continue;let z=0;for(let j of F){let oe=j[Q];typeof oe=="number"&&(z+=oe)}p[Q]=z}p.count=F.length,delete p.threads,delete p.byThread}for(let[p,S]of u){let T=c.get(p);S.sort((Ne,xe)=>Ne.value>xe.value?1:-1);let A=T.count-1,y=[],I=0,B=0,U;for(let Ne of KD){let xe=A*Ne;for(;I<xe;)U=S[B++],I+=U.count,B===1&&I--;let n_=S[B>1?B-2:0];U||(U=S[0]),y.push(U.value-(U.value-n_.value)*(I-xe)/U.count)}let[F,M,Q,z,j,oe,ue,le,Be]=y;Object.assign(T,{p1:F,p10:M,p25:Q,median:z,p75:j,p90:oe,p95:ue,p99:le,p999:Be})}let d;for(let[p,S]of c)S.id=(0,wd.getNextMonotonicTime)(),S.time=l,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,wd.getNextMonotonicTime)(),S={id:p,metric:"main-thread-utilization",idle:f-UD,active:h-vD,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(p,S,{append:!0}).then(T=>{T||n.primaryStore.put(p,S)})}UD=f,vD=h}async function BD(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function LS(){return xD||(xD=Et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function QD(){return HD||(HD=Et({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function F3(){zD=!0;let e=(0,mu.get)(DS.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await H3(VD,e),await BD(LS(),G3),await BD(QD(),q3)},Math.min(e/2,2147483647)).unref()}function JD(e,t){let r=e.report;r.threadId=t?.threadId||oo.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(GD+=n.mean*n.count);r.totalBytesProcessed=GD,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(qD.get(t))}),qD.set(t,t.performance.eventLoopUtilization())),r.id=(0,wd.getNextMonotonicTime)(),LS().primaryStore.put(r.id,r),zD||F3(),k3&&(XD=$3(r))}async function $3(e){if(await XD,!fi){let r=(0,hu.dirname)((0,Eu.getLogFilePath)());try{fi=await(0,CS.open)((0,hu.join)(r,"analytics.log"),"r+")}catch{fi=await(0,CS.open)((0,hu.join)(r,"analytics.log"),"w+")}}let t=(await fi.stat()).size;if(t>V3){let r=Buffer.alloc(t);await fi.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await fi.write(r,{position:0}),await fi.truncate(r.length),t=r.length}await fi.write(JSON.stringify(e)+`
|
|
10
|
+
`,t)}var oo,FD,Eu,hu,CS,wd,mu,DS,Cd,kD,Id,VD,$D,YD,KD,UD,vD,WD,G3,q3,xD,HD,zD,GD,qD,k3,XD,fi,V3,Ds=Re(()=>{oo=require("worker_threads"),FD=H(Qe());Ae();Eu=H($()),hu=require("path"),CS=require("fs/promises"),wd=H(Br()),mu=H(ee()),DS=H(P());fr();(0,mu.initSync)();Cd=new Map,kD=(0,mu.get)(DS.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(B3,"setAnalyticsEnabled");a(nr,"recordAction");at.recordAnalytics=nr;a(Qr,"recordActionBinary");Id=0,VD=1e3,$D="analytics-report",YD=[];a(pu,"addAnalyticsListener");KD=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(x3,"sendAnalytics");a(H3,"aggregation");UD=0,vD=0,WD=a(()=>new Promise(setImmediate),"rest");a(BD,"cleanup");G3=36e5,q3=31536e6;a(LS,"getRawAnalyticsTable");a(QD,"getAnalyticsTable");(0,FD.setChildListenerByType)($D,JD);a(F3,"startScheduledTasks");GD=0,qD=new Map,k3=!1;a(JD,"recordAnalytics");V3=1e6;a($3,"logAnalytics")});var BS=g(($fe,uL)=>{"use strict";var{decode:Y3}=require("msgpackr"),{isMainThread:Ffe,parentPort:kfe,threadId:Vfe}=require("worker_threads"),Md=ut(),_a=Ve(),US=P(),sr=$(),PS=ee(),K3=P(),{onMessageByType:W3}=Qe(),tL=Os(),{recordAction:jD,recordActionBinary:Q3}=(Ds(),ie(Su)),{publishToStream:z3}=Md,{ConsumerEvents:ZD}=require("nats"),J3=qr(),{promisify:X3}=require("util"),rL=X3(setTimeout),Pd=1e4,Ud,Ld,j3,Z3,nL,Tu=new Map,da=new Map;uL.exports={initialize:sL,ingestConsumer:vS,setSubscription:eX,setIgnoreOrigin:nX,getDatabaseSubscriptions:rX,updateConsumer:iL};async function sL(){W3(US.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await iL(n)}),nL=!0,sr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await Md.getNATSReferences();Ud=e,Ld=e.info.server_name,j3=t,Z3=r}a(sL,"initialize");async function iL(e){if(e.status==="start"){let{js:t,jsm:r}=await oL(e.node_domain_name);vS(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=Tu.get(e.stream_name+e.node_domain_name);t&&(sr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),Tu.set(e.stream_name+e.node_domain_name,"close")),da.get(e.node_domain_name)==="failed"&&da.set(e.node_domain_name,"close")}}a(iL,"updateConsumer");var vd=new Map;function eX(e,t,r){let n=vd.get(e);n||vd.set(e,n=new Map),n.set(t,r),nL||sL().then(tX)}a(eX,"setSubscription");async function tX(){let e=await J3.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+_a.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions)if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await oL(r),!n))break;let{schema:o,table:c}=i,u=tL.createNatsTableStreamName(o,c);vS(u,n,s,r)}}}a(tX,"accessConsumers");async function oL(e){let t,r,n=1;for(;!r;)try{t=await Ud.jetstream({domain:e}),r=await Ud.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(da.get(e)==="close")break;da.set(e,"failed"),n%10===1&&sr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<Pd?n++*100:Pd;await rL(i)}return{js:t,jsm:r}}a(oL,"connectToRemoteJS");function rX(){return vd}a(rX,"getDatabaseSubscriptions");var aL;function nX(e){aL=e}a(nX,"setIgnoreOrigin");var cL=100,eL=new Array(cL),Dd=0;async function vS(e,t,r,n){let{connection:s}=await Md.getNATSReferences();Ud=s,Ld=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,Ld),sr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(_){if(da.get(n)==="close")break;o%10===1&&sr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",_.message),_.code==="404"&&(sr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await Md.createConsumer(r,e,Ld,new Date(Date.now()).toISOString()));let l=o++*100<Pd?o++*100:Pd;await rL(l)}let c=!1,u;for(;!c;){if(Tu.get(e+n)==="close"||da.get(n)==="close"){Tu.delete(e+n),c=!0;continue}u=await i.consume({max_messages:PS.get(US.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),Tu.set(e+n,u);let _=!1;(async()=>{for await(let l of await u.status())if(l.type===ZD.ConsumerDeleted&&(await u.close(),c=!0),l.type===ZD.HeartbeatsMissed){let d=l.data;sr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${u.consumer.stream}`),d===100&&(sr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${u.consumer.stream}`),u.stop(),_=!0)}})();try{for await(let l of u)await eL[Dd],eL[Dd]=sX(l).catch(d=>{sr.error(d)}),++Dd>=cL&&(Dd=0)}catch(l){l.message==="consumer deleted"?(sr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",u.consumer.stream),await u.close(),c=!0):sr.error("Error consuming clustering ingest, restarting consumer",l)}}}a(vS,"ingestConsumer");async function sX(e){let t=Y3(e.data);jD(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),sr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=PS.get(US.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(_a.MSG_HEADERS.TRANSACTED_NODES)&&r.values(_a.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(_a.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!aL),Q3(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(_a.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:u,table:_,records:l,hash_values:d,__origin:E,expiresAt:f}=t;sr.trace("processing message:",o,c,_,(l?"records: "+l.map(B=>B?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),sr.trace(`messageProcessor nats msg id: ${e.headers.get(_a.MSG_HEADERS.NATS_MSG_ID)}`);let h;l||(l=d);let p=new Promise(B=>h=B),{timestamp:S,user:T,node_name:A}=E||{},y=vd.get(c)?.get(_);if(!y)throw new Error(`Missing table for replication message: ${_}`);if(o==="define_schema")t.type=o,t.onCommit=h,y.send(t);else if(l.length===1&&!u)y.send({type:MS(o),value:l[0],id:d?.[0],expiresAt:f,timestamp:S,table:_,onCommit:h,user:T,nodeName:A});else{let B=l.map((U,F)=>({type:MS(o),value:U,expiresAt:f,id:d?.[F],table:_}));for(;u;)B.push({type:MS(u.operation),value:u.record,expiresAt:u.expiresAt,id:u.id,table:u.table}),u=u.next;y.send({type:"transaction",writes:B,table:_,timestamp:S,onCommit:h,user:T,nodeName:A})}PS.get(K3.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&z3(e.subject.split(".").slice(0,-1).join("."),tL.createNatsTableStreamName(c,_),e.headers,e.data),await p;let I=Date.now()-S;S&&jD(I,"replication-latency",e.subject,o,"ingest")}catch(o){sr.error(o)}e.ack()}a(sX,"messageProcessor");function MS(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(MS,"convertOperation")});var ut=g((Xfe,NL)=>{"use strict";var Ht=ee();Ht.initSync();var iX=require("fs-extra"),oX=require("semver"),Au=require("path"),{monotonicFactory:aX}=require("ulidx"),_L=aX(),cX=require("util"),dL=require("child_process"),uX=cX.promisify(dL.exec),lX=dL.spawn,Wt=Ve(),Ie=P(),Bd=J(),xn=$(),xd=Os(),_X=Nd(),gu=pr(),{broadcast:dX,onMessageByType:fX,getWorkerIndex:EX}=Qe(),{isMainThread:fL}=require("worker_threads"),{Encoder:hX,decode:qS}=require("msgpackr"),EL=new hX,{isEmpty:lo}=Bd,hL=_n(),Kfe=48*36e11;fL&&fX(Ie.ITC_EVENT_TYPES.RESTART,()=>{ir=void 0,uo=void 0});var{connect:mX,StorageType:pX,RetentionPolicy:SX,AckPolicy:FS,DeliverPolicy:kS,DiscardPolicy:TX,NatsConnection:Wfe,JetStreamManager:Qfe,JetStreamClient:zfe,StringCodec:Jfe,JSONCodec:gX,createInbox:VS,headers:RX,ErrorCode:lL}=require("nats"),{PACKAGE_ROOT:AX}=P(),OX=fu(),{recordAction:bX}=(Ds(),ie(Su)),mL=gX(),yX="clustering",NX=OX.engines[Wt.NATS_SERVER_NAME],IX=Au.join(AX,"dependencies"),GS=Au.join(IX,`${process.platform}-${process.arch}`,Wt.NATS_BINARY_NAME),xS,HS,Ru,ao,co;NL.exports={runCommand:pL,checkNATSServerInstalled:wX,createConnection:$S,getConnection:Ou,getJetStreamManager:bu,getJetStream:TL,getNATSReferences:as,getServerList:DX,createLocalStream:YS,listStreams:gL,deleteLocalStream:LX,getServerConfig:fa,listRemoteStreams:MX,viewStream:PX,viewStreamIterator:UX,publishToStream:vX,request:HX,reloadNATS:KS,reloadNATSHub:GX,reloadNATSLeaf:qX,extractServerName:xX,requestErrorHandler:FX,createLocalTableStream:bL,createTableStreams:$X,purgeTableStream:yL,purgeSchemaTableStreams:YX,getStreamInfo:KX,updateLocalStreams:QX,closeConnection:CX,getJsmServerName:Hd,addNatsMsgHeader:RL,clearClientCache:SL,updateRemoteConsumer:kX,createConsumer:AL,updateConsumerIterator:VX};async function pL(e,t=void 0){let{stdout:r,stderr:n}=await uX(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
11
11
|
`,""));return r.replace(`
|
|
12
|
-
`,"")}a(mL,"runCommand");async function IX(){try{await sX.access(xS)}catch{return!1}let e=await mL(`${xS} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return iX.eq(t,yX)}a(IX,"checkNATSServerInstalled");async function kS(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await EL.getClusterUser();if(lo(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}xn.trace("create nats connection called");let i=await hX({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(),xn.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&xn.error("Error with Nats client connection, connection closed",o),i===ir&&pL()}),i}a(kS,"createConnection");function pL(){ir=void 0,ao=void 0,co=void 0,uo=void 0}a(pL,"clearClientCache");async function wX(){ir&&(await ir.drain(),ir=void 0,ao=void 0,co=void 0,uo=void 0)}a(wX,"closeConnection");var ir,uo;async function Au(){return uo||(uo=kS(Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),ir=await uo),ir||uo}a(Au,"getConnection");async function Ou(){if(ao)return ao;lo(ir)&&await Au();let{domain:e}=fa(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(lo(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ao=await ir.jetstreamManager({domain:e,timeout:6e4}),ao}a(Ou,"getJetStreamManager");async function SL(){if(co)return co;lo(ir)&&await Au();let{domain:e}=fa(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(lo(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return co=ir.jetstream({domain:e,timeout:6e4}),co}a(SL,"getJetStream");async function as(){let e=ir||await Au(),t=ao||await Ou(),r=co||await SL();return{connection:e,jsm:t,js:r}}a(as,"getNATSReferences");async function CX(e){let t=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await EL.getClusterUser(),s=await kS(t,r,n),i=FS(),o=s.subscribe(i),c=[],u,_=(async()=>{for await(let l of o){let d=hL.decode(l.data);d.response_time=Date.now()-u,c.push(d)}})();return u=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Bd.async_set_timeout(e),await o.drain(),await s.close(),await _,c}a(CX,"getServerList");async function VS(e,t){let{jsm:r}=await as(),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:mX.File,retention:pX.Limits,subjects:t,discard:SX.Old,max_msgs:s,max_bytes:i,max_age:n})}a(VS,"createLocalStream");async function TL(){let{jsm:e}=await as(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(TL,"listStreams");async function DX(e){let{jsm:t}=await as();await t.streams.delete(e)}a(DX,"deleteLocalStream");async function LX(e){let{connection:t}=await as(),r=[],n=FS(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(hL.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(LX,"listRemoteStreams");async function MX(e,t=void 0,r=void 0){let{jsm:n,js:s}=await as(),i=lL(),o={durable_name:i,ack_policy:GS.Explicit};t&&(o.deliver_policy=qS.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),u=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let _=[];for await(let l of u){let d=HS(l.data),E={nats_timestamp:l.info.timestampNanos,nats_sequence:l.info.streamSequence,entry:d};if(l.headers&&(E.origin=l.headers.get(Wt.MSG_HEADERS.ORIGIN)),_.push(E),l.ack(),l.info.pending===0)break}return await c.delete(),_}a(MX,"viewStream");async function*PX(e,t=void 0,r=void 0){let{jsm:n,js:s}=await as(),i=lL(),o={durable_name:i,ack_policy:GS.Explicit};t&&(o.deliver_policy=qS.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),u=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let _ of u){let l=HS(_.data);l[0]||(l=[l]);for(let d of l){let E={nats_timestamp:_.info.timestampNanos,nats_sequence:_.info.streamSequence,entry:d};_.headers&&(E.origin=_.headers.get(Wt.MSG_HEADERS.ORIGIN)),yield E}if(_.ack(),_.info.pending===0)break}await c.delete()}a(PX,"viewStreamIterator");async function UX(e,t,r,n){xn.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=gL(n,r);let{js:s}=await as(),i=await Hd(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:fL.encode(n);try{xn.trace(`publishToStream publishing to subject: ${o}`),OX(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(u){if(u.code&&u.code.toString()==="503")return AL(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(u.code&&u.code.toString()==="503"){xn.trace(`publishToStream creating stream: ${t}`);let l=o.split(".");l[2]="*",await VS(t,[o]),await s.publish(o,c,{headers:r})}else throw u}});throw u}}a(UX,"publishToStream");function gL(e,t){t===void 0&&(t=gX());let r=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Wt.MSG_HEADERS.ORIGIN)&&r&&t.append(Wt.MSG_HEADERS.ORIGIN,r),t}a(gL,"addNatsMsgHeader");function fa(e){e=e.toLowerCase();let t=Ru.join(Ht.get(Ie.CONFIG_PARAMS.ROOTPATH),bX);if(e===Ie.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return lo(BS)&&(BS={port:Tu.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:Tu.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wt.SERVER_SUFFIX.HUB,config_file:Wt.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:Ru.join(t,Wt.PID_FILES.HUB),hdb_nats_path:t}),BS;if(e===Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return lo(vS)&&(vS={port:Tu.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:Tu.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wt.SERVER_SUFFIX.LEAF,config_file:Wt.NATS_CONFIG_FILES.LEAF_SERVER,domain:Tu.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wt.SERVER_SUFFIX.LEAF,pid_file_path:Ru.join(t,Wt.PID_FILES.LEAF),hdb_nats_path:t}),vS;xn.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(fa,"getServerConfig");async function RL(e,t,r,n){try{await e.consumers.add(t,{ack_policy:GS.Explicit,durable_name:r,deliver_policy:qS.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(RL,"createConsumer");async function vX(e,t,r){await e.consumers.delete(t,r)}a(vX,"removeConsumer");function BX(e){return e.split(".")[1]}a(BX,"extractServerName");async function xX(e,t,r=6e4,n=FS()){if(!Bd.isObject(t))throw new Error("data param must be an object");let s=fL.encode(t),{connection:i}=await as(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return HS(c.data)}a(xX,"request");function $S(e){return new Promise(async(t,r)=>{let n=uX(xS,["--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($S,"reloadNATS");async function HX(){let{pid_file_path:e}=fa(Ie.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await $S(e)}a(HX,"reloadNATSHub");async function GX(){let{pid_file_path:e}=fa(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await $S(e)}a(GX,"reloadNATSLeaf");function qX(e,t,r){let n;switch(e.code){case uL.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case uL.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(qX,"requestErrorHandler");async function FX(e,t){let r=t+Wt.SERVER_SUFFIX.LEAF,{connection:n}=await as(),{jsm:s}=await zX(r),{schema:i,table:o}=e,c=xd.createNatsTableStreamName(i,o),u=e.start_time?e.start_time:new Date(Date.now()).toISOString();await AL(async()=>{if(e.subscribe===!0)await RL(s,c,n.info.server_name,u);else try{await vX(s,c,n.info.server_name)}catch(_){xn.trace(_)}})}a(FX,"updateRemoteConsumer");async function kX(e,t,r,n){let s=xd.createNatsTableStreamName(e,t),i=r+Wt.SERVER_SUFFIX.LEAF,o={type:Ie.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!dL&&fX()<Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=US();await c(o)}await _X(o),n==="stop"&&await Bd.async_set_timeout(1e3)}a(kX,"updateConsumerIterator");function AL(e){return lX.writeTransaction(Ie.SYSTEM_SCHEMA_NAME,Ie.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(AL,"exclusiveLock");async function OL(e,t){let r=xd.createNatsTableStreamName(e,t),n=await Hd(),s=KX(e,t,n);await VS(r,[s])}a(OL,"createLocalTableStream");async function VX(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await OL(n,s)}}a(VX,"createTableStreams");async function bL(e,t,r=void 0){if(Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=xd.createNatsTableStreamName(e,t),{domain:s}=fa(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await Au()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")xn.warn(n);else throw n}}a(bL,"purgeTableStream");async function $X(e,t){if(Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await bL(e,t[r])}a($X,"purgeSchemaTableStreams");async function YX(e){return(await Ou()).streams.info(e)}a(YX,"getStreamInfo");function KX(e,t,r){return`${Wt.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(KX,"createSubjectName");async function Hd(){if(gu)return gu;if(gu=(await Ou())?.nc?.info?.server_name,gu===void 0)throw new Error("Unable to get jetstream manager server name");return gu}a(Hd,"getJsmServerName");async function WX(){let e=await Ou(),t=await Hd(),r=await TL();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=QX(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let _=i.split(".");_[_.length-1]=t;let l=_.join(".");xn.trace(`Updating stream subject name from: ${i} to: ${l}`),s.subjects[0]=l,await e.streams.update(s.name,s)}}a(WX,"updateLocalStreams");function QX(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(QX,"updateStreamLimits");async function zX(e){let t,r;try{t=await ir.jetstream({domain:e}),r=await ir.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw xn.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(zX,"connectToRemoteJS")});var bu=g((jfe,CL)=>{"use strict";var Ea=H_(),ha=MD(),JX=$(),XX=require("uuid").v4,Xfe=require("clone"),qd=Ns(),ma=P(),jX=require("util"),Ei=Dn(),{handleHDBError:Rr,hdb_errors:ZX}=se(),{HDB_ERROR_MSGS:Gd,HTTP_STATUS_CODES:Ar}=ZX,{SchemaEventMsg:Fd}=Pn(),NL=ut(),{getDatabases:ej}=(Ae(),ie(ke)),{transformReq:pa}=J();CL.exports={createSchema:tj,createSchemaStructure:IL,createTable:rj,createTableStructure:wL,createAttribute:aj,dropSchema:nj,dropTable:sj,dropAttribute:ij,getBackup:cj};async function tj(e){let t=await IL(e);return qd.signalSchemaChange(new Fd(process.pid,e.operation,e.schema)),t}a(tj,"createSchema");async function IL(e){let t=Ea.schema_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);if(pa(e),!await ha.checkSchemaExists(e.schema))throw Rr(new Error,Gd.SCHEMA_EXISTS_ERR(e.schema),Ar.BAD_REQUEST,ma.LOG_LEVELS.ERROR,Gd.SCHEMA_EXISTS_ERR(e.schema),!0);return await Ei.createSchema(e),`database '${e.schema}' successfully created`}a(IL,"createSchemaStructure");async function rj(e){return pa(e),e.hash_attribute=e.primary_key??e.hash_attribute,await wL(e)}a(rj,"createTable");async function wL(e){let t=Ea.create_table_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);if(Ea.validateTableResidence(e.residence),!await ha.checkSchemaTableExists(e.schema,e.table))throw Rr(new Error,Gd.TABLE_EXISTS_ERR(e.schema,e.table),Ar.BAD_REQUEST,ma.LOG_LEVELS.ERROR,Gd.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:XX(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await Ei.createTable(n,e);else throw Rr(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Ar.BAD_REQUEST);else await Ei.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(wL,"createTableStructure");async function nj(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=Ea.schema_object(e),n=t??r;if(n)throw Rr(n,n.message,Ar.BAD_REQUEST,void 0,void 0,!0);pa(e);let s=await ha.checkSchemaExists(e.schema);if(s)throw Rr(new Error,s,Ar.NOT_FOUND,ma.LOG_LEVELS.ERROR,s,!0);let i=await ha.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);return await Ei.dropSchema(e),qd.signalSchemaChange(new Fd(process.pid,e.operation,e.schema)),await NL.purgeSchemaTableStreams(e.schema,o),`successfully deleted '${e.schema}'`}a(nj,"dropSchema");async function sj(e){let t=Ea.table_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);pa(e);let r=await ha.checkSchemaTableExists(e.schema,e.table);if(r)throw Rr(new Error,r,Ar.NOT_FOUND,ma.LOG_LEVELS.ERROR,r,!0);return await Ei.dropTable(e),await NL.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(sj,"dropTable");async function ij(e){let t=Ea.attribute_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);pa(e);let r=await ha.checkSchemaTableExists(e.schema,e.table);if(r)throw Rr(new Error,r,Ar.NOT_FOUND,ma.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Rr(new Error,"You cannot drop a hash attribute",Ar.BAD_REQUEST,void 0,void 0,!0);if(ma.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Rr(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Ar.BAD_REQUEST,void 0,void 0,!0);try{return await Ei.dropAttribute(e),oj(e),qd.signalSchemaChange(new Fd(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw JX.error(`Got an error deleting attribute ${jX.inspect(e)}.`),n}}a(ij,"dropAttribute");function oj(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(oj,"dropAttributeFromGlobal");async function aj(e){pa(e);let t=ej()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Rr(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Ar.BAD_REQUEST,void 0,void 0,!0);return await Ei.createAttribute(e),qd.signalSchemaChange(new Fd(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(aj,"createAttribute");function cj(e){return Ei.getBackup(e)}a(cj,"getBackup")});var LL=g((eEe,DL)=>{"use strict";var{OPERATIONS_ENUM:uj}=P(),YS=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=uj.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};DL.exports=YS});var KS=g((nEe,BL)=>{"use strict";var lj=Dn(),rEe=LL(),kd=J(),Vd=P(),_j=ee(),{handleHDBError:ML,hdb_errors:dj}=se(),{HDB_ERROR_MSGS:PL,HTTP_STATUS_CODES:UL}=dj,fj=Object.values(Vd.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),vL="To use this operation audit log must be enabled in harperdb-config.yaml";BL.exports=Ej;async function Ej(e){if(kd.isEmpty(e.schema))throw new Error(PL.SCHEMA_REQUIRED_ERR);if(kd.isEmpty(e.table))throw new Error(PL.TABLE_REQUIRED_ERR);if(!_j.get(Vd.CONFIG_PARAMS.LOGGING_AUDITLOG))throw ML(new Error,vL,UL.BAD_REQUEST,Vd.LOG_LEVELS.ERROR,vL,!0);let t=kd.checkSchemaTableExist(e.schema,e.table);if(t)throw ML(new Error,t,UL.NOT_FOUND,Vd.LOG_LEVELS.ERROR,t,!0);if(!kd.isEmpty(e.search_type)&&fj.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await lj.readAuditLog(e)}a(Ej,"readAuditLog")});var HL=g((iEe,xL)=>{"use strict";var{OPERATIONS_ENUM:hj}=P(),WS=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=hj.GET_BACKUP,this.schema=t,this.table=r}};xL.exports=WS});var FL=g((uEe,qL)=>{"use strict";var mj=Dn(),aEe=HL(),QS=J(),pj=P(),cEe=ee(),{handleHDBError:Sj,hdb_errors:Tj}=se(),{HDB_ERROR_MSGS:GL,HTTP_STATUS_CODES:gj}=Tj;qL.exports=Rj;async function Rj(e){if(QS.isEmpty(e.schema))throw new Error(GL.SCHEMA_REQUIRED_ERR);if(QS.isEmpty(e.table))throw new Error(GL.TABLE_REQUIRED_ERR);let t=QS.checkSchemaTableExist(e.schema,e.table);if(t)throw Sj(new Error,t,gj.NOT_FOUND,pj.LOG_LEVELS.ERROR,t,!0);return await mj.getBackup(read_audit_log_object)}a(Rj,"getBackup")});var WL=g((_Ee,KL)=>{var hi=require("validate.js"),VL=je(),Sa=P(),{handleHDBError:Aj,hdb_errors:Oj}=se(),{HDB_ERROR_MSGS:mt,HTTP_STATUS_CODES:bj}=Oj,zS=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),yj={STRUCTURE_USER:"structure_user"},kL=Object.values(Sa.ROLE_TYPES_ENUM),Nj="attribute_permissions",Ij="attribute_name",{PERMS_CRUD_ENUM:Ta}=Sa,wj=[Nj,...Object.values(Ta)],$L=[Ta.READ,Ta.INSERT,Ta.UPDATE],Cj=[Ij,...$L];function Dj(e){let t=zS();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,YL(e,t)}a(Dj,"addRoleValidation");function Lj(e){let t=zS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,YL(e,t)}a(Lj,"alterRoleValidation");function Mj(e){let t=zS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,VL.validateObject(e,t)}a(Mj,"dropRoleValidation");var Pj=["operation","role","id","permission","hdb_user","hdb_auth_header"];function YL(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)Pj.includes(n[o])||s.push(n[o]);s.length>0&&At(mt.INVALID_ROLE_JSON_KEYS(s),r);let i=VL.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{At(o,r)}),e.permission){let o=Uj(e);o&&At(o,r),kL.forEach(c=>{e.permission[c]&&!hi.isBoolean(e.permission[c])&&At(mt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(kL.indexOf(o)<0){if(o===yj.STRUCTURE_USER){let u=e.permission[o];if(typeof u=="boolean")continue;if(Array.isArray(u)){for(let _=0,l=u.length;_<l;_++){let d=u[_];global.hdb_schema[d]||At(mt.SCHEMA_NOT_FOUND(d),r)}continue}At(mt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){At(mt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let u in c.tables){let _=c.tables[u];if(!u||!global.hdb_schema[o][u]){At(mt.TABLE_NOT_FOUND(o,u),r);continue}if(Object.keys(_).forEach(l=>{wj.includes(l)||At(mt.INVALID_PERM_KEY(l),r,o,u)}),Object.values(Ta).forEach(l=>{hi.isDefined(_[l])?hi.isBoolean(_[l])||At(mt.TABLE_PERM_NOT_BOOLEAN(l),r,o,u):At(mt.TABLE_PERM_MISSING(l),r,o,u)}),hi.isDefined(_.attribute_permissions)){if(!hi.isArray(_.attribute_permissions)){At(mt.ATTR_PERMS_NOT_ARRAY,r,o,u);continue}}else{At(mt.ATTR_PERMS_ARRAY_MISSING,r,o,u);continue}if(_.attribute_permissions){let l=global.hdb_schema[o][u].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=>{!Cj.includes(p)&&p!==Ta.DELETE&&At(mt.INVALID_ATTR_PERM_KEY(p),r,o,u)}),!hi.isDefined(f.attribute_name)){At(mt.ATTR_PERM_MISSING_NAME,r,o,u);continue}let h=f.attribute_name;if(!l.includes(h)){At(mt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,u);continue}$L.forEach(p=>{hi.isDefined(f[p])?hi.isBoolean(f[p])||At(mt.ATTR_PERM_NOT_BOOLEAN(p,h),r,o,u):At(mt.ATTR_PERM_MISSING(p,h),r,o,u)}),!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}.${u}`;At(mt.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,u)}}}}return vj(r)}a(YL,"customValidate");KL.exports={addRoleValidation:Dj,alterRoleValidation:Lj,dropRoleValidation:Mj};function Uj(e){let{operation:t,permission:r}=e;if(t===Sa.OPERATIONS_ENUM.ADD_ROLE||t===Sa.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 mt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Sa.ROLE_TYPES_ENUM.SUPER_USER:Sa.ROLE_TYPES_ENUM.CLUSTER_USER;return mt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(Uj,"validateNoSUPerms");function vj(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:mt.ROLE_PERMS_ERROR,...e};return Aj(new Error,n,bj.BAD_REQUEST)}else return null}a(vj,"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 tT=g((fEe,XL)=>{"use strict";var QL=Fr(),zL=qr(),Bj=ci(),XS=WL(),jS=Ns(),xj=require("uuid").v4,Hj=require("util"),$d=P(),Gj=J(),ZS=zL.searchByValue,qj=zL.searchByHash,Fj=Hj.promisify(Bj.delete),kj=ns(),Vj=oa(),{hdb_errors:$j,handleHDBError:_o}=se(),{HDB_ERROR_MSGS:JL,HTTP_STATUS_CODES:yu}=$j,{UserEventMsg:eT}=Pn();XL.exports={addRole:Yj,alterRole:Kj,dropRole:Wj,listRoles:Qj};function JS(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(JS,"scrubRoleDetails");async function Yj(e){let t=XS.addRoleValidation(e);if(t)throw t;e=JS(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 ZS(r)||[])}catch(i){throw _o(i)}if(n&&n.length>0)throw _o(new Error,JL.ROLE_ALREADY_EXISTS(e.role),yu.CONFLICT,void 0,void 0,!0);e.id||(e.id=xj());let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await QL.insert(s),jS.signalUserChange(new eT(process.pid)),e=JS(e),e}a(Yj,"addRole");async function Kj(e){let t=XS.alterRoleValidation(e);if(t)throw t;e=JS(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await QL.update(r)}catch(s){throw _o(s)}if(n&&n?.message==="updated 0 of 1 records")throw _o(new Error,"Invalid role id",yu.BAD_REQUEST,void 0,void 0,!0);return await jS.signalUserChange(new eT(process.pid)),e}a(Kj,"alterRole");async function Wj(e){let t=XS.dropRoleValidation(e);if(t)throw _o(new Error,t,yu.BAD_REQUEST,void 0,void 0,!0);let r=new Vj($d.SYSTEM_SCHEMA_NAME,$d.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await qj(r));if(n.length===0)throw _o(new Error,JL.ROLE_NOT_FOUND,yu.NOT_FOUND,void 0,void 0,!0);let s=new kj($d.SYSTEM_SCHEMA_NAME,$d.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await ZS(s)),o=!1;if(Gj.isEmptyOrZeroLength(i)===!1){for(let u=0;u<i.length;u++)if(i[u].active===!0){o=!0;break}}if(o===!0)throw _o(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,yu.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Fj(c),jS.signalUserChange(new eT(process.pid)),`${n[0].role} successfully deleted`}a(Wj,"dropRole");async function Qj(){return ZS({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Qj,"listRoles")});var tM=g((hEe,eM)=>{"use strict";var zj=ee(),mi=require("joi"),Jj=je(),jL=require("moment"),Xj=require("fs-extra"),rT=require("path"),jj=require("lodash"),Nu=P(),{LOG_LEVELS:fo}=P(),Zj="YYYY-MM-DD hh:mm:ss",eZ=rT.resolve(__dirname,"../logs");eM.exports=function(e){return Jj.validateBySchema(e,tZ)};var tZ=mi.object({from:mi.custom(ZL),until:mi.custom(ZL),level:mi.valid(fo.NOTIFY,fo.FATAL,fo.ERROR,fo.WARN,fo.INFO,fo.DEBUG,fo.TRACE),order:mi.valid("asc","desc"),limit:mi.number().min(1),start:mi.number().min(0),log_name:mi.custom(rZ)});function ZL(e,t){if(jL(e,jL.ISO_8601).format(Zj)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(ZL,"validateDatetime");function rZ(e,t){if(jj.invert(Nu.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=zj.get(Nu.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Nu.LOG_NAMES.HDB:e,i=s===Nu.LOG_NAMES.INSTALL?rT.join(eZ,Nu.LOG_NAMES.INSTALL):rT.join(n,s);return Xj.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(rZ,"validateReadLogPath")});var sT=g((pEe,nM)=>{"use strict";var Yd=P(),nZ=$(),sZ=ee(),iZ=tM(),nT=require("path"),rM=require("fs-extra"),{once:oZ}=require("events"),{handleHDBError:aZ,hdb_errors:cZ}=se(),{PACKAGE_ROOT:uZ}=P(),lZ=nT.join(uZ,"logs"),_Z=1e3,dZ=200;nM.exports=fZ;async function fZ(e){let t=iZ(e);if(t)throw aZ(t,t.message,cZ.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=sZ.get(Yd.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?Yd.LOG_NAMES.HDB:e.log_name,s=n===Yd.LOG_NAMES.INSTALL?nT.join(lZ,Yd.LOG_NAMES.INSTALL):nT.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,u=c?new Date(e.from):void 0,_=e.until!==void 0,l=_?new Date(e.until):void 0,d=e.limit===void 0?_Z: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"&&!u&&!l&&(p=Math.max(rM.statSync(s).size-(h+5)*dZ,0));let S=rM.createReadStream(s,{start:p});S.on("error",U=>{nZ.error(U)});let T=0,A=[],b="",I;S.on("data",U=>{let F=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;U=b+U;let M=0,Q;for(;(Q=F.exec(U))&&!S.destroyed;){I&&(I.message=U.slice(M,Q.index),B(I));let[z,j,oe]=Q,ue=oe.split("] ["),le=ue[0],Be=ue[1];ue.splice(0,2),I={timestamp:j,thread:le,level:Be,tags:ue,message:""},M=Q.index+z.length}b=U.slice(M)}),S.on("end",U=>{S.destroyed||I&&(I.message=b.trim(),B(I))}),S.resume();function B(U){let F,M,Q;switch(!0){case(i&&c&&_):F=new Date(U.timestamp),M=new Date(u),Q=new Date(l),U.level===o&&F>=M&&F<=Q&&T<f?T++:U.level===o&&F>=M&&F<=Q&&(pi(U,E,A),T++,T===h&&S.destroy());break;case(i&&c):F=new Date(U.timestamp),M=new Date(u),U.level===o&&F>=M&&T<f?T++:U.level===o&&F>=M&&(pi(U,E,A),T++,T===h&&S.destroy());break;case(i&&_):F=new Date(U.timestamp),Q=new Date(l),U.level===o&&F<=Q&&T<f?T++:U.level===o&&F<=Q&&(pi(U,E,A),T++,T===h&&S.destroy());break;case(c&&_):F=new Date(U.timestamp),M=new Date(u),Q=new Date(l),F>=M&&F<=Q&&T<f?T++:F>=M&&F<=Q&&(pi(U,E,A),T++,T===h&&S.destroy());break;case i:U.level===o&&T<f?T++:U.level===o&&(pi(U,E,A),T++,T===h&&S.destroy());break;case c:F=new Date(U.timestamp),M=new Date(u),F>=M&&T<f?T++:F>=M&&T>=f&&(pi(U,E,A),T++,T===h&&S.destroy());break;case _:F=new Date(U.timestamp),Q=new Date(l),F<=Q&&T<f?T++:F<=Q&&T>=f&&(pi(U,E,A),T++,T===h&&S.destroy());break;default:T<f?T++:(pi(U,E,A),T++,T===h&&S.destroy())}}return a(B,"onLogMessage"),await oZ(S,"close"),A}a(fZ,"readLog");function pi(e,t,r){t==="desc"?EZ(e,r):t==="asc"?hZ(e,r):r.push(e)}a(pi,"pushLineToResult");function EZ(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(EZ,"insertDescending");function hZ(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(hZ,"insertAscending")});var Kd=g((AEe,aM)=>{"use strict";var iT=require("joi"),{string:Iu,boolean:sM,date:mZ}=iT.types(),pZ=je(),{validateSchemaExists:TEe,validateTableExists:gEe,validateSchemaName:REe}=jn(),SZ=P(),TZ=Ve(),iM=ee();iM.initSync();var gZ=Iu.invalid(iM.get(SZ.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(TZ.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(),oM={operation:Iu.valid("add_node","update_node","set_node_replication"),node_name:gZ,subscriptions:iT.array().items({table:Iu.optional(),schema:Iu.optional(),database:Iu.optional(),subscribe:sM.required(),publish:sM.required().custom(AZ),start_time:mZ.iso()}).min(1).required()};function RZ(e){return pZ.validateBySchema(e,iT.object(oM))}a(RZ,"addUpdateNodeValidator");function AZ(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(AZ,"checkForFalsy");aM.exports={addUpdateNodeValidator:RZ,validation_schema:oM}});var uM=g((bEe,cM)=>{var OZ=je(),bZ={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};cM.exports=function(e){return OZ.validateObject(e,bZ)}});var Wd=g((yEe,lM)=>{"use strict";var yZ=P().OPERATIONS_ENUM,oT=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=yZ.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};lM.exports=oT});var dM=g((IEe,_M)=>{"use strict";var NZ={OPERATION:"operation",REFRESH:"refresh"},aT=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},cT=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};_M.exports={JWTTokens:aT,TOKEN_TYPE_ENUM:NZ,JWTRSAKeys:cT}});var Du=g((CEe,mM)=>{"use strict";var Cu=require("jsonwebtoken"),uT=require("fs-extra"),lT=J(),dn=P(),{handleHDBError:Or,hdb_errors:IZ}=se(),{HTTP_STATUS_CODES:br,AUTHENTICATION_ERROR_MSGS:yr}=IZ,wu=$(),fM=z_(),fT=_n(),wZ=Fr().update,CZ=Wd(),DZ=Ns(),{UserEventMsg:LZ}=Pn(),Si=ee();Si.initSync();var _T=require("path"),{JWTTokens:MZ,JWTRSAKeys:PZ,TOKEN_TYPE_ENUM:Qd}=dM(),UZ=Si.get(dn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?Si.get(dn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",vZ=Si.get(dn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?Si.get(dn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",zd="RS256",dT;mM.exports={createTokens:BZ,validateOperationToken:HZ,refreshOperationToken:xZ,validateRefreshToken:hM};async function BZ(e){if(lT.isEmpty(e)||typeof e!="object")throw Or(new Error,yr.INVALID_AUTH_OBJECT,br.BAD_REQUEST,void 0,void 0,!0);if(lT.isEmpty(e.username))throw Or(new Error,yr.USERNAME_REQUIRED,br.BAD_REQUEST,void 0,void 0,!0);if(lT.isEmpty(e.password))throw Or(new Error,yr.PASSWORD_REQUIRED,br.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await fT.findAndValidateUser(e.username,e.password),!t)throw Or(new Error,yr.INVALID_CREDENTIALS,br.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw wu.error(E),Or(new Error,yr.INVALID_CREDENTIALS,br.UNAUTHORIZED,void 0,void 0,!0)}let r=await Jd(),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 Cu.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:vZ,algorithm:zd,subject:Qd.REFRESH}),u=fM.hash(c),_=new CZ(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]),l,d;try{l=await wZ(_)}catch(E){wu.error(E),d=E}if(d!==void 0||l.skipped_hashes.length>0)throw Or(new Error,yr.REFRESH_TOKEN_SAVE_FAILED,br.INTERNAL_SERVER_ERROR);return DZ.signalUserChange(new LZ(process.pid)),new MZ(o,c)}a(BZ,"createTokens");async function EM(e,t,r){return await Cu.sign(e,{key:t,passphrase:r},{expiresIn:UZ,algorithm:zd,subject:Qd.OPERATION})}a(EM,"signOperationToken");async function Jd(){if(dT===void 0)try{let e=_T.join(Si.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PASSPHRASE_NAME),t=_T.join(Si.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=_T.join(Si.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await uT.readFile(e)).toString(),s=(await uT.readFile(t)).toString(),i=(await uT.readFile(r)).toString();dT=new PZ(i,s,n)}catch(e){throw wu.error(e),Or(new Error,yr.NO_ENCRYPTION_KEYS,br.INTERNAL_SERVER_ERROR)}return dT}a(Jd,"getJWTRSAKeys");async function xZ(e){if(!e)throw Or(new Error,yr.INVALID_BODY,br.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw Or(new Error,yr.REFRESH_TOKEN_REQUIRED,br.BAD_REQUEST,void 0,void 0,!0);await hM(e.refresh_token);let t=await Jd(),r=await Cu.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(xZ,"refreshOperationToken");async function HZ(e){try{let t=await Jd(),r=await Cu.verify(e,t.public_key,{algorithms:zd,subject:Qd.OPERATION});return await fT.findAndValidateUser(r.username,void 0,!1)}catch(t){throw wu.warn(t),t.name&&t.name==="TokenExpiredError"?Or(new Error,yr.TOKEN_EXPIRED,br.FORBIDDEN):Or(new Error,yr.INVALID_TOKEN,br.UNAUTHORIZED)}}a(HZ,"validateOperationToken");async function hM(e){let t;try{let r=await Jd(),n=await Cu.verify(e,r.public_key,{algorithms:zd,subject:Qd.REFRESH});t=await fT.findAndValidateUser(n.username,void 0,!1)}catch(r){throw wu.warn(r),r.name&&r.name==="TokenExpiredError"?Or(new Error,yr.TOKEN_EXPIRED,br.FORBIDDEN):Or(new Error,yr.INVALID_TOKEN,br.UNAUTHORIZED)}if(!fM.validate(t.refresh_token,e))throw Or(new Error,yr.INVALID_TOKEN,br.UNAUTHORIZED);return t}a(hM,"validateRefreshToken")});var ET=g((MEe,TM)=>{"use strict";var GZ=uM(),ga=require("passport"),qZ=require("passport-local").Strategy,FZ=require("passport-http").BasicStrategy,kZ=require("util"),VZ=_n(),SM=kZ.callbackify(VZ.findAndValidateUser),LEe=vr(),$Z=P(),pM=Du();ga.use(new qZ(function(e,t,r){SM(e,t,r)}));ga.use(new FZ(function(e,t,r){SM(e,t,r)}));ga.serializeUser(function(e,t){t(null,e)});ga.deserializeUser(function(e,t){t(null,e)});function YZ(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":ga.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===$Z.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?pM.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):pM.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:ga.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(YZ,"authorize");function KZ(e,t){let r=GZ(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(KZ,"checkPermissions");TM.exports={authorize:YZ,checkPermissions:KZ}});var Ti=g((UEe,gM)=>{"use strict";var hT=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},mT=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};gM.exports={Node:hT,NodeSubscription:mT}});var AM=g((BEe,RM)=>{"use strict";var WZ=P().OPERATIONS_ENUM,pT=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=WZ.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};RM.exports=pT});var Lu=g((HEe,OM)=>{"use strict";var ST=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},TT=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)}};OM.exports={RemotePayloadObject:ST,RemotePayloadSubscription:TT}});var yM=g((qEe,bM)=>{"use strict";var gT=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}};bM.exports=gT});var wM=g((YEe,IM)=>{"use strict";var QZ=yM(),kEe=ft(),NM=ze(),zZ=$(),{getSchemaPath:VEe,getTransactionAuditStorePath:$Ee}=Xe(),{getDatabases:JZ}=(Ae(),ie(ke));IM.exports=XZ;async function XZ(e){let t=new QZ;try{let r=JZ()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats(),i=await NM.environmentDataSize(schema_path,e.name),o=await NM.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){zZ.warn(`unable to stat table dbi due to ${r}`)}return t}a(XZ,"lmdbGetTableSize")});var DM=g((WEe,CM)=>{"use strict";var RT=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}};CM.exports=RT});var Ra=g((ZEe,UM)=>{"use strict";var jZ=require("fs-extra"),ZZ=require("path"),or=require("systeminformation"),gi=$(),LM=ut(),zEe=Ve(),jd=P(),e5=wM(),t5=bs(),{getThreadInfo:MM}=Qe(),MT=ee();MT.initSync();var r5=DM(),{openEnvironment:JEe}=ze(),{getSchemaPath:XEe}=Xe(),{database:jEe,databases:AT}=(Ae(),ie(ke)),Xd;UM.exports={getHDBProcessInfo:NT,getNetworkInfo:wT,getDiskInfo:IT,getMemoryInfo:yT,getCPUInfo:bT,getTimeInfo:OT,getSystemInformation:CT,systemInformation:n5,getTableSize:DT,getMetrics:LT};function OT(){return or.time()}a(OT,"getTimeInfo");async function bT(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:u,cache:_,...l}=await or.cpu();l.cpu_speed=await or.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,...A}=await or.currentLoad();return A.cpus=[],T.forEach(b=>{let{raw_load:I,raw_load_idle:B,raw_load_irq:U,raw_load_nice:F,raw_load_system:M,raw_load_user:Q,...z}=b;A.cpus.push(z)}),l.current_load=A,l}catch(e){return gi.error(`error in getCPUInfo: ${e}`),{}}}a(bT,"getCPUInfo");async function yT(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await or.mem();return Object.assign(s,process.memoryUsage())}catch(e){return gi.error(`error in getMemoryInfo: ${e}`),{}}}a(yT,"getMemoryInfo");async function NT(){let e={core:[],clustering:[]};try{let t=await or.processes(),r;try{r=Number.parseInt(await jZ.readFile(ZZ.join(MT.get(jd.CONFIG_PARAMS.ROOTPATH),jd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===jd.NODE_ERROR_CODES.ENOENT)gi.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 gi.error(`error in getHDBProcessInfo: ${t}`),e}}a(NT,"getHDBProcessInfo");async function IT(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await or.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:u,..._}=await or.fsStats();return e.read_write=_,e.size=await or.fsSize(),e}catch(t){return gi.error(`error in getDiskInfo: ${t}`),e}}a(IT,"getDiskInfo");async function wT(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await or.networkInterfaceDefault(),e.latency=await or.inetChecksite("google.com"),(await or.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:u,ieee8021xAuth:_,ieee8021xState:l,carrier_changes:d,...E}=n;e.interfaces.push(E)}),(await or.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)}),e}catch(t){return gi.error(`error in getNetworkInfo: ${t}`),e}}a(wT,"getNetworkInfo");async function CT(){if(Xd!==void 0)return Xd;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await or.osInfo();e=c;let u=await or.versions("node, npm");return e.node_version=u.node,e.npm_version=u.npm,Xd=e,Xd}catch(t){return gi.error(`error in getSystemInformation: ${t}`),e}}a(CT,"getSystemInformation");async function DT(){let e=[],t=await t5.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await e5(n));return e}a(DT,"getTableSize");async function LT(){let e={};for(let t in AT){let r=e[t]={},n=r.tables={};for(let s in AT[t])try{let i=AT[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(u=>{let[_,l,d]=u.trim().split(" ");return{pid:_,thread:l,txnid:d}}),i.primaryStore.auditStore&&(r.audit=i.auditStore.getStats()));let o=i.primaryStore.getStats(),c={};for(let u of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[u]=o[u];n[s]=c}catch(i){gi.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(LT,"getMetrics");async function PM(){if(MT.get(jd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await LM.getNATSReferences(),t=await LM.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(PM,"getNatsStreamInfo");async function n5(e){let t=new r5;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await CT(),t.time=OT(),t.cpu=await bT(),t.memory=await yT(),t.disk=await IT(),t.network=await wT(),t.harperdb_processes=await NT(),t.table_size=await DT(),t.metrics=await LT(),t.threads=await MM(),t.replication=await PM(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await CT();break;case"time":t.time=OT();break;case"cpu":t.cpu=await bT();break;case"memory":t.memory=await yT();break;case"disk":t.disk=await IT();break;case"network":t.network=await wT();break;case"harperdb_processes":t.harperdb_processes=await NT();break;case"table_size":t.table_size=await DT();break;case"database_metrics":case"metrics":t.metrics=await LT();break;case"threads":t.threads=await MM();break;case"replication":t.replication=await PM();break;default:break}return t}a(n5,"systemInformation")});var ef=g((the,vM)=>{"use strict";vM.exports={version:s5,printVersion:i5};var Zd=du();function s5(){if(Zd)return Zd.version}a(s5,"version");function i5(){Zd&&console.log(`HarperDB Version ${Zd.version}`)}a(i5,"printVersion")});var fn=g((ihe,GM)=>{"use strict";var o5=Fr(),PT=J(),a5=require("util"),Eo=P(),BM=ee();BM.initSync();var c5=ET(),xM=qr(),{Node:nhe,NodeSubscription:she}=Ti(),u5=oa(),l5=AM(),{RemotePayloadObject:_5,RemotePayloadSubscription:d5}=Lu(),{handleHDBError:f5,hdb_errors:E5}=se(),{HTTP_STATUS_CODES:h5,HDB_ERROR_MSGS:m5}=E5,p5=ns(),S5=Ra(),T5=ef(),{getDatabases:g5}=(Ae(),ie(ke)),R5=a5.promisify(c5.authorize),A5=xM.searchByHash,O5=xM.searchByValue;GM.exports={authHeaderToUser:b5,isEmpty:y5,getNodeRecord:N5,upsertNodeRecord:I5,buildNodePayloads:w5,checkClusteringEnabled:C5,getAllNodeRecords:D5,getSystemInfo:L5,reverseSubscription:HM};async function b5(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await R5(t,null),e}a(b5,"authHeaderToUser");function y5(e){return e==null}a(y5,"isEmpty");async function N5(e){let t=new u5(Eo.SYSTEM_SCHEMA_NAME,Eo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return A5(t)}a(N5,"getNodeRecord");async function I5(e){let t=new l5(Eo.SYSTEM_SCHEMA_NAME,Eo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return o5.upsert(t)}a(I5,"upsertNodeRecord");function HM(e){if(PT.isEmpty(e.subscribe)||PT.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(HM,"reverseSubscription");function w5(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:u,table:_}=c,l=PT.getTableHashAttribute(u,_),{subscribe:d,publish:E}=HM(c),f=g5()[u]?.[_],h=new d5(u,_,l,E,d,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new _5(r,t,s,n)}a(w5,"buildNodePayloads");function C5(){if(!BM.get(Eo.CONFIG_PARAMS.CLUSTERING_ENABLED))throw f5(new Error,m5.CLUSTERING_NOT_ENABLED,h5.BAD_REQUEST,void 0,void 0,!0)}a(C5,"checkClusteringEnabled");async function D5(){let e=new p5(Eo.SYSTEM_SCHEMA_NAME,Eo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await O5(e))}a(D5,"getAllNodeRecords");async function L5(){let e=await S5.getSystemInformation();return{hdb_version:T5.version(),node_version:e.node_version,platform:e.platform}}a(L5,"getSystemInfo")});var UT=g((ahe,WM)=>{"use strict";var tf=ut(),qM=J(),FM=Ve(),kM=P(),rf=$(),VM=bu(),M5=md(),{RemotePayloadObject:P5}=Lu(),{handleHDBError:$M,hdb_errors:U5}=se(),{HTTP_STATUS_CODES:YM}=U5,{NodeSubscription:KM}=Ti();WM.exports=v5;async function v5(e,t){let r;try{r=await tf.request(`${t}.${FM.REQUEST_SUFFIX}`,new P5(kM.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),rf.trace("Response from remote describe all request:",r)}catch(o){rf.error(`addNode received error from describe all request to remote node: ${o}`);let c=tf.requestErrorHandler(o,"add_node",t);throw $M(new Error,c,YM.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===FM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw $M(new Error,o,YM.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,u=o.database??o.schema??"data";if(u===kM.SYSTEM_SCHEMA_NAME){await tf.createLocalTableStream(u,c);let h=new KM(u,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let _=qM.doesSchemaExist(u),l=n[u]!==void 0,d=c?qM.doesTableExist(u,c):!0,E=c?n?.[u]?.[c]!==void 0:!0;if(!_&&!l||!d&&!E){s.push(o);continue}if(!_&&l&&(rf.trace(`addNode creating schema: ${u}`),await VM.createSchema({operation:"create_schema",schema:u})),!d&&E){rf.trace(`addNode creating table: ${c} in schema: ${u} with attributes ${JSON.stringify(n[u][c].attributes)}`);let h=new M5(u,c,n[u][c].hash_attribute);n[u][c].attributes&&(h.attributes=n[u][c].attributes),await VM.createTable(h)}await tf.createLocalTableStream(u,c);let f=new KM(u,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(v5,"reviewSubscriptions")});var af=g((uhe,JM)=>{"use strict";var{handleHDBError:nf,hdb_errors:B5}=se(),{HTTP_STATUS_CODES:sf}=B5,{addUpdateNodeValidator:x5}=Kd(),of=$(),zM=P(),QM=Ve(),H5=J(),Mu=ut(),Pu=fn(),G5=ee(),q5=UT(),{Node:F5,NodeSubscription:k5}=Ti(),{broadcast:V5}=Qe(),$5="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Y5="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",K5=G5.get(zM.CONFIG_PARAMS.CLUSTERING_NODENAME);JM.exports=W5;async function W5(e,t=!1){of.trace("addNode called with:",e),Pu.checkClusteringEnabled();let r=x5(e);if(r)throw nf(r,r.message,sf.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await Pu.getNodeRecord(n);if(!H5.isEmptyOrZeroLength(d))throw nf(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,sf.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await q5(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=$5,o;let c=Pu.buildNodePayloads(s,K5,zM.OPERATIONS_ENUM.ADD_NODE,await Pu.getSystemInfo()),u=[];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,u.push(new k5(f.schema,f.table,f.publish,f.subscribe))}of.trace("addNode sending remote payload:",c);let _;try{_=await Mu.request(`${n}.${QM.REQUEST_SUFFIX}`,c)}catch(d){of.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 Mu.updateRemoteConsumer(p,n)}let E=Mu.requestErrorHandler(d,"add_node",n);throw nf(new Error,E,sf.INTERNAL_SERVER_ERROR,"error",E)}if(_.status===QM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${_.message}`;throw nf(new Error,d,sf.INTERNAL_SERVER_ERROR,"error",d)}of.trace(_);for(let d=0,E=s.length;d<E;d++){let f=s[d];await Mu.updateRemoteConsumer(f,n),f.subscribe===!0&&await Mu.updateConsumerIterator(f.schema,f.table,n,"start")}let l=new F5(n,u,_.system_info);return await Pu.upsertNodeRecord(l),V5({type:"nats_update"}),i.length>0?o.message=Y5:o.message=`Successfully added '${n}' to manifest`,o}a(W5,"addNode")});var xT=g((dhe,ZM)=>{"use strict";var{handleHDBError:vT,hdb_errors:Q5}=se(),{HTTP_STATUS_CODES:BT}=Q5,{addUpdateNodeValidator:z5}=Kd(),Uu=$(),jM=P(),XM=Ve(),_he=J(),vu=ut(),Bu=fn(),J5=ee(),{cloneDeep:X5}=require("lodash"),j5=UT(),{Node:Z5,NodeSubscription:e8}=Ti(),{broadcast:t8}=Qe(),r8="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",n8="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",s8=J5.get(jM.CONFIG_PARAMS.CLUSTERING_NODENAME);ZM.exports=i8;async function i8(e){Uu.trace("updateNode called with:",e),Bu.checkClusteringEnabled();let t=z5(e);if(t)throw vT(t,t.message,BT.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Bu.getNodeRecord(r);s.length>0&&(n=X5(s));let{added:i,skipped:o}=await j5(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=r8,c;let u=Bu.buildNodePayloads(i,s8,jM.OPERATIONS_ENUM.UPDATE_NODE,await Bu.getSystemInfo());for(let l=0,d=i.length;l<d;l++){let E=i[l];Uu.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[l].start_time===void 0&&delete i[l].start_time}Uu.trace("updateNode sending remote payload:",u);let _;try{_=await vu.request(`${r}.${XM.REQUEST_SUFFIX}`,u)}catch(l){Uu.error(`updateNode received error from request: ${l}`);let d=vu.requestErrorHandler(l,"update_node",r);throw vT(new Error,d,BT.INTERNAL_SERVER_ERROR,"error",d)}if(_.status===XM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let l=`Error returned from remote node ${r}: ${_.message}`;throw vT(new Error,l,BT.INTERNAL_SERVER_ERROR,"error",l)}Uu.trace(_);for(let l=0,d=i.length;l<d;l++){let E=i[l];await vu.updateRemoteConsumer(E,r),E.subscribe===!0?await vu.updateConsumerIterator(E.schema,E.table,r,"start"):await vu.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new Z5(r,[],_.system_info)]),await o8(n[0],i,_.system_info),o.length>0?c.message=n8:c.message=`Successfully updated '${r}'`,c}a(i8,"updateNode");async function o8(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let u=0,_=e.subscriptions.length;u<_;u++){let l=n.subscriptions[u];if(l.schema===o.schema&&l.table===o.table){l.publish=o.publish,l.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new e8(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Bu.upsertNodeRecord(n),t8({type:"nats_update"})}a(o8,"updateNodeTable")});var sP=g((Ehe,nP)=>{"use strict";var rP=require("joi"),{string:eP}=rP.types(),a8=je(),tP=P(),c8=ee(),u8=Ve();nP.exports=l8;function l8(e){let t=eP.invalid(c8.get(tP.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(u8.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=rP.object({operation:eP.valid(tP.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return a8.validateBySchema(e,r)}a(l8,"removeNodeValidator")});var uf=g((mhe,uP)=>{"use strict";var{handleHDBError:iP,hdb_errors:_8}=se(),{HTTP_STATUS_CODES:oP}=_8,d8=sP(),xu=$(),aP=fn(),f8=J(),cf=P(),cP=Ve(),HT=ut(),E8=ee(),{RemotePayloadObject:h8}=Lu(),{NodeSubscription:m8}=Ti(),p8=aa(),S8=ci(),{broadcast:T8}=Qe(),g8=E8.get(cf.CONFIG_PARAMS.CLUSTERING_NODENAME);uP.exports=R8;async function R8(e){xu.trace("removeNode called with:",e),aP.checkClusteringEnabled();let t=d8(e);if(t)throw iP(t,t.message,oP.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await aP.getNodeRecord(r);if(f8.isEmptyOrZeroLength(n))throw iP(new Error,`Node '${r}' was not found.`,oP.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new h8(cf.OPERATIONS_ENUM.REMOVE_NODE,g8,[]),i,o=!1;for(let u=0,_=n.subscriptions.length;u<_;u++){let l=n.subscriptions[u];l.subscribe===!0&&await HT.updateConsumerIterator(l.schema,l.table,r,"stop");try{await HT.updateRemoteConsumer(new m8(l.schema,l.table,!1,!1),r)}catch(d){xu.error(d)}}try{i=await HT.request(`${r}.${cP.REQUEST_SUFFIX}`,s),xu.trace("Remove node reply from remote node:",r,i)}catch(u){xu.error("removeNode received error from request:",u),o=!0}let c=new p8(cf.SYSTEM_SCHEMA_NAME,cf.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await S8.deleteRecord(c),T8({type:"nats_update"}),i?.status===cP.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(xu.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(R8,"removeNode")});var dP=g((She,_P)=>{"use strict";var lP=require("joi"),{string:A8,array:O8}=lP.types(),b8=je(),y8=Kd();_P.exports=N8;function N8(e){let t=lP.object({operation:A8.valid("configure_cluster").required(),connections:O8.items(y8.validation_schema).required()});return b8.validateBySchema(e,t)}a(N8,"configureClusterValidator")});var GT=g((ghe,pP)=>{"use strict";var I8=P(),lf=$(),w8=J(),C8=uf(),D8=af(),fP=fn(),L8=dP(),{handleHDBError:EP,hdb_errors:M8}=se(),{HTTP_STATUS_CODES:hP}=M8,P8="Configure cluster complete.",U8="Failed to configure the cluster. Check the logs for more details.",v8="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";pP.exports=B8;async function B8(e){lf.trace("configure cluster called with:",e),fP.checkClusteringEnabled();let t=L8(e);if(t)throw EP(t,t.message,hP.BAD_REQUEST,void 0,void 0,!0);let r=await fP.getAllNodeRecords(),n=[];for(let l=0,d=r.length;l<d;l++){let E=await mP(C8,{operation:I8.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[l].name},r[l].name);n.push(E)}lf.trace("All results from configure_cluster remove node:",n);let s=[],i=e.connections.length;for(let l=0;l<i;l++){let d=e.connections[l],E=await mP(D8,d,d.node_name);s.push(E)}lf.trace("All results from configure_cluster add node:",s);let o=[],c=[],u=!1,_=n.concat(s);for(let l=0,d=_.length;l<d;l++){let E=_[l];E.status==="rejected"&&(lf.error(E),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(u=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,subscriptions:E?.result})}if(w8.isEmptyOrZeroLength(o))return{message:P8,connections:c};if(u)return{message:v8,failed_nodes:o,connections:c};throw EP(new Error,U8,hP.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(B8,"configureCluster");async function mP(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(mP,"functionWrapper")});var RP=g((Ahe,gP)=>{"use strict";var Hu=require("joi"),x8=je(),{validateSchemaExists:SP,validateTableExists:H8,validateSchemaName:TP}=jn(),G8=Hu.object({operation:Hu.string().valid("purge_stream"),schema:Hu.string().custom(SP).custom(TP).optional(),database:Hu.string().custom(SP).custom(TP).optional(),table:Hu.string().custom(H8).required()});function q8(e){return x8.validateBySchema(e,G8)}a(q8,"purgeStreamValidator");gP.exports=q8});var qT=g((bhe,AP)=>{"use strict";var{handleHDBError:F8,hdb_errors:k8}=se(),{HTTP_STATUS_CODES:V8}=k8,$8=RP(),Y8=ut(),K8=fn();AP.exports=W8;async function W8(e){e.schema=e.schema??e.database;let t=$8(e);if(t)throw F8(t,t.message,V8.BAD_REQUEST,void 0,void 0,!0);K8.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await Y8.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(W8,"purgeStream")});var VT=g((Nhe,wP)=>{"use strict";var kT=fn(),Q8=ut(),yP=ee(),_f=P(),ho=Ve(),z8=J(),FT=$(),{RemotePayloadObject:J8}=Lu(),{ErrorCode:OP}=require("nats"),bP=yP.get(_f.CONFIG_PARAMS.CLUSTERING_ENABLED),NP=yP.get(_f.CONFIG_PARAMS.CLUSTERING_NODENAME);wP.exports={clusterStatus:X8,buildNodeStatus:IP};async function X8(){let e={node_name:NP,is_enabled:bP,connections:[]};if(!bP)return e;let t=await kT.getAllNodeRecords();if(z8.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(IP(t[n],e.connections));return await Promise.allSettled(r),e}a(X8,"clusterStatus");async function IP(e,t){let r=e.name,n=new J8(_f.OPERATIONS_ENUM.CLUSTER_STATUS,NP,void 0,await kT.getSystemInfo()),s,i,o=ho.CLUSTER_STATUS_STATUSES.OPEN;try{let u=Date.now();s=await Q8.request(ho.REQUEST_SUBJECT(r),n),i=Date.now()-u,s.status===ho.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=ho.CLUSTER_STATUS_STATUSES.CLOSED,FT.error(`Error getting node status from ${r} `,s))}catch(u){FT.warn(`Error getting node status from ${r}`,u),u.code===OP.NoResponders?o=ho.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:u.code===OP.Timeout?o=ho.CLUSTER_STATUS_STATUSES.TIMEOUT:o=ho.CLUSTER_STATUS_STATUSES.CLOSED}let c=new j8(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let u={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==_f.PRE_4_0_0_VERSION&&await kT.upsertNodeRecord(u)}catch(u){FT.error("Cluster status encountered an error updating system info for node:",r,u)}t.push(c)}a(IP,"buildNodeStatus");function j8(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(j8,"NodeStatusObject")});var YT=g((whe,CP)=>{"use strict";var{handleHDBError:Z8,hdb_errors:e6}=se(),{HTTP_STATUS_CODES:t6}=e6,r6=ut(),n6=fn(),$T=J(),df=require("joi"),s6=je(),i6=2e3,o6=df.object({timeout:df.number().min(1),connected_nodes:df.boolean(),routes:df.boolean()});CP.exports=a6;async function a6(e){n6.checkClusteringEnabled();let t=s6.validateBySchema(e,o6);if(t)throw Z8(t,t.message,t6.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||$T.autoCastBoolean(n),o=s===void 0||$T.autoCastBoolean(s),c={nodes:[]},u=await r6.getServerList(r??i6),_={};if(i)for(let l=0,d=u.length;l<d;l++){let E=u[l].statsz;E&&(_[u[l].server.name]=E.routes)}for(let l=0,d=u.length;l<d;l++){if(u[l].statsz)continue;let E=u[l].server,f=u[l].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:u[l].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:$T.autoCast(p.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(a6,"clusterNetwork")});var PP=g((Dhe,MP)=>{"use strict";var KT=require("joi"),DP=je(),{route_constraints:LP}=cp();MP.exports={setRoutesValidator:c6,deleteRoutesValidator:u6};function c6(e){let t=KT.object({server:KT.valid("hub","leaf").required(),routes:LP.required()});return DP.validateBySchema(e,t)}a(c6,"setRoutesValidator");function u6(e){let t=KT.object({routes:LP.required()});return DP.validateBySchema(e,t)}a(u6,"deleteRoutesValidator")});var QT=g((Mhe,xP)=>{"use strict";var mo=pr(),WT=J(),ff=P(),UP=PP(),{handleHDBError:vP,hdb_errors:l6}=se(),{HTTP_STATUS_CODES:BP}=l6,_6="cluster routes successfully set",d6="cluster routes successfully deleted";xP.exports={setRoutes:f6,getRoutes:E6,deleteRoutes:h6};function f6(e){let t=UP.setRoutesValidator(e);if(t)throw vP(t,t.message,BP.BAD_REQUEST,void 0,void 0,!0);let r=mo.getClusteringRoutes(),n=e.server==="hub"?r.hub_routes:r.leaf_routes,s=e.server==="hub"?r.leaf_routes:r.hub_routes,i=[],o=[];for(let c=0,u=e.routes.length;c<u;c++){let _=e.routes[c];_.port=WT.autoCast(_.port);let l=n.some(E=>E.host===_.host&&E.port===_.port),d=s.some(E=>E.host===_.host&&E.port===_.port);l||d?i.push(_):(n.push(_),o.push(_))}return e.server==="hub"?mo.updateConfigValue(ff.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n):mo.updateConfigValue(ff.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n),{message:_6,set:o,skipped:i}}a(f6,"setRoutes");function E6(){let e=mo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}a(E6,"getRoutes");function h6(e){let t=UP.deleteRoutesValidator(e);if(t)throw vP(t,t.message,BP.BAD_REQUEST,void 0,void 0,!0);let r=mo.getClusteringRoutes(),n=r.hub_routes,s=r.leaf_routes,i=[],o=[],c=!1,u=!1;for(let _=0,l=e.routes.length;_<l;_++){let d=e.routes[_],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),u=!0,f=!1,i.push(d);break}}f&&o.push(d)}}return c&&(n=WT.isEmptyOrZeroLength(n)?null:n,mo.updateConfigValue(ff.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n)),u&&(s=WT.isEmptyOrZeroLength(s)?null:s,mo.updateConfigValue(ff.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,s)),{message:d6,deleted:i,skipped:o}}a(h6,"deleteRoutes")});var GP=g((Uhe,HP)=>{"use strict";var Gu=require("alasql"),po=require("recursive-iterator"),Hn=$(),m6=J(),qu=P(),zT=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,S6(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=>qu.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=>!qu.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][qu.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=p6(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(_=>({attribute_name:_.attribute}));let u=this.affected_attributes.get(i).get(o).filter(_=>!qu.SEARCH_WILDCARDS.includes(_));c.forEach(({attribute_name:_})=>{let l=new Gu.yy.Column({columnid:_});s.tableid&&(l.tableid=s.tableid),this.ast.columns.push(l),u.includes(_)||u.push(_)}),this.affected_attributes.get(i).set(o,u)}}),this.ast}};function p6(e){return e.filter(t=>t[qu.PERMS_CRUD_ENUM.READ])}a(p6,"filterReadRestrictedAttrs");function S6(e,t,r,n,s){T6(e,t,r,n,s)}a(S6,"interpretAST");function Fu(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(Fu,"addSchemaTableToMap");function T6(e,t,r,n,s){if(!e){Hn.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Gu.yy.Insert?O6(e,t,r):e instanceof Gu.yy.Select?g6(e,t,r,n,s):e instanceof Gu.yy.Update?R6(e,t,r):e instanceof Gu.yy.Delete?A6(e,t,r):Hn.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(T6,"getRecordAttributesAST");function g6(e,t,r,n,s){if(!e){Hn.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(m6.isEmptyOrZeroLength(i)){Hn.error("No schema specified");return}e.from.forEach(c=>{Fu(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Fu(c.table,t,r,n,s)});let o=new po(e.columns);for(let{node:c}of o)if(c&&c.columnid){let u=c.tableid,_=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(_).has(u))if(r.has(u))u=r.get(u);else{Hn.info(`table specified as ${u} not found.`);return}t.get(_).get(u).indexOf(c.columnid)<0&&t.get(_).get(u).push(c.columnid)}if(e.where){let c=new po(e.where),u=e.from[0].tableid;for(let{node:_}of c)if(_&&_.columnid){let l=_.tableid?_.tableid:u;if(!t.get(i).has(l))if(r.has(l))l=r.get(l);else{Hn.info(`table specified as ${l} not found.`);continue}t.get(i).get(l).indexOf(_.columnid)<0&&t.get(i).get(l).push(_.columnid)}}if(e.joins&&e.joins.forEach(c=>{let u=new po(c.on);for(let{node:_}of u)if(_&&_.columnid){let l=_.tableid,d=s.get(l);if(!t.get(d).has(l))if(r.has(l))l=r.get(l);else{Hn.info(`table specified as ${l} not found.`);continue}t.get(d).get(l).indexOf(_.columnid)<0&&t.get(d).get(l).push(_.columnid)}}),e.order){let c=new po(e.order);for(let{node:u}of c)if(u&&u.columnid){let _=u.tableid,l=n.has(_)?n.get(_):i;if(_||(_=e.from[0].tableid),!t.get(l).has(_))if(r.has(_))_=r.get(_);else{Hn.info(`table specified as ${_} not found.`);return}t.get(l).get(_).indexOf(u.columnid)<0&&t.get(l).get(_).push(u.columnid)}}}a(g6,"getSelectAttributes");function R6(e,t,r){if(!e){Hn.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new po(e.columns),s=e.table.databaseid;Fu(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&JT(e.table.tableid,s,i.columnid,t,r)}a(R6,"getUpdateAttributes");function A6(e,t,r){if(!e){Hn.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new po(e.where),s=e.table.databaseid;Fu(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&JT(e.table.tableid,s,i.columnid,t,r)}a(A6,"getDeleteAttributes");function O6(e,t,r){if(!e){Hn.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new po(e.columns),s=e.into.databaseid;Fu(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&JT(e.into.tableid,s,i.columnid,t,r)}a(O6,"getInsertAttributes");function JT(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(JT,"pushAttribute");HP.exports=zT});var ZT=g((Bhe,VP)=>{var Ef=ji(),qP=require("chalk"),zr=$(),FP=require("prompt"),{promisify:b6}=require("util"),XT=P(),y6=require("fs-extra"),N6=require("path"),I6=J(),w6=ef(),kP=ee();kP.initSync();var C6=require("moment"),D6=b6(FP.get),L6=N6.join(kP.getHdbBasePath(),XT.LICENSE_KEY_DIR_NAME,XT.LICENSE_FILE_NAME,XT.LICENSE_FILE_NAME);VP.exports={getFingerprint:P6,setLicense:M6,parseLicense:jT,register:U6,getRegistrationInfo:B6};async function M6(e){if(e&&e.key&&e.company){try{zr.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await jT(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw zr.error(r),zr.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(M6,"setLicense");async function P6(){let e={};try{e=await Ef.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw zr.error(r),zr.error(t),new Error(r)}return e}a(P6,"getFingerprint");async function jT(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");zr.info("Validating license input...");let r=Ef.validateLicense(e,t);if(zr.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(zr.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(zr.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{zr.info("writing license to disk"),await y6.writeFile(L6,JSON.stringify({license_key:e,company:t}))}catch(n){throw zr.error("Failed to write License"),n}return"Registration successful."}a(jT,"parseLicense");async function U6(){let e=await v6();return jT(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(U6,"register");async function v6(){let e=await Ef.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:qP.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:qP.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{FP.start()}catch(n){zr.error(n)}let r;try{r=await D6(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(v6,"promptForRegistration");async function B6(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await Ef.getLicense()}catch(r){throw zr.error(`There was an error when searching licenses due to: ${r.message}`),r}if(I6.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=w6.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=C6.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(B6,"getRegistrationInfo")});var YP=g((Hhe,$P)=>{"use strict";var x6=Ve(),eg=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,u,_,l,d,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+x6.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:u},this.leafnodes={port:_,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:l,port:d,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:u}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};$P.exports=eg});var QP=g((qhe,WP)=>{"use strict";var KP=Ve(),tg=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,u,_,l,d){this.port=t,d===null&&(d=void 0),this.server_name=r+KP.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+KP.SERVER_SUFFIX.LEAF},this.tls={cert_file:_,key_file:l,ca_file:d,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:d,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:d,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:u,jetstream:"enabled"}},this.system_account="SYS"}};WP.exports=tg});var JP=g((khe,zP)=>{"use strict";var rg=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};zP.exports=rg});var jP=g(($he,XP)=>{"use strict";var H6=Ve(),ng=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+H6.SERVER_SUFFIX.ADMIN,this.password=r}};XP.exports=ng});var og=g((Khe,tU)=>{"use strict";var Aa=require("path"),pf=require("fs-extra"),G6=YP(),q6=QP(),F6=JP(),k6=jP(),sg=_n(),ba=J(),Nr=pr(),mf=P(),ku=Ve(),{CONFIG_PARAMS:pt}=mf,ya=$(),Vu=ee(),ZP=Os(),ig=ut(),Oa="clustering",V6=1e4,eU=50;tU.exports={generateNatsConfig:Y6,removeNatsConfig:K6,getHubConfigPath:$6};function $6(){let e=Vu.get(pt.ROOTPATH);return Aa.join(e,Oa,ku.NATS_CONFIG_FILES.HUB_SERVER)}a($6,"getHubConfigPath");async function Y6(e=!1,t=void 0){Vu.initSync();let r=Vu.get(pt.ROOTPATH),n=Aa.join(r,Oa,ku.PID_FILES.HUB),s=Aa.join(r,Oa,ku.PID_FILES.LEAF),i=Nr.getConfigFromFile(pt.CLUSTERING_LEAFSERVER_STREAMS_PATH),o=Aa.join(r,Oa,ku.NATS_CONFIG_FILES.HUB_SERVER),c=Aa.join(r,Oa,ku.NATS_CONFIG_FILES.LEAF_SERVER),u=Nr.getConfigFromFile(pt.CLUSTERING_TLS_CERTIFICATE),_=Nr.getConfigFromFile(pt.CLUSTERING_TLS_PRIVATEKEY),l=Nr.getConfigFromFile(pt.CLUSTERING_TLS_CERT_AUTH),d=Nr.getConfigFromFile(pt.CLUSTERING_TLS_INSECURE),E=Nr.getConfigFromFile(pt.CLUSTERING_TLS_VERIFY),f=Nr.getConfigFromFile(pt.CLUSTERING_NODENAME),h=Nr.getConfigFromFile(pt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await ig.checkNATSServerInstalled()||Sf("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let p=await sg.listUsers(),S=Nr.getConfigFromFile(pt.CLUSTERING_USER),T=await sg.getClusterUser();(ba.isEmpty(T)||T.active!==!0)&&Sf(`Invalid cluster user '${S}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await hf(pt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await hf(pt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await hf(pt.CLUSTERING_HUBSERVER_NETWORK_PORT),await hf(pt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let A=[],b=[];for(let[z,j]of p.entries())j.role?.role===mf.ROLE_TYPES_ENUM.CLUSTER_USER&&j.active&&(A.push(new k6(j.username,ZP.decrypt(j.hash))),b.push(new F6(j.username,ZP.decrypt(j.hash))));let I=[],{hub_routes:B}=Nr.getClusteringRoutes();if(!ba.isEmptyOrZeroLength(B))for(let z of B)I.push(`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@${z.host}:${z.port}`);let U=new G6(Nr.getConfigFromFile(pt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,n,u,_,l,d,E,h,Nr.getConfigFromFile(pt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Nr.getConfigFromFile(pt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),I,A,b);l==null&&(delete U.tls.ca_file,delete U.leafnodes.tls.ca_file),t=ba.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===mf.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await pf.writeJson(o,U),ya.trace(`Hub server config written to ${o}`));let F=`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 q6(Nr.getConfigFromFile(pt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,s,i,[F],[M],A,b,u,_,l,d);l==null&&delete Q.tls.ca_file,(t===void 0||t===mf.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await pf.writeJson(c,Q),ya.trace(`Leaf server config written to ${c}`))}a(Y6,"generateNatsConfig");async function hf(e){let t=Vu.get(e);return ba.isEmpty(t)&&Sf(`port undefined for '${e}'`),await ba.isPortTaken(t)&&Sf(`'${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(hf,"isPortAvailable");function Sf(e){let t=`Error generating clustering config: ${e}`;ya.error(t),console.error(t),process.exit(1)}a(Sf,"generateNatsConfigError");async function K6(e){let{port:t,config_file:r}=ig.getServerConfig(e),{username:n,decrypt_hash:s}=await sg.getClusterUser(),i=0,o=2e3;for(;i<eU;){try{let l=await ig.createConnection(t,n,s,!1);if(l.protocol.connected===!0){l.close();break}}catch(l){ya.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${l}`)}if(i++,i>=eU)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&&ya.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await ba.async_set_timeout(_)}let c="0".repeat(V6),u=Aa.join(Vu.get(pt.ROOTPATH),Oa,r);await pf.writeFile(u,c),await pf.remove(u),ya.notify(e,"started.")}a(K6,"removeNatsConfig")});var aU=g((Qhe,oU)=>{"use strict";var Jr=ee(),W6=ji(),pe=P(),$u=Ve(),Ls=require("path"),{PACKAGE_ROOT:gf}=P(),rU=ee(),Tf=J(),Na="/dev/null",Q6=Ls.join(gf,"launchServiceScripts"),nU=Ls.join(gf,"utility/scripts"),z6=Ls.join(nU,pe.HDB_RESTART_SCRIPT),sU=Ls.resolve(gf,"dependencies",`${process.platform}-${process.arch}`,$u.NATS_BINARY_NAME);function iU(){let t=W6.licenseSearch().ram_allocation||pe.RAM_ALLOCATION_ENUM.DEFAULT,r=pe.MEM_SETTING_KEY+t,n={[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Tf.noBootFile()&&(n[pe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Tf.getEnvCliRootPath()),{name:pe.PROCESS_DESCRIPTORS.HDB,script:pe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:gf}}a(iU,"generateMainServerConfig");var J6=9930;function X6(){Jr.initSync(!0);let e=Jr.get(pe.CONFIG_PARAMS.ROOTPATH),t=Ls.join(e,"clustering",$u.NATS_CONFIG_FILES.HUB_SERVER),r=Ls.join(Jr.get(pe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),pe.LOG_NAMES.HDB),n=rU.get(pe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=$u.LOG_LEVEL_FLAGS[Jr.get(pe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==J6?"-"+n:""),script:sU,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Jr.get(pe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Na,i.error_file=Na),i}a(X6,"generateNatsHubServerConfig");var j6=9940;function Z6(){Jr.initSync(!0);let e=Jr.get(pe.CONFIG_PARAMS.ROOTPATH),t=Ls.join(e,"clustering",$u.NATS_CONFIG_FILES.LEAF_SERVER),r=Ls.join(Jr.get(pe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),pe.LOG_NAMES.HDB),n=rU.get(pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=$u.LOG_LEVEL_FLAGS[Jr.get(pe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==j6?"-"+n:""),script:sU,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Jr.get(pe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Na,i.error_file=Na),i}a(Z6,"generateNatsLeafServerConfig");function e9(){Jr.initSync();let e=Ls.join(Jr.get(pe.CONFIG_PARAMS.LOGGING_ROOT),pe.LOG_NAMES.HDB),t={name:pe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:pe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Q6,autorestart:!1};return Jr.get(pe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Na,t.error_file=Na),t}a(e9,"generateClusteringUpgradeV4ServiceConfig");function t9(){let e={[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.RESTART_HDB};return Tf.noBootFile()&&(e[pe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Tf.getEnvCliRootPath()),{...{name:pe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:nU},script:z6}}a(t9,"generateRestart");function r9(){return{apps:[iU()]}}a(r9,"generateAllServiceConfigs");oU.exports={generateAllServiceConfigs:r9,generateMainServerConfig:iU,generateRestart:t9,generateNatsHubServerConfig:X6,generateNatsLeafServerConfig:Z6,generateClusteringUpgradeV4ServiceConfig:e9}});var AU=g((Xhe,RU)=>{"use strict";var ve=P(),n9=J(),Ps=og(),Rf=ut(),Ms=Ve(),Ri=aU(),Af=ee(),Ai=$(),s9=fn(),{startWorker:cU,onMessageFromWorkers:i9}=Qe(),o9=Ra(),Jhe=require("util"),a9=require("child_process"),c9=require("fs"),{execFile:u9}=a9,we;RU.exports={enterPM2Mode:l9,start:Oi,stop:ag,reload:lU,restart:_U,list:cg,describe:EU,connect:Us,kill:h9,startAllServices:m9,startService:ug,getUniqueServicesList:hU,restartAllServices:p9,isServiceRegistered:mU,reloadStopStart:pU,restartHdb:fU,deleteProcess:f9,startClusteringProcesses:TU,startClusteringThreads:gU,isHdbRestartRunning:E9,isClusteringRunning:T9,stopClustering:S9,reloadClustering:g9,expectedRestartOfChildren:dU};var Yu=!1;i9(e=>{e.type==="restart"&&Af.initSync(!0)});function l9(){Yu=!0}a(l9,"enterPM2Mode");function Us(){return we||(we=require("pm2")),new Promise((e,t)=>{we.connect((r,n)=>{Ai.setupConsoleLogging(),r&&t(r),e(n)})})}a(Us,"connect");var ar,_9=10,uU;function Oi(e,t=!1){if(Yu)return d9(e);let r=u9(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=ar.indexOf(r);o>-1&&ar.splice(o,1),!uU&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<_9&&(c9.existsSync(Ps.getHubConfigPath())?Oi(e):(await Ps.generateNatsConfig(!0),Oi(e),await new Promise(c=>setTimeout(c,3e3)),await Ps.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Ps.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Af.get(ve.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,u,_=0,l;for(;u=c.exec(i);){if(u.index&&Ms.LOG_LEVEL_HIERARCHY[o]>=Ms.LOG_LEVEL_HIERARCHY[l||"info"]){let f=l===Ms.LOG_LEVELS.ERR||l===Ms.LOG_LEVELS.WRN?Ai.OUTPUTS.STDERR:Ai.OUTPUTS.STDOUT;Ai.logCustomLevel(l||"info",f,n,i.slice(_,u.index).trim())}let[d,E]=u;_=u.index+d.length,l=Ms.LOG_LEVELS[E]}if(Ms.LOG_LEVEL_HIERARCHY[o]>=Ms.LOG_LEVEL_HIERARCHY[l||"info"]){let d=l===Ms.LOG_LEVELS.ERR||l===Ms.LOG_LEVELS.WRN?Ai.OUTPUTS.STDERR:Ai.OUTPUTS.STDOUT;Ai.logCustomLevel(l||"info",d,n,i.slice(_).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!ar&&(ar=[],!t)){let i=a(()=>{uU=!0,ar&&(ar.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)}ar.push(r)}a(Oi,"start");function d9(e){return new Promise(async(t,r)=>{try{await Us()}catch(n){r(n)}we.start(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(d9,"startWithPM2");function ag(e){if(!Yu){for(let t of ar||[])t.name===e&&(ar.splice(ar.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Us()}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(ag,"stop");function lU(e){return new Promise(async(t,r)=>{try{await Us()}catch(n){r(n)}we.reload(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(lU,"reload");function _U(e){if(!Yu){dU();for(let t of ar||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await Us()}catch(n){r(n)}we.restart(e,(n,s)=>{we.disconnect(),t(s)})})}a(_U,"restart");function dU(){for(let e of ar||[])e.config&&(e.config.restarts=0)}a(dU,"expectedRestartOfChildren");function f9(e){return new Promise(async(t,r)=>{try{await Us()}catch(n){r(n)}we.delete(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(f9,"deleteProcess");async function fU(){await Oi(Ri.generateRestart())}a(fU,"restartHdb");async function E9(){let e=await cg();for(let t in e)if(e[t].name===ve.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(E9,"isHdbRestartRunning");function cg(){return new Promise(async(e,t)=>{try{await Us()}catch(r){t(r)}we.list((r,n)=>{r&&(we.disconnect(),t(r)),we.disconnect(),e(n)})})}a(cg,"list");function EU(e){return new Promise(async(t,r)=>{try{await Us()}catch(n){r(n)}we.describe(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(EU,"describe");function h9(){if(!Yu){for(let e of ar||[])e.kill();ar=[];return}return new Promise(async(e,t)=>{try{await Us()}catch(r){t(r)}we.killDaemon((r,n)=>{r&&(we.disconnect(),t(r)),we.disconnect(),e(n)})})}a(h9,"kill");async function m9(){try{await TU(),await gU(),await Oi(Ri.generateAllServiceConfigs())}catch(e){throw we?.disconnect(),e}}a(m9,"startAllServices");async function ug(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case ve.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ri.generateMainServerConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ri.generateNatsIngestServiceConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ri.generateNatsReplyServiceConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ri.generateNatsHubServerConfig(),await Oi(r,t),await Ps.removeNatsConfig(e);return;case ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ri.generateNatsLeafServerConfig(),await Oi(r,t),await Ps.removeNatsConfig(e);return;case ve.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ri.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Oi(r)}catch(r){throw we?.disconnect(),r}}a(ug,"startService");async function hU(){try{let e=await cg(),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(hU,"getUniqueServicesList");async function p9(e=[]){try{let t=!1,r=await hU();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===ve.PROCESS_DESCRIPTORS.HDB?t=!0:await _U(o))}t&&await pU(ve.PROCESS_DESCRIPTORS.HDB)}catch(t){throw we?.disconnect(),t}}a(p9,"restartAllServices");async function mU(e){if(ar?.find(r=>r.name===e))return!0;let t=await o9.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(mU,"isServiceRegistered");async function pU(e){let t=Af.get(ve.CONFIG_PARAMS.THREADS_COUNT)??Af.get(ve.CONFIG_PARAMS.THREADS),r=await EU(e),n=n9.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await ag(e),await ug(e)):e===ve.PROCESS_DESCRIPTORS.HDB?await fU():await lU(e)}a(pU,"reloadStopStart");var SU;async function TU(e=!1){for(let t in ve.CLUSTERING_PROCESSES){let r=ve.CLUSTERING_PROCESSES[t];await ug(r,e)}}a(TU,"startClusteringProcesses");async function gU(){SU=cU(ve.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:ve.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await Rf.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await Rf.updateLocalStreams();let e=await s9.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===ve.PRE_4_0_0_VERSION){Ai.info("Starting clustering upgrade 4.0.0 process"),cU(ve.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(gU,"startClusteringThreads");async function S9(){for(let e in ve.CLUSTERING_PROCESSES)if(e!==ve.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===ve.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await SU.terminate();else{let t=ve.CLUSTERING_PROCESSES[e];await ag(t)}}a(S9,"stopClustering");async function T9(){for(let e in ve.CLUSTERING_PROCESSES){let t=ve.CLUSTERING_PROCESSES[e];if(await mU(t)===!1)return!1}return!0}a(T9,"isClusteringRunning");async function g9(){await Ps.generateNatsConfig(!0),await Rf.reloadNATSHub(),await Rf.reloadNATSLeaf(),await Ps.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await Ps.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(g9,"reloadClustering")});var CU={};Fe(CU,{compactOnStart:()=>R9,copyDb:()=>wU});async function R9(){Wu.notify("Running compact on start"),console.log("Running compact on start");let e=(0,lg.get)(bi.CONFIG_PARAMS.ROOTPATH),t=new Map,r=Tr();try{for(let n in r){if(n==="system")continue;let s;for(let u in r[n]){s=r[n][u].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,Of.join)(e,"backup",n+".mdb"),o=(0,Of.join)(e,bi.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await OU(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 wU(n,o),console.log("Backing up",n,"to",i),await(0,So.move)(s,i,{overwrite:!0})}Ku();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,So.move)(i,s,{overwrite:!0}),await(0,So.remove)((0,Of.join)(e,bi.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));Ku()}catch(n){Wu.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,_g.updateConfigValue)(bi.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,So.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Ku(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await OU(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let u=`There is a discrepancy between pre and post compact record count for database ${n}.
|
|
12
|
+
`,"")}a(pL,"runCommand");async function wX(){try{await iX.access(GS)}catch{return!1}let e=await pL(`${GS} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return oX.eq(t,NX)}a(wX,"checkNATSServerInstalled");async function $S(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await hL.getClusterUser();if(lo(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}xn.trace("create nats connection called");let i=await mX({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(),xn.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&xn.error("Error with Nats client connection, connection closed",o),i===ir&&SL()}),i}a($S,"createConnection");function SL(){ir=void 0,ao=void 0,co=void 0,uo=void 0}a(SL,"clearClientCache");async function CX(){ir&&(await ir.drain(),ir=void 0,ao=void 0,co=void 0,uo=void 0)}a(CX,"closeConnection");var ir,uo;async function Ou(){return uo||(uo=$S(Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),ir=await uo),ir||uo}a(Ou,"getConnection");async function bu(){if(ao)return ao;lo(ir)&&await Ou();let{domain:e}=fa(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(lo(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ao=await ir.jetstreamManager({domain:e,timeout:6e4}),ao}a(bu,"getJetStreamManager");async function TL(){if(co)return co;lo(ir)&&await Ou();let{domain:e}=fa(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(lo(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return co=ir.jetstream({domain:e,timeout:6e4}),co}a(TL,"getJetStream");async function as(){let e=ir||await Ou(),t=ao||await bu(),r=co||await TL();return{connection:e,jsm:t,js:r}}a(as,"getNATSReferences");async function DX(e){let t=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await hL.getClusterUser(),s=await $S(t,r,n),i=VS(),o=s.subscribe(i),c=[],u,_=(async()=>{for await(let l of o){let d=mL.decode(l.data);d.response_time=Date.now()-u,c.push(d)}})();return u=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Bd.async_set_timeout(e),await o.drain(),await s.close(),await _,c}a(DX,"getServerList");async function YS(e,t){let{jsm:r}=await as(),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:pX.File,retention:SX.Limits,subjects:t,discard:TX.Old,max_msgs:s,max_bytes:i,max_age:n})}a(YS,"createLocalStream");async function gL(){let{jsm:e}=await as(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(gL,"listStreams");async function LX(e){let{jsm:t}=await as();await t.streams.delete(e)}a(LX,"deleteLocalStream");async function MX(e){let{connection:t}=await as(),r=[],n=VS(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(mL.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(MX,"listRemoteStreams");async function PX(e,t=void 0,r=void 0){let{jsm:n,js:s}=await as(),i=_L(),o={durable_name:i,ack_policy:FS.Explicit};t&&(o.deliver_policy=kS.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),u=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let _=[];for await(let l of u){let d=qS(l.data),E={nats_timestamp:l.info.timestampNanos,nats_sequence:l.info.streamSequence,entry:d};if(l.headers&&(E.origin=l.headers.get(Wt.MSG_HEADERS.ORIGIN)),_.push(E),l.ack(),l.info.pending===0)break}return await c.delete(),_}a(PX,"viewStream");async function*UX(e,t=void 0,r=void 0){let{jsm:n,js:s}=await as(),i=_L(),o={durable_name:i,ack_policy:FS.Explicit};t&&(o.deliver_policy=kS.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),u=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let _ of u){let l=qS(_.data);l[0]||(l=[l]);for(let d of l){let E={nats_timestamp:_.info.timestampNanos,nats_sequence:_.info.streamSequence,entry:d};_.headers&&(E.origin=_.headers.get(Wt.MSG_HEADERS.ORIGIN)),yield E}if(_.ack(),_.info.pending===0)break}await c.delete()}a(UX,"viewStreamIterator");async function vX(e,t,r,n){xn.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=RL(n,r);let{js:s}=await as(),i=await Hd(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:EL.encode(n);try{xn.trace(`publishToStream publishing to subject: ${o}`),bX(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(u){if(u.code&&u.code.toString()==="503")return OL(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(u.code&&u.code.toString()==="503"){xn.trace(`publishToStream creating stream: ${t}`);let l=o.split(".");l[2]="*",await YS(t,[o]),await s.publish(o,c,{headers:r})}else throw u}});throw u}}a(vX,"publishToStream");function RL(e,t){t===void 0&&(t=RX());let r=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Wt.MSG_HEADERS.ORIGIN)&&r&&t.append(Wt.MSG_HEADERS.ORIGIN,r),t}a(RL,"addNatsMsgHeader");function fa(e){e=e.toLowerCase();let t=Au.join(Ht.get(Ie.CONFIG_PARAMS.ROOTPATH),yX);if(e===Ie.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return lo(HS)&&(HS={port:gu.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:gu.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wt.SERVER_SUFFIX.HUB,config_file:Wt.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:Au.join(t,Wt.PID_FILES.HUB),hdb_nats_path:t}),HS;if(e===Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return lo(xS)&&(xS={port:gu.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:gu.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wt.SERVER_SUFFIX.LEAF,config_file:Wt.NATS_CONFIG_FILES.LEAF_SERVER,domain:gu.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wt.SERVER_SUFFIX.LEAF,pid_file_path:Au.join(t,Wt.PID_FILES.LEAF),hdb_nats_path:t}),xS;xn.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(fa,"getServerConfig");async function AL(e,t,r,n){try{await e.consumers.add(t,{ack_policy:FS.Explicit,durable_name:r,deliver_policy:kS.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(AL,"createConsumer");async function BX(e,t,r){await e.consumers.delete(t,r)}a(BX,"removeConsumer");function xX(e){return e.split(".")[1]}a(xX,"extractServerName");async function HX(e,t,r=6e4,n=VS()){if(!Bd.isObject(t))throw new Error("data param must be an object");let s=EL.encode(t),{connection:i}=await as(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return qS(c.data)}a(HX,"request");function KS(e){return new Promise(async(t,r)=>{let n=lX(GS,["--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(KS,"reloadNATS");async function GX(){let{pid_file_path:e}=fa(Ie.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await KS(e)}a(GX,"reloadNATSHub");async function qX(){let{pid_file_path:e}=fa(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await KS(e)}a(qX,"reloadNATSLeaf");function FX(e,t,r){let n;switch(e.code){case lL.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case lL.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(FX,"requestErrorHandler");async function kX(e,t){let r=t+Wt.SERVER_SUFFIX.LEAF,{connection:n}=await as(),{jsm:s}=await JX(r),{schema:i,table:o}=e,c=xd.createNatsTableStreamName(i,o),u=e.start_time?e.start_time:new Date(Date.now()).toISOString();await OL(async()=>{if(e.subscribe===!0)await AL(s,c,n.info.server_name,u);else try{await BX(s,c,n.info.server_name)}catch(_){xn.trace(_)}})}a(kX,"updateRemoteConsumer");async function VX(e,t,r,n){let s=xd.createNatsTableStreamName(e,t),i=r+Wt.SERVER_SUFFIX.LEAF,o={type:Ie.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!fL&&EX()<Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=BS();await c(o)}await dX(o),n==="stop"&&await Bd.async_set_timeout(1e3)}a(VX,"updateConsumerIterator");function OL(e){return _X.writeTransaction(Ie.SYSTEM_SCHEMA_NAME,Ie.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(OL,"exclusiveLock");async function bL(e,t){let r=xd.createNatsTableStreamName(e,t),n=await Hd(),s=WX(e,t,n);await YS(r,[s])}a(bL,"createLocalTableStream");async function $X(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await bL(n,s)}}a($X,"createTableStreams");async function yL(e,t,r=void 0){if(Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=xd.createNatsTableStreamName(e,t),{domain:s}=fa(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await Ou()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")xn.warn(n);else throw n}}a(yL,"purgeTableStream");async function YX(e,t){if(Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await yL(e,t[r])}a(YX,"purgeSchemaTableStreams");async function KX(e){return(await bu()).streams.info(e)}a(KX,"getStreamInfo");function WX(e,t,r){return`${Wt.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(WX,"createSubjectName");async function Hd(){if(Ru)return Ru;if(Ru=(await bu())?.nc?.info?.server_name,Ru===void 0)throw new Error("Unable to get jetstream manager server name");return Ru}a(Hd,"getJsmServerName");async function QX(){let e=await bu(),t=await Hd(),r=await gL();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=zX(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let _=i.split(".");_[_.length-1]=t;let l=_.join(".");xn.trace(`Updating stream subject name from: ${i} to: ${l}`),s.subjects[0]=l,await e.streams.update(s.name,s)}}a(QX,"updateLocalStreams");function zX(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(zX,"updateStreamLimits");async function JX(e){let t,r;try{t=await ir.jetstream({domain:e}),r=await ir.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw xn.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(JX,"connectToRemoteJS")});var yu=g((eEe,DL)=>{"use strict";var Ea=H_(),ha=PD(),XX=$(),jX=require("uuid").v4,Zfe=require("clone"),qd=Ns(),ma=P(),ZX=require("util"),Ei=Dn(),{handleHDBError:Rr,hdb_errors:ej}=se(),{HDB_ERROR_MSGS:Gd,HTTP_STATUS_CODES:Ar}=ej,{SchemaEventMsg:Fd}=Pn(),IL=ut(),{getDatabases:tj}=(Ae(),ie(ke)),{transformReq:pa}=J();DL.exports={createSchema:rj,createSchemaStructure:wL,createTable:nj,createTableStructure:CL,createAttribute:cj,dropSchema:sj,dropTable:ij,dropAttribute:oj,getBackup:uj};async function rj(e){let t=await wL(e);return qd.signalSchemaChange(new Fd(process.pid,e.operation,e.schema)),t}a(rj,"createSchema");async function wL(e){let t=Ea.schema_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);if(pa(e),!await ha.checkSchemaExists(e.schema))throw Rr(new Error,Gd.SCHEMA_EXISTS_ERR(e.schema),Ar.BAD_REQUEST,ma.LOG_LEVELS.ERROR,Gd.SCHEMA_EXISTS_ERR(e.schema),!0);return await Ei.createSchema(e),`database '${e.schema}' successfully created`}a(wL,"createSchemaStructure");async function nj(e){return pa(e),e.hash_attribute=e.primary_key??e.hash_attribute,await CL(e)}a(nj,"createTable");async function CL(e){let t=Ea.create_table_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);if(Ea.validateTableResidence(e.residence),!await ha.checkSchemaTableExists(e.schema,e.table))throw Rr(new Error,Gd.TABLE_EXISTS_ERR(e.schema,e.table),Ar.BAD_REQUEST,ma.LOG_LEVELS.ERROR,Gd.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:jX(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await Ei.createTable(n,e);else throw Rr(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Ar.BAD_REQUEST);else await Ei.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(CL,"createTableStructure");async function sj(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=Ea.schema_object(e),n=t??r;if(n)throw Rr(n,n.message,Ar.BAD_REQUEST,void 0,void 0,!0);pa(e);let s=await ha.checkSchemaExists(e.schema);if(s)throw Rr(new Error,s,Ar.NOT_FOUND,ma.LOG_LEVELS.ERROR,s,!0);let i=await ha.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);return await Ei.dropSchema(e),qd.signalSchemaChange(new Fd(process.pid,e.operation,e.schema)),await IL.purgeSchemaTableStreams(e.schema,o),`successfully deleted '${e.schema}'`}a(sj,"dropSchema");async function ij(e){let t=Ea.table_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);pa(e);let r=await ha.checkSchemaTableExists(e.schema,e.table);if(r)throw Rr(new Error,r,Ar.NOT_FOUND,ma.LOG_LEVELS.ERROR,r,!0);return await Ei.dropTable(e),await IL.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(ij,"dropTable");async function oj(e){let t=Ea.attribute_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);pa(e);let r=await ha.checkSchemaTableExists(e.schema,e.table);if(r)throw Rr(new Error,r,Ar.NOT_FOUND,ma.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Rr(new Error,"You cannot drop a hash attribute",Ar.BAD_REQUEST,void 0,void 0,!0);if(ma.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Rr(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Ar.BAD_REQUEST,void 0,void 0,!0);try{return await Ei.dropAttribute(e),aj(e),qd.signalSchemaChange(new Fd(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw XX.error(`Got an error deleting attribute ${ZX.inspect(e)}.`),n}}a(oj,"dropAttribute");function aj(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(aj,"dropAttributeFromGlobal");async function cj(e){pa(e);let t=tj()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Rr(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Ar.BAD_REQUEST,void 0,void 0,!0);return await Ei.createAttribute(e),qd.signalSchemaChange(new Fd(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(cj,"createAttribute");function uj(e){return Ei.getBackup(e)}a(uj,"getBackup")});var ML=g((rEe,LL)=>{"use strict";var{OPERATIONS_ENUM:lj}=P(),WS=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=lj.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};LL.exports=WS});var QS=g((iEe,xL)=>{"use strict";var _j=Dn(),sEe=ML(),kd=J(),Vd=P(),dj=ee(),{handleHDBError:PL,hdb_errors:fj}=se(),{HDB_ERROR_MSGS:UL,HTTP_STATUS_CODES:vL}=fj,Ej=Object.values(Vd.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),BL="To use this operation audit log must be enabled in harperdb-config.yaml";xL.exports=hj;async function hj(e){if(kd.isEmpty(e.schema))throw new Error(UL.SCHEMA_REQUIRED_ERR);if(kd.isEmpty(e.table))throw new Error(UL.TABLE_REQUIRED_ERR);if(!dj.get(Vd.CONFIG_PARAMS.LOGGING_AUDITLOG))throw PL(new Error,BL,vL.BAD_REQUEST,Vd.LOG_LEVELS.ERROR,BL,!0);let t=kd.checkSchemaTableExist(e.schema,e.table);if(t)throw PL(new Error,t,vL.NOT_FOUND,Vd.LOG_LEVELS.ERROR,t,!0);if(!kd.isEmpty(e.search_type)&&Ej.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await _j.readAuditLog(e)}a(hj,"readAuditLog")});var GL=g((aEe,HL)=>{"use strict";var{OPERATIONS_ENUM:mj}=P(),zS=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=mj.GET_BACKUP,this.schema=t,this.table=r}};HL.exports=zS});var kL=g((_Ee,FL)=>{"use strict";var pj=Dn(),uEe=GL(),JS=J(),Sj=P(),lEe=ee(),{handleHDBError:Tj,hdb_errors:gj}=se(),{HDB_ERROR_MSGS:qL,HTTP_STATUS_CODES:Rj}=gj;FL.exports=Aj;async function Aj(e){if(JS.isEmpty(e.schema))throw new Error(qL.SCHEMA_REQUIRED_ERR);if(JS.isEmpty(e.table))throw new Error(qL.TABLE_REQUIRED_ERR);let t=JS.checkSchemaTableExist(e.schema,e.table);if(t)throw Tj(new Error,t,Rj.NOT_FOUND,Sj.LOG_LEVELS.ERROR,t,!0);return await pj.getBackup(read_audit_log_object)}a(Aj,"getBackup")});var QL=g((fEe,WL)=>{var hi=require("validate.js"),$L=je(),Sa=P(),{handleHDBError:Oj,hdb_errors:bj}=se(),{HDB_ERROR_MSGS:mt,HTTP_STATUS_CODES:yj}=bj,XS=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Nj={STRUCTURE_USER:"structure_user"},VL=Object.values(Sa.ROLE_TYPES_ENUM),Ij="attribute_permissions",wj="attribute_name",{PERMS_CRUD_ENUM:Ta}=Sa,Cj=[Ij,...Object.values(Ta)],YL=[Ta.READ,Ta.INSERT,Ta.UPDATE],Dj=[wj,...YL];function Lj(e){let t=XS();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,KL(e,t)}a(Lj,"addRoleValidation");function Mj(e){let t=XS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,KL(e,t)}a(Mj,"alterRoleValidation");function Pj(e){let t=XS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,$L.validateObject(e,t)}a(Pj,"dropRoleValidation");var Uj=["operation","role","id","permission","hdb_user","hdb_auth_header"];function KL(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)Uj.includes(n[o])||s.push(n[o]);s.length>0&&At(mt.INVALID_ROLE_JSON_KEYS(s),r);let i=$L.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{At(o,r)}),e.permission){let o=vj(e);o&&At(o,r),VL.forEach(c=>{e.permission[c]&&!hi.isBoolean(e.permission[c])&&At(mt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(VL.indexOf(o)<0){if(o===Nj.STRUCTURE_USER){let u=e.permission[o];if(typeof u=="boolean")continue;if(Array.isArray(u)){for(let _=0,l=u.length;_<l;_++){let d=u[_];global.hdb_schema[d]||At(mt.SCHEMA_NOT_FOUND(d),r)}continue}At(mt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){At(mt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let u in c.tables){let _=c.tables[u];if(!u||!global.hdb_schema[o][u]){At(mt.TABLE_NOT_FOUND(o,u),r);continue}if(Object.keys(_).forEach(l=>{Cj.includes(l)||At(mt.INVALID_PERM_KEY(l),r,o,u)}),Object.values(Ta).forEach(l=>{hi.isDefined(_[l])?hi.isBoolean(_[l])||At(mt.TABLE_PERM_NOT_BOOLEAN(l),r,o,u):At(mt.TABLE_PERM_MISSING(l),r,o,u)}),hi.isDefined(_.attribute_permissions)){if(!hi.isArray(_.attribute_permissions)){At(mt.ATTR_PERMS_NOT_ARRAY,r,o,u);continue}}else{At(mt.ATTR_PERMS_ARRAY_MISSING,r,o,u);continue}if(_.attribute_permissions){let l=global.hdb_schema[o][u].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=>{!Dj.includes(p)&&p!==Ta.DELETE&&At(mt.INVALID_ATTR_PERM_KEY(p),r,o,u)}),!hi.isDefined(f.attribute_name)){At(mt.ATTR_PERM_MISSING_NAME,r,o,u);continue}let h=f.attribute_name;if(!l.includes(h)){At(mt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,u);continue}YL.forEach(p=>{hi.isDefined(f[p])?hi.isBoolean(f[p])||At(mt.ATTR_PERM_NOT_BOOLEAN(p,h),r,o,u):At(mt.ATTR_PERM_MISSING(p,h),r,o,u)}),!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}.${u}`;At(mt.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,u)}}}}return Bj(r)}a(KL,"customValidate");WL.exports={addRoleValidation:Lj,alterRoleValidation:Mj,dropRoleValidation:Pj};function vj(e){let{operation:t,permission:r}=e;if(t===Sa.OPERATIONS_ENUM.ADD_ROLE||t===Sa.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 mt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Sa.ROLE_TYPES_ENUM.SUPER_USER:Sa.ROLE_TYPES_ENUM.CLUSTER_USER;return mt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(vj,"validateNoSUPerms");function Bj(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:mt.ROLE_PERMS_ERROR,...e};return Oj(new Error,n,yj.BAD_REQUEST)}else return null}a(Bj,"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 nT=g((hEe,jL)=>{"use strict";var zL=Fr(),JL=qr(),xj=ci(),ZS=QL(),eT=Ns(),Hj=require("uuid").v4,Gj=require("util"),$d=P(),qj=J(),tT=JL.searchByValue,Fj=JL.searchByHash,kj=Gj.promisify(xj.delete),Vj=ns(),$j=oa(),{hdb_errors:Yj,handleHDBError:_o}=se(),{HDB_ERROR_MSGS:XL,HTTP_STATUS_CODES:Nu}=Yj,{UserEventMsg:rT}=Pn();jL.exports={addRole:Kj,alterRole:Wj,dropRole:Qj,listRoles:zj};function jS(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(jS,"scrubRoleDetails");async function Kj(e){let t=ZS.addRoleValidation(e);if(t)throw t;e=jS(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 tT(r)||[])}catch(i){throw _o(i)}if(n&&n.length>0)throw _o(new Error,XL.ROLE_ALREADY_EXISTS(e.role),Nu.CONFLICT,void 0,void 0,!0);e.id||(e.id=Hj());let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await zL.insert(s),eT.signalUserChange(new rT(process.pid)),e=jS(e),e}a(Kj,"addRole");async function Wj(e){let t=ZS.alterRoleValidation(e);if(t)throw t;e=jS(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await zL.update(r)}catch(s){throw _o(s)}if(n&&n?.message==="updated 0 of 1 records")throw _o(new Error,"Invalid role id",Nu.BAD_REQUEST,void 0,void 0,!0);return await eT.signalUserChange(new rT(process.pid)),e}a(Wj,"alterRole");async function Qj(e){let t=ZS.dropRoleValidation(e);if(t)throw _o(new Error,t,Nu.BAD_REQUEST,void 0,void 0,!0);let r=new $j($d.SYSTEM_SCHEMA_NAME,$d.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await Fj(r));if(n.length===0)throw _o(new Error,XL.ROLE_NOT_FOUND,Nu.NOT_FOUND,void 0,void 0,!0);let s=new Vj($d.SYSTEM_SCHEMA_NAME,$d.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await tT(s)),o=!1;if(qj.isEmptyOrZeroLength(i)===!1){for(let u=0;u<i.length;u++)if(i[u].active===!0){o=!0;break}}if(o===!0)throw _o(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,Nu.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await kj(c),eT.signalUserChange(new rT(process.pid)),`${n[0].role} successfully deleted`}a(Qj,"dropRole");async function zj(){return tT({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(zj,"listRoles")});var rM=g((pEe,tM)=>{"use strict";var Jj=ee(),mi=require("joi"),Xj=je(),ZL=require("moment"),jj=require("fs-extra"),sT=require("path"),Zj=require("lodash"),Iu=P(),{LOG_LEVELS:fo}=P(),eZ="YYYY-MM-DD hh:mm:ss",tZ=sT.resolve(__dirname,"../logs");tM.exports=function(e){return Xj.validateBySchema(e,rZ)};var rZ=mi.object({from:mi.custom(eM),until:mi.custom(eM),level:mi.valid(fo.NOTIFY,fo.FATAL,fo.ERROR,fo.WARN,fo.INFO,fo.DEBUG,fo.TRACE),order:mi.valid("asc","desc"),limit:mi.number().min(1),start:mi.number().min(0),log_name:mi.custom(nZ)});function eM(e,t){if(ZL(e,ZL.ISO_8601).format(eZ)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(eM,"validateDatetime");function nZ(e,t){if(Zj.invert(Iu.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=Jj.get(Iu.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Iu.LOG_NAMES.HDB:e,i=s===Iu.LOG_NAMES.INSTALL?sT.join(tZ,Iu.LOG_NAMES.INSTALL):sT.join(n,s);return jj.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(nZ,"validateReadLogPath")});var oT=g((TEe,sM)=>{"use strict";var Yd=P(),sZ=$(),iZ=ee(),oZ=rM(),iT=require("path"),nM=require("fs-extra"),{once:aZ}=require("events"),{handleHDBError:cZ,hdb_errors:uZ}=se(),{PACKAGE_ROOT:lZ}=P(),_Z=iT.join(lZ,"logs"),dZ=1e3,fZ=200;sM.exports=EZ;async function EZ(e){let t=oZ(e);if(t)throw cZ(t,t.message,uZ.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=iZ.get(Yd.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?Yd.LOG_NAMES.HDB:e.log_name,s=n===Yd.LOG_NAMES.INSTALL?iT.join(_Z,Yd.LOG_NAMES.INSTALL):iT.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,u=c?new Date(e.from):void 0,_=e.until!==void 0,l=_?new Date(e.until):void 0,d=e.limit===void 0?dZ: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"&&!u&&!l&&(p=Math.max(nM.statSync(s).size-(h+5)*fZ,0));let S=nM.createReadStream(s,{start:p});S.on("error",U=>{sZ.error(U)});let T=0,A=[],y="",I;S.on("data",U=>{let F=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;U=y+U;let M=0,Q;for(;(Q=F.exec(U))&&!S.destroyed;){I&&(I.message=U.slice(M,Q.index),B(I));let[z,j,oe]=Q,ue=oe.split("] ["),le=ue[0],Be=ue[1];ue.splice(0,2),I={timestamp:j,thread:le,level:Be,tags:ue,message:""},M=Q.index+z.length}y=U.slice(M)}),S.on("end",U=>{S.destroyed||I&&(I.message=y.trim(),B(I))}),S.resume();function B(U){let F,M,Q;switch(!0){case(i&&c&&_):F=new Date(U.timestamp),M=new Date(u),Q=new Date(l),U.level===o&&F>=M&&F<=Q&&T<f?T++:U.level===o&&F>=M&&F<=Q&&(pi(U,E,A),T++,T===h&&S.destroy());break;case(i&&c):F=new Date(U.timestamp),M=new Date(u),U.level===o&&F>=M&&T<f?T++:U.level===o&&F>=M&&(pi(U,E,A),T++,T===h&&S.destroy());break;case(i&&_):F=new Date(U.timestamp),Q=new Date(l),U.level===o&&F<=Q&&T<f?T++:U.level===o&&F<=Q&&(pi(U,E,A),T++,T===h&&S.destroy());break;case(c&&_):F=new Date(U.timestamp),M=new Date(u),Q=new Date(l),F>=M&&F<=Q&&T<f?T++:F>=M&&F<=Q&&(pi(U,E,A),T++,T===h&&S.destroy());break;case i:U.level===o&&T<f?T++:U.level===o&&(pi(U,E,A),T++,T===h&&S.destroy());break;case c:F=new Date(U.timestamp),M=new Date(u),F>=M&&T<f?T++:F>=M&&T>=f&&(pi(U,E,A),T++,T===h&&S.destroy());break;case _:F=new Date(U.timestamp),Q=new Date(l),F<=Q&&T<f?T++:F<=Q&&T>=f&&(pi(U,E,A),T++,T===h&&S.destroy());break;default:T<f?T++:(pi(U,E,A),T++,T===h&&S.destroy())}}return a(B,"onLogMessage"),await aZ(S,"close"),A}a(EZ,"readLog");function pi(e,t,r){t==="desc"?hZ(e,r):t==="asc"?mZ(e,r):r.push(e)}a(pi,"pushLineToResult");function hZ(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(hZ,"insertDescending");function mZ(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(mZ,"insertAscending")});var Kd=g((bEe,cM)=>{"use strict";var aT=require("joi"),{string:wu,boolean:iM,date:pZ}=aT.types(),SZ=je(),{validateSchemaExists:REe,validateTableExists:AEe,validateSchemaName:OEe}=jn(),TZ=P(),gZ=Ve(),oM=ee();oM.initSync();var RZ=wu.invalid(oM.get(TZ.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(gZ.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(),aM={operation:wu.valid("add_node","update_node","set_node_replication"),node_name:RZ,subscriptions:aT.array().items({table:wu.optional(),schema:wu.optional(),database:wu.optional(),subscribe:iM.required(),publish:iM.required().custom(OZ),start_time:pZ.iso()}).min(1).required()};function AZ(e){return SZ.validateBySchema(e,aT.object(aM))}a(AZ,"addUpdateNodeValidator");function OZ(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(OZ,"checkForFalsy");cM.exports={addUpdateNodeValidator:AZ,validation_schema:aM}});var lM=g((NEe,uM)=>{var bZ=je(),yZ={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};uM.exports=function(e){return bZ.validateObject(e,yZ)}});var Wd=g((IEe,_M)=>{"use strict";var NZ=P().OPERATIONS_ENUM,cT=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=NZ.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};_M.exports=cT});var fM=g((CEe,dM)=>{"use strict";var IZ={OPERATION:"operation",REFRESH:"refresh"},uT=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},lT=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};dM.exports={JWTTokens:uT,TOKEN_TYPE_ENUM:IZ,JWTRSAKeys:lT}});var Lu=g((LEe,pM)=>{"use strict";var Du=require("jsonwebtoken"),_T=require("fs-extra"),dT=J(),dn=P(),{handleHDBError:Or,hdb_errors:wZ}=se(),{HTTP_STATUS_CODES:br,AUTHENTICATION_ERROR_MSGS:yr}=wZ,Cu=$(),EM=z_(),hT=_n(),CZ=Fr().update,DZ=Wd(),LZ=Ns(),{UserEventMsg:MZ}=Pn(),Si=ee();Si.initSync();var fT=require("path"),{JWTTokens:PZ,JWTRSAKeys:UZ,TOKEN_TYPE_ENUM:Qd}=fM(),vZ=Si.get(dn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?Si.get(dn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",BZ=Si.get(dn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?Si.get(dn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",zd="RS256",ET;pM.exports={createTokens:xZ,validateOperationToken:GZ,refreshOperationToken:HZ,validateRefreshToken:mM};async function xZ(e){if(dT.isEmpty(e)||typeof e!="object")throw Or(new Error,yr.INVALID_AUTH_OBJECT,br.BAD_REQUEST,void 0,void 0,!0);if(dT.isEmpty(e.username))throw Or(new Error,yr.USERNAME_REQUIRED,br.BAD_REQUEST,void 0,void 0,!0);if(dT.isEmpty(e.password))throw Or(new Error,yr.PASSWORD_REQUIRED,br.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await hT.findAndValidateUser(e.username,e.password),!t)throw Or(new Error,yr.INVALID_CREDENTIALS,br.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw Cu.error(E),Or(new Error,yr.INVALID_CREDENTIALS,br.UNAUTHORIZED,void 0,void 0,!0)}let r=await Jd(),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 hM(i,r.private_key,r.passphrase),c=await Du.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:BZ,algorithm:zd,subject:Qd.REFRESH}),u=EM.hash(c),_=new DZ(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]),l,d;try{l=await CZ(_)}catch(E){Cu.error(E),d=E}if(d!==void 0||l.skipped_hashes.length>0)throw Or(new Error,yr.REFRESH_TOKEN_SAVE_FAILED,br.INTERNAL_SERVER_ERROR);return LZ.signalUserChange(new MZ(process.pid)),new PZ(o,c)}a(xZ,"createTokens");async function hM(e,t,r){return await Du.sign(e,{key:t,passphrase:r},{expiresIn:vZ,algorithm:zd,subject:Qd.OPERATION})}a(hM,"signOperationToken");async function Jd(){if(ET===void 0)try{let e=fT.join(Si.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PASSPHRASE_NAME),t=fT.join(Si.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=fT.join(Si.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await _T.readFile(e)).toString(),s=(await _T.readFile(t)).toString(),i=(await _T.readFile(r)).toString();ET=new UZ(i,s,n)}catch(e){throw Cu.error(e),Or(new Error,yr.NO_ENCRYPTION_KEYS,br.INTERNAL_SERVER_ERROR)}return ET}a(Jd,"getJWTRSAKeys");async function HZ(e){if(!e)throw Or(new Error,yr.INVALID_BODY,br.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw Or(new Error,yr.REFRESH_TOKEN_REQUIRED,br.BAD_REQUEST,void 0,void 0,!0);await mM(e.refresh_token);let t=await Jd(),r=await Du.decode(e.refresh_token);return{operation_token:await hM({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(HZ,"refreshOperationToken");async function GZ(e){try{let t=await Jd(),r=await Du.verify(e,t.public_key,{algorithms:zd,subject:Qd.OPERATION});return await hT.findAndValidateUser(r.username,void 0,!1)}catch(t){throw Cu.warn(t),t.name&&t.name==="TokenExpiredError"?Or(new Error,yr.TOKEN_EXPIRED,br.FORBIDDEN):Or(new Error,yr.INVALID_TOKEN,br.UNAUTHORIZED)}}a(GZ,"validateOperationToken");async function mM(e){let t;try{let r=await Jd(),n=await Du.verify(e,r.public_key,{algorithms:zd,subject:Qd.REFRESH});t=await hT.findAndValidateUser(n.username,void 0,!1)}catch(r){throw Cu.warn(r),r.name&&r.name==="TokenExpiredError"?Or(new Error,yr.TOKEN_EXPIRED,br.FORBIDDEN):Or(new Error,yr.INVALID_TOKEN,br.UNAUTHORIZED)}if(!EM.validate(t.refresh_token,e))throw Or(new Error,yr.INVALID_TOKEN,br.UNAUTHORIZED);return t}a(mM,"validateRefreshToken")});var mT=g((UEe,gM)=>{"use strict";var qZ=lM(),ga=require("passport"),FZ=require("passport-local").Strategy,kZ=require("passport-http").BasicStrategy,VZ=require("util"),$Z=_n(),TM=VZ.callbackify($Z.findAndValidateUser),PEe=vr(),YZ=P(),SM=Lu();ga.use(new FZ(function(e,t,r){TM(e,t,r)}));ga.use(new kZ(function(e,t,r){TM(e,t,r)}));ga.serializeUser(function(e,t){t(null,e)});ga.deserializeUser(function(e,t){t(null,e)});function KZ(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":ga.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===YZ.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?SM.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):SM.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:ga.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(KZ,"authorize");function WZ(e,t){let r=qZ(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(WZ,"checkPermissions");gM.exports={authorize:KZ,checkPermissions:WZ}});var Ti=g((BEe,RM)=>{"use strict";var pT=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},ST=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};RM.exports={Node:pT,NodeSubscription:ST}});var OM=g((HEe,AM)=>{"use strict";var QZ=P().OPERATIONS_ENUM,TT=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=QZ.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};AM.exports=TT});var Mu=g((qEe,bM)=>{"use strict";var gT=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},RT=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)}};bM.exports={RemotePayloadObject:gT,RemotePayloadSubscription:RT}});var NM=g((kEe,yM)=>{"use strict";var AT=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}};yM.exports=AT});var CM=g((WEe,wM)=>{"use strict";var zZ=NM(),$Ee=ft(),IM=ze(),JZ=$(),{getSchemaPath:YEe,getTransactionAuditStorePath:KEe}=Xe(),{getDatabases:XZ}=(Ae(),ie(ke));wM.exports=jZ;async function jZ(e){let t=new zZ;try{let r=XZ()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats(),i=await IM.environmentDataSize(schema_path,e.name),o=await IM.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){JZ.warn(`unable to stat table dbi due to ${r}`)}return t}a(jZ,"lmdbGetTableSize")});var LM=g((zEe,DM)=>{"use strict";var OT=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}};DM.exports=OT});var Ra=g((the,vM)=>{"use strict";var ZZ=require("fs-extra"),e5=require("path"),or=require("systeminformation"),gi=$(),MM=ut(),XEe=Ve(),jd=P(),t5=CM(),r5=bs(),{getThreadInfo:PM}=Qe(),UT=ee();UT.initSync();var n5=LM(),{openEnvironment:jEe}=ze(),{getSchemaPath:ZEe}=Xe(),{database:ehe,databases:bT}=(Ae(),ie(ke)),Xd;vM.exports={getHDBProcessInfo:wT,getNetworkInfo:DT,getDiskInfo:CT,getMemoryInfo:IT,getCPUInfo:NT,getTimeInfo:yT,getSystemInformation:LT,systemInformation:s5,getTableSize:MT,getMetrics:PT};function yT(){return or.time()}a(yT,"getTimeInfo");async function NT(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:u,cache:_,...l}=await or.cpu();l.cpu_speed=await or.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,...A}=await or.currentLoad();return A.cpus=[],T.forEach(y=>{let{raw_load:I,raw_load_idle:B,raw_load_irq:U,raw_load_nice:F,raw_load_system:M,raw_load_user:Q,...z}=y;A.cpus.push(z)}),l.current_load=A,l}catch(e){return gi.error(`error in getCPUInfo: ${e}`),{}}}a(NT,"getCPUInfo");async function IT(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await or.mem();return Object.assign(s,process.memoryUsage())}catch(e){return gi.error(`error in getMemoryInfo: ${e}`),{}}}a(IT,"getMemoryInfo");async function wT(){let e={core:[],clustering:[]};try{let t=await or.processes(),r;try{r=Number.parseInt(await ZZ.readFile(e5.join(UT.get(jd.CONFIG_PARAMS.ROOTPATH),jd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===jd.NODE_ERROR_CODES.ENOENT)gi.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 gi.error(`error in getHDBProcessInfo: ${t}`),e}}a(wT,"getHDBProcessInfo");async function CT(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await or.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:u,..._}=await or.fsStats();return e.read_write=_,e.size=await or.fsSize(),e}catch(t){return gi.error(`error in getDiskInfo: ${t}`),e}}a(CT,"getDiskInfo");async function DT(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await or.networkInterfaceDefault(),e.latency=await or.inetChecksite("google.com"),(await or.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:u,ieee8021xAuth:_,ieee8021xState:l,carrier_changes:d,...E}=n;e.interfaces.push(E)}),(await or.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)}),e}catch(t){return gi.error(`error in getNetworkInfo: ${t}`),e}}a(DT,"getNetworkInfo");async function LT(){if(Xd!==void 0)return Xd;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await or.osInfo();e=c;let u=await or.versions("node, npm");return e.node_version=u.node,e.npm_version=u.npm,Xd=e,Xd}catch(t){return gi.error(`error in getSystemInformation: ${t}`),e}}a(LT,"getSystemInformation");async function MT(){let e=[],t=await r5.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await t5(n));return e}a(MT,"getTableSize");async function PT(){let e={};for(let t in bT){let r=e[t]={},n=r.tables={};for(let s in bT[t])try{let i=bT[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(u=>{let[_,l,d]=u.trim().split(" ");return{pid:_,thread:l,txnid:d}}),i.primaryStore.auditStore&&(r.audit=i.auditStore.getStats()));let o=i.primaryStore.getStats(),c={};for(let u of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[u]=o[u];n[s]=c}catch(i){gi.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(PT,"getMetrics");async function UM(){if(UT.get(jd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await MM.getNATSReferences(),t=await MM.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(UM,"getNatsStreamInfo");async function s5(e){let t=new n5;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await LT(),t.time=yT(),t.cpu=await NT(),t.memory=await IT(),t.disk=await CT(),t.network=await DT(),t.harperdb_processes=await wT(),t.table_size=await MT(),t.metrics=await PT(),t.threads=await PM(),t.replication=await UM(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await LT();break;case"time":t.time=yT();break;case"cpu":t.cpu=await NT();break;case"memory":t.memory=await IT();break;case"disk":t.disk=await CT();break;case"network":t.network=await DT();break;case"harperdb_processes":t.harperdb_processes=await wT();break;case"table_size":t.table_size=await MT();break;case"database_metrics":case"metrics":t.metrics=await PT();break;case"threads":t.threads=await PM();break;case"replication":t.replication=await UM();break;default:break}return t}a(s5,"systemInformation")});var ef=g((nhe,BM)=>{"use strict";BM.exports={version:i5,printVersion:o5};var Zd=fu();function i5(){if(Zd)return Zd.version}a(i5,"version");function o5(){Zd&&console.log(`HarperDB Version ${Zd.version}`)}a(o5,"printVersion")});var fn=g((ahe,qM)=>{"use strict";var a5=Fr(),vT=J(),c5=require("util"),Eo=P(),xM=ee();xM.initSync();var u5=mT(),HM=qr(),{Node:ihe,NodeSubscription:ohe}=Ti(),l5=oa(),_5=OM(),{RemotePayloadObject:d5,RemotePayloadSubscription:f5}=Mu(),{handleHDBError:E5,hdb_errors:h5}=se(),{HTTP_STATUS_CODES:m5,HDB_ERROR_MSGS:p5}=h5,S5=ns(),T5=Ra(),g5=ef(),{getDatabases:R5}=(Ae(),ie(ke)),A5=c5.promisify(u5.authorize),O5=HM.searchByHash,b5=HM.searchByValue;qM.exports={authHeaderToUser:y5,isEmpty:N5,getNodeRecord:I5,upsertNodeRecord:w5,buildNodePayloads:C5,checkClusteringEnabled:D5,getAllNodeRecords:L5,getSystemInfo:M5,reverseSubscription:GM};async function y5(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await A5(t,null),e}a(y5,"authHeaderToUser");function N5(e){return e==null}a(N5,"isEmpty");async function I5(e){let t=new l5(Eo.SYSTEM_SCHEMA_NAME,Eo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return O5(t)}a(I5,"getNodeRecord");async function w5(e){let t=new _5(Eo.SYSTEM_SCHEMA_NAME,Eo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return a5.upsert(t)}a(w5,"upsertNodeRecord");function GM(e){if(vT.isEmpty(e.subscribe)||vT.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(GM,"reverseSubscription");function C5(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:u,table:_}=c,l=vT.getTableHashAttribute(u,_),{subscribe:d,publish:E}=GM(c),f=R5()[u]?.[_],h=new f5(u,_,l,E,d,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new d5(r,t,s,n)}a(C5,"buildNodePayloads");function D5(){if(!xM.get(Eo.CONFIG_PARAMS.CLUSTERING_ENABLED))throw E5(new Error,p5.CLUSTERING_NOT_ENABLED,m5.BAD_REQUEST,void 0,void 0,!0)}a(D5,"checkClusteringEnabled");async function L5(){let e=new S5(Eo.SYSTEM_SCHEMA_NAME,Eo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await b5(e))}a(L5,"getAllNodeRecords");async function M5(){let e=await T5.getSystemInformation();return{hdb_version:g5.version(),node_version:e.node_version,platform:e.platform}}a(M5,"getSystemInfo")});var BT=g((uhe,QM)=>{"use strict";var tf=ut(),FM=J(),kM=Ve(),VM=P(),rf=$(),$M=yu(),P5=md(),{RemotePayloadObject:U5}=Mu(),{handleHDBError:YM,hdb_errors:v5}=se(),{HTTP_STATUS_CODES:KM}=v5,{NodeSubscription:WM}=Ti();QM.exports=B5;async function B5(e,t){let r;try{r=await tf.request(`${t}.${kM.REQUEST_SUFFIX}`,new U5(VM.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),rf.trace("Response from remote describe all request:",r)}catch(o){rf.error(`addNode received error from describe all request to remote node: ${o}`);let c=tf.requestErrorHandler(o,"add_node",t);throw YM(new Error,c,KM.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===kM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw YM(new Error,o,KM.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,u=o.database??o.schema??"data";if(u===VM.SYSTEM_SCHEMA_NAME){await tf.createLocalTableStream(u,c);let h=new WM(u,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let _=FM.doesSchemaExist(u),l=n[u]!==void 0,d=c?FM.doesTableExist(u,c):!0,E=c?n?.[u]?.[c]!==void 0:!0;if(!_&&!l||!d&&!E){s.push(o);continue}if(!_&&l&&(rf.trace(`addNode creating schema: ${u}`),await $M.createSchema({operation:"create_schema",schema:u})),!d&&E){rf.trace(`addNode creating table: ${c} in schema: ${u} with attributes ${JSON.stringify(n[u][c].attributes)}`);let h=new P5(u,c,n[u][c].hash_attribute);n[u][c].attributes&&(h.attributes=n[u][c].attributes),await $M.createTable(h)}await tf.createLocalTableStream(u,c);let f=new WM(u,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(B5,"reviewSubscriptions")});var af=g((_he,XM)=>{"use strict";var{handleHDBError:nf,hdb_errors:x5}=se(),{HTTP_STATUS_CODES:sf}=x5,{addUpdateNodeValidator:H5}=Kd(),of=$(),JM=P(),zM=Ve(),G5=J(),Pu=ut(),Uu=fn(),q5=ee(),F5=BT(),{Node:k5,NodeSubscription:V5}=Ti(),{broadcast:$5}=Qe(),Y5="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",K5="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",W5=q5.get(JM.CONFIG_PARAMS.CLUSTERING_NODENAME);XM.exports=Q5;async function Q5(e,t=!1){of.trace("addNode called with:",e),Uu.checkClusteringEnabled();let r=H5(e);if(r)throw nf(r,r.message,sf.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await Uu.getNodeRecord(n);if(!G5.isEmptyOrZeroLength(d))throw nf(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,sf.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await F5(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=Y5,o;let c=Uu.buildNodePayloads(s,W5,JM.OPERATIONS_ENUM.ADD_NODE,await Uu.getSystemInfo()),u=[];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,u.push(new V5(f.schema,f.table,f.publish,f.subscribe))}of.trace("addNode sending remote payload:",c);let _;try{_=await Pu.request(`${n}.${zM.REQUEST_SUFFIX}`,c)}catch(d){of.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 Pu.updateRemoteConsumer(p,n)}let E=Pu.requestErrorHandler(d,"add_node",n);throw nf(new Error,E,sf.INTERNAL_SERVER_ERROR,"error",E)}if(_.status===zM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${_.message}`;throw nf(new Error,d,sf.INTERNAL_SERVER_ERROR,"error",d)}of.trace(_);for(let d=0,E=s.length;d<E;d++){let f=s[d];await Pu.updateRemoteConsumer(f,n),f.subscribe===!0&&await Pu.updateConsumerIterator(f.schema,f.table,n,"start")}let l=new k5(n,u,_.system_info);return await Uu.upsertNodeRecord(l),$5({type:"nats_update"}),i.length>0?o.message=K5:o.message=`Successfully added '${n}' to manifest`,o}a(Q5,"addNode")});var GT=g((Ehe,eP)=>{"use strict";var{handleHDBError:xT,hdb_errors:z5}=se(),{HTTP_STATUS_CODES:HT}=z5,{addUpdateNodeValidator:J5}=Kd(),vu=$(),ZM=P(),jM=Ve(),fhe=J(),Bu=ut(),xu=fn(),X5=ee(),{cloneDeep:j5}=require("lodash"),Z5=BT(),{Node:e8,NodeSubscription:t8}=Ti(),{broadcast:r8}=Qe(),n8="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",s8="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",i8=X5.get(ZM.CONFIG_PARAMS.CLUSTERING_NODENAME);eP.exports=o8;async function o8(e){vu.trace("updateNode called with:",e),xu.checkClusteringEnabled();let t=J5(e);if(t)throw xT(t,t.message,HT.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await xu.getNodeRecord(r);s.length>0&&(n=j5(s));let{added:i,skipped:o}=await Z5(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=n8,c;let u=xu.buildNodePayloads(i,i8,ZM.OPERATIONS_ENUM.UPDATE_NODE,await xu.getSystemInfo());for(let l=0,d=i.length;l<d;l++){let E=i[l];vu.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[l].start_time===void 0&&delete i[l].start_time}vu.trace("updateNode sending remote payload:",u);let _;try{_=await Bu.request(`${r}.${jM.REQUEST_SUFFIX}`,u)}catch(l){vu.error(`updateNode received error from request: ${l}`);let d=Bu.requestErrorHandler(l,"update_node",r);throw xT(new Error,d,HT.INTERNAL_SERVER_ERROR,"error",d)}if(_.status===jM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let l=`Error returned from remote node ${r}: ${_.message}`;throw xT(new Error,l,HT.INTERNAL_SERVER_ERROR,"error",l)}vu.trace(_);for(let l=0,d=i.length;l<d;l++){let E=i[l];await Bu.updateRemoteConsumer(E,r),E.subscribe===!0?await Bu.updateConsumerIterator(E.schema,E.table,r,"start"):await Bu.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new e8(r,[],_.system_info)]),await a8(n[0],i,_.system_info),o.length>0?c.message=s8:c.message=`Successfully updated '${r}'`,c}a(o8,"updateNode");async function a8(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let u=0,_=e.subscriptions.length;u<_;u++){let l=n.subscriptions[u];if(l.schema===o.schema&&l.table===o.table){l.publish=o.publish,l.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new t8(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await xu.upsertNodeRecord(n),r8({type:"nats_update"})}a(a8,"updateNodeTable")});var iP=g((mhe,sP)=>{"use strict";var nP=require("joi"),{string:tP}=nP.types(),c8=je(),rP=P(),u8=ee(),l8=Ve();sP.exports=_8;function _8(e){let t=tP.invalid(u8.get(rP.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(l8.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=nP.object({operation:tP.valid(rP.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return c8.validateBySchema(e,r)}a(_8,"removeNodeValidator")});var uf=g((She,lP)=>{"use strict";var{handleHDBError:oP,hdb_errors:d8}=se(),{HTTP_STATUS_CODES:aP}=d8,f8=iP(),Hu=$(),cP=fn(),E8=J(),cf=P(),uP=Ve(),qT=ut(),h8=ee(),{RemotePayloadObject:m8}=Mu(),{NodeSubscription:p8}=Ti(),S8=aa(),T8=ci(),{broadcast:g8}=Qe(),R8=h8.get(cf.CONFIG_PARAMS.CLUSTERING_NODENAME);lP.exports=A8;async function A8(e){Hu.trace("removeNode called with:",e),cP.checkClusteringEnabled();let t=f8(e);if(t)throw oP(t,t.message,aP.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await cP.getNodeRecord(r);if(E8.isEmptyOrZeroLength(n))throw oP(new Error,`Node '${r}' was not found.`,aP.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new m8(cf.OPERATIONS_ENUM.REMOVE_NODE,R8,[]),i,o=!1;for(let u=0,_=n.subscriptions.length;u<_;u++){let l=n.subscriptions[u];l.subscribe===!0&&await qT.updateConsumerIterator(l.schema,l.table,r,"stop");try{await qT.updateRemoteConsumer(new p8(l.schema,l.table,!1,!1),r)}catch(d){Hu.error(d)}}try{i=await qT.request(`${r}.${uP.REQUEST_SUFFIX}`,s),Hu.trace("Remove node reply from remote node:",r,i)}catch(u){Hu.error("removeNode received error from request:",u),o=!0}let c=new S8(cf.SYSTEM_SCHEMA_NAME,cf.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await T8.deleteRecord(c),g8({type:"nats_update"}),i?.status===uP.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(Hu.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(A8,"removeNode")});var fP=g((ghe,dP)=>{"use strict";var _P=require("joi"),{string:O8,array:b8}=_P.types(),y8=je(),N8=Kd();dP.exports=I8;function I8(e){let t=_P.object({operation:O8.valid("configure_cluster").required(),connections:b8.items(N8.validation_schema).required()});return y8.validateBySchema(e,t)}a(I8,"configureClusterValidator")});var FT=g((Ahe,SP)=>{"use strict";var w8=P(),lf=$(),C8=J(),D8=uf(),L8=af(),EP=fn(),M8=fP(),{handleHDBError:hP,hdb_errors:P8}=se(),{HTTP_STATUS_CODES:mP}=P8,U8="Configure cluster complete.",v8="Failed to configure the cluster. Check the logs for more details.",B8="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";SP.exports=x8;async function x8(e){lf.trace("configure cluster called with:",e),EP.checkClusteringEnabled();let t=M8(e);if(t)throw hP(t,t.message,mP.BAD_REQUEST,void 0,void 0,!0);let r=await EP.getAllNodeRecords(),n=[];for(let l=0,d=r.length;l<d;l++){let E=await pP(D8,{operation:w8.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[l].name},r[l].name);n.push(E)}lf.trace("All results from configure_cluster remove node:",n);let s=[],i=e.connections.length;for(let l=0;l<i;l++){let d=e.connections[l],E=await pP(L8,d,d.node_name);s.push(E)}lf.trace("All results from configure_cluster add node:",s);let o=[],c=[],u=!1,_=n.concat(s);for(let l=0,d=_.length;l<d;l++){let E=_[l];E.status==="rejected"&&(lf.error(E),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(u=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,subscriptions:E?.result})}if(C8.isEmptyOrZeroLength(o))return{message:U8,connections:c};if(u)return{message:B8,failed_nodes:o,connections:c};throw hP(new Error,v8,mP.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(x8,"configureCluster");async function pP(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(pP,"functionWrapper")});var AP=g((bhe,RP)=>{"use strict";var Gu=require("joi"),H8=je(),{validateSchemaExists:TP,validateTableExists:G8,validateSchemaName:gP}=jn(),q8=Gu.object({operation:Gu.string().valid("purge_stream"),schema:Gu.string().custom(TP).custom(gP).optional(),database:Gu.string().custom(TP).custom(gP).optional(),table:Gu.string().custom(G8).required()});function F8(e){return H8.validateBySchema(e,q8)}a(F8,"purgeStreamValidator");RP.exports=F8});var kT=g((Nhe,OP)=>{"use strict";var{handleHDBError:k8,hdb_errors:V8}=se(),{HTTP_STATUS_CODES:$8}=V8,Y8=AP(),K8=ut(),W8=fn();OP.exports=Q8;async function Q8(e){e.schema=e.schema??e.database;let t=Y8(e);if(t)throw k8(t,t.message,$8.BAD_REQUEST,void 0,void 0,!0);W8.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await K8.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(Q8,"purgeStream")});var YT=g((whe,CP)=>{"use strict";var $T=fn(),z8=ut(),NP=ee(),_f=P(),ho=Ve(),J8=J(),VT=$(),{RemotePayloadObject:X8}=Mu(),{ErrorCode:bP}=require("nats"),yP=NP.get(_f.CONFIG_PARAMS.CLUSTERING_ENABLED),IP=NP.get(_f.CONFIG_PARAMS.CLUSTERING_NODENAME);CP.exports={clusterStatus:j8,buildNodeStatus:wP};async function j8(){let e={node_name:IP,is_enabled:yP,connections:[]};if(!yP)return e;let t=await $T.getAllNodeRecords();if(J8.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(wP(t[n],e.connections));return await Promise.allSettled(r),e}a(j8,"clusterStatus");async function wP(e,t){let r=e.name,n=new X8(_f.OPERATIONS_ENUM.CLUSTER_STATUS,IP,void 0,await $T.getSystemInfo()),s,i,o=ho.CLUSTER_STATUS_STATUSES.OPEN;try{let u=Date.now();s=await z8.request(ho.REQUEST_SUBJECT(r),n),i=Date.now()-u,s.status===ho.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=ho.CLUSTER_STATUS_STATUSES.CLOSED,VT.error(`Error getting node status from ${r} `,s))}catch(u){VT.warn(`Error getting node status from ${r}`,u),u.code===bP.NoResponders?o=ho.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:u.code===bP.Timeout?o=ho.CLUSTER_STATUS_STATUSES.TIMEOUT:o=ho.CLUSTER_STATUS_STATUSES.CLOSED}let c=new Z8(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let u={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==_f.PRE_4_0_0_VERSION&&await $T.upsertNodeRecord(u)}catch(u){VT.error("Cluster status encountered an error updating system info for node:",r,u)}t.push(c)}a(wP,"buildNodeStatus");function Z8(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(Z8,"NodeStatusObject")});var WT=g((Dhe,DP)=>{"use strict";var{handleHDBError:e6,hdb_errors:t6}=se(),{HTTP_STATUS_CODES:r6}=t6,n6=ut(),s6=fn(),KT=J(),df=require("joi"),i6=je(),o6=2e3,a6=df.object({timeout:df.number().min(1),connected_nodes:df.boolean(),routes:df.boolean()});DP.exports=c6;async function c6(e){s6.checkClusteringEnabled();let t=i6.validateBySchema(e,a6);if(t)throw e6(t,t.message,r6.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||KT.autoCastBoolean(n),o=s===void 0||KT.autoCastBoolean(s),c={nodes:[]},u=await n6.getServerList(r??o6),_={};if(i)for(let l=0,d=u.length;l<d;l++){let E=u[l].statsz;E&&(_[u[l].server.name]=E.routes)}for(let l=0,d=u.length;l<d;l++){if(u[l].statsz)continue;let E=u[l].server,f=u[l].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:u[l].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:KT.autoCast(p.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(c6,"clusterNetwork")});var UP=g((Mhe,PP)=>{"use strict";var QT=require("joi"),LP=je(),{route_constraints:MP}=lp();PP.exports={setRoutesValidator:u6,deleteRoutesValidator:l6};function u6(e){let t=QT.object({server:QT.valid("hub","leaf").required(),routes:MP.required()});return LP.validateBySchema(e,t)}a(u6,"setRoutesValidator");function l6(e){let t=QT.object({routes:MP.required()});return LP.validateBySchema(e,t)}a(l6,"deleteRoutesValidator")});var JT=g((Uhe,HP)=>{"use strict";var mo=pr(),zT=J(),ff=P(),vP=UP(),{handleHDBError:BP,hdb_errors:_6}=se(),{HTTP_STATUS_CODES:xP}=_6,d6="cluster routes successfully set",f6="cluster routes successfully deleted";HP.exports={setRoutes:E6,getRoutes:h6,deleteRoutes:m6};function E6(e){let t=vP.setRoutesValidator(e);if(t)throw BP(t,t.message,xP.BAD_REQUEST,void 0,void 0,!0);let r=mo.getClusteringRoutes(),n=e.server==="hub"?r.hub_routes:r.leaf_routes,s=e.server==="hub"?r.leaf_routes:r.hub_routes,i=[],o=[];for(let c=0,u=e.routes.length;c<u;c++){let _=e.routes[c];_.port=zT.autoCast(_.port);let l=n.some(E=>E.host===_.host&&E.port===_.port),d=s.some(E=>E.host===_.host&&E.port===_.port);l||d?i.push(_):(n.push(_),o.push(_))}return e.server==="hub"?mo.updateConfigValue(ff.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n):mo.updateConfigValue(ff.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n),{message:d6,set:o,skipped:i}}a(E6,"setRoutes");function h6(){let e=mo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}a(h6,"getRoutes");function m6(e){let t=vP.deleteRoutesValidator(e);if(t)throw BP(t,t.message,xP.BAD_REQUEST,void 0,void 0,!0);let r=mo.getClusteringRoutes(),n=r.hub_routes,s=r.leaf_routes,i=[],o=[],c=!1,u=!1;for(let _=0,l=e.routes.length;_<l;_++){let d=e.routes[_],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),u=!0,f=!1,i.push(d);break}}f&&o.push(d)}}return c&&(n=zT.isEmptyOrZeroLength(n)?null:n,mo.updateConfigValue(ff.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n)),u&&(s=zT.isEmptyOrZeroLength(s)?null:s,mo.updateConfigValue(ff.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,s)),{message:f6,deleted:i,skipped:o}}a(m6,"deleteRoutes")});var qP=g((Bhe,GP)=>{"use strict";var qu=require("alasql"),po=require("recursive-iterator"),Hn=$(),p6=J(),Fu=P(),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,T6(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=>Fu.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=>!Fu.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][Fu.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=S6(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(_=>({attribute_name:_.attribute}));let u=this.affected_attributes.get(i).get(o).filter(_=>!Fu.SEARCH_WILDCARDS.includes(_));c.forEach(({attribute_name:_})=>{let l=new qu.yy.Column({columnid:_});s.tableid&&(l.tableid=s.tableid),this.ast.columns.push(l),u.includes(_)||u.push(_)}),this.affected_attributes.get(i).set(o,u)}}),this.ast}};function S6(e){return e.filter(t=>t[Fu.PERMS_CRUD_ENUM.READ])}a(S6,"filterReadRestrictedAttrs");function T6(e,t,r,n,s){g6(e,t,r,n,s)}a(T6,"interpretAST");function ku(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(ku,"addSchemaTableToMap");function g6(e,t,r,n,s){if(!e){Hn.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof qu.yy.Insert?b6(e,t,r):e instanceof qu.yy.Select?R6(e,t,r,n,s):e instanceof qu.yy.Update?A6(e,t,r):e instanceof qu.yy.Delete?O6(e,t,r):Hn.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(g6,"getRecordAttributesAST");function R6(e,t,r,n,s){if(!e){Hn.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(p6.isEmptyOrZeroLength(i)){Hn.error("No schema specified");return}e.from.forEach(c=>{ku(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),ku(c.table,t,r,n,s)});let o=new po(e.columns);for(let{node:c}of o)if(c&&c.columnid){let u=c.tableid,_=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(_).has(u))if(r.has(u))u=r.get(u);else{Hn.info(`table specified as ${u} not found.`);return}t.get(_).get(u).indexOf(c.columnid)<0&&t.get(_).get(u).push(c.columnid)}if(e.where){let c=new po(e.where),u=e.from[0].tableid;for(let{node:_}of c)if(_&&_.columnid){let l=_.tableid?_.tableid:u;if(!t.get(i).has(l))if(r.has(l))l=r.get(l);else{Hn.info(`table specified as ${l} not found.`);continue}t.get(i).get(l).indexOf(_.columnid)<0&&t.get(i).get(l).push(_.columnid)}}if(e.joins&&e.joins.forEach(c=>{let u=new po(c.on);for(let{node:_}of u)if(_&&_.columnid){let l=_.tableid,d=s.get(l);if(!t.get(d).has(l))if(r.has(l))l=r.get(l);else{Hn.info(`table specified as ${l} not found.`);continue}t.get(d).get(l).indexOf(_.columnid)<0&&t.get(d).get(l).push(_.columnid)}}),e.order){let c=new po(e.order);for(let{node:u}of c)if(u&&u.columnid){let _=u.tableid,l=n.has(_)?n.get(_):i;if(_||(_=e.from[0].tableid),!t.get(l).has(_))if(r.has(_))_=r.get(_);else{Hn.info(`table specified as ${_} not found.`);return}t.get(l).get(_).indexOf(u.columnid)<0&&t.get(l).get(_).push(u.columnid)}}}a(R6,"getSelectAttributes");function A6(e,t,r){if(!e){Hn.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new po(e.columns),s=e.table.databaseid;ku(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&jT(e.table.tableid,s,i.columnid,t,r)}a(A6,"getUpdateAttributes");function O6(e,t,r){if(!e){Hn.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new po(e.where),s=e.table.databaseid;ku(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&jT(e.table.tableid,s,i.columnid,t,r)}a(O6,"getDeleteAttributes");function b6(e,t,r){if(!e){Hn.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new po(e.columns),s=e.into.databaseid;ku(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&jT(e.into.tableid,s,i.columnid,t,r)}a(b6,"getInsertAttributes");function jT(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(jT,"pushAttribute");GP.exports=XT});var tg=g((Hhe,$P)=>{var Ef=ji(),FP=require("chalk"),zr=$(),kP=require("prompt"),{promisify:y6}=require("util"),ZT=P(),N6=require("fs-extra"),I6=require("path"),w6=J(),C6=ef(),VP=ee();VP.initSync();var D6=require("moment"),L6=y6(kP.get),M6=I6.join(VP.getHdbBasePath(),ZT.LICENSE_KEY_DIR_NAME,ZT.LICENSE_FILE_NAME,ZT.LICENSE_FILE_NAME);$P.exports={getFingerprint:U6,setLicense:P6,parseLicense:eg,register:v6,getRegistrationInfo:x6};async function P6(e){if(e&&e.key&&e.company){try{zr.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await eg(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw zr.error(r),zr.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(P6,"setLicense");async function U6(){let e={};try{e=await Ef.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw zr.error(r),zr.error(t),new Error(r)}return e}a(U6,"getFingerprint");async function eg(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");zr.info("Validating license input...");let r=Ef.validateLicense(e,t);if(zr.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(zr.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(zr.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{zr.info("writing license to disk"),await N6.writeFile(M6,JSON.stringify({license_key:e,company:t}))}catch(n){throw zr.error("Failed to write License"),n}return"Registration successful."}a(eg,"parseLicense");async function v6(){let e=await B6();return eg(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(v6,"register");async function B6(){let e=await Ef.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:FP.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:FP.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{kP.start()}catch(n){zr.error(n)}let r;try{r=await L6(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(B6,"promptForRegistration");async function x6(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await Ef.getLicense()}catch(r){throw zr.error(`There was an error when searching licenses due to: ${r.message}`),r}if(w6.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=C6.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=D6.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(x6,"getRegistrationInfo")});var KP=g((qhe,YP)=>{"use strict";var H6=Ve(),rg=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,u,_,l,d,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+H6.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:u},this.leafnodes={port:_,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:l,port:d,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:u}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};YP.exports=rg});var zP=g((khe,QP)=>{"use strict";var WP=Ve(),ng=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,u,_,l,d){this.port=t,d===null&&(d=void 0),this.server_name=r+WP.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+WP.SERVER_SUFFIX.LEAF},this.tls={cert_file:_,key_file:l,ca_file:d,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:d,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:d,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:u,jetstream:"enabled"}},this.system_account="SYS"}};QP.exports=ng});var XP=g(($he,JP)=>{"use strict";var sg=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};JP.exports=sg});var ZP=g((Khe,jP)=>{"use strict";var G6=Ve(),ig=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+G6.SERVER_SUFFIX.ADMIN,this.password=r}};jP.exports=ig});var cg=g((Qhe,rU)=>{"use strict";var Aa=require("path"),pf=require("fs-extra"),q6=KP(),F6=zP(),k6=XP(),V6=ZP(),og=_n(),ba=J(),Nr=pr(),mf=P(),Vu=Ve(),{CONFIG_PARAMS:pt}=mf,ya=$(),$u=ee(),eU=Os(),ag=ut(),Oa="clustering",$6=1e4,tU=50;rU.exports={generateNatsConfig:K6,removeNatsConfig:W6,getHubConfigPath:Y6};function Y6(){let e=$u.get(pt.ROOTPATH);return Aa.join(e,Oa,Vu.NATS_CONFIG_FILES.HUB_SERVER)}a(Y6,"getHubConfigPath");async function K6(e=!1,t=void 0){$u.initSync();let r=$u.get(pt.ROOTPATH),n=Aa.join(r,Oa,Vu.PID_FILES.HUB),s=Aa.join(r,Oa,Vu.PID_FILES.LEAF),i=Nr.getConfigFromFile(pt.CLUSTERING_LEAFSERVER_STREAMS_PATH),o=Aa.join(r,Oa,Vu.NATS_CONFIG_FILES.HUB_SERVER),c=Aa.join(r,Oa,Vu.NATS_CONFIG_FILES.LEAF_SERVER),u=Nr.getConfigFromFile(pt.CLUSTERING_TLS_CERTIFICATE),_=Nr.getConfigFromFile(pt.CLUSTERING_TLS_PRIVATEKEY),l=Nr.getConfigFromFile(pt.CLUSTERING_TLS_CERT_AUTH),d=Nr.getConfigFromFile(pt.CLUSTERING_TLS_INSECURE),E=Nr.getConfigFromFile(pt.CLUSTERING_TLS_VERIFY),f=Nr.getConfigFromFile(pt.CLUSTERING_NODENAME),h=Nr.getConfigFromFile(pt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await ag.checkNATSServerInstalled()||Sf("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let p=await og.listUsers(),S=Nr.getConfigFromFile(pt.CLUSTERING_USER),T=await og.getClusterUser();(ba.isEmpty(T)||T.active!==!0)&&Sf(`Invalid cluster user '${S}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await hf(pt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await hf(pt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await hf(pt.CLUSTERING_HUBSERVER_NETWORK_PORT),await hf(pt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let A=[],y=[];for(let[z,j]of p.entries())j.role?.role===mf.ROLE_TYPES_ENUM.CLUSTER_USER&&j.active&&(A.push(new V6(j.username,eU.decrypt(j.hash))),y.push(new k6(j.username,eU.decrypt(j.hash))));let I=[],{hub_routes:B}=Nr.getClusteringRoutes();if(!ba.isEmptyOrZeroLength(B))for(let z of B)I.push(`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@${z.host}:${z.port}`);let U=new q6(Nr.getConfigFromFile(pt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,n,u,_,l,d,E,h,Nr.getConfigFromFile(pt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Nr.getConfigFromFile(pt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),I,A,y);l==null&&(delete U.tls.ca_file,delete U.leafnodes.tls.ca_file),t=ba.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===mf.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await pf.writeJson(o,U),ya.trace(`Hub server config written to ${o}`));let F=`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 F6(Nr.getConfigFromFile(pt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,s,i,[F],[M],A,y,u,_,l,d);l==null&&delete Q.tls.ca_file,(t===void 0||t===mf.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await pf.writeJson(c,Q),ya.trace(`Leaf server config written to ${c}`))}a(K6,"generateNatsConfig");async function hf(e){let t=$u.get(e);return ba.isEmpty(t)&&Sf(`port undefined for '${e}'`),await ba.isPortTaken(t)&&Sf(`'${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(hf,"isPortAvailable");function Sf(e){let t=`Error generating clustering config: ${e}`;ya.error(t),console.error(t),process.exit(1)}a(Sf,"generateNatsConfigError");async function W6(e){let{port:t,config_file:r}=ag.getServerConfig(e),{username:n,decrypt_hash:s}=await og.getClusterUser(),i=0,o=2e3;for(;i<tU;){try{let l=await ag.createConnection(t,n,s,!1);if(l.protocol.connected===!0){l.close();break}}catch(l){ya.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${l}`)}if(i++,i>=tU)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&&ya.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await ba.async_set_timeout(_)}let c="0".repeat($6),u=Aa.join($u.get(pt.ROOTPATH),Oa,r);await pf.writeFile(u,c),await pf.remove(u),ya.notify(e,"started.")}a(W6,"removeNatsConfig")});var cU=g((Jhe,aU)=>{"use strict";var Jr=ee(),Q6=ji(),pe=P(),Yu=Ve(),Ls=require("path"),{PACKAGE_ROOT:gf}=P(),nU=ee(),Tf=J(),Na="/dev/null",z6=Ls.join(gf,"launchServiceScripts"),sU=Ls.join(gf,"utility/scripts"),J6=Ls.join(sU,pe.HDB_RESTART_SCRIPT),iU=Ls.resolve(gf,"dependencies",`${process.platform}-${process.arch}`,Yu.NATS_BINARY_NAME);function oU(){let t=Q6.licenseSearch().ram_allocation||pe.RAM_ALLOCATION_ENUM.DEFAULT,r=pe.MEM_SETTING_KEY+t,n={[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Tf.noBootFile()&&(n[pe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Tf.getEnvCliRootPath()),{name:pe.PROCESS_DESCRIPTORS.HDB,script:pe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:gf}}a(oU,"generateMainServerConfig");var X6=9930;function j6(){Jr.initSync(!0);let e=Jr.get(pe.CONFIG_PARAMS.ROOTPATH),t=Ls.join(e,"clustering",Yu.NATS_CONFIG_FILES.HUB_SERVER),r=Ls.join(Jr.get(pe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),pe.LOG_NAMES.HDB),n=nU.get(pe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Yu.LOG_LEVEL_FLAGS[Jr.get(pe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==X6?"-"+n:""),script:iU,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Jr.get(pe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Na,i.error_file=Na),i}a(j6,"generateNatsHubServerConfig");var Z6=9940;function e9(){Jr.initSync(!0);let e=Jr.get(pe.CONFIG_PARAMS.ROOTPATH),t=Ls.join(e,"clustering",Yu.NATS_CONFIG_FILES.LEAF_SERVER),r=Ls.join(Jr.get(pe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),pe.LOG_NAMES.HDB),n=nU.get(pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Yu.LOG_LEVEL_FLAGS[Jr.get(pe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Z6?"-"+n:""),script:iU,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Jr.get(pe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Na,i.error_file=Na),i}a(e9,"generateNatsLeafServerConfig");function t9(){Jr.initSync();let e=Ls.join(Jr.get(pe.CONFIG_PARAMS.LOGGING_ROOT),pe.LOG_NAMES.HDB),t={name:pe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:pe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:z6,autorestart:!1};return Jr.get(pe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Na,t.error_file=Na),t}a(t9,"generateClusteringUpgradeV4ServiceConfig");function r9(){let e={[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.RESTART_HDB};return Tf.noBootFile()&&(e[pe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Tf.getEnvCliRootPath()),{...{name:pe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:sU},script:J6}}a(r9,"generateRestart");function n9(){return{apps:[oU()]}}a(n9,"generateAllServiceConfigs");aU.exports={generateAllServiceConfigs:n9,generateMainServerConfig:oU,generateRestart:r9,generateNatsHubServerConfig:j6,generateNatsLeafServerConfig:e9,generateClusteringUpgradeV4ServiceConfig:t9}});var OU=g((Zhe,AU)=>{"use strict";var ve=P(),s9=J(),Ps=cg(),Rf=ut(),Ms=Ve(),Ri=cU(),Af=ee(),Ai=$(),i9=fn(),{startWorker:uU,onMessageFromWorkers:o9}=Qe(),a9=Ra(),jhe=require("util"),c9=require("child_process"),u9=require("fs"),{execFile:l9}=c9,we;AU.exports={enterPM2Mode:_9,start:Oi,stop:ug,reload:_U,restart:dU,list:lg,describe:hU,connect:Us,kill:m9,startAllServices:p9,startService:_g,getUniqueServicesList:mU,restartAllServices:S9,isServiceRegistered:pU,reloadStopStart:SU,restartHdb:EU,deleteProcess:E9,startClusteringProcesses:gU,startClusteringThreads:RU,isHdbRestartRunning:h9,isClusteringRunning:g9,stopClustering:T9,reloadClustering:R9,expectedRestartOfChildren:fU};var Ku=!1;o9(e=>{e.type==="restart"&&Af.initSync(!0)});function _9(){Ku=!0}a(_9,"enterPM2Mode");function Us(){return we||(we=require("pm2")),new Promise((e,t)=>{we.connect((r,n)=>{Ai.setupConsoleLogging(),r&&t(r),e(n)})})}a(Us,"connect");var ar,d9=10,lU;function Oi(e,t=!1){if(Ku)return f9(e);let r=l9(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=ar.indexOf(r);o>-1&&ar.splice(o,1),!lU&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<d9&&(u9.existsSync(Ps.getHubConfigPath())?Oi(e):(await Ps.generateNatsConfig(!0),Oi(e),await new Promise(c=>setTimeout(c,3e3)),await Ps.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Ps.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Af.get(ve.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,u,_=0,l;for(;u=c.exec(i);){if(u.index&&Ms.LOG_LEVEL_HIERARCHY[o]>=Ms.LOG_LEVEL_HIERARCHY[l||"info"]){let f=l===Ms.LOG_LEVELS.ERR||l===Ms.LOG_LEVELS.WRN?Ai.OUTPUTS.STDERR:Ai.OUTPUTS.STDOUT;Ai.logCustomLevel(l||"info",f,n,i.slice(_,u.index).trim())}let[d,E]=u;_=u.index+d.length,l=Ms.LOG_LEVELS[E]}if(Ms.LOG_LEVEL_HIERARCHY[o]>=Ms.LOG_LEVEL_HIERARCHY[l||"info"]){let d=l===Ms.LOG_LEVELS.ERR||l===Ms.LOG_LEVELS.WRN?Ai.OUTPUTS.STDERR:Ai.OUTPUTS.STDOUT;Ai.logCustomLevel(l||"info",d,n,i.slice(_).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!ar&&(ar=[],!t)){let i=a(()=>{lU=!0,ar&&(ar.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)}ar.push(r)}a(Oi,"start");function f9(e){return new Promise(async(t,r)=>{try{await Us()}catch(n){r(n)}we.start(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(f9,"startWithPM2");function ug(e){if(!Ku){for(let t of ar||[])t.name===e&&(ar.splice(ar.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Us()}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(ug,"stop");function _U(e){return new Promise(async(t,r)=>{try{await Us()}catch(n){r(n)}we.reload(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(_U,"reload");function dU(e){if(!Ku){fU();for(let t of ar||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await Us()}catch(n){r(n)}we.restart(e,(n,s)=>{we.disconnect(),t(s)})})}a(dU,"restart");function fU(){for(let e of ar||[])e.config&&(e.config.restarts=0)}a(fU,"expectedRestartOfChildren");function E9(e){return new Promise(async(t,r)=>{try{await Us()}catch(n){r(n)}we.delete(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(E9,"deleteProcess");async function EU(){await Oi(Ri.generateRestart())}a(EU,"restartHdb");async function h9(){let e=await lg();for(let t in e)if(e[t].name===ve.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(h9,"isHdbRestartRunning");function lg(){return new Promise(async(e,t)=>{try{await Us()}catch(r){t(r)}we.list((r,n)=>{r&&(we.disconnect(),t(r)),we.disconnect(),e(n)})})}a(lg,"list");function hU(e){return new Promise(async(t,r)=>{try{await Us()}catch(n){r(n)}we.describe(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(hU,"describe");function m9(){if(!Ku){for(let e of ar||[])e.kill();ar=[];return}return new Promise(async(e,t)=>{try{await Us()}catch(r){t(r)}we.killDaemon((r,n)=>{r&&(we.disconnect(),t(r)),we.disconnect(),e(n)})})}a(m9,"kill");async function p9(){try{await gU(),await RU(),await Oi(Ri.generateAllServiceConfigs())}catch(e){throw we?.disconnect(),e}}a(p9,"startAllServices");async function _g(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case ve.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ri.generateMainServerConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ri.generateNatsIngestServiceConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ri.generateNatsReplyServiceConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ri.generateNatsHubServerConfig(),await Oi(r,t),await Ps.removeNatsConfig(e);return;case ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ri.generateNatsLeafServerConfig(),await Oi(r,t),await Ps.removeNatsConfig(e);return;case ve.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ri.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Oi(r)}catch(r){throw we?.disconnect(),r}}a(_g,"startService");async function mU(){try{let e=await lg(),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(mU,"getUniqueServicesList");async function S9(e=[]){try{let t=!1,r=await mU();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===ve.PROCESS_DESCRIPTORS.HDB?t=!0:await dU(o))}t&&await SU(ve.PROCESS_DESCRIPTORS.HDB)}catch(t){throw we?.disconnect(),t}}a(S9,"restartAllServices");async function pU(e){if(ar?.find(r=>r.name===e))return!0;let t=await a9.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(pU,"isServiceRegistered");async function SU(e){let t=Af.get(ve.CONFIG_PARAMS.THREADS_COUNT)??Af.get(ve.CONFIG_PARAMS.THREADS),r=await hU(e),n=s9.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await ug(e),await _g(e)):e===ve.PROCESS_DESCRIPTORS.HDB?await EU():await _U(e)}a(SU,"reloadStopStart");var TU;async function gU(e=!1){for(let t in ve.CLUSTERING_PROCESSES){let r=ve.CLUSTERING_PROCESSES[t];await _g(r,e)}}a(gU,"startClusteringProcesses");async function RU(){TU=uU(ve.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:ve.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await Rf.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await Rf.updateLocalStreams();let e=await i9.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===ve.PRE_4_0_0_VERSION){Ai.info("Starting clustering upgrade 4.0.0 process"),uU(ve.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(RU,"startClusteringThreads");async function T9(){for(let e in ve.CLUSTERING_PROCESSES)if(e!==ve.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===ve.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await TU.terminate();else{let t=ve.CLUSTERING_PROCESSES[e];await ug(t)}}a(T9,"stopClustering");async function g9(){for(let e in ve.CLUSTERING_PROCESSES){let t=ve.CLUSTERING_PROCESSES[e];if(await pU(t)===!1)return!1}return!0}a(g9,"isClusteringRunning");async function R9(){await Ps.generateNatsConfig(!0),await Rf.reloadNATSHub(),await Rf.reloadNATSLeaf(),await Ps.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await Ps.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(R9,"reloadClustering")});var DU={};Fe(DU,{compactOnStart:()=>A9,copyDb:()=>CU});async function A9(){Qu.notify("Running compact on start"),console.log("Running compact on start");let e=(0,dg.get)(bi.CONFIG_PARAMS.ROOTPATH),t=new Map,r=Tr();try{for(let n in r){if(n==="system")continue;let s;for(let u in r[n]){s=r[n][u].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,Of.join)(e,"backup",n+".mdb"),o=(0,Of.join)(e,bi.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await bU(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 CU(n,o),console.log("Backing up",n,"to",i),await(0,So.move)(s,i,{overwrite:!0})}Wu();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,So.move)(i,s,{overwrite:!0}),await(0,So.remove)((0,Of.join)(e,bi.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));Wu()}catch(n){Qu.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,fg.updateConfigValue)(bi.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,So.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Wu(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await bU(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let u=`There is a discrepancy between pre and post compact record count for database ${n}.
|
|
13
13
|
Total record count before compaction: ${i}, total after: ${c}.
|
|
14
|
-
Database backup has not been removed and can be found here: ${s}`;
|
|
15
|
-
${r.stack}`;throw pg.error(n),xU(new Error)}}}a(B9,"getRolePermissions");function x9(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]=H9(t[i]);return}r[i]=FU(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],u=t[i][o],_=G9(c,u);r[i].describe||VU.forEach(l=>{_[l]&&(r[i].describe=!0)}),r[i].tables[o]=_}else r[i].tables[o]=Sg()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=Sg()})}),r}a(x9,"translateRolePermissions");function H9(e){let t=FU(!0);return Object.keys(e).forEach(r=>{t.tables[r]=Sg(!0,!0,!0,!0,!0)}),t}a(H9,"createStructureUserPermissions");function G9(e,t){let{attribute_permissions:r}=e;if(r.length>0){let s=Object.assign({},e);s.attribute_permissions=[];let i=r.reduce((_,l)=>{let{attribute_name:d}=l,E=l;return Ir.TIME_STAMP_NAMES.includes(d)&&(E=GU(d,l[ju])),_[d]=E,_},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],u=HU(o);return t.attributes.forEach(({attribute:_})=>{if(i[_]){let l=i[_];l.describe=YU(l),s.attribute_permissions.push(l),c||q9(l,u)}else if(_!==o){let l;Ir.TIME_STAMP_NAMES.includes(_)?l=GU(_):l=HU(_),s.attribute_permissions.push(l)}}),c||s.attribute_permissions.push(u),s.describe=qU(s),s}else return e.describe=qU(e),e}a(G9,"getTableAttrPerms");function qU(e){return VU.filter(t=>e[t]).length>0}a(qU,"getSchemaTableDescribePerm");function YU(e){return $U.filter(t=>e[t]).length>0}a(YU,"getAttributeDescribePerm");function q9(e,t){$U.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(q9,"checkForHashPerms")});var QU={};Fe(QU,{Resources:()=>Df,keyArrayToString:()=>wa,resetResources:()=>F9,resources:()=>yi});function F9(){return yi=new Df}function wa(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var Df,yi,Zu=Re(()=>{so();Df=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,type:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s)throw new Error(`Conflicting paths for ${t}`);super.set(t,i);for(let[c,u]of this){let _=2;for(;(_=c.indexOf("/",_))>-1;){let l=this.get(c.slice(0,_));l&&(l.hasSubPaths=!0),_+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),u=this.get(c);if(!u&&c.indexOf(".")>-1){let _=c.split(".");u=this.get(_[0])}if(u){if(u.relativeURL=t.slice(n),!u.hasSubPaths)return u;s=u}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),!s&&o.indexOf(".")>-1&&(s=this.get(o.split(".")[0])),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 rt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(F9,"resetResources");a(wa,"keyArrayToString")});var zU={};Fe(zU,{Headers:()=>Ni,appendHeader:()=>Lf});function Lf(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 Ni,el=Re(()=>{Ni=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(Lf,"appendHeader")});var tl={};Fe(tl,{authentication:()=>nv,bypassAuth:()=>Q9,login:()=>J9,logout:()=>X9,start:()=>z9});function Q9(){rv=!0}async function nv(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let f=e.isOperationsServer?Y9?$9:[]:V9?k9:[];if(f.includes(i)||f.includes("*")){if(e.method==="OPTIONS"){let h=new Ni([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Mf&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Mf&&o.push("Access-Control-Allow-Credentials","true")}}let u,_;if(Mf){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(";");u=p.slice(f.length,S===-1?p.length:S),_=await XU.get(u);break}e.session=_||(_={})}let l=a((f,h,p)=>{let S=new Ca.AuthAuditLog(f,h,Gt.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);S.auth_strategy=p,u&&(S.session_id=u),r.referer&&(S.referer=r.referer),r.origin&&(S.origin=r.origin),h===Gt.AUTH_AUDIT_STATUS.SUCCESS?JU.notify(S):JU.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 at.getUser(f,null,null),l(f,Gt.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,Ca.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=go.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 A=atob(p),b=A.indexOf(":");S=A.slice(0,b),T=A.slice(b+1),d=S||T?await at.getUser(S,T,e):null;break;case"Bearer":try{d=await(0,Pf.validateOperationToken)(p)}catch(I){if(I.message==="invalid token")try{return await(0,Pf.validateRefreshToken)(p),c({status:-1})}catch{throw I}}break}}catch(A){return W9&&(go.get(p)||(go.set(p,p),l(S,Gt.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:Ro({error:A.message},e)})}go.set(n,d),K9&&l(d.username,Gt.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=d}else _?.user?e.user=await at.getUser(_.user,null,e):(rv&&(e.ip?.includes("127.0.0.1")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,ZU.getSuperUser)());Mf&&(e.session.update=function(f){if(!u){u=(0,ev.v4)();let p=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${u}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",p):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=u,XU.put(f)},e.login=async function(f,h){e.user=await at.getUser(f,h,e),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")&&yi.loginPath?(E.status=302,E.headers.set("Location",yi.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(u){throw c(u)}function c(u){let _=o.length;if(_>0){let l=u.headers;l||(u.headers=l=new Ni);for(let d=0;d<_;){let E=o[d++];l.set(E,o[d++])}}return o=null,u}a(c,"applyResponseHeaders")}function z9({server:e,port:t}){e.http(nv,{port:t||"all"}),jU||(jU=!0,setInterval(()=>{go=new Map},hn.get(Gt.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),tv.user.addListener(()=>{go=new Map}))}async function J9(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 X9(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var ZU,Pf,ev,hn,Gt,Ca,tv,JU,k9,V9,$9,Y9,XU,Mf,rv,K9,W9,go,jU,Uf=Re(()=>{ZU=H(_n());fr();Zu();Pf=H(Du());Ae();ev=require("uuid"),hn=H(ee()),Gt=H(P()),Ca=H($()),tv=H(Jc());el();Da();JU=(0,Ca.loggerWithTag)("auth-event");hn.initSync();k9=hn.get(Gt.CONFIG_PARAMS.HTTP_CORSACCESSLIST),V9=hn.get(Gt.CONFIG_PARAMS.HTTP_CORS),$9=hn.get(Gt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),Y9=hn.get(Gt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),XU=Et({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Mf=hn.get(Gt.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,rv=hn.get(Gt.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,K9=hn.get(Gt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,W9=hn.get(Gt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,go=new Map;at.onInvalidatedUser(()=>{go=new Map});a(Q9,"bypassAuth");a(nv,"authentication");a(z9,"start");a(J9,"login");a(X9,"logout")});var lv=g((Sme,uv)=>{"use strict";var Ce=require("joi"),sv=require("fs-extra"),iv=require("path"),Bs=je(),ov=ee(),av=P(),cv=$(),{hdb_errors:j9}=se(),{HDB_ERROR_MSGS:cr}=j9,vs=/^[a-zA-Z0-9-_]+$/;uv.exports={getDropCustomFunctionValidator:e7,setCustomFunctionValidator:t7,addComponentValidator:i7,dropCustomFunctionProjectValidator:o7,packageComponentValidator:a7,deployComponentValidator:c7,setComponentFileValidator:r7,getComponentFileValidator:s7,dropComponentFileValidator:n7};function vf(e,t,r){try{let n=ov.get(av.CONFIG_PARAMS.COMPONENTSROOT),s=iv.join(n,t);return sv.existsSync(s)?e?t:r.message(cr.PROJECT_EXISTS):e?r.message(cr.NO_PROJECT):t}catch(n){return cv.error(n),r.message(cr.VALIDATION_ERR)}}a(vf,"checkProjectExists");function rl(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(rl,"checkFilePath");function Z9(e,t,r,n){try{let s=ov.get(av.CONFIG_PARAMS.COMPONENTSROOT),i=iv.join(s,e,t,r+".js");return sv.existsSync(i)?r:n.message(cr.NO_FILE)}catch(s){return cv.error(s),n.message(cr.VALIDATION_ERR)}}a(Z9,"checkFileExists");function e7(e){let t=Ce.object({project:Ce.string().pattern(vs).custom(vf.bind(null,!0)).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME}),type:Ce.string().valid("helpers","routes").required(),file:Ce.string().pattern(vs).custom(Z9.bind(null,e.project,e.type)).custom(rl).required().messages({"string.pattern.base":cr.BAD_FILE_NAME})});return Bs.validateBySchema(e,t)}a(e7,"getDropCustomFunctionValidator");function t7(e){let t=Ce.object({project:Ce.string().pattern(vs).custom(vf.bind(null,!0)).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME}),type:Ce.string().valid("helpers","routes").required(),file:Ce.string().custom(rl).required(),function_content:Ce.string().required()});return Bs.validateBySchema(e,t)}a(t7,"setCustomFunctionValidator");function r7(e){let t=Ce.object({project:Ce.string().pattern(vs).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME}),file:Ce.string().custom(rl).required(),payload:Ce.string().allow("").optional(),encoding:Ce.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Bs.validateBySchema(e,t)}a(r7,"setComponentFileValidator");function n7(e){let t=Ce.object({project:Ce.string().pattern(vs).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME}),file:Ce.string().custom(rl).optional()});return Bs.validateBySchema(e,t)}a(n7,"dropComponentFileValidator");function s7(e){let t=Ce.object({project:Ce.string().required(),file:Ce.string().custom(rl).required(),encoding:Ce.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Bs.validateBySchema(e,t)}a(s7,"getComponentFileValidator");function i7(e){let t=Ce.object({project:Ce.string().pattern(vs).custom(vf.bind(null,!1)).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME})});return Bs.validateBySchema(e,t)}a(i7,"addComponentValidator");function o7(e){let t=Ce.object({project:Ce.string().pattern(vs).custom(vf.bind(null,!0)).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME})});return Bs.validateBySchema(e,t)}a(o7,"dropCustomFunctionProjectValidator");function a7(e){let t=Ce.object({project:Ce.string().pattern(vs).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME}),skip_node_modules:Ce.boolean()});return Bs.validateBySchema(e,t)}a(a7,"packageComponentValidator");function c7(e){let t=Ce.object({project:Ce.string().pattern(vs).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME}),payload:Ce.string().optional().messages({"string.pattern.base":cr.BAD_PACKAGE}),package:Ce.string().optional()});return Bs.validateBySchema(e,t)}a(c7,"deployComponentValidator")});var Gf=g((gme,pv)=>{"use strict";var Bf=require("joi"),xf=require("path"),_v=require("fs-extra"),{exec:u7}=require("child_process"),l7=require("util"),dv=l7.promisify(u7),nl=P(),{handleHDBError:La,hdb_errors:_7}=se(),{HTTP_STATUS_CODES:Ma}=_7,sl=ee(),d7=je(),Pa=$();sl.initSync();var Rg=sl.get(nl.CONFIG_PARAMS.COMPONENTSROOT),fv="npm install --omit=dev --json",f7=`${fv} --dry-run`;pv.exports={installModules:p7,auditModules:S7,installAllRootModules:E7,uninstallRootModule:h7,linkHarperdb:m7};async function E7(e=!1){await Hf(),await il(e?"npm install --ignore-scripts":"npm install",sl.get(nl.CONFIG_PARAMS.ROOTPATH))}a(E7,"installAllRootModules");async function h7(e){await il(`npm uninstall ${e}`,sl.get(nl.CONFIG_PARAMS.ROOTPATH))}a(h7,"uninstallRootModule");async function m7(){await Hf(),await il(`npm link ${nl.PACKAGE_ROOT}`,sl.get(nl.CONFIG_PARAMS.ROOTPATH))}a(m7,"linkHarperdb");async function il(e,t=void 0){let r,n;try{({stdout:r,stderr:n}=await dv(e,{cwd:t}))}catch(s){throw new Error(s.stderr.replace(`
|
|
14
|
+
Database backup has not been removed and can be found here: ${s}`;Qu.error(u),console.error(u)}(0,dg.get)(bi.CONFIG_PARAMS.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,So.remove)(s))}(0,fg.updateConfigValue)(bi.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1)}async function bU(e){let t=await(0,wU.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function CU(e,t){console.log("copyDb start");let r=Tr()[e],n;for(let d in r){n=r[d].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,yU.open)(new NU.default(t)),c=o.openDB(bf.INTERNAL_DBIS_NAME),u,_=0,l=s.useReadTransaction();try{for(let{key:f,value:h}of s.getRange({transaction:l})){let p=h.is_hash_attribute||h.isPrimaryKey,S,T;if(p&&(S=h.compression,T=Nf(),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 A=new IU.default(!p,p);A.encoding="binary",A.compression=S;let y=n.openDB(f,A);y.decoder=null,A.compression=T;let I=o.openDB(f,A);I.encoder=null,console.log("copying",f,"from",e,"to",t),await E(y,I,p,l)}let d=n.openDB(bf.AUDIT_STORE_NAME,yf);console.log("copying audit log"),E(i,d,!1,l);async function E(f,h,p,S){let T=0,A=0;for(let{key:y,value:I,version:B}of f.getRange({start:null,versions:p,transaction:S}))u=h.put(y,I,B),T++,S.openTimer&&(S.openTimer=0),A+=(y?.length||10)+I.length,_++>5e3&&(await u,console.log("copied",T,"entries",A,"bytes"),_=0);console.log("finish copying, copied",T,"entries",A,"bytes")}a(E,"copyDbi"),await u,console.log("copied database "+e+" to "+t)}finally{l.done(),o.close()}}var yU,Of,So,dg,NU,IU,bf,bi,wU,fg,Qu,LU=Re(()=>{Ae();yU=require("lmdb"),Of=require("path"),So=require("fs-extra"),dg=H(ee()),NU=H(Gc()),IU=H(Hc()),bf=H(ft()),bi=H(P());ni();wU=H(bs()),fg=H(pr()),Qu=H($());a(A9,"compactOnStart");a(bU,"getTotalDBRecordCount");a(CU,"copyDb")});var ju=g((ome,xU)=>{"use strict";var O9=require("minimist"),{isMainThread:mg,parentPort:Eg,threadId:sme}=require("worker_threads"),nt=P(),{PROCESS_DESCRIPTORS_VALIDATE:zu}=nt,cs=$(),pg=J(),wf=cg(),If=ut(),ime=Ve(),UU=pr(),Gn=OU(),MU=Ra(),{compactOnStart:b9}=(LU(),ie(DU)),y9=Vh(),{restartWorkers:Cf,onMessageByType:N9}=Qe(),{handleHDBError:I9,hdb_errors:w9}=se(),{HTTP_STATUS_CODES:C9}=w9,Xu=ee();Xu.initSync();var Ju=`Restarting HarperDB. This may take up to ${nt.RESTART_TIMEOUT_MS/1e3} seconds.`,D9="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",L9="Invalid service",Ia,En;xU.exports={restart:vU,restartService:Sg};mg&&N9(nt.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await Sg({service:e.workerType}):vU({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function vU(e){En=Object.keys(e).length===0,Ia=await Gn.isServiceRegistered(nt.HDB_PROC_DESCRIPTOR);let t=O9(process.argv);if(t.service){await Sg(t);return}if(En&&!Ia){console.error(D9);return}if(En&&console.log(Ju),Ia){Gn.enterPM2Mode(),cs.notify(Ju);let r=y9(Object.keys(nt.CONFIG_PARAM_MAP),!0);return pg.isEmptyOrZeroLength(Object.keys(r))||UU.updateConfigValue(void 0,void 0,r,!0,!0),M9(),Ju}return mg?(cs.notify(Ju),Xu.get(nt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await b9(),setTimeout(()=>{Cf()},50)):Eg.postMessage({type:nt.ITC_EVENT_TYPES.RESTART}),Ju}a(vU,"restart");async function Sg(e){let{service:t}=e;if(nt.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw I9(new Error,L9,C9.BAD_REQUEST,void 0,void 0,!0);if(Gn.expectedRestartOfChildren(),Ia=await Gn.isServiceRegistered(nt.HDB_PROC_DESCRIPTOR),!mg)return Eg.postMessage({type:nt.ITC_EVENT_TYPES.RESTART,workerType:t}),new Promise(n=>{Eg.on("message",s=>{s.type==="restart-complete"&&n()})});let r;switch(t){case zu.clustering:if(!Xu.get(nt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=PU;break}En&&console.log("Restarting clustering"),cs.notify("Restarting clustering"),await BU();break;case zu.clustering_config:case zu["clustering config"]:if(!Xu.get(nt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=PU;break}En&&console.log("Restarting clustering_config"),cs.notify("Restarting clustering_config"),await Gn.reloadClustering();break;case"custom_functions":case"custom functions":case zu.harperdb:case zu.http_workers:if(En&&!Ia){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}En&&console.log("Restarting http_workers"),cs.notify("Restarting http_workers"),En?await Gn.restart(nt.HDB_PROC_DESCRIPTOR):await Cf("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(cs.error(r),En&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(Sg,"restartService");async function M9(){await BU(),await Gn.restart(nt.HDB_PROC_DESCRIPTOR),await pg.async_set_timeout(2e3),Xu.get(nt.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await hg(),En&&(await If.closeConnection(),process.exit(0))}a(M9,"restartPM2Mode");async function BU(){if(!UU.getConfigFromFile(nt.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await MU.getHDBProcessInfo()).clustering.length===0)cs.trace("Clustering not running, restart will start clustering services"),await wf.generateNatsConfig(!0),await Gn.startClusteringProcesses(),await Gn.startClusteringThreads(),await hg(),En&&await If.closeConnection();else{await wf.generateNatsConfig(!0),Ia?(cs.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await Gn.restart(nt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Gn.restart(nt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await MU.getHDBProcessInfo()).clustering.forEach(s=>{cs.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await pg.async_set_timeout(3e3),await hg(),await If.updateLocalStreams(),En&&await If.closeConnection(),cs.trace("Restart clustering restarting ingest and reply service threads");let t=Cf(nt.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=Cf(nt.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(BU,"restartClustering");async function hg(){await wf.removeNatsConfig(nt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await wf.removeNatsConfig(nt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(hg,"removeNatsConfig")});var QU=g((ume,WU)=>{"use strict";var cme=require("lodash"),Ir=P(),{handleHDBError:HU,hdb_errors:P9}=se(),{HDB_ERROR_MSGS:U9,HTTP_STATUS_CODES:v9}=P9,Tg=$();WU.exports={getRolePermissions:x9};var To=Object.create(null),B9=a(e=>({key:e,perms:{}}),"perms_template_obj"),kU=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),VU=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"),gg=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...VU(t,r,n,s)}),"table_perms_template"),GU=a((e,t=VU())=>({attribute_name:e,describe:KU(t),[Zu]:t[Zu],[Rg]:t[Rg],[Ag]:t[Ag]}),"attr_perms_template"),qU=a((e,t=!1)=>({attribute_name:e,describe:t,[Zu]:t}),"timestamp_attr_perms_template"),{READ:Zu,INSERT:Rg,UPDATE:Ag}=Ir.PERMS_CRUD_ENUM,$U=Object.values(Ir.PERMS_CRUD_ENUM),YU=[Zu,Rg,Ag];function x9(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(To[t]&&To[t].key===n)return To[t].perms;let s=H9(e,r);return To[t]?To[t].key=n:To[t]=B9(n),To[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 Tg.error(n),Tg.debug(r),HU(new Error,U9.OUTDATED_PERMS_TRANSLATION_ERROR,v9.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
|
|
15
|
+
${r.stack}`;throw Tg.error(n),HU(new Error)}}}a(x9,"getRolePermissions");function H9(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]=G9(t[i]);return}r[i]=kU(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],u=t[i][o],_=q9(c,u);r[i].describe||$U.forEach(l=>{_[l]&&(r[i].describe=!0)}),r[i].tables[o]=_}else r[i].tables[o]=gg()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=gg()})}),r}a(H9,"translateRolePermissions");function G9(e){let t=kU(!0);return Object.keys(e).forEach(r=>{t.tables[r]=gg(!0,!0,!0,!0,!0)}),t}a(G9,"createStructureUserPermissions");function q9(e,t){let{attribute_permissions:r}=e;if(r.length>0){let s=Object.assign({},e);s.attribute_permissions=[];let i=r.reduce((_,l)=>{let{attribute_name:d}=l,E=l;return Ir.TIME_STAMP_NAMES.includes(d)&&(E=qU(d,l[Zu])),_[d]=E,_},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],u=GU(o);return t.attributes.forEach(({attribute:_})=>{if(i[_]){let l=i[_];l.describe=KU(l),s.attribute_permissions.push(l),c||F9(l,u)}else if(_!==o){let l;Ir.TIME_STAMP_NAMES.includes(_)?l=qU(_):l=GU(_),s.attribute_permissions.push(l)}}),c||s.attribute_permissions.push(u),s.describe=FU(s),s}else return e.describe=FU(e),e}a(q9,"getTableAttrPerms");function FU(e){return $U.filter(t=>e[t]).length>0}a(FU,"getSchemaTableDescribePerm");function KU(e){return YU.filter(t=>e[t]).length>0}a(KU,"getAttributeDescribePerm");function F9(e,t){YU.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(F9,"checkForHashPerms")});var zU={};Fe(zU,{Resources:()=>Df,keyArrayToString:()=>wa,resetResources:()=>k9,resources:()=>yi});function k9(){return yi=new Df}function wa(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var Df,yi,el=Re(()=>{so();Df=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,type:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s)throw new Error(`Conflicting paths for ${t}`);super.set(t,i);for(let[c,u]of this){let _=2;for(;(_=c.indexOf("/",_))>-1;){let l=this.get(c.slice(0,_));l&&(l.hasSubPaths=!0),_+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),u=this.get(c);if(!u&&c.indexOf(".")>-1){let _=c.split(".");u=this.get(_[0])}if(u){if(u.relativeURL=t.slice(n),!u.hasSubPaths)return u;s=u}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),!s&&o.indexOf(".")>-1&&(s=this.get(o.split(".")[0])),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 rt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(k9,"resetResources");a(wa,"keyArrayToString")});var JU={};Fe(JU,{Headers:()=>Ni,appendHeader:()=>Lf});function Lf(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 Ni,tl=Re(()=>{Ni=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(Lf,"appendHeader")});var rl={};Fe(rl,{authentication:()=>sv,bypassAuth:()=>z9,login:()=>X9,logout:()=>j9,start:()=>J9});function z9(){nv=!0}async function sv(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let f=e.isOperationsServer?K9?Y9:[]:$9?V9:[];if(f.includes(i)||f.includes("*")){if(e.method==="OPTIONS"){let h=new Ni([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Mf&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Mf&&o.push("Access-Control-Allow-Credentials","true")}}let u,_;if(Mf){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(";");u=p.slice(f.length,S===-1?p.length:S),_=await jU.get(u);break}e.session=_||(_={})}let l=a((f,h,p)=>{let S=new Ca.AuthAuditLog(f,h,Gt.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);S.auth_strategy=p,u&&(S.session_id=u),r.referer&&(S.referer=r.referer),r.origin&&(S.origin=r.origin),h===Gt.AUTH_AUDIT_STATUS.SUCCESS?XU.notify(S):XU.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 at.getUser(f,null,null),l(f,Gt.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,Ca.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=go.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 A=atob(p),y=A.indexOf(":");S=A.slice(0,y),T=A.slice(y+1),d=S||T?await at.getUser(S,T,e):null;break;case"Bearer":try{d=await(0,Pf.validateOperationToken)(p)}catch(I){if(I.message==="invalid token")try{return await(0,Pf.validateRefreshToken)(p),c({status:-1})}catch{throw I}}break}}catch(A){return Q9&&(go.get(p)||(go.set(p,p),l(S,Gt.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:Ro({error:A.message},e)})}go.set(n,d),W9&&l(d.username,Gt.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=d}else _?.user?e.user=await at.getUser(_.user,null,e):(nv&&(e.ip?.includes("127.0.0.1")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,ev.getSuperUser)());Mf&&(e.session.update=function(f){if(!u){u=(0,tv.v4)();let p=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${u}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",p):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=u,jU.put(f)},e.login=async function(f,h){e.user=await at.getUser(f,h,e),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")&&yi.loginPath?(E.status=302,E.headers.set("Location",yi.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(u){throw c(u)}function c(u){let _=o.length;if(_>0){let l=u.headers;l||(u.headers=l=new Ni);for(let d=0;d<_;){let E=o[d++];l.set(E,o[d++])}}return o=null,u}a(c,"applyResponseHeaders")}function J9({server:e,port:t}){e.http(sv,{port:t||"all"}),ZU||(ZU=!0,setInterval(()=>{go=new Map},hn.get(Gt.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),rv.user.addListener(()=>{go=new Map}))}async function X9(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 j9(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var ev,Pf,tv,hn,Gt,Ca,rv,XU,V9,$9,Y9,K9,jU,Mf,nv,W9,Q9,go,ZU,Uf=Re(()=>{ev=H(_n());fr();el();Pf=H(Lu());Ae();tv=require("uuid"),hn=H(ee()),Gt=H(P()),Ca=H($()),rv=H(Xc());tl();Da();XU=(0,Ca.loggerWithTag)("auth-event");hn.initSync();V9=hn.get(Gt.CONFIG_PARAMS.HTTP_CORSACCESSLIST),$9=hn.get(Gt.CONFIG_PARAMS.HTTP_CORS),Y9=hn.get(Gt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),K9=hn.get(Gt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),jU=Et({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Mf=hn.get(Gt.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,nv=hn.get(Gt.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,W9=hn.get(Gt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,Q9=hn.get(Gt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,go=new Map;at.onInvalidatedUser(()=>{go=new Map});a(z9,"bypassAuth");a(sv,"authentication");a(J9,"start");a(X9,"login");a(j9,"logout")});var _v=g((gme,lv)=>{"use strict";var Ce=require("joi"),iv=require("fs-extra"),ov=require("path"),Bs=je(),av=ee(),cv=P(),uv=$(),{hdb_errors:Z9}=se(),{HDB_ERROR_MSGS:cr}=Z9,vs=/^[a-zA-Z0-9-_]+$/;lv.exports={getDropCustomFunctionValidator:t7,setCustomFunctionValidator:r7,addComponentValidator:o7,dropCustomFunctionProjectValidator:a7,packageComponentValidator:c7,deployComponentValidator:u7,setComponentFileValidator:n7,getComponentFileValidator:i7,dropComponentFileValidator:s7};function vf(e,t,r){try{let n=av.get(cv.CONFIG_PARAMS.COMPONENTSROOT),s=ov.join(n,t);return iv.existsSync(s)?e?t:r.message(cr.PROJECT_EXISTS):e?r.message(cr.NO_PROJECT):t}catch(n){return uv.error(n),r.message(cr.VALIDATION_ERR)}}a(vf,"checkProjectExists");function nl(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(nl,"checkFilePath");function e7(e,t,r,n){try{let s=av.get(cv.CONFIG_PARAMS.COMPONENTSROOT),i=ov.join(s,e,t,r+".js");return iv.existsSync(i)?r:n.message(cr.NO_FILE)}catch(s){return uv.error(s),n.message(cr.VALIDATION_ERR)}}a(e7,"checkFileExists");function t7(e){let t=Ce.object({project:Ce.string().pattern(vs).custom(vf.bind(null,!0)).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME}),type:Ce.string().valid("helpers","routes").required(),file:Ce.string().pattern(vs).custom(e7.bind(null,e.project,e.type)).custom(nl).required().messages({"string.pattern.base":cr.BAD_FILE_NAME})});return Bs.validateBySchema(e,t)}a(t7,"getDropCustomFunctionValidator");function r7(e){let t=Ce.object({project:Ce.string().pattern(vs).custom(vf.bind(null,!0)).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME}),type:Ce.string().valid("helpers","routes").required(),file:Ce.string().custom(nl).required(),function_content:Ce.string().required()});return Bs.validateBySchema(e,t)}a(r7,"setCustomFunctionValidator");function n7(e){let t=Ce.object({project:Ce.string().pattern(vs).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME}),file:Ce.string().custom(nl).required(),payload:Ce.string().allow("").optional(),encoding:Ce.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Bs.validateBySchema(e,t)}a(n7,"setComponentFileValidator");function s7(e){let t=Ce.object({project:Ce.string().pattern(vs).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME}),file:Ce.string().custom(nl).optional()});return Bs.validateBySchema(e,t)}a(s7,"dropComponentFileValidator");function i7(e){let t=Ce.object({project:Ce.string().required(),file:Ce.string().custom(nl).required(),encoding:Ce.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Bs.validateBySchema(e,t)}a(i7,"getComponentFileValidator");function o7(e){let t=Ce.object({project:Ce.string().pattern(vs).custom(vf.bind(null,!1)).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME})});return Bs.validateBySchema(e,t)}a(o7,"addComponentValidator");function a7(e){let t=Ce.object({project:Ce.string().pattern(vs).custom(vf.bind(null,!0)).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME})});return Bs.validateBySchema(e,t)}a(a7,"dropCustomFunctionProjectValidator");function c7(e){let t=Ce.object({project:Ce.string().pattern(vs).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME}),skip_node_modules:Ce.boolean()});return Bs.validateBySchema(e,t)}a(c7,"packageComponentValidator");function u7(e){let t=Ce.object({project:Ce.string().pattern(vs).required().messages({"string.pattern.base":cr.BAD_PROJECT_NAME}),payload:Ce.string().optional().messages({"string.pattern.base":cr.BAD_PACKAGE}),package:Ce.string().optional()});return Bs.validateBySchema(e,t)}a(u7,"deployComponentValidator")});var Gf=g((Ame,Sv)=>{"use strict";var Bf=require("joi"),xf=require("path"),dv=require("fs-extra"),{exec:l7}=require("child_process"),_7=require("util"),fv=_7.promisify(l7),sl=P(),{handleHDBError:La,hdb_errors:d7}=se(),{HTTP_STATUS_CODES:Ma}=d7,il=ee(),f7=je(),Pa=$();il.initSync();var Og=il.get(sl.CONFIG_PARAMS.COMPONENTSROOT),Ev="npm install --omit=dev --json",E7=`${Ev} --dry-run`;Sv.exports={installModules:S7,auditModules:T7,installAllRootModules:h7,uninstallRootModule:m7,linkHarperdb:p7};async function h7(e=!1){await Hf(),await ol(e?"npm install --ignore-scripts":"npm install",il.get(sl.CONFIG_PARAMS.ROOTPATH))}a(h7,"installAllRootModules");async function m7(e){await ol(`npm uninstall ${e}`,il.get(sl.CONFIG_PARAMS.ROOTPATH))}a(m7,"uninstallRootModule");async function p7(){await Hf(),await ol(`npm link ${sl.PACKAGE_ROOT}`,il.get(sl.CONFIG_PARAMS.ROOTPATH))}a(p7,"linkHarperdb");async function ol(e,t=void 0){let r,n;try{({stdout:r,stderr:n}=await fv(e,{cwd:t}))}catch(s){throw new Error(s.stderr.replace(`
|
|
16
16
|
`,""))}return n&&!n.includes("Debugger listening")&&Pa.error("Error running NPM command:",e,n),Pa.trace(r,n),r?.replace(`
|
|
17
|
-
`,"")}a(
|
|
17
|
+
`,"")}a(ol,"runCommand");async function S7(e){Pa.info(`starting installModules for request: ${e}`);let t=pv(e);if(t)throw La(t,t.message,Ma.BAD_REQUEST);let{projects:r,dry_run:n}=e,s=n===!0?E7:Ev;await Hf(),await mv(r);let i={};for(let o=0,c=r.length;o<c;o++){let u=r[o];i[u]={npm_output:null,npm_error:null};let _=xf.join(Og,u),l,d=null;try{let{stdout:E,stderr:f}=await fv(s,{cwd:_});l=E?E.replace(`
|
|
18
18
|
`,""):null,d=f?f.replace(`
|
|
19
|
-
`,""):null}catch(E){E.stderr?i[u].npm_error=
|
|
20
|
-
`);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(Ev,"parseNPMStdErr");async function S7(e){Pa.info(`starting auditModules for request: ${e}`);let t=mv(e);if(t)throw La(t,t.message,Ma.BAD_REQUEST);let{projects:r}=e;await Hf(),await hv(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=xf.join(Rg,o);n[o]={npm_output:null,npm_error:null};try{let u=await il("npm audit --json",c);n[o].npm_output=JSON.parse(u)}catch(u){n[o].npm_error=Ev(u.stderr)}}return Pa.info(`finished auditModules with response ${n}`),n}a(S7,"auditModules");async function Hf(){try{return await il("npm -v"),!0}catch{throw La(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",Ma.BAD_REQUEST,void 0,void 0,!0)}}a(Hf,"checkNPMInstalled");async function hv(e){if(!Array.isArray(e)||e.length===0)throw La(new Error,"projects argument must be an array with at least 1 element",Ma.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=xf.join(Rg,i.toString());if(!await _v.pathExists(o)){t.push(i);continue}let u=xf.join(o,"package.json");await _v.pathExists(u)||r.push(i)}if(t.length>0)throw La(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Ma.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw La(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Ma.BAD_REQUEST,void 0,void 0,!0)}a(hv,"checkProjectPaths");function mv(e){let t=Bf.object({projects:Bf.array().min(1).items(Bf.string()).required(),dry_run:Bf.boolean().default(!1)});return d7.validateBySchema(e,t)}a(mv,"modulesValidator")});var Og=g((Ame,Av)=>{"use strict";var Ua=require("fs-extra"),Ag=require("path"),qf=$(),Sv=J(),Ff=P(),Rv=ee(),T7=pr();Av.exports=g7;async function g7(){let e=R7(),t=Rv.get(Ff.CONFIG_PARAMS.ROOTPATH),r=Ag.join(t,"package.json"),n={dependencies:{harperdb:"file:"+Ff.PACKAGE_ROOT}},s=Ag.join(t,"node_modules");await Ua.ensureDir(s);let i,o=!0,c=!1;try{i=await Ua.readJson(r)}catch(u){if(Sv.isEmptyOrZeroLength(e))return;if(u.code!==Ff.NODE_ERROR_CODES.ENOENT)throw u;o=!1}if(!Sv.isEmptyOrZeroLength(e)){for(let{name:u,package:_}of e){let l=await Tv(_);n.dependencies[u]=l+_}if(!o){qf.notify("Installing components"),await gv(r,n,null);return}for(let{name:u,package:_}of e){let l=i.dependencies[u],d=await Tv(_);if(l===void 0||l!==d+_){c=!0;break}}}for(let u in i.dependencies)n.dependencies[u]===void 0&&(qf.notify("Removing component",u),c=!0);c&&(qf.notify("Updating components."),await gv(r,n,i))}a(g7,"installComponents");function R7(){let e=T7.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(R7,"getComponentsConfig");async function Tv(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Ag.extname(e)||await Ua.pathExists(e)?"file:":"github:"}a(Tv,"getPkgPrefix");async function gv(e,t,r){qf.trace("npm installing components package.json",t),await Ua.writeFile(e,JSON.stringify(t,null," "));try{await Gf().installAllRootModules(Rv.get(Ff.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?await Ua.writeFile(e,JSON.stringify(r,null," ")):await Ua.unlink(e),n}}a(gv,"installPackages")});var Ng=g((yme,Nv)=>{"use strict";var $e=require("fs-extra"),bg=require("fast-glob"),ge=require("path"),bv=require("tar-fs"),bme=require("uuid").v4,yg=require("normalize-path"),us=lv(),Ct=$(),Je=P(),Ot=ee(),ol=pr(),A7=J(),{PACKAGE_ROOT:O7}=P(),{handleHDBError:qt,hdb_errors:b7}=se(),{basename:y7}=require("path"),N7=Og(),yv=ee(),I7=P(),{Readable:w7}=require("stream"),{isMainThread:C7}=require("worker_threads"),{HDB_ERROR_MSGS:Ao,HTTP_STATUS_CODES:Ft}=b7,D7=ge.join(O7,"application-template"),Ov=ge.join(Ot.get(Je.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp");function L7(){Ct.trace("getting custom api status");let e={};try{e={port:Ot.get(Je.CONFIG_PARAMS.HTTP_PORT),directory:Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw qt(new Error,Ao.FUNCTION_STATUS,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,t)}return e}a(L7,"customFunctionsStatus");function M7(){Ct.trace("getting custom api endpoints");let e={},t=Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT);try{bg.sync(yg(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:bg.sync(yg(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:bg.sync(yg(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw qt(new Error,Ao.GET_FUNCTIONS,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,r)}return e}a(M7,"getCustomFunctions");function P7(e){e.project&&(e.project=ge.parse(e.project).name),e.file&&(e.file=ge.parse(e.file).name);let t=us.getDropCustomFunctionValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);Ct.trace("getting custom api endpoint file content");let r=Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=ge.join(r,n,s,i+".js");try{return $e.readFileSync(o,{encoding:"utf8"})}catch(c){throw qt(new Error,Ao.GET_FUNCTION,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,c)}}a(P7,"getCustomFunction");function U7(e){e.project&&(e.project=ge.parse(e.project).name),e.file&&(e.file=ge.parse(e.file).name);let t=us.setCustomFunctionValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);Ct.trace("setting custom function file content");let r=Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{return $e.outputFileSync(ge.join(r,n,s,i+".js"),o),`Successfully updated custom function: ${i}.js`}catch(c){throw qt(new Error,Ao.SET_FUNCTION,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,c)}}a(U7,"setCustomFunction");function v7(e){e.project&&(e.project=ge.parse(e.project).name),e.file&&(e.file=ge.parse(e.file).name);let t=us.getDropCustomFunctionValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);Ct.trace("dropping custom function file");let r=Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{return $e.unlinkSync(ge.join(r,n,s,i+".js")),`Successfully deleted custom function: ${i}.js`}catch(o){throw qt(new Error,Ao.DROP_FUNCTION,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,o)}}a(v7,"dropCustomFunction");function B7(e){e.project&&(e.project=ge.parse(e.project).name);let t=us.addComponentValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);Ct.trace("adding component");let r=Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=ge.join(r,n);return $e.mkdirSync(s,{recursive:!0}),$e.copySync(D7,s),`Successfully added project: ${n}`}catch(s){throw qt(new Error,Ao.ADD_FUNCTION,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,s)}}a(B7,"addComponent");function x7(e){e.project&&(e.project=ge.parse(e.project).name);let t=us.dropCustomFunctionProjectValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);Ct.trace("dropping custom function project");let r=Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Ot.get(Je.CONFIG_PARAMS.APPS);if(!A7.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 ol.updateConfigValue(Je.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=ge.join(r,n);return $e.rmSync(i,{recursive:!0}),`Successfully deleted project: ${n}`}catch(i){throw qt(new Error,Ao.DROP_FUNCTION_PROJECT,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,i)}}a(x7,"dropCustomFunctionProject");async function H7(e){e.project&&(e.project=ge.parse(e.project).name);let t=us.packageComponentValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);let r=Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Ct.trace("packaging component",n);let s;try{s=await $e.realpath(ge.join(r,n))}catch(u){if(u.code!==Je.NODE_ERROR_CODES.ENOENT)throw u;try{s=await $e.realpath(ge.join(Ot.get(Je.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(_){if(_.code===Je.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}await $e.ensureDir(Ov);let i=ge.join(Ov,`${n}.tar`),o={};(e.skip_node_modules===!0||e.skip_node_modules==="true")&&(o={ignore:u=>u.includes(ge.join(s,"node_modules"))}),bv.pack(s,o).pipe($e.createWriteStream(i,{overwrite:!0})),await new Promise(u=>setTimeout(u,2e3));let c=$e.readFileSync(i,{encoding:"base64"});return await $e.remove(i),{project:n,payload:c}}a(H7,"packageComponent");async function G7(e){e.project&&(e.project=ge.parse(e.project).name);let t=us.deployComponentValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);let r=Ot.get(Je.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=ge.join(r,n),i="file:"+o,await $e.emptyDir(o);let E=w7.from(Buffer.from(s,"base64"));await new Promise((h,p)=>{E.pipe(bv.extract(o,{finish:h})).on("error",p)});let f=await $e.readdir(o);f.length===1&&f[0]==="package"&&(await $e.copy(ge.join(o,"package"),o),await $e.remove(ge.join(o,"package")))}if(await ol.addConfig(n,{package:i}),!s){await N7();let E=yv.get(I7.CONFIG_PARAMS.ROOTPATH);o=ge.join(E,"node_modules",n)}if(C7)return;let c=new Map;c.isWorker=!0;let u=(Vf(),ie(kf)),_;u.setErrorReporter(E=>_=E);let l=y7(o),d=u.component_errors.get(l);try{await u.loadComponent(o,c)}finally{u.component_errors.set(l,d)}if(_)throw _;return Ct.info("Installed component"),`Successfully deployed: ${n}`}a(G7,"deployComponent");async function q7(){let e=ol.getConfiguration(),t=[];for(let o in e)if(e[o]?.package){if(e[o].package.startsWith("file:"))continue;t.push(Object.assign({},e[o],{name:o}))}let r=a(async(o,c)=>{try{let u=await $e.readdir(o,{withFileTypes:!0});for(let _ of u){let l=_.name;if(l.startsWith(".")||l==="node_modules")continue;let d=ge.join(o,l);if(_.isDirectory()||_.isSymbolicLink()){let E={name:l,entries:[]};c.entries.push(E),await r(d,E)}else{let E=await $e.stat(d),f={name:ge.basename(l),mtime:E.mtime,size:E.size};c.entries.push(f)}}return c}catch(u){return Ct.warn("Error loading package",u),{error:u.toString(),entries:[]}}},"walk_dir"),n=await r(Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),{name:Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT).split(ge.sep).slice(-1).pop(),entries:t});for(let o of n.entries)if(o.package){let c=await r(ge.join(Ot.get(Je.CONFIG_PARAMS.ROOTPATH),"node_modules",o.name),{name:o.name,entries:[]});Object.assign(o,c)}let i=(Vf(),ie(kf)).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(q7,"getComponents");async function F7(e){let t=us.getComponentFileValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);let n=ol.getConfigObj()[e.project]||e.project==="harperdb"?ge.join(yv.get(Je.CONFIG_PARAMS.ROOTPATH),"node_modules"):Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await $e.stat(ge.join(n,e.project,e.file));return{message:await $e.readFile(ge.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===Je.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${ge.join(e.project,e.file)}'`):i}}a(F7,"getComponentFile");async function k7(e){let t=us.setComponentFileValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=ge.join(Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);return e.payload!==void 0?(await $e.ensureFile(n),await $e.outputFile(n,e.payload,r)):await $e.ensureDir(n),"Successfully set component: "+e.file}a(k7,"setComponentFile");async function V7(e){let t=us.dropComponentFileValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);let r=e.file?ge.join(e.project,e.file):e.project,n=ge.join(Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),r);return await $e.pathExists(n)&&await $e.remove(n),ol.deleteConfigFromFile([e.project]),"Successfully dropped: "+r}a(V7,"dropComponent");Nv.exports={customFunctionsStatus:L7,getCustomFunctions:M7,getCustomFunction:P7,setCustomFunction:U7,dropCustomFunction:v7,addComponent:B7,dropCustomFunctionProject:x7,packageComponent:H7,deployComponent:G7,getComponents:q7,getComponentFile:F7,setComponentFile:k7,dropComponent:V7}});var Ig=g((Ime,wv)=>{"use strict";var ls=require("joi"),Iv=je();wv.exports={readTransactionLogValidator:$7,deleteTransactionLogsBeforeValidator:Y7};function $7(e){let t=ls.object({schema:ls.string().required(),table:ls.string().required(),from:ls.date().timestamp(),to:ls.date().timestamp(),limit:ls.number().min(1)});return Iv.validateBySchema(e,t)}a($7,"readTransactionLogValidator");function Y7(e){let t=ls.object({schema:ls.string().required(),table:ls.string().required(),timestamp:ls.date().timestamp().required()});return Iv.validateBySchema(e,t)}a(Y7,"deleteTransactionLogsBeforeValidator")});var $f=g((Cme,Pv)=>{"use strict";var wg=P(),al=ut(),Cv=J(),Dv=ee(),Lv=Os(),{handleHDBError:va,hdb_errors:K7}=se(),{HTTP_STATUS_CODES:Ba}=K7,{readTransactionLogValidator:W7,deleteTransactionLogsBeforeValidator:Q7}=Ig(),Mv="This operation relies on clustering and cannot run with it disable.",z7="Logs successfully deleted from transaction log.",J7="All logs successfully deleted from transaction log.";Pv.exports={readTransactionLog:X7,deleteTransactionLogsBefore:j7};async function*X7(e){let t=W7(e);if(t)throw va(t,t.message,Ba.BAD_REQUEST,void 0,void 0,!0);if(!Dv.get(wg.CONFIG_PARAMS.CLUSTERING_ENABLED))throw va(new Error,Mv,Ba.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:n}=e,s=Cv.checkSchemaTableExist(r,n);if(s)throw va(new Error,s,Ba.NOT_FOUND,void 0,void 0,!0);let i=Lv.createNatsTableStreamName(r,n),o=await al.viewStreamIterator(i,parseInt(e.from),e.limit);for await(let c of o){let u=Math.floor(c?.nats_timestamp/1e6);if(e.to&&u>e.to)break;let _={operation:c?.entry?.operation,user:c?.entry?.__origin?.user,timestamp:u,records:c?.entry?.records,attributes:c?.entry?.attributes};c?.entry?.operation===wg.OPERATIONS_ENUM.DELETE&&(_.hash_values=c?.entry?.hash_values),yield _}}a(X7,"readTransactionLog");async function j7(e){let t=Q7(e);if(t)throw va(t,t.message,Ba.BAD_REQUEST,void 0,void 0,!0);if(!Dv.get(wg.CONFIG_PARAMS.CLUSTERING_ENABLED))throw va(new Error,Mv,Ba.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:n,timestamp:s}=e,i=Cv.checkSchemaTableExist(r,n);if(i)throw va(new Error,i,Ba.NOT_FOUND,void 0,void 0,!0);let o=Lv.createNatsTableStreamName(r,n),{jsm:c}=await al.getNATSReferences(),u=await al.getStreamInfo(o),_=new Date(u.state.first_ts).getTime();if(s<=_)return`No transactions exist before: ${s}`;let l=z7,d,E=new Date(u.state.last_ts).getTime();return s>E?(d=u.state.last_seq+1,l=J7):d=(await al.viewStream(o,parseInt(s),1))[0].nats_sequence,await al.purgeTableStream(r,n,{seq:d}),l}a(j7,"deleteTransactionLogsBefore")});var vv=g((Lme,Uv)=>{"use strict";var Cg=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}};Uv.exports=Cg});var xv=g((Pme,Bv)=>{"use strict";var Dg=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};Bv.exports=Dg});var Mg=g((vme,Gv)=>{"use strict";var Hv=vv(),Z7=xv(),{HDB_ERROR_MSGS:eee}=vr(),Lg=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=eee.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 Hv(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let u=new Z7(c,s[c]);i.push(u)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new Hv(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}};Gv.exports=Lg});var Qf=g((xme,t0)=>{"use strict";var Pg=Fr(),Yf=qr(),pn=bu(),ll=bs(),Ug=ci(),tee=KS(),ree=FL(),_l=_n(),Kf=tT(),Dt=$(),nee=sT(),see=af(),iee=xT(),oee=uf(),aee=GT(),cee=qT(),uee=VT(),lee=YT(),vg=QT(),xs=J(),_ee=GP(),Bg=ZT(),kv=Xu(),mn=P(),Vv=WU(),dee=Ra(),$v=Du(),Yv=(Uf(),ie(tl)),Kv=pr(),Xr=Ng(),fee=require("alasql"),Wv=$f(),Qv=Gf(),zv=Mg(),{handleHDBError:wr,hdb_errors:Jv}=se(),{HDB_ERROR_MSGS:Qt,HTTP_STATUS_CODES:cl}=Jv,V=new Map,Xv="delete",Ii="insert",Hs="read",Oo="update",ul="describe",qv=ll.describeSchema.name,Fv=ll.describeTable.name,jv={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},Eee="catchup",hee="handleGetJob",mee="handleGetJobsByStartDate",Wf={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},pee=[pn.createTable.name,pn.createAttribute.name,pn.dropTable.name,pn.dropAttribute.name],Zv={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(Pg.insert.name,new W(!1,[Ii]));V.set(Pg.update.name,new W(!1,[Oo]));V.set(Pg.upsert.name,new W(!1,[Ii,Oo]));V.set(Yf.searchByConditions.name,new W(!1,[Hs]));V.set(Yf.searchByHash.name,new W(!1,[Hs]));V.set(Yf.searchByValue.name,new W(!1,[Hs]));V.set(Yf.search.name,new W(!1,[Hs]));V.set(pn.createSchema.name,new W(!0,[]));V.set(pn.createTable.name,new W(!0,[]));V.set(pn.createAttribute.name,new W(!1,[Ii]));V.set(pn.dropSchema.name,new W(!0,[]));V.set(pn.dropTable.name,new W(!0,[]));V.set(pn.dropAttribute.name,new W(!0,[]));V.set(ll.describeSchema.name,new W(!1,[Hs]));V.set(ll.describeTable.name,new W(!1,[Hs]));V.set(Ug.deleteRecord.name,new W(!1,[Xv]));V.set(_l.addUser.name,new W(!0,[]));V.set(_l.alterUser.name,new W(!0,[]));V.set(_l.dropUser.name,new W(!0,[]));V.set(_l.listUsersExternal.name,new W(!0,[]));V.set(Kf.listRoles.name,new W(!0,[]));V.set(Kf.addRole.name,new W(!0,[]));V.set(Kf.alterRole.name,new W(!0,[]));V.set(Kf.dropRole.name,new W(!0,[]));V.set(nee.name,new W(!0,[]));V.set(see.name,new W(!0,[]));V.set(iee.name,new W(!0,[]));V.set(oee.name,new W(!0,[]));V.set(aee.name,new W(!0,[]));V.set(cee.name,new W(!0,[]));V.set(vg.setRoutes.name,new W(!0,[]));V.set(vg.getRoutes.name,new W(!0,[]));V.set(vg.deleteRoutes.name,new W(!0,[]));V.set(Kv.setConfiguration.name,new W(!0,[]));V.set(uee.clusterStatus.name,new W(!0,[]));V.set(lee.name,new W(!0,[]));V.set(Bg.getFingerprint.name,new W(!0,[]));V.set(Bg.setLicense.name,new W(!0,[]));V.set(Ug.deleteFilesBefore.name,new W(!0,[]));V.set(Ug.deleteAuditLogsBefore.name,new W(!0,[]));V.set(kv.restart.name,new W(!0,[]));V.set(kv.restartService.name,new W(!0,[]));V.set(tee.name,new W(!0,[]));V.set(ree.name,new W(!0,[Hs]));V.set(dee.systemInformation.name,new W(!0,[]));V.set(Kv.getConfiguration.name,new W(!0,[]));V.set(Wv.readTransactionLog.name,new W(!0,[]));V.set(Wv.deleteTransactionLogsBefore.name,new W(!0,[]));V.set(Qv.installModules.name,new W(!0,[]));V.set(Qv.auditModules.name,new W(!0,[]));V.set($v.createTokens.name,new W(!1,[]));V.set($v.refreshOperationToken.name,new W(!1,[]));V.set(Yv.login.name,new W(!1,[]));V.set(Yv.logout.name,new W(!1,[]));V.set(Xr.customFunctionsStatus.name,new W(!0,[]));V.set(Xr.getCustomFunctions.name,new W(!0,[]));V.set(Xr.getComponents.name,new W(!0,[]));V.set(Xr.getComponentFile.name,new W(!0,[]));V.set(Xr.setComponentFile.name,new W(!0,[]));V.set(Xr.dropComponent.name,new W(!0,[]));V.set(Xr.getCustomFunction.name,new W(!0,[]));V.set(Xr.setCustomFunction.name,new W(!0,[]));V.set(Xr.dropCustomFunction.name,new W(!0,[]));V.set(Xr.addComponent.name,new W(!0,[]));V.set(Xr.dropCustomFunctionProject.name,new W(!0,[]));V.set(Xr.packageComponent.name,new W(!0,[]));V.set(Xr.deployComponent.name,new W(!0,[]));V.set(Bg.getRegistrationInfo.name,new W(!1,[]));V.set(_l.userInfo.name,new W(!1,[]));V.set(ll.describeAll.name,new W(!1,[]));V.set(hee,new W(!1,[]));V.set(mee,new W(!0,[]));V.set(Eee,new W(!0,[]));V.set(Wf.CSV_DATA_LOAD,new W(!1,[Ii,Oo]));V.set(Wf.CSV_URL_LOAD,new W(!1,[Ii,Oo]));V.set(Wf.CSV_FILE_LOAD,new W(!1,[Ii,Oo]));V.set(Wf.IMPORT_FROM_S3,new W(!1,[Ii,Oo]));V.set(Zv.EXPORT_TO_S3,new W(!0,[]));V.set(Zv.EXPORT_LOCAL,new W(!0,[]));V.set(mn.VALID_SQL_OPS_ENUM.DELETE,new W(!1,[Xv]));V.set(mn.VALID_SQL_OPS_ENUM.SELECT,new W(!1,[Hs]));V.set(mn.VALID_SQL_OPS_ENUM.INSERT,new W(!1,[Ii]));V.set(mn.VALID_SQL_OPS_ENUM.UPDATE,new W(!1,[Oo]));t0.exports={verifyPerms:Tee,verifyPermsAst:See,verifyBulkLoadAttributePerms:Ree};function See(e,t,r){if(xs.isEmptyOrZeroLength(e))throw Dt.info("verify_perms_ast has an empty user parameter"),wr(new Error);if(xs.isEmptyOrZeroLength(t))throw Dt.info("verify_perms_ast has an empty user parameter"),wr(new Error);if(xs.isEmptyOrZeroLength(r))throw Dt.info("verify_perms_ast has a null operation parameter"),wr(new Error);try{let n=new zv,s=new _ee(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,u=i.includes("system");if(u&&jv[r])throw wr(new Error,Qt.DROP_SYSTEM,cl.FORBIDDEN);if(c&&!u)return null;let _=Vv.getRolePermissions(t.role);t.role.permission=_,!c&&e instanceof fee.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 l=e0(t,r,o,n);return l||(o.forEach((d,E)=>{for(let f=0;f<d.length;f++){let h=s.getAttributesBySchemaTableName(E,d[f]),p=Hg(t.role.permission,E,d[f]);xg(h,p,r,d[f],E,n)}}),n.getPermsResponse())}catch(n){throw wr(n)}}a(See,"verifyPermsAst");function Tee(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,Qt.DEFAULT_INVALID_REQUEST,cl.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 zv;if(xs.isEmptyOrZeroLength(e.hdb_user?.role)||xs.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(Qt.USER_HAS_NO_PERMS(e.hdb_user?.username));let u=!!e.hdb_user?.role?.permission?.super_user,_=e.hdb_user?.role?.permission?.structure_user,l=o.has(mn.SYSTEM_SCHEMA_NAME)||s===mn.SYSTEM_SCHEMA_NAME;if(l&&jv[r])throw wr(new Error,Qt.DROP_SYSTEM,cl.FORBIDDEN);if(u&&!l||_===!0&&(r===pn.createSchema.name||r===pn.dropSchema.name))return null;if(pee.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=Vv.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=d),r===qv||r===Fv){if(s===mn.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(Qt.SCHEMA_PERM_ERROR(s));if(!d.super_user){if(r===qv&&(!d[s]||!d[s][ul]))return c.handleInvalidItem(Qt.SCHEMA_NOT_FOUND(s));if(r===Fv&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][ul]))return c.handleInvalidItem(Qt.TABLE_NOT_FOUND(s,i))}}let E=e0(e.hdb_user,r,o,c,n);if(E)return E;if(V.get(r)&&V.get(r).perms.length===0)return null;if(!u&&e.get_attributes&&mn.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let p=[],S=d[s].tables[i];S[mn.PERMS_CRUD_ENUM.READ]&&(S.attribute_permissions.length>0?S.attribute_permissions.filter(A=>A[mn.PERMS_CRUD_ENUM.READ]).forEach(A=>{p.push(A.attribute_name)}):p=global.hdb_schema[s][i].attributes.map(T=>T.attribute),e.get_attributes=p)}let f=gee(e),h=Hg(e.hdb_user?.role?.permission,s,i);return xg(f,h,r,i,s,c,n),c.getPermsResponse()}a(Tee,"verifyPerms");function e0(e,t,r,n,s){if(xs.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,Qt.OP_NOT_FOUND(t),cl.BAD_REQUEST);if(V.get(t)&&V.get(t).requires_su)return Dt.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(Qt.OP_IS_SU_ONLY(t));let c=r.keys();for(let u of c){try{if(u&&!o[u]||o[u][ul]===!1){n.addInvalidItem(Qt.SCHEMA_NOT_FOUND(u));continue}}catch{n.addInvalidItem(Qt.SCHEMA_NOT_FOUND(u));continue}let _=r.get(u);for(let l of _){let d=o[u].tables[l];if(!d||d[ul]===!1)n.addInvalidItem(Qt.TABLE_NOT_FOUND(u,l));else try{let E=[],f=V.get(t).perms;!xs.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(u,l,E)}catch(E){let f=Qt.UNKNOWN_OP_AUTH_ERROR(t,u,l);throw Dt.error(f),Dt.error(E),wr(Jv.CHECK_LOGS_WRAPPER(f))}}}return r.size<2?n.getPermsResponse():null}a(e0,"hasPermissions");function xg(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(xs.isEmptyOrZeroLength(t))return Dt.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let u={};for(let l of e){let d=t.get(l);if(d){if(d[ul]===!1){i.addInvalidItem(Qt.ATTR_NOT_FOUND(s,n,l),s,n);continue}if(c)for(let E of c){if(mn.TIME_STAMP_NAMES.includes(d.attribute_name)&&E!==Hs)throw wr(new Error,Qt.SYSTEM_TIMESTAMP_PERMS_ERR,cl.FORBIDDEN);d[E]===!1&&(u[d.attribute_name]?u[d.attribute_name].push(E):u[d.attribute_name]=[E])}}else i.addInvalidItem(Qt.ATTR_NOT_FOUND(s,n,l),s,n)}let _=Object.keys(u);_.length>0&&i.addUnauthorizedAttributes(_,s,n,u)}a(xg,"checkAttributePerms");function gee(e){let t=new Set;try{if(e.action)return t;if(e.operation===mn.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(gee,"getRecordAttributes");function Hg(e,t,r){let n=new Map;if(xs.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(Hg,"getAttributePermissions");function Ree(e,t,r,n,s,i,o){let c=new Set(i),u=Hg(e,n,s);xg(c,u,t,s,n,o,r)}a(Ree,"verifyBulkLoadAttributePerms")});var Jf=g((Gme,o0)=>{"use strict";o0.exports={evaluateSQL:Uee,processAST:i0,convertSQLToAST:s0,checkASTPermissions:n0};var Aee=Fr(),r0=require("util"),Oee=r0.callbackify(Aee.insert),bee=qr().search,yee=yD().update,Nee=r0.callbackify(yee),Iee=ID().convertDelete,wi=require("alasql"),wee=Qf(),zf=$(),Cee=bd(),Dee=J(),dl=P(),{hdb_errors:Lee,handleHDBError:Gg}=se(),{HTTP_STATUS_CODES:qg}=Lee;Cee(wi);var Mee=403,Pee="There was a problem performing this insert. Please check the logs and try again.",Fg=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function Uee(e,t){let r=e.parsed_sql_object;if(!r){r=s0(e.sql);let n,s=r.ast.statements[0];if(s instanceof wi.yy.Insert?n=s.into.databaseid:s instanceof wi.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof wi.yy.Update||s instanceof wi.yy.Delete?n=s.table.databaseid:zf.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof wi.yy.Select)&&Dee.isEmptyOrZeroLength(n))return t("No schema specified",null)}i0(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(Uee,"evaluateSQL");function n0(e,t){let r;try{r=wee.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(n0,"checkASTPermissions");function s0(e){let t=new Fg;if(!e)throw Gg(new Error,"The 'sql' parameter is missing from the request body",qg.BAD_REQUEST);try{let r=e.trim(),n=wi.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
|
|
21
|
-
`);throw n[1]?Gg(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,qg.BAD_REQUEST):Gg(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",qg.BAD_REQUEST)}return t}a(s0,"convertSQLToAST");function i0(e,t,r){try{let n=vee;if(!e.bypass_auth&&!t.permissions_checked){let i=n0(e,t);if(i&&i.length>0)return r(Mee,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case dl.VALID_SQL_OPS_ENUM.SELECT:n=bee,s=t.ast.statements[0];break;case dl.VALID_SQL_OPS_ENUM.INSERT:n=Bee;break;case dl.VALID_SQL_OPS_ENUM.UPDATE:n=Nee;break;case dl.VALID_SQL_OPS_ENUM.DELETE:n=Iee;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(i0,"processAST");function vee(e,t){zf.info(e),t("unknown sql statement")}a(vee,"nullFunction");function Bee({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=xee(i,e.values)}catch(o){return r(o)}Oee(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(u){zf.error(`Error delete new_attributes from insert response: ${u}`)}r(null,c)})}a(Bee,"convertInsert");function xee(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]]=wi.compile(`SELECT ${s.toString()} AS [${dl.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw zf.error(r),new Error(Pee)}}a(xee,"createDataObjects")});var kg=g((Fme,c0)=>{"use strict";var{S3:Hee,GetObjectCommand:Gee}=require("@aws-sdk/client-s3");c0.exports={getFileStreamFromS3:qee,getS3AuthObj:a0};async function qee(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await a0(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new Gee(r))).Body}a(qee,"getFileStreamFromS3");function a0(e,t,r){return new Hee({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(a0,"getS3AuthObj")});var Xf=g((Vme,p0)=>{"use strict";var $g=qr(),Fee=Jf(),kee=kg(),{AsyncParser:Vee,Transform:$ee}=require("json2csv"),El=require("stream"),jr=J(),Vg=require("fs-extra"),Yee=require("path"),Sn=$(),{promisify:_0}=require("util"),fl=J(),{handleHDBError:bt,hdb_errors:Kee}=se(),{HDB_ERROR_MSGS:Cr,HTTP_STATUS_CODES:yt}=Kee,{streamAsJSON:Wee}=(lm(),ie(qb)),{Upload:Qee}=require("@aws-sdk/lib-storage"),u0=["search_by_value","search_by_hash","sql","search_by_conditions"],l0=["json","csv"],d0="json",f0="csv",zee="Successfully exported JSON locally.",Jee="Successfully exported CSV locally.",Xee=1e3,jee=$g.searchByHash,Zee=$g.searchByValue,ete=_0(Fee.evaluateSQL),tte=_0(El.finished);p0.exports={export_to_s3:ite,export_local:rte,toCsvStream:E0};async function rte(e){Sn.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=h0(e);if(!jr.isEmpty(t))throw Sn.error(t),bt(new Error,t,yt.BAD_REQUEST,void 0,void 0,!0);if(jr.isEmpty(e.path))throw Sn.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(Yee.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=jr.buildFolderPath(e.path,r);await nte(e.path);let s=await m0(e);return await ste(n,e.format,s)}a(rte,"export_local");async function nte(e){if(Sn.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 Vg.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,Sn.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 Sn.error(r),bt(new Error,r,yt.BAD_REQUEST,void 0,void 0,!0)}return!0}a(nte,"confirmPath");async function ste(e,t,r){if(Sn.trace("in saveToLocal"),fl.isEmptyOrZeroLength(e))throw bt(new Error,Cr.INVALID_VALUE("file_path"),yt.BAD_REQUEST,void 0,void 0,!0);if(fl.isEmptyOrZeroLength(t))throw bt(new Error,Cr.INVALID_VALUE("Source format"),yt.BAD_REQUEST,void 0,void 0,!0);if(fl.isEmpty(r))throw bt(new Error,Cr.NOT_FOUND("Data"),yt.BAD_REQUEST,void 0,void 0,!0);if(t===d0){let n=Vg.createWriteStream(e);return Wee(r).pipe(n),await tte(n),{message:zee,path:e}}else if(t===f0){let n=Vg.createWriteStream(e),s=El.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(l=>({label:l,value:l})));let c={objectMode:!0};return await new Vee(i,c).fromInput(s).toOutput(n).promise(!1),{message:Jee,path:e}}throw bt(new Error,Cr.INVALID_VALUE("format"),yt.BAD_REQUEST)}a(ste,"saveToLocal");async function ite(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=h0(e);if(!jr.isEmpty(t))throw bt(new Error,t,yt.BAD_REQUEST);Sn.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await m0(e)}catch(u){throw Sn.error(u),u}let n,s=await kee.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new El.PassThrough;if(e.format===f0){i=e.s3.key+".csv";let u=E0(r,r.getColumns?.());u.on("error",_=>{throw _}),u.pipe(o)}else if(e.format===d0){i=e.s3.key+".json";let u=new El.Readable;u.pipe(o),u.on("error",d=>{throw d}),u.push("[");let _=r.length,l="";for(let[d,E]of r.entries()){let f=d===_-1?JSON.stringify(E):JSON.stringify(E)+",";l+=f,d!==0&&d%Xee===0&&(u.push(l),l="")}l.length!==0&&u.push(l),u.push("]"),u.push(null)}else throw bt(new Error,Cr.INVALID_VALUE("format"),yt.BAD_REQUEST);return new Qee({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(ite,"export_to_s3");function E0(e,t){let r=El.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 $ee(n,s);return r.pipe(i)}a(E0,"toCsvStream");function h0(e){if(Sn.trace("in exportCoreValidation"),jr.isEmpty(e.format))return"format missing";if(l0.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${l0.join(", ")}`;let t=e.search_operation.operation;if(jr.isEmpty(t))return"search_operation.operation missing";if(u0.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${u0.join(", ")}`}a(h0,"exportCoreValidation");async function m0(e){Sn.trace("in getRecords");let t,r;if(fl.isEmpty(e.search_operation)||fl.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=Zee;break;case"search_by_hash":t=jee;break;case"search_by_conditions":t=$g.searchByConditions;break;case"sql":t=ete;break;default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,Sn.error(r),bt(new Error,r,yt.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(m0,"getRecords")});var N0={};Fe(N0,{contentTypes:()=>Qg,findBestSerializer:()=>eE,getDeserializer:()=>yo,registerContentHandlers:()=>zg,serialize:()=>tE,serializeMessage:()=>Ro});function ote(e){try{return e?.[0]===123?Wg(e):e}catch{return e}}function zg(e){e.register(cte,{serializers:[{regex:/^application\/json$/,serializer:Lc},{regex:/^application\/cbor$/,serializer:function(t){return new bo.EncoderStream(ml).end(t)}},{regex:/^application\/(x-)?msgpack$/,serializer:function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?Zf.Readable.from((0,_s.encodeIter)(t,ml)):(0,_s.pack)(t)}},{regex:/^text\/csv$/,serializer:function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,jf.toCsvStream)(t)}}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,_s.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,bo.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function eE(e){let t=e.headers.asObject||e.headers,r=e.requestedContentType??t.accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let u of c){let[_,...l]=u.split(/\s*;\s*/),d=1,E={q:1};for(let h of l){let p=h.indexOf("=");E[h.substring(0,p)]=h.substring(p+1)}d=+E.q;let f=kt.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 R0.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(kt.keys()).join(", "),406);n=kt.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function tE(e,t,r){let n=T0&&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=eE(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,Gs.createBrotliCompress)({params:{[Gs.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?Gs.constants.BROTLI_MODE_TEXT:Gs.constants.BROTLI_MODE_GENERIC,[Gs.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>T0?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,Gs.brotliCompress)(s,(c,u)=>{c?o(c):i(u)}))):s}function Ro(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return hl(e);let r=t.serialize;if(r)return r(e);let n=eE(t);return r=t.serialize=n.serializer.serialize,r(e)}function ute(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 yo(e,t){e||(e="");let r=e.indexOf(";"),n;r>-1&&(n=e.slice(r+1),e=e.slice(0,r));let s=kt.get(e);if(t){if(s?.deserializeStream)return s.deserializeStream;let i=kt.get(e)?.deserialize||g0(e,n);return o=>ute(o).then(i)}return e&&kt.get(e)?.deserialize||g0(e,n)}function g0(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 Wg(r)}catch{}return{contentType:e||"application/octet-stream",data:r}}}function lte(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 jf,_s,bo,Gs,R0,Zf,A0,Yg,Kg,O0,b0,hl,Wg,ml,kt,Qg,S0,y0,ate,cte,T0,Da=Re(()=>{lm();jf=H(Xf()),_s=require("msgpackr"),bo=require("cbor-x"),Gs=require("zlib"),R0=H(se()),Zf=require("stream");fr();A0=require("../index"),Yg=H(ee()),Kg=H(P()),O0=H(require("yaml")),b0=Yg.default.get(Kg.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,hl=b0?qi:JSON.stringify,Wg=b0?um:JSON.parse,ml={useRecords:!1,useToJSON:!0},kt=new Map,Qg=kt;at.contentTypes=Qg;(0,A0._assignPackageExport)("contentTypes",Qg);kt.set("application/json",{serializeStream:Lc,serialize:hl,deserialize:Wg,q:.8});S0=new bo.Encoder(ml);kt.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new bo.EncoderStream(ml).end(e)},serialize:S0.encode,deserialize:S0.decode,q:1});kt.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?Zf.Readable.from((0,_s.encodeIter)(e,ml)):(0,_s.pack)(e)},serialize:_s.pack,deserialize:_s.unpack,q:.9});kt.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,jf.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,jf.toCsvStream)(e,e?.getColumns?.())},q:.1});kt.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.2});kt.set("text/yaml",{serialize(e){return O0.stringify(e,{aliasDuplicateObjects:!1})},q:.7});kt.set("text/event-stream",{serializeStream:function(e){return Zf.Readable.from(lte(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+`
|
|
22
|
-
`),e.data){let r=e.data;typeof r=="object"&&(r=
|
|
19
|
+
`,""):null}catch(E){E.stderr?i[u].npm_error=hv(E.stderr):i[u].npm_error=E.message;continue}try{i[u].npm_output=JSON.parse(l)}catch{i[u].npm_output=l}try{i[u].npm_error=JSON.parse(d)}catch{i[u].npm_error=d}}return Pa.info(`finished installModules with response ${i}`),i}a(S7,"installModules");function hv(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
|
|
20
|
+
`);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(hv,"parseNPMStdErr");async function T7(e){Pa.info(`starting auditModules for request: ${e}`);let t=pv(e);if(t)throw La(t,t.message,Ma.BAD_REQUEST);let{projects:r}=e;await Hf(),await mv(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=xf.join(Og,o);n[o]={npm_output:null,npm_error:null};try{let u=await ol("npm audit --json",c);n[o].npm_output=JSON.parse(u)}catch(u){n[o].npm_error=hv(u.stderr)}}return Pa.info(`finished auditModules with response ${n}`),n}a(T7,"auditModules");async function Hf(){try{return await ol("npm -v"),!0}catch{throw La(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",Ma.BAD_REQUEST,void 0,void 0,!0)}}a(Hf,"checkNPMInstalled");async function mv(e){if(!Array.isArray(e)||e.length===0)throw La(new Error,"projects argument must be an array with at least 1 element",Ma.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=xf.join(Og,i.toString());if(!await dv.pathExists(o)){t.push(i);continue}let u=xf.join(o,"package.json");await dv.pathExists(u)||r.push(i)}if(t.length>0)throw La(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Ma.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw La(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Ma.BAD_REQUEST,void 0,void 0,!0)}a(mv,"checkProjectPaths");function pv(e){let t=Bf.object({projects:Bf.array().min(1).items(Bf.string()).required(),dry_run:Bf.boolean().default(!1)});return f7.validateBySchema(e,t)}a(pv,"modulesValidator")});var yg=g((bme,Ov)=>{"use strict";var Ua=require("fs-extra"),bg=require("path"),qf=$(),Tv=J(),Ff=P(),Av=ee(),g7=pr();Ov.exports=R7;async function R7(){let e=A7(),t=Av.get(Ff.CONFIG_PARAMS.ROOTPATH),r=bg.join(t,"package.json"),n={dependencies:{harperdb:"file:"+Ff.PACKAGE_ROOT}},s=bg.join(t,"node_modules");await Ua.ensureDir(s);let i,o=!0,c=!1;try{i=await Ua.readJson(r)}catch(u){if(Tv.isEmptyOrZeroLength(e))return;if(u.code!==Ff.NODE_ERROR_CODES.ENOENT)throw u;o=!1}if(!Tv.isEmptyOrZeroLength(e)){for(let{name:u,package:_}of e){let l=await gv(_);n.dependencies[u]=l+_}if(!o){qf.notify("Installing components"),await Rv(r,n,null);return}for(let{name:u,package:_}of e){let l=i.dependencies[u],d=await gv(_);if(l===void 0||l!==d+_){c=!0;break}}}for(let u in i.dependencies)n.dependencies[u]===void 0&&(qf.notify("Removing component",u),c=!0);c&&(qf.notify("Updating components."),await Rv(r,n,i))}a(R7,"installComponents");function A7(){let e=g7.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(A7,"getComponentsConfig");async function gv(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":bg.extname(e)||await Ua.pathExists(e)?"file:":"github:"}a(gv,"getPkgPrefix");async function Rv(e,t,r){qf.trace("npm installing components package.json",t),await Ua.writeFile(e,JSON.stringify(t,null," "));try{await Gf().installAllRootModules(Av.get(Ff.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?await Ua.writeFile(e,JSON.stringify(r,null," ")):await Ua.unlink(e),n}}a(Rv,"installPackages")});var wg=g((Ime,Iv)=>{"use strict";var $e=require("fs-extra"),Ng=require("fast-glob"),ge=require("path"),yv=require("tar-fs"),Nme=require("uuid").v4,Ig=require("normalize-path"),us=_v(),Ct=$(),Je=P(),Ot=ee(),al=pr(),O7=J(),{PACKAGE_ROOT:b7}=P(),{handleHDBError:qt,hdb_errors:y7}=se(),{basename:N7}=require("path"),I7=yg(),Nv=ee(),w7=P(),{Readable:C7}=require("stream"),{isMainThread:D7}=require("worker_threads"),{HDB_ERROR_MSGS:Ao,HTTP_STATUS_CODES:Ft}=y7,L7=ge.join(b7,"application-template"),bv=ge.join(Ot.get(Je.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp");function M7(){Ct.trace("getting custom api status");let e={};try{e={port:Ot.get(Je.CONFIG_PARAMS.HTTP_PORT),directory:Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw qt(new Error,Ao.FUNCTION_STATUS,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,t)}return e}a(M7,"customFunctionsStatus");function P7(){Ct.trace("getting custom api endpoints");let e={},t=Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT);try{Ng.sync(Ig(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:Ng.sync(Ig(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:Ng.sync(Ig(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw qt(new Error,Ao.GET_FUNCTIONS,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,r)}return e}a(P7,"getCustomFunctions");function U7(e){e.project&&(e.project=ge.parse(e.project).name),e.file&&(e.file=ge.parse(e.file).name);let t=us.getDropCustomFunctionValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);Ct.trace("getting custom api endpoint file content");let r=Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=ge.join(r,n,s,i+".js");try{return $e.readFileSync(o,{encoding:"utf8"})}catch(c){throw qt(new Error,Ao.GET_FUNCTION,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,c)}}a(U7,"getCustomFunction");function v7(e){e.project&&(e.project=ge.parse(e.project).name),e.file&&(e.file=ge.parse(e.file).name);let t=us.setCustomFunctionValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);Ct.trace("setting custom function file content");let r=Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{return $e.outputFileSync(ge.join(r,n,s,i+".js"),o),`Successfully updated custom function: ${i}.js`}catch(c){throw qt(new Error,Ao.SET_FUNCTION,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,c)}}a(v7,"setCustomFunction");function B7(e){e.project&&(e.project=ge.parse(e.project).name),e.file&&(e.file=ge.parse(e.file).name);let t=us.getDropCustomFunctionValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);Ct.trace("dropping custom function file");let r=Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{return $e.unlinkSync(ge.join(r,n,s,i+".js")),`Successfully deleted custom function: ${i}.js`}catch(o){throw qt(new Error,Ao.DROP_FUNCTION,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,o)}}a(B7,"dropCustomFunction");function x7(e){e.project&&(e.project=ge.parse(e.project).name);let t=us.addComponentValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);Ct.trace("adding component");let r=Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=ge.join(r,n);return $e.mkdirSync(s,{recursive:!0}),$e.copySync(L7,s),`Successfully added project: ${n}`}catch(s){throw qt(new Error,Ao.ADD_FUNCTION,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,s)}}a(x7,"addComponent");function H7(e){e.project&&(e.project=ge.parse(e.project).name);let t=us.dropCustomFunctionProjectValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);Ct.trace("dropping custom function project");let r=Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Ot.get(Je.CONFIG_PARAMS.APPS);if(!O7.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 al.updateConfigValue(Je.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=ge.join(r,n);return $e.rmSync(i,{recursive:!0}),`Successfully deleted project: ${n}`}catch(i){throw qt(new Error,Ao.DROP_FUNCTION_PROJECT,Ft.INTERNAL_SERVER_ERROR,Ct.ERR,i)}}a(H7,"dropCustomFunctionProject");async function G7(e){e.project&&(e.project=ge.parse(e.project).name);let t=us.packageComponentValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);let r=Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Ct.trace("packaging component",n);let s;try{s=await $e.realpath(ge.join(r,n))}catch(u){if(u.code!==Je.NODE_ERROR_CODES.ENOENT)throw u;try{s=await $e.realpath(ge.join(Ot.get(Je.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(_){if(_.code===Je.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}await $e.ensureDir(bv);let i=ge.join(bv,`${n}.tar`),o={};(e.skip_node_modules===!0||e.skip_node_modules==="true")&&(o={ignore:u=>u.includes(ge.join(s,"node_modules"))}),yv.pack(s,o).pipe($e.createWriteStream(i,{overwrite:!0})),await new Promise(u=>setTimeout(u,2e3));let c=$e.readFileSync(i,{encoding:"base64"});return await $e.remove(i),{project:n,payload:c}}a(G7,"packageComponent");async function q7(e){e.project&&(e.project=ge.parse(e.project).name);let t=us.deployComponentValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);let r=Ot.get(Je.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=ge.join(r,n),i="file:"+o,await $e.emptyDir(o);let E=C7.from(Buffer.from(s,"base64"));await new Promise((h,p)=>{E.pipe(yv.extract(o,{finish:h})).on("error",p)});let f=await $e.readdir(o);f.length===1&&f[0]==="package"&&(await $e.copy(ge.join(o,"package"),o),await $e.remove(ge.join(o,"package")))}if(await al.addConfig(n,{package:i}),!s){await I7();let E=Nv.get(w7.CONFIG_PARAMS.ROOTPATH);o=ge.join(E,"node_modules",n)}if(D7)return;let c=new Map;c.isWorker=!0;let u=(Vf(),ie(kf)),_;u.setErrorReporter(E=>_=E);let l=N7(o),d=u.component_errors.get(l);try{await u.loadComponent(o,c)}finally{u.component_errors.set(l,d)}if(_)throw _;return Ct.info("Installed component"),`Successfully deployed: ${n}`}a(q7,"deployComponent");async function F7(){let e=al.getConfiguration(),t=[];for(let o in e)if(e[o]?.package){if(e[o].package.startsWith("file:"))continue;t.push(Object.assign({},e[o],{name:o}))}let r=a(async(o,c)=>{try{let u=await $e.readdir(o,{withFileTypes:!0});for(let _ of u){let l=_.name;if(l.startsWith(".")||l==="node_modules")continue;let d=ge.join(o,l);if(_.isDirectory()||_.isSymbolicLink()){let E={name:l,entries:[]};c.entries.push(E),await r(d,E)}else{let E=await $e.stat(d),f={name:ge.basename(l),mtime:E.mtime,size:E.size};c.entries.push(f)}}return c}catch(u){return Ct.warn("Error loading package",u),{error:u.toString(),entries:[]}}},"walk_dir"),n=await r(Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),{name:Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT).split(ge.sep).slice(-1).pop(),entries:t});for(let o of n.entries)if(o.package){let c=await r(ge.join(Ot.get(Je.CONFIG_PARAMS.ROOTPATH),"node_modules",o.name),{name:o.name,entries:[]});Object.assign(o,c)}let i=(Vf(),ie(kf)).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(F7,"getComponents");async function k7(e){let t=us.getComponentFileValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);let n=al.getConfigObj()[e.project]||e.project==="harperdb"?ge.join(Nv.get(Je.CONFIG_PARAMS.ROOTPATH),"node_modules"):Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await $e.stat(ge.join(n,e.project,e.file));return{message:await $e.readFile(ge.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===Je.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${ge.join(e.project,e.file)}'`):i}}a(k7,"getComponentFile");async function V7(e){let t=us.setComponentFileValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=ge.join(Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);return e.payload!==void 0?(await $e.ensureFile(n),await $e.outputFile(n,e.payload,r)):await $e.ensureDir(n),"Successfully set component: "+e.file}a(V7,"setComponentFile");async function $7(e){let t=us.dropComponentFileValidator(e);if(t)throw qt(t,t.message,Ft.BAD_REQUEST);let r=e.file?ge.join(e.project,e.file):e.project,n=ge.join(Ot.get(Je.CONFIG_PARAMS.COMPONENTSROOT),r);return await $e.pathExists(n)&&await $e.remove(n),al.deleteConfigFromFile([e.project]),"Successfully dropped: "+r}a($7,"dropComponent");Iv.exports={customFunctionsStatus:M7,getCustomFunctions:P7,getCustomFunction:U7,setCustomFunction:v7,dropCustomFunction:B7,addComponent:x7,dropCustomFunctionProject:H7,packageComponent:G7,deployComponent:q7,getComponents:F7,getComponentFile:k7,setComponentFile:V7,dropComponent:$7}});var Cg=g((Cme,Cv)=>{"use strict";var ls=require("joi"),wv=je();Cv.exports={readTransactionLogValidator:Y7,deleteTransactionLogsBeforeValidator:K7};function Y7(e){let t=ls.object({schema:ls.string().required(),table:ls.string().required(),from:ls.date().timestamp(),to:ls.date().timestamp(),limit:ls.number().min(1)});return wv.validateBySchema(e,t)}a(Y7,"readTransactionLogValidator");function K7(e){let t=ls.object({schema:ls.string().required(),table:ls.string().required(),timestamp:ls.date().timestamp().required()});return wv.validateBySchema(e,t)}a(K7,"deleteTransactionLogsBeforeValidator")});var $f=g((Lme,Uv)=>{"use strict";var Dg=P(),cl=ut(),Dv=J(),Lv=ee(),Mv=Os(),{handleHDBError:va,hdb_errors:W7}=se(),{HTTP_STATUS_CODES:Ba}=W7,{readTransactionLogValidator:Q7,deleteTransactionLogsBeforeValidator:z7}=Cg(),Pv="This operation relies on clustering and cannot run with it disable.",J7="Logs successfully deleted from transaction log.",X7="All logs successfully deleted from transaction log.";Uv.exports={readTransactionLog:j7,deleteTransactionLogsBefore:Z7};async function*j7(e){let t=Q7(e);if(t)throw va(t,t.message,Ba.BAD_REQUEST,void 0,void 0,!0);if(!Lv.get(Dg.CONFIG_PARAMS.CLUSTERING_ENABLED))throw va(new Error,Pv,Ba.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:n}=e,s=Dv.checkSchemaTableExist(r,n);if(s)throw va(new Error,s,Ba.NOT_FOUND,void 0,void 0,!0);let i=Mv.createNatsTableStreamName(r,n),o=await cl.viewStreamIterator(i,parseInt(e.from),e.limit);for await(let c of o){let u=Math.floor(c?.nats_timestamp/1e6);if(e.to&&u>e.to)break;let _={operation:c?.entry?.operation,user:c?.entry?.__origin?.user,timestamp:u,records:c?.entry?.records,attributes:c?.entry?.attributes};c?.entry?.operation===Dg.OPERATIONS_ENUM.DELETE&&(_.hash_values=c?.entry?.hash_values),yield _}}a(j7,"readTransactionLog");async function Z7(e){let t=z7(e);if(t)throw va(t,t.message,Ba.BAD_REQUEST,void 0,void 0,!0);if(!Lv.get(Dg.CONFIG_PARAMS.CLUSTERING_ENABLED))throw va(new Error,Pv,Ba.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:n,timestamp:s}=e,i=Dv.checkSchemaTableExist(r,n);if(i)throw va(new Error,i,Ba.NOT_FOUND,void 0,void 0,!0);let o=Mv.createNatsTableStreamName(r,n),{jsm:c}=await cl.getNATSReferences(),u=await cl.getStreamInfo(o),_=new Date(u.state.first_ts).getTime();if(s<=_)return`No transactions exist before: ${s}`;let l=J7,d,E=new Date(u.state.last_ts).getTime();return s>E?(d=u.state.last_seq+1,l=X7):d=(await cl.viewStream(o,parseInt(s),1))[0].nats_sequence,await cl.purgeTableStream(r,n,{seq:d}),l}a(Z7,"deleteTransactionLogsBefore")});var Bv=g((Pme,vv)=>{"use strict";var Lg=class{static{a(this,"PermissionTableResponseObject")}constructor(t,r,n=[],s=[]){this.schema=t,this.table=r,this.required_table_permissions=n,this.required_attribute_permissions=s}};vv.exports=Lg});var Hv=g((vme,xv)=>{"use strict";var Mg=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};xv.exports=Mg});var Ug=g((xme,qv)=>{"use strict";var Gv=Bv(),eee=Hv(),{HDB_ERROR_MSGS:tee}=vr(),Pg=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=tee.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 Gv(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let u=new eee(c,s[c]);i.push(u)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new Gv(r,n,[],i);this.unauthorized_access[o]=c}}getPermsResponse(){let t=Object.values(this.unauthorized_access);return t.length>0||this.invalid_schema_items.length>0?(this.unauthorized_access=t,this):null}};qv.exports=Pg});var Qf=g((Gme,r0)=>{"use strict";var vg=Fr(),Yf=qr(),pn=yu(),_l=bs(),Bg=ci(),ree=QS(),nee=kL(),dl=_n(),Kf=nT(),Dt=$(),see=oT(),iee=af(),oee=GT(),aee=uf(),cee=FT(),uee=kT(),lee=YT(),_ee=WT(),xg=JT(),xs=J(),dee=qP(),Hg=tg(),Vv=ju(),mn=P(),$v=QU(),fee=Ra(),Yv=Lu(),Kv=(Uf(),ie(rl)),Wv=pr(),Xr=wg(),Eee=require("alasql"),Qv=$f(),zv=Gf(),Jv=Ug(),{handleHDBError:wr,hdb_errors:Xv}=se(),{HDB_ERROR_MSGS:Qt,HTTP_STATUS_CODES:ul}=Xv,V=new Map,jv="delete",Ii="insert",Hs="read",Oo="update",ll="describe",Fv=_l.describeSchema.name,kv=_l.describeTable.name,Zv={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},hee="catchup",mee="handleGetJob",pee="handleGetJobsByStartDate",Wf={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},See=[pn.createTable.name,pn.createAttribute.name,pn.dropTable.name,pn.dropAttribute.name],e0={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(vg.insert.name,new W(!1,[Ii]));V.set(vg.update.name,new W(!1,[Oo]));V.set(vg.upsert.name,new W(!1,[Ii,Oo]));V.set(Yf.searchByConditions.name,new W(!1,[Hs]));V.set(Yf.searchByHash.name,new W(!1,[Hs]));V.set(Yf.searchByValue.name,new W(!1,[Hs]));V.set(Yf.search.name,new W(!1,[Hs]));V.set(pn.createSchema.name,new W(!0,[]));V.set(pn.createTable.name,new W(!0,[]));V.set(pn.createAttribute.name,new W(!1,[Ii]));V.set(pn.dropSchema.name,new W(!0,[]));V.set(pn.dropTable.name,new W(!0,[]));V.set(pn.dropAttribute.name,new W(!0,[]));V.set(_l.describeSchema.name,new W(!1,[Hs]));V.set(_l.describeTable.name,new W(!1,[Hs]));V.set(Bg.deleteRecord.name,new W(!1,[jv]));V.set(dl.addUser.name,new W(!0,[]));V.set(dl.alterUser.name,new W(!0,[]));V.set(dl.dropUser.name,new W(!0,[]));V.set(dl.listUsersExternal.name,new W(!0,[]));V.set(Kf.listRoles.name,new W(!0,[]));V.set(Kf.addRole.name,new W(!0,[]));V.set(Kf.alterRole.name,new W(!0,[]));V.set(Kf.dropRole.name,new W(!0,[]));V.set(see.name,new W(!0,[]));V.set(iee.name,new W(!0,[]));V.set(oee.name,new W(!0,[]));V.set(aee.name,new W(!0,[]));V.set(cee.name,new W(!0,[]));V.set(uee.name,new W(!0,[]));V.set(xg.setRoutes.name,new W(!0,[]));V.set(xg.getRoutes.name,new W(!0,[]));V.set(xg.deleteRoutes.name,new W(!0,[]));V.set(Wv.setConfiguration.name,new W(!0,[]));V.set(lee.clusterStatus.name,new W(!0,[]));V.set(_ee.name,new W(!0,[]));V.set(Hg.getFingerprint.name,new W(!0,[]));V.set(Hg.setLicense.name,new W(!0,[]));V.set(Bg.deleteFilesBefore.name,new W(!0,[]));V.set(Bg.deleteAuditLogsBefore.name,new W(!0,[]));V.set(Vv.restart.name,new W(!0,[]));V.set(Vv.restartService.name,new W(!0,[]));V.set(ree.name,new W(!0,[]));V.set(nee.name,new W(!0,[Hs]));V.set(fee.systemInformation.name,new W(!0,[]));V.set(Wv.getConfiguration.name,new W(!0,[]));V.set(Qv.readTransactionLog.name,new W(!0,[]));V.set(Qv.deleteTransactionLogsBefore.name,new W(!0,[]));V.set(zv.installModules.name,new W(!0,[]));V.set(zv.auditModules.name,new W(!0,[]));V.set(Yv.createTokens.name,new W(!1,[]));V.set(Yv.refreshOperationToken.name,new W(!1,[]));V.set(Kv.login.name,new W(!1,[]));V.set(Kv.logout.name,new W(!1,[]));V.set(Xr.customFunctionsStatus.name,new W(!0,[]));V.set(Xr.getCustomFunctions.name,new W(!0,[]));V.set(Xr.getComponents.name,new W(!0,[]));V.set(Xr.getComponentFile.name,new W(!0,[]));V.set(Xr.setComponentFile.name,new W(!0,[]));V.set(Xr.dropComponent.name,new W(!0,[]));V.set(Xr.getCustomFunction.name,new W(!0,[]));V.set(Xr.setCustomFunction.name,new W(!0,[]));V.set(Xr.dropCustomFunction.name,new W(!0,[]));V.set(Xr.addComponent.name,new W(!0,[]));V.set(Xr.dropCustomFunctionProject.name,new W(!0,[]));V.set(Xr.packageComponent.name,new W(!0,[]));V.set(Xr.deployComponent.name,new W(!0,[]));V.set(Hg.getRegistrationInfo.name,new W(!1,[]));V.set(dl.userInfo.name,new W(!1,[]));V.set(_l.describeAll.name,new W(!1,[]));V.set(mee,new W(!1,[]));V.set(pee,new W(!0,[]));V.set(hee,new W(!0,[]));V.set(Wf.CSV_DATA_LOAD,new W(!1,[Ii,Oo]));V.set(Wf.CSV_URL_LOAD,new W(!1,[Ii,Oo]));V.set(Wf.CSV_FILE_LOAD,new W(!1,[Ii,Oo]));V.set(Wf.IMPORT_FROM_S3,new W(!1,[Ii,Oo]));V.set(e0.EXPORT_TO_S3,new W(!0,[]));V.set(e0.EXPORT_LOCAL,new W(!0,[]));V.set(mn.VALID_SQL_OPS_ENUM.DELETE,new W(!1,[jv]));V.set(mn.VALID_SQL_OPS_ENUM.SELECT,new W(!1,[Hs]));V.set(mn.VALID_SQL_OPS_ENUM.INSERT,new W(!1,[Ii]));V.set(mn.VALID_SQL_OPS_ENUM.UPDATE,new W(!1,[Oo]));r0.exports={verifyPerms:gee,verifyPermsAst:Tee,verifyBulkLoadAttributePerms:Aee};function Tee(e,t,r){if(xs.isEmptyOrZeroLength(e))throw Dt.info("verify_perms_ast has an empty user parameter"),wr(new Error);if(xs.isEmptyOrZeroLength(t))throw Dt.info("verify_perms_ast has an empty user parameter"),wr(new Error);if(xs.isEmptyOrZeroLength(r))throw Dt.info("verify_perms_ast has a null operation parameter"),wr(new Error);try{let n=new Jv,s=new dee(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,u=i.includes("system");if(u&&Zv[r])throw wr(new Error,Qt.DROP_SYSTEM,ul.FORBIDDEN);if(c&&!u)return null;let _=$v.getRolePermissions(t.role);t.role.permission=_,!c&&e instanceof Eee.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 l=t0(t,r,o,n);return l||(o.forEach((d,E)=>{for(let f=0;f<d.length;f++){let h=s.getAttributesBySchemaTableName(E,d[f]),p=qg(t.role.permission,E,d[f]);Gg(h,p,r,d[f],E,n)}}),n.getPermsResponse())}catch(n){throw wr(n)}}a(Tee,"verifyPermsAst");function gee(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,Qt.DEFAULT_INVALID_REQUEST,ul.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 Jv;if(xs.isEmptyOrZeroLength(e.hdb_user?.role)||xs.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(Qt.USER_HAS_NO_PERMS(e.hdb_user?.username));let u=!!e.hdb_user?.role?.permission?.super_user,_=e.hdb_user?.role?.permission?.structure_user,l=o.has(mn.SYSTEM_SCHEMA_NAME)||s===mn.SYSTEM_SCHEMA_NAME;if(l&&Zv[r])throw wr(new Error,Qt.DROP_SYSTEM,ul.FORBIDDEN);if(u&&!l||_===!0&&(r===pn.createSchema.name||r===pn.dropSchema.name))return null;if(See.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=$v.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=d),r===Fv||r===kv){if(s===mn.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(Qt.SCHEMA_PERM_ERROR(s));if(!d.super_user){if(r===Fv&&(!d[s]||!d[s][ll]))return c.handleInvalidItem(Qt.SCHEMA_NOT_FOUND(s));if(r===kv&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][ll]))return c.handleInvalidItem(Qt.TABLE_NOT_FOUND(s,i))}}let E=t0(e.hdb_user,r,o,c,n);if(E)return E;if(V.get(r)&&V.get(r).perms.length===0)return null;if(!u&&e.get_attributes&&mn.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let p=[],S=d[s].tables[i];S[mn.PERMS_CRUD_ENUM.READ]&&(S.attribute_permissions.length>0?S.attribute_permissions.filter(A=>A[mn.PERMS_CRUD_ENUM.READ]).forEach(A=>{p.push(A.attribute_name)}):p=global.hdb_schema[s][i].attributes.map(T=>T.attribute),e.get_attributes=p)}let f=Ree(e),h=qg(e.hdb_user?.role?.permission,s,i);return Gg(f,h,r,i,s,c,n),c.getPermsResponse()}a(gee,"verifyPerms");function t0(e,t,r,n,s){if(xs.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,Qt.OP_NOT_FOUND(t),ul.BAD_REQUEST);if(V.get(t)&&V.get(t).requires_su)return Dt.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(Qt.OP_IS_SU_ONLY(t));let c=r.keys();for(let u of c){try{if(u&&!o[u]||o[u][ll]===!1){n.addInvalidItem(Qt.SCHEMA_NOT_FOUND(u));continue}}catch{n.addInvalidItem(Qt.SCHEMA_NOT_FOUND(u));continue}let _=r.get(u);for(let l of _){let d=o[u].tables[l];if(!d||d[ll]===!1)n.addInvalidItem(Qt.TABLE_NOT_FOUND(u,l));else try{let E=[],f=V.get(t).perms;!xs.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(u,l,E)}catch(E){let f=Qt.UNKNOWN_OP_AUTH_ERROR(t,u,l);throw Dt.error(f),Dt.error(E),wr(Xv.CHECK_LOGS_WRAPPER(f))}}}return r.size<2?n.getPermsResponse():null}a(t0,"hasPermissions");function Gg(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(xs.isEmptyOrZeroLength(t))return Dt.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let u={};for(let l of e){let d=t.get(l);if(d){if(d[ll]===!1){i.addInvalidItem(Qt.ATTR_NOT_FOUND(s,n,l),s,n);continue}if(c)for(let E of c){if(mn.TIME_STAMP_NAMES.includes(d.attribute_name)&&E!==Hs)throw wr(new Error,Qt.SYSTEM_TIMESTAMP_PERMS_ERR,ul.FORBIDDEN);d[E]===!1&&(u[d.attribute_name]?u[d.attribute_name].push(E):u[d.attribute_name]=[E])}}else i.addInvalidItem(Qt.ATTR_NOT_FOUND(s,n,l),s,n)}let _=Object.keys(u);_.length>0&&i.addUnauthorizedAttributes(_,s,n,u)}a(Gg,"checkAttributePerms");function Ree(e){let t=new Set;try{if(e.action)return t;if(e.operation===mn.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(Ree,"getRecordAttributes");function qg(e,t,r){let n=new Map;if(xs.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(qg,"getAttributePermissions");function Aee(e,t,r,n,s,i,o){let c=new Set(i),u=qg(e,n,s);Gg(c,u,t,s,n,o,r)}a(Aee,"verifyBulkLoadAttributePerms")});var Jf=g((Fme,a0)=>{"use strict";a0.exports={evaluateSQL:vee,processAST:o0,convertSQLToAST:i0,checkASTPermissions:s0};var Oee=Fr(),n0=require("util"),bee=n0.callbackify(Oee.insert),yee=qr().search,Nee=ND().update,Iee=n0.callbackify(Nee),wee=wD().convertDelete,wi=require("alasql"),Cee=Qf(),zf=$(),Dee=bd(),Lee=J(),fl=P(),{hdb_errors:Mee,handleHDBError:Fg}=se(),{HTTP_STATUS_CODES:kg}=Mee;Dee(wi);var Pee=403,Uee="There was a problem performing this insert. Please check the logs and try again.",Vg=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function vee(e,t){let r=e.parsed_sql_object;if(!r){r=i0(e.sql);let n,s=r.ast.statements[0];if(s instanceof wi.yy.Insert?n=s.into.databaseid:s instanceof wi.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof wi.yy.Update||s instanceof wi.yy.Delete?n=s.table.databaseid:zf.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof wi.yy.Select)&&Lee.isEmptyOrZeroLength(n))return t("No schema specified",null)}o0(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(vee,"evaluateSQL");function s0(e,t){let r;try{r=Cee.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(s0,"checkASTPermissions");function i0(e){let t=new Vg;if(!e)throw Fg(new Error,"The 'sql' parameter is missing from the request body",kg.BAD_REQUEST);try{let r=e.trim(),n=wi.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
|
|
21
|
+
`);throw n[1]?Fg(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,kg.BAD_REQUEST):Fg(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",kg.BAD_REQUEST)}return t}a(i0,"convertSQLToAST");function o0(e,t,r){try{let n=Bee;if(!e.bypass_auth&&!t.permissions_checked){let i=s0(e,t);if(i&&i.length>0)return r(Pee,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case fl.VALID_SQL_OPS_ENUM.SELECT:n=yee,s=t.ast.statements[0];break;case fl.VALID_SQL_OPS_ENUM.INSERT:n=xee;break;case fl.VALID_SQL_OPS_ENUM.UPDATE:n=Iee;break;case fl.VALID_SQL_OPS_ENUM.DELETE:n=wee;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(o0,"processAST");function Bee(e,t){zf.info(e),t("unknown sql statement")}a(Bee,"nullFunction");function xee({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=Hee(i,e.values)}catch(o){return r(o)}bee(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(u){zf.error(`Error delete new_attributes from insert response: ${u}`)}r(null,c)})}a(xee,"convertInsert");function Hee(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]]=wi.compile(`SELECT ${s.toString()} AS [${fl.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw zf.error(r),new Error(Uee)}}a(Hee,"createDataObjects")});var $g=g((Vme,u0)=>{"use strict";var{S3:Gee,GetObjectCommand:qee}=require("@aws-sdk/client-s3");u0.exports={getFileStreamFromS3:Fee,getS3AuthObj:c0};async function Fee(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await c0(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new qee(r))).Body}a(Fee,"getFileStreamFromS3");function c0(e,t,r){return new Gee({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(c0,"getS3AuthObj")});var Xf=g((Yme,S0)=>{"use strict";var Kg=qr(),kee=Jf(),Vee=$g(),{AsyncParser:$ee,Transform:Yee}=require("json2csv"),hl=require("stream"),jr=J(),Yg=require("fs-extra"),Kee=require("path"),Sn=$(),{promisify:d0}=require("util"),El=J(),{handleHDBError:bt,hdb_errors:Wee}=se(),{HDB_ERROR_MSGS:Cr,HTTP_STATUS_CODES:yt}=Wee,{streamAsJSON:Qee}=(dm(),ie(Fb)),{Upload:zee}=require("@aws-sdk/lib-storage"),l0=["search_by_value","search_by_hash","sql","search_by_conditions"],_0=["json","csv"],f0="json",E0="csv",Jee="Successfully exported JSON locally.",Xee="Successfully exported CSV locally.",jee=1e3,Zee=Kg.searchByHash,ete=Kg.searchByValue,tte=d0(kee.evaluateSQL),rte=d0(hl.finished);S0.exports={export_to_s3:ote,export_local:nte,toCsvStream:h0};async function nte(e){Sn.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=m0(e);if(!jr.isEmpty(t))throw Sn.error(t),bt(new Error,t,yt.BAD_REQUEST,void 0,void 0,!0);if(jr.isEmpty(e.path))throw Sn.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(Kee.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=jr.buildFolderPath(e.path,r);await ste(e.path);let s=await p0(e);return await ite(n,e.format,s)}a(nte,"export_local");async function ste(e){if(Sn.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 Yg.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,Sn.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 Sn.error(r),bt(new Error,r,yt.BAD_REQUEST,void 0,void 0,!0)}return!0}a(ste,"confirmPath");async function ite(e,t,r){if(Sn.trace("in saveToLocal"),El.isEmptyOrZeroLength(e))throw bt(new Error,Cr.INVALID_VALUE("file_path"),yt.BAD_REQUEST,void 0,void 0,!0);if(El.isEmptyOrZeroLength(t))throw bt(new Error,Cr.INVALID_VALUE("Source format"),yt.BAD_REQUEST,void 0,void 0,!0);if(El.isEmpty(r))throw bt(new Error,Cr.NOT_FOUND("Data"),yt.BAD_REQUEST,void 0,void 0,!0);if(t===f0){let n=Yg.createWriteStream(e);return Qee(r).pipe(n),await rte(n),{message:Jee,path:e}}else if(t===E0){let n=Yg.createWriteStream(e),s=hl.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(l=>({label:l,value:l})));let c={objectMode:!0};return await new $ee(i,c).fromInput(s).toOutput(n).promise(!1),{message:Xee,path:e}}throw bt(new Error,Cr.INVALID_VALUE("format"),yt.BAD_REQUEST)}a(ite,"saveToLocal");async function ote(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=m0(e);if(!jr.isEmpty(t))throw bt(new Error,t,yt.BAD_REQUEST);Sn.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await p0(e)}catch(u){throw Sn.error(u),u}let n,s=await Vee.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new hl.PassThrough;if(e.format===E0){i=e.s3.key+".csv";let u=h0(r,r.getColumns?.());u.on("error",_=>{throw _}),u.pipe(o)}else if(e.format===f0){i=e.s3.key+".json";let u=new hl.Readable;u.pipe(o),u.on("error",d=>{throw d}),u.push("[");let _=r.length,l="";for(let[d,E]of r.entries()){let f=d===_-1?JSON.stringify(E):JSON.stringify(E)+",";l+=f,d!==0&&d%jee===0&&(u.push(l),l="")}l.length!==0&&u.push(l),u.push("]"),u.push(null)}else throw bt(new Error,Cr.INVALID_VALUE("format"),yt.BAD_REQUEST);return new zee({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(ote,"export_to_s3");function h0(e,t){let r=hl.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 Yee(n,s);return r.pipe(i)}a(h0,"toCsvStream");function m0(e){if(Sn.trace("in exportCoreValidation"),jr.isEmpty(e.format))return"format missing";if(_0.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${_0.join(", ")}`;let t=e.search_operation.operation;if(jr.isEmpty(t))return"search_operation.operation missing";if(l0.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${l0.join(", ")}`}a(m0,"exportCoreValidation");async function p0(e){Sn.trace("in getRecords");let t,r;if(El.isEmpty(e.search_operation)||El.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=ete;break;case"search_by_hash":t=Zee;break;case"search_by_conditions":t=Kg.searchByConditions;break;case"sql":t=tte;break;default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,Sn.error(r),bt(new Error,r,yt.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(p0,"getRecords")});var I0={};Fe(I0,{contentTypes:()=>Jg,findBestSerializer:()=>eE,getDeserializer:()=>yo,registerContentHandlers:()=>Xg,serialize:()=>tE,serializeMessage:()=>Ro});function ate(e){try{return e?.[0]===123?zg(e):e}catch{return e}}function Xg(e){e.register(ute,{serializers:[{regex:/^application\/json$/,serializer:Mc},{regex:/^application\/cbor$/,serializer:function(t){return new bo.EncoderStream(pl).end(t)}},{regex:/^application\/(x-)?msgpack$/,serializer:function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?Zf.Readable.from((0,_s.encodeIter)(t,pl)):(0,_s.pack)(t)}},{regex:/^text\/csv$/,serializer:function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,jf.toCsvStream)(t)}}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,_s.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,bo.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function eE(e){let t=e.headers.asObject||e.headers,r=e.requestedContentType??t.accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let u of c){let[_,...l]=u.split(/\s*;\s*/),d=1,E={q:1};for(let h of l){let p=h.indexOf("=");E[h.substring(0,p)]=h.substring(p+1)}d=+E.q;let f=kt.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 A0.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(kt.keys()).join(", "),406);n=kt.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function tE(e,t,r){let n=g0&&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=eE(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,Gs.createBrotliCompress)({params:{[Gs.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?Gs.constants.BROTLI_MODE_TEXT:Gs.constants.BROTLI_MODE_GENERIC,[Gs.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>g0?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,Gs.brotliCompress)(s,(c,u)=>{c?o(c):i(u)}))):s}function Ro(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return ml(e);let r=t.serialize;if(r)return r(e);let n=eE(t);return r=t.serialize=n.serializer.serialize,r(e)}function lte(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 yo(e,t){e||(e="");let r=e.indexOf(";"),n;r>-1&&(n=e.slice(r+1),e=e.slice(0,r));let s=kt.get(e);if(t){if(s?.deserializeStream)return s.deserializeStream;let i=kt.get(e)?.deserialize||R0(e,n);return o=>lte(o).then(i)}return e&&kt.get(e)?.deserialize||R0(e,n)}function R0(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 zg(r)}catch{}return{contentType:e||"application/octet-stream",data:r}}}function _te(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 jf,_s,bo,Gs,A0,Zf,O0,Wg,Qg,b0,y0,ml,zg,pl,kt,Jg,T0,N0,cte,ute,g0,Da=Re(()=>{dm();jf=H(Xf()),_s=require("msgpackr"),bo=require("cbor-x"),Gs=require("zlib"),A0=H(se()),Zf=require("stream");fr();O0=require("../index"),Wg=H(ee()),Qg=H(P()),b0=H(require("yaml")),y0=Wg.default.get(Qg.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,ml=y0?qi:JSON.stringify,zg=y0?_m:JSON.parse,pl={useRecords:!1,useToJSON:!0},kt=new Map,Jg=kt;at.contentTypes=Jg;(0,O0._assignPackageExport)("contentTypes",Jg);kt.set("application/json",{serializeStream:Mc,serialize:ml,deserialize:zg,q:.8});T0=new bo.Encoder(pl);kt.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new bo.EncoderStream(pl).end(e)},serialize:T0.encode,deserialize:T0.decode,q:1});kt.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?Zf.Readable.from((0,_s.encodeIter)(e,pl)):(0,_s.pack)(e)},serialize:_s.pack,deserialize:_s.unpack,q:.9});kt.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,jf.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,jf.toCsvStream)(e,e?.getColumns?.())},q:.1});kt.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.2});kt.set("text/yaml",{serialize(e){return b0.stringify(e,{aliasDuplicateObjects:!1})},q:.7});kt.set("text/event-stream",{serializeStream:function(e){return Zf.Readable.from(_te(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+`
|
|
22
|
+
`),e.data){let r=e.data;typeof r=="object"&&(r=ml(r)),t+="data: "+r+`
|
|
23
23
|
`}return e.id&&(t+="id: "+e.id+`
|
|
24
24
|
`),e.retry&&(t+="retry: "+e.retry+`
|
|
25
25
|
`),t+`
|
|
26
|
-
`}else return typeof e=="object"?`data: ${
|
|
26
|
+
`}else return typeof e=="object"?`data: ${ml(e)}
|
|
27
27
|
|
|
28
28
|
`:`data: ${e}
|
|
29
29
|
|
|
30
|
-
`},compressible:!1,q:.8});kt.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()}});y0={type:"application/json",serializeStream:Lc,serialize:hl,deserialize:ote,q:.5};kt.set("*/*",y0);kt.set("",y0);a(ote,"tryJSONParse");a(zg,"registerContentHandlers");ate=require("fastify-plugin"),cte=ate(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=eE(n.raw);s.type(c),s.serializer(function(u){return(o.serializeStream||o.serialize)(u,{headers:{set:(_,l)=>{s.header(_,l)}}})})}),r()},{name:"content-type-negotiation"});a(eE,"findBestSerializer");T0=Yg.default.get(Kg.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(tE,"serialize");a(Ro,"serializeMessage");a(ute,"streamToBuffer");a(yo,"getDeserializer");a(g0,"deserializerUnknownType");a(lte,"transformIterable")});function jg(e,t,r,n,s,i,o,c){let u=e[0];if(t==="or"){let d=_(u);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=_(u),E=l(e.slice(1),!0,u.estimated_count);return E.length>0?o(d,E):d}function _(d){return d.conditions?jg(d.conditions,d.operator,r,n,s,i,o,c):Ga(d,n,d.descending||s.reverse===!0,r,s.allowFullScan,c)}a(_,"executeCondition");function l(d,E,f){return d.map((h,p)=>{if(h.conditions){let A=h.operator==="or",b=l(h.conditions,!A,f);return A?(I,B)=>b.some(U=>U(I,B)):(I,B)=>b.every(U=>U(I,B))}let S=(h.attribute||h[0])===r.primaryKey,T=Tl(h,r,i,c,S,f);return E&&p<d.length-1&&f&&(f=Tte(r.primaryStore,h.estimated_count,f)),T}).filter(Boolean)}a(l,"mapConditionsToFilters")}function Ga(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,u=e.comparator;if(Array.isArray(o)){let A=o[0],b=Fs(n.attributes,A);if(b.relationship){if(o.length<2)throw new Zr.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let I=b.definition?.tableClass||b.elements?.definition?.tableClass,B=new Map,U=Ga({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:u},t,r,I,s,B);if(b.relationship.to){i[o[0]]=B;let F=!!Fs(I.attributes,b.relationship.to)?.elements;U=hte(U,b,I.primaryStore,F,B)}if(b.relationship.from){let F=a(M=>Ga({attribute:b.relationship.from,value:M},t,r,n,s,B),"searchEntry");b.elements?(i[o[0]]=B,U=mte(U,b,I.primaryStore,B,F)):U=U.flatMap(F)}return U}else if(o.length===1)o=o[0];else throw new Zr.ClientError("Unable to query by attribute "+JSON.stringify(o))}let _,l,d,E;c instanceof Date&&(c=c.getTime());let f;switch(Zg[u]||u){case"lt":_=!0,l=c;break;case"le":_=!0,l=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,l=c.slice(0),l[l.length-1]=ds.MAXIMUM_KEY;break;case"starts_with":_=c.toString(),l=c+"\uFFFF";break;case"between":_=c[0],_ instanceof Date&&(_=_.getTime()),l=c[1],l instanceof Date&&(l=l.getTime()),d=!0;break;case"equals":case void 0:_=c,l=c,d=!0;break;case"ne":if(c===null){_=c,E=!0;break}case"sort":case"contains":case"ends_with":_=!0,f=!0;break;default:throw new Zr.ClientError(`Unknown query comparator "${u}"`)}let h,p=o===n.primaryKey||o==null;if(typeof _=="string"&&_.length>Tn.MAX_SEARCH_KEY_LENGTH&&(_=_.slice(0,Tn.MAX_SEARCH_KEY_LENGTH)+Tn.OVERFLOW_MARKER,E=!1,h=Tl(e,n,null,i,p)),typeof l=="string"&&l.length>Tn.MAX_SEARCH_KEY_LENGTH&&(l=l.slice(0,Tn.MAX_SEARCH_KEY_LENGTH)+Tn.OVERFLOW_MARKER,d=!0,h=h??Tl(e,n,null,i,p)),r){let A=_;_=l,l=A,A=!E,E=!d,d=A}let S=p?n.primaryStore:n.indices[o];if(!S||S.isIndexing||f||c===null&&!S.indexNulls){if(s===!1&&!S)throw new Zr.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&f)throw new Zr.ClientError(`Can not use ${u||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(S?.isIndexing)throw new Zr.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&!S.indexNulls)throw new Zr.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(h=h??Tl(e,n,null,i,p),!h)throw new Zr.ClientError(`Unknown search operator ${e.comparator}`)}let T={start:_,end:l,inclusiveEnd:d,exclusiveStart:E,values:!0,versions:p,transaction:t,reverse:r};if(p){let A=S.getRange(T).map(h?function({key:b,value:I}){return this.isSync?I&&h(I)?b:Ci.SKIP:new Promise((B,U)=>setImmediate(()=>{try{B(I&&h(I)?b:Ci.SKIP)}catch(F){U(F)}}))}:b=>b.value==null?Ci.SKIP:b);return A.hasEntries=!0,A}else return S?S.getRange(T).map(h?function({key:A,value:b}){let I;return typeof A=="string"&&A.length>Tn.MAX_SEARCH_KEY_LENGTH?I=n.primaryStore.get(b):I={[o]:A},this.isSync?h(I)?b:Ci.SKIP:new Promise((B,U)=>setImmediate(()=>{try{B(h(I)?b:Ci.SKIP)}catch(F){U(F)}}))}:({value:A})=>A):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:A,value:b}){return this.isSync?b&&h(b)?A:Ci.SKIP:new Promise((I,B)=>setImmediate(()=>{try{I(b&&h(b)?A:Ci.SKIP)}catch(U){B(U)}}))})}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 hte(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;s.hasMappings=!0;let o;return{next(){if(!i){let u=t.relationship.to,_=a((l,d)=>{let E=l;Array.isArray(l)&&(E=qn(l),o=!0);let f=s.get(E);f?f.push(d):s.set(E,f=[d]),l!==E&&(f.key=l)},"add_entry");for(let l of e){let d=l.value??r.get(l.key??l),E=d?.[u];if(E!=null&&!s.filters?.some(f=>!f(d)))if(n)for(let f=0;f<E.length;f++)_(E[f],l);else _(E,l)}return i=(o?s:s.keys())[Symbol.iterator](),this.next()}let c=i.next();return c.done?c:{value:o?c.value[1].key||c.value[0]:c.value}},return(){if(i?.return)return i.return()}}}})}function mte(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let u;if(o)for(;u=o.next(),!u.done;){let _=qn(u.value);if(!c.has(_))return c.add(_),u}if(!i){let _=new Map;n.fromRecord=l=>l[t.relationship.from]?.filter?.(d=>_.has(qn(d)));for(let l of e){if(n.filters){let d=r.get(l);if(n.filters.some(E=>!E(d)))continue}_.set(qn(l),l)}return i=_.values()[Symbol.iterator](),this.next()}do{let _=i.next();return _.done?_:(o=s(_.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function Tl(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,u=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let l=c[0],d=Fs(t.attributes,l),E=d.definition?.tableClass||d.elements.definition?.tableClass,f=n?.[l],h=Tl({attribute:c.length>2?c.slice(1):c[1],value:u,comparator:o},E,r,f?.[l]?.joined,c[1]===E.primaryKey,i);if(!h)return;if(f){f.filters||(f.filters=[]),f.filters.push(h);return}let p=t.propertyResolvers?.[l],S,T=a((A,b)=>{let I,B;if(p){if(p.from&&h.idFilter){if(!S)if(h.idFilter.idSet?.size===1){for(let F of h.idFilter.idSet)e={attribute:p.from,value:F};S=_(p.from,h.idFilter,!0,!0)}else S=_(p.from,h.idFilter,!1,!0);let U=S(A);return S.idFilter&&(T.idFilter=S.idFilter),U}B=p(A,r,b),I=B?.value}else I=A[l];return I?Array.isArray(I)?I.some(h):h(I,B):!1},"recordFilter");return T}}switch(u instanceof Date&&(u=u.getTime()),Zg[o]||o){case Tn.SEARCH_TYPES.EQUALS:case void 0:return _(c,l=>l===u,!0);case"contains":return _(c,l=>l?.toString().includes(u));case"ends_with":return _(c,l=>l?.toString().endsWith(u));case"starts_with":return _(c,l=>typeof l=="string"&&l.startsWith(u),!0);case"prefix":return Array.isArray(u)?u[u.length-1]==null&&(u=u.slice(0,-1)):u=[u],_(c,l=>{if(!Array.isArray(l))return!1;for(let d=0,E=u.length;d<E;d++)if(l[d]!==u[d])return!1;return!0},!0);case"between":return u[0]instanceof Date&&(u[0]=u[0].getTime()),u[1]instanceof Date&&(u[1]=u[1].getTime()),_(c,l=>(0,ds.compareKeys)(l,u[0])>=0&&(0,ds.compareKeys)(l,u[1])<=0,!0);case"gt":return _(c,l=>(0,ds.compareKeys)(l,u)>0);case"ge":return _(c,l=>(0,ds.compareKeys)(l,u)>=0);case"lt":return _(c,l=>(0,ds.compareKeys)(l,u)<0);case"le":return _(c,l=>(0,ds.compareKeys)(l,u)<=0);case"ne":return _(c,l=>(0,ds.compareKeys)(l,u)!==0);case"sort":return()=>!0;default:throw new Zr.ClientError(`Unknown query comparator "${o}"`)}function _(l,d,E,f){let h;E=E&&!s&&t?.indices[l]&&i>3,E&&(e.estimated_count==null&&nE(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(E=!1));let p=0,S=3;function T(A){let b=A[l],I;if(typeof b!="object"||!b||f?I=d(b):Array.isArray(b)?I=b.some(d):b instanceof Date&&(I=d(b.getTime())),E&&(S++,!I&&!T.idFilter&&++p/S*(i-S)>h)){let B=Ga(e,r.transaction.getReadTxn(),!1,t).map(qn),U=new Set(B);T.idFilter=F=>U.has(qn(F)),T.idFilter.idSet=U}return I}return a(T,"recordFilter"),s&&(T.idFilter=d),T}a(_,"attributeComparator")}function nE(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/qs(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=Zg[n]||n,n===Tn.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=nE(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),u=e.indices[i.relationship.from];r.estimated_count=c+(u?c*qs(e.indices[i.relationship.from])/(qs(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=qs(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=fte*qs(e.primaryStore)+1:n==="between"?r.estimated_count=dte*qs(e.primaryStore)+1:n==="sort"?r.estimated_count=qs(e.primaryStore)+1:r.estimated_count=_te*qs(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function sE(e){if(e)if(Di=e,xa.lastIndex=0,pte.test(e))try{let t=pl(new Ha,"");if(Dr!==Di.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 '${Di}'`,t}else{let t=new URLSearchParams(e);return t.conditions=t,t}}function pl(e,t){let r=xa,n,s,i,o,c,u=decodeURIComponent,_;for(;n=r.exec(Di);){Dr=r.lastIndex;let[,l,d]=n;if(o){if(l)throw new SyntaxError(`expected operator, but encountered '${l}'`);o=!1,c=!1}else c=!0;let E;switch(d){case"=":if(s){if(l.length<=2)i=l;else throw new SyntaxError(`invalid FIQL operator ${l}`);u=Jg}else{if(u=decodeURIComponent,i="equals",!l)throw new SyntaxError("attribute must be specified before equality comparator");s=Sl(l)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=Ete[d],u=Xg[i]?Jg:decodeURIComponent,!l)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=Sl(l);break;case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${d[0]?"'"+d[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${d?"'"+d+"'":"end of string"}`)}else{if(!e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");let h={comparator:i,attribute:s,value:u(l)};i==="eq"&&I0(h,l),rE(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(Sl(l)),s=void 0;break;case"(":xa.lastIndex=Dr;let f=pl(l?[]:new Ha,")");switch(l){case"":rE(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=w0(f);break;default:throw new SyntaxError(`unknown query function call ${l}`)}Di[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(!l)throw new SyntaxError("property sets must have a defined parent property name");xa.lastIndex=Dr,E=pl([],"}"),E.name=l,e.push(E),Di[Dr]===","?r.lastIndex=++Dr:o=!0;break;case"[":xa.lastIndex=Dr,l?(E=pl(new Ha,"]"),E.name=l):E=pl(e.conditions?new Ha:[],"]"),e.conditions?(rE(e,_),e.conditions.push(E),s=null):e.push(E),Di[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:u(l)};i==="eq"&&I0(h,l),rE(e,_),e.conditions.push(h)}else if(l)throw new SyntaxError("no attribute or comparison specified")}else(l||e.length>0&&c)&&e.push(Sl(l));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${d[0]}'`):new SyntaxError(`unexpected token '${d[0]}'`);default:throw new SyntaxError(`unexpected operator '${d}'`)}if(t!==")"&&(r=s?Ste:xa,r.lastIndex=Dr),Dr===Di.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function rE(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 Sl(e){return e.indexOf(".")>-1?e.split(".").map(Sl):decodeURIComponent(e)}function Jg(e){if(e==="null")return null;if(e.indexOf("/")>-1){let t=e.split("/"),r=new qa(t.length);for(let n=0,s=t.length;n<s;n++)r[n]=Jg(t[n]);return r}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 Zr.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function I0(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new Zr.ClientError("wildcard can only be used at the end of a string")}function w0(e){let t=C0(e[0]);return e.length>1&&(t.next=w0(e.slice(1))),t}function C0(e){if(Array.isArray(e)){let t=C0(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 qn(e){return Array.isArray(e)?e.join("\0"):e}function qs(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function Tte(e,t,r){return t*r/qs(e)}var Zr,Tn,ds,Ci,_te,dte,fte,Ete,Xg,Zg,pte,xa,Ste,Dr,Di,Ha,iE=Re(()=>{Zr=H(se()),Tn=H(ft()),ds=require("ordered-binary"),Ci=require("lmdb");cn();_te=.3,dte=.1,fte=.05,Ete={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},Xg={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(jg,"executeConditions");a(Ga,"searchByIndex");a(Fs,"findAttribute");a(hte,"joinTo");a(mte,"joinFrom");Zg={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(Tl,"filterByType");a(nE,"estimateCondition");pte=/[()[\]|!<>.]|(=\w*=)/,xa=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,Ste=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(sE,"parseQuery");a(pl,"parseBlock");a(rE,"assignOperator");a(Sl,"decodeProperty");a(Jg,"typedDecoding");a(I0,"wildcardDecoding");a(w0,"toSortObject");a(C0,"toSortEntry");Ha=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(qn,"flattenKey");a(qs,"estimatedEntryCount");a(Tte,"intersectionEstimate")});function U0(e){let t={openapi:gte,info:{title:"HarperDB HTTP REST interface",version:(0,P0.version)()},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:u}=n.Resource;if(c=c??"id",!c)continue;let _={},l=[];if(o)for(let{type:b,name:I,elements:B,relationship:U,definition:F}of o){if(U)b==="array"?_[I]={type:"array",items:{$ref:Li+B.type}}:_[I]={$ref:Li+b};else{let M=F??B?.definition;if(M){if(!t.components.schemas[M.type]){let Q={};M.properties.forEach(z=>{Q[z.name]=new nR(eR[z.type],z.type)}),t.components.schemas[M.type]=new M0(Q)}b==="array"?_[I]={type:"array",items:{$ref:Li+M.type}}:_[I]={$ref:Li+M.type}}else b==="array"?B.type==="Any"||B.type=="ID"?_[I]={type:"array",items:{format:B.type}}:_[I]={type:"array",items:new nR(eR[B.type],B.type)}:b==="Any"||b=="ID"?_[I]={format:b}:_[I]=new nR(eR[b],b)}l.push(new sR(I,"query",_[I]))}let d=Object.keys(_),E=new sR(c,"path",{format:"ID"});E.required=!0,E.description="primary key of record";let f=new sR("property","path",{enum:d});f.required=!0,t.components.schemas[i]=new M0(_);let h=u.post!==Resource.prototype.post||u.update,p=typeof u.put=="function",S=typeof u.get=="function",T=typeof u.delete=="function",A="/"+s+"/";h&&(t.paths[A]={},t.paths[A].post=new Rte(i,r,"create a new record auto-assigning a primary key")),S&&(t.paths[A]||(t.paths[A]={}),t.paths[A].get=new tR(l,r,{200:new rR({$ref:Li+i})},"search for records by the specified property name and value pairs")),T&&(t.paths[A]||(t.paths[A]={}),t.paths[A].delete=new L0(l,r,"delete all the records that match the provided query",{204:new D0})),A="/"+s+"/{"+c+"}",S&&(t.paths[A]={},t.paths[A].get=new tR([E],r,{200:new rR({$ref:Li+i})},"retrieve a record by its primary key")),p&&(t.paths[A]||(t.paths[A]={}),t.paths[A].put=new Ate([E],r,i,"create or update the record with the URL path that maps to the record's primary key")),T&&(t.paths[A]||(t.paths[A]={}),t.paths[A].delete=new L0([E],r,"delete a record with the given primary key",{204:new D0})),S&&f.schema.enum.length>0&&(A="/"+s+"/{"+c+"}.{property}",t.paths[A]={},t.paths[A].get=new tR([E,f],r,{200:new rR({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function Rte(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Li+e}}}},this.security=t,this.responses={200:{description:iR,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function tR(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function rR(e){this.description=iR,this.content={"application/json":{schema:e}}}function D0(){this.description="successfully processed request, no content returned to client"}function Ate(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Li+r}}}},this.responses={200:{description:iR}}}function L0(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function M0(e){this.type="object",this.properties=e}function nR(e,t){this.type=e,this.format=t}function sR(e,t,r){this.name=e,this.in=t,this.schema=r}var P0,gte,eR,Li,iR,v0=Re(()=>{P0=H(ef()),gte="3.0.3",eR={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Li="#/components/schemas/",iR="successful operation";a(U0,"generateJsonApi");a(Rte,"Post");a(tR,"Get");a(rR,"Response200");a(D0,"Response204");a(Ate,"Put");a(L0,"Delete");a(M0,"ResourceSchema");a(nR,"Type");a(sR,"Parameter")});var aE={};Fe(aE,{start:()=>yte});async function bte(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream"?"CONNECT":e.method;e.search&&sE(e);let s=new Ni;try{e.responseHeaders=s;let i=e.url.slice(1),o,c;if(i!==B0){let f=oE.getMatch(i);if(!f)return t(e);e.handlerPath=f.path,o={url:f.relativeURL,async:!0},c=f.Resource}if(c.isCaching){let f=r["cache-control"];if(f){f=f.toLowerCase();let h=f.match(/max-age=(\d+)/)?.[1];h&&(e.expiresAt=h*1e3+Date.now()),f.includes("only-if-cached")&&(e.onlyIfCached=!0),f.includes("no-cache")&&(e.noCache=!0),f.includes("no-store")&&(e.noCacheStore=!0),f.includes("stale-if-error")&&(e.staleIfError=!0),f.includes("must-revalidate")&&(e.mustRevalidate=!0)}}let u=await rt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=yo(r["content-type"],!0)(e.body,e.headers)}catch(f){throw new Fa.ClientError(f,400)}if(e.authorize=!0,i===B0&&n==="GET"){if(e?.user?.role?.permission?.super_user)return U0(oE);throw new Fa.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 Fa.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Fa.ServerError(`Method ${n} is not recognized`,501)}}),_=200,l;if(u==null)_=n==="GET"||n==="HEAD"?404:204,oR.lastModified&&e.lastModified&&s.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(l=e.lastModified){Ote[0]=l;let f=String.fromCharCode(34,(zt[0]&63)+62,(zt[0]>>6)+(zt[1]<<2&63)+62,(zt[1]>>4)+(zt[2]<<4&63)+62,(zt[2]>>2)+62,(zt[3]&63)+62,(zt[3]>>6)+(zt[4]<<2&63)+62,(zt[4]>>4)+(zt[5]<<4&63)+62,(zt[5]>>2)+62,(zt[6]&63)+62,(zt[6]>>6)+(zt[7]<<2&63)+62,34),h=r["if-none-match"];h&&f==h?(u?.onDone&&u.onDone(),_=304,u=void 0):s.setIfNone("ETag",f),oR.lastModified&&s.setIfNone("Last-Modified",new Date(l).toUTCString())}e.createdResource&&(_=201),e.newLocation&&s.setIfNone("Location",e.newLocation);let d={status:_,headers:s,body:void 0},E=u?.wasLoadedFromSource?.();return E!==void 0&&(d.wasCacheMiss=E,!E&&l&&s.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||l))/1e3))),u!==void 0&&(d.body=tE(u,e,d),n==="HEAD"&&(d.body=void 0)),d}catch(i){i.statusCode?i.statusCode===500?No.warn(i):No.info(i):No.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=tE(i.contentType?i:i.toString(),e,o),o}}function yte(e){oR=e,!x0&&(x0=!0,oE=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return bte(t,r)},e),e.server.ws(async(t,r,n)=>{gl++;let s=new In;H0||(H0=!0,mu(u=>{gl>0&&u.push({metric:"ws-connections",connections:gl,byThread:!0})}));let i;t.on("error",u=>{i=!0,No.warn(u)});let o;t.on("message",a(function(_){o||(o=yo(r.requestedContentType??r.headers.asObject["content-type"],!1));let l=o(_);s.push(l)},"message"));let c;t.on("close",()=>{gl--,Qr(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let u=r.url.slice(1),_=oE.getMatch(u);if(Qr(!!_,"connection","ws","connect"),_){r.handlerPath=_.path,nr(h=>({count:h.count,total:gl}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let l={url:_.relativeURL,async:!0},d=_.Resource;c=(await rt(r,()=>d.connect(l,s,r)))[Symbol.asyncIterator]();let f;for(;!(f=await c.next()).done;){let h=Ro(f.value,r);t.send(h),nr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(u){t.close(Nte[u.statusCode]||1011,u.toString()),t.close("login failed")}t.close()},e))}var No,Fa,zt,Ote,oR,B0,x0,oE,H0,gl,Nte,G0=Re(()=>{Da();Ds();No=H($()),Fa=H(se());iE();Cc();so();el();v0();zt=new Uint8Array(8),Ote=new Float64Array(zt.buffer,0,1),oR={},B0="openapi";a(bte,"http");gl=0;a(yte,"start");Nte={401:3e3,403:3003}});var aR=g((cpe,F0)=>{var{recordAction:cE,recordActionBinary:q0}=(Ds(),ie(pu)),Ite=require("fastify-plugin"),wte=200;F0.exports=Ite(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(),u=s.request.routeOptions,_,l,d;u.config?.isOperation?(_=n.body?.operation,l="operation"):(_=u.url,l="fastify-route",d=u.method),cE(o,"duration",_,d,l),q0(s.raw.statusCode<400,"success",_,d,l),q0(1,"response_"+s.raw.statusCode,_,d,l);let E=wte;i?.pipe?(i.on("data",S=>{E+=S.length}),i.on("end",()=>{cE(performance.now()-c,"transfer",_,d,l),cE(E,"bytes-sent",_,d,l)})):(E+=i?.length||0,cE(E,"bytes-sent",_,d,l));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 fR=g((_pe,Y0)=>{var dE=require("clone"),fE=je(),Cte=J(),lE=P(),upe=$(),cR=require("fs"),lR=require("joi"),{string:_E}=lR.types(),{hdb_errors:Dte,handleHDBError:uE}=se(),{HDB_ERROR_MSGS:lpe,HTTP_STATUS_CODES:uR}=Dte,{common_validators:ka}=jn(),k0=" is required",Lte=["insert","update","upsert"],_R={database:{presence:!1,format:ka.schema_format,length:ka.schema_length},schema:{presence:!1,format:ka.schema_format,length:ka.schema_length},table:{presence:!0,format:ka.schema_format,length:ka.schema_length},action:{inclusion:{within:Lte,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},Mte={schema:_E.required(),table:_E.required(),action:_E.valid("insert","update","upsert")},{AWS_ACCESS_KEY:Pte,AWS_SECRET:Ute,AWS_BUCKET:vte,AWS_FILE_KEY:Bte,REGION:xte}=lE.S3_BUCKET_AUTH_KEYS,Hte={s3:{presence:!0},[`s3.${Pte}`]:{presence:!0,type:"String"},[`s3.${Ute}`]:{presence:!0,type:"String"},[`s3.${vte}`]:{presence:!0,type:"String"},[`s3.${Bte}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${xte}`]:{presence:!0,type:"String"}},V0=dE(_R);V0.data.presence={message:k0};var $0=dE(_R);$0.file_path.presence={message:k0};var Gte=Object.assign(dE(_R),Hte),dR=dE(Mte);dR.csv_url=_E.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();dR.passthrough_headers=lR.object();function qte(e){let t=fE.validateObject(e,V0);return EE(e,t)}a(qte,"dataObject");function Fte(e){let t=fE.validateBySchema(e,lR.object(dR));return EE(e,t)}a(Fte,"urlObject");function kte(e){let t=fE.validateObject(e,$0);return EE(e,t)}a(kte,"fileObject");function Vte(e){let t=fE.validateObject(e,Gte);return EE(e,t)}a(Vte,"s3FileObject");function EE(e,t){if(!t){let r=Cte.checkGlobalSchemaTable(e.schema,e.table);if(r)return uE(new Error,r,uR.BAD_REQUEST);if(e.operation===lE.OPERATIONS_ENUM.CSV_FILE_LOAD)try{cR.accessSync(e.file_path,cR.constants.R_OK|cR.constants.F_OK)}catch(n){return n.code===lE.NODE_ERROR_CODES.ENOENT?uE(n,`No such file or directory ${n.path}`,uR.BAD_REQUEST):n.code===lE.NODE_ERROR_CODES.EACCES?uE(n,`Permission denied ${n.path}`,uR.BAD_REQUEST):uE(n)}}return t}a(EE,"postValidateChecks");Y0.exports={dataObject:qte,urlObject:Fte,fileObject:kte,s3FileObject:Vte}});var ER=g((fpe,K0)=>{"use strict";var Rl=$(),hE=P();async function $te(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===hE.OPERATIONS_ENUM.INSERT||t.operation===hE.OPERATIONS_ENUM.UPDATE||t.operation===hE.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===hE.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(Rl.info(i.message),i):i.http_resp_msg?(Rl.error(`Error calling operation: ${e.name}`),Rl.error(i.http_resp_msg),i):(Rl.error(`Error calling operation: ${e.name}`),Rl.error(i),i)}}a($te,"callOperationFunctionAsAwait");K0.exports={callOperationFunctionAsAwait:$te}});var Q0=g((hpe,W0)=>{"use strict";var hR=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}},mR=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};W0.exports={BulkLoadFileObject:hR,BulkLoadDataObject:mR}});var J0=g((ppe,z0)=>{"use strict";var pR=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};z0.exports=pR});var OR=g((Ope,fB)=>{"use strict";var mE=Fr(),SE=fR(),Yte=require("needle"),Fn=P(),Tpe=Ve(),Va=J(),{handleHDBError:lt,hdb_errors:iB}=se(),{HTTP_STATUS_CODES:Jt,HDB_ERROR_MSGS:Lt,CHECK_LOGS_WRAPPER:wo}=iB,$a=$(),SR=require("papaparse");Va.promisifyPapaParse();var kn=require("fs-extra"),Kte=require("path"),{chain:X0}=require("stream-chain"),j0=require("stream-json/streamers/StreamArray"),Z0=require("stream-json/utils/Batch"),eB=require("stream-chain/utils/comp"),{finished:tB}=require("stream"),Wte=ee(),oB=ER(),Qte=kg(),{BulkLoadFileObject:gR,BulkLoadDataObject:zte}=Q0(),RR=Mg(),{verifyBulkLoadAttributePerms:aB}=Qf(),gpe=J0(),Rpe=ut(),Ape=Os(),{databases:Jte}=(Ae(),ie(ke)),{coerceType:Xte}=(TE(),ie(bR)),rB="No records parsed from csv file.",Io=`${Wte.get("HDB_ROOT")}/tmp`,{schema_regex:jte}=jn(),nB=1024*1024*2,sB=5e3,Zte={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};fB.exports={csvDataLoad:ere,csvURLLoad:tre,csvFileLoad:rre,importFromS3:nre};async function ere(e,t){let r=SE.dataObject(e);if(r)throw lt(r,r.message,Jt.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=lB(e.schema,e.table),i=SR.parse(e.data,{header:!0,skipEmptyLines:!0,transform:TR.bind(null,s),dynamicTyping:!1}),o=new RR;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&aB(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,Jt.BAD_REQUEST,void 0,void 0,!0);let u=new zte(e.action,e.schema,e.table,i.data);return n=await oB.callOperationFunctionAsAwait(_B,u,null),n.message===rB?rB:dB(n.records,n.number_written)}catch(s){throw Co(s)}}a(ere,"csvDataLoad");async function tre(e){let t=SE.urlObject(e);if(t)throw lt(t,t.message,Jt.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Io}/${r}`;try{await sre(e,r)}catch(s){throw $a.error(Lt.DOWNLOAD_FILE_ERR(r)+" - "+s),lt(s,wo(Lt.DOWNLOAD_FILE_ERR(r)))}try{let s=new gR(this.job_operation_function.name,e.action,e.schema,e.table,n,Fn.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await AR(s);return await pE(n),i}catch(s){throw await pE(n),Co(s)}}a(tre,"csvURLLoad");async function rre(e){let t=SE.fileObject(e);if(t)throw lt(t,t.message,Jt.BAD_REQUEST,void 0,void 0,!0);let r=new gR(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,Fn.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await AR(r)}catch(n){throw Co(n)}}a(rre,"csvFileLoad");async function nre(e){let t=SE.s3FileObject(e);if(t)throw lt(t,t.message,Jt.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=Kte.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Io}/${s}`;let i=new gR(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await ire(s,e);let o=await AR(i);return await pE(r),o}catch(n){throw await pE(r),Co(n)}}a(nre,"importFromS3");async function sre(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await Yte("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,Fn.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}are(r,e.csv_url),await ore(t,r.raw)}a(sre,"downloadCSVFile");async function ire(e,t){try{let r=`${Io}/${e}`;await kn.mkdirp(Io),await kn.writeFile(`${Io}/${e}`,"",{flag:"a+"});let n=await kn.createWriteStream(r),s=await Qte.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(){$a.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw $a.error(Lt.S3_DOWNLOAD_ERR+" - "+r),lt(r,wo(Lt.S3_DOWNLOAD_ERR))}}a(ire,"downloadFileFromS3");async function ore(e,t){try{await kn.mkdirp(Io),await kn.writeFile(`${Io}/${e}`,t)}catch(r){throw $a.error(Lt.WRITE_TEMP_FILE_ERR),lt(r,wo(Lt.DEFAULT_BULK_LOAD_ERR))}}a(ore,"writeFileToTempFolder");async function pE(e){if(e)try{await kn.access(e),await kn.unlink(e)}catch{$a.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(pE,"deleteTempFile");function are(e,t){if(e.statusCode!==iB.HTTP_STATUS_CODES.OK)throw lt(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Jt.BAD_REQUEST);if(!Zte[e.headers["content-type"]])throw lt(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Jt.BAD_REQUEST);if(!e.raw)throw lt(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Jt.BAD_REQUEST)}a(are,"validateURLResponse");async function AR(e){try{let t;switch(e.file_type){case Fn.VALID_S3_FILE_TYPES.CSV:t=await cre(e);break;case Fn.VALID_S3_FILE_TYPES.JSON:t=await ure(e);break;default:throw lt(new Error,Lt.DEFAULT_BULK_LOAD_ERR,Jt.BAD_REQUEST,Fn.LOG_LEVELS.ERROR,Lt.INVALID_FILE_EXT_ERR(e))}return dB(t.records,t.number_written)}catch(t){throw Co(t)}}a(AR,"fileLoad");async function cB(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 mE.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&aB(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let u=lt(c);r(u)}}a(cB,"validateChunk");async function uB(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Va.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Va.isEmpty(c)&&!Va.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(u=>{Object.keys(u).forEach(_=>c.add(_))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},u=await oB.callOperationFunctionAsAwait(_B,c,null);t.records+=u.records,t.number_written+=u.number_written,s&&s.resume()}catch(c){let u=lt(c,wo(Lt.INSERT_CSV_ERR),Jt.INTERNAL_SERVER_ERROR,Fn.LOG_LEVELS.ERROR,Lt.INSERT_CSV_ERR+" - "+c);r(u)}}a(uB,"insertChunk");async function cre(e){let t={records:0,number_written:0},r=lB(e.schema,e.table);try{let n=new RR,s=kn.createReadStream(e.file_path,{highWaterMark:nB});s.setEncoding("utf8"),await SR.parsePromise(s,cB.bind(null,e,n),TR.bind(null,r));let i=n.getPermsResponse();if(i)throw lt(new Error,i,Jt.BAD_REQUEST);return s=kn.createReadStream(e.file_path,{highWaterMark:nB}),s.setEncoding("utf8"),await SR.parsePromise(s,uB.bind(null,e,t),TR.bind(null,r)),s.destroy(),t}catch(n){throw lt(n,wo(Lt.PAPA_PARSE_ERR),Jt.INTERNAL_SERVER_ERROR,Fn.LOG_LEVELS.ERROR,Lt.PAPA_PARSE_ERR+n)}}a(cre,"callPapaParse");function lB(e,t){let r=Jte[e][t].attributes,n=new Map;for(let s of r)s.type&&n.set(s.name,i=>Xte(i,s));return n}a(lB,"createTransformMap");function TR(e,t,r){let n=e.get(r);return n?n(t):Va.autoCast(t)}a(TR,"typeFunction");async function ure(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new RR,s=X0([kn.createReadStream(e.file_path,{encoding:"utf-8"}),j0.withParser(),c=>c.value,new Z0({batchSize:sB}),eB(async c=>{await cB(e,n,r,c)})]);await new Promise((c,u)=>{tB(s,_=>{_?u(_):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw lt(new Error,i,Jt.BAD_REQUEST);let o=X0([kn.createReadStream(e.file_path,{encoding:"utf-8"}),j0.withParser(),c=>c.value,new Z0({batchSize:sB}),eB(async c=>{await uB(e,t,r,c)})]);return await new Promise((c,u)=>{tB(o,_=>{_?u(_):c()}),o.resume()}),t}catch(n){throw lt(n,wo(Lt.INSERT_JSON_ERR),Jt.INTERNAL_SERVER_ERROR,Fn.LOG_LEVELS.ERROR,Lt.INSERT_JSON_ERR+n)}}a(ure,"insertJson");async function _B(e){let t={};try{e.data&&e.data.length>0&&lre(e.data[0])?t=await _re(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",$a.info(t.message))}catch(r){throw Co(r)}return t}a(_B,"callBulkFileLoad");function lre(e){let t=Object.keys(e);for(let r of t)if(!jte.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(lre,"validateColumnNames");async function _re(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=mE.insert;break;case"update":i=mE.update;break;case"upsert":i=mE.upsert;break;default:throw lt(new Error,Lt.INVALID_ACTION_PARAM_ERR(n),Jt.BAD_REQUEST,Fn.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 l=global.hdb_schema[t][r].hash_attribute,d=e.length;for(;d--;)o.skipped_hashes.indexOf(e[d][l])>=0&&e.splice(d,1)}let u=Va.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:u,new_attributes:o.new_attributes}}catch(o){throw Co(o)}}a(_re,"bulkFileLoad");function dB(e,t){return`successfully loaded ${t} of ${e} records`}a(dB,"buildResponseMsg");function Co(e){return lt(e,wo(Lt.DEFAULT_BULK_LOAD_ERR),Jt.INTERNAL_SERVER_ERROR,Fn.LOG_LEVELS.ERROR,Lt.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(Co,"buildTopLevelErrMsg")});var hB=g((ype,EB)=>{"use strict";var yR=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};EB.exports=yR});var SB=g((Ipe,pB)=>{"use strict";var dre=P(),mB=require("moment"),fre=require("uuid").v4,NR=class{static{a(this,"JobObject")}constructor(){this.id=fre(),this.type=void 0,this.start_datetime=mB().valueOf(),this.created_datetime=mB().valueOf(),this.end_datetime=void 0,this.status=dre.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};pB.exports=NR});var IR=g((Cpe,NB)=>{"use strict";var Ere=require("uuid").v4,OB=Fr(),bB=qr(),hre=ns(),mre=oa(),pre=hB(),Ze=P(),Sre=SB(),Tre=Wd(),gn=$(),gre=Ic(),Ya=J(),{promisify:Rre}=require("util"),Do=require("moment"),Are=Jf(),gE=fR(),TB=Zm(),{deleteTransactionLogsBeforeValidator:Ore}=Ig(),{handleHDBError:gB,hdb_errors:bre}=se(),{HTTP_STATUS_CODES:RB}=bre,AB=bB.searchByValue,yre=bB.searchByHash,Nre=OB.insert,Ire=Rre(Are.evaluateSQL),wre=OB.update;NB.exports={addJob:Lre,updateJob:Pre,handleGetJob:Cre,handleGetJobsByStartDate:Dre,getJobById:yB};async function Cre(e){try{let t=await yB(e.id);return Ya.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 gn.error("There was an error getting job",t),new Error(r)}}a(Cre,"handleGetJob");async function Dre(e){try{let t=await Mre(e);if(gn.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=Do(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Do(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 gn.error(r),new Error(r)}}a(Dre,"handleGetJobsByStartDate");async function Lre(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||Ya.isEmptyOrZeroLength(e.operation)){let l="job parameter is invalid";return gn.info(l),t.error=l,t}if(!Ze.JOB_TYPE_ENUM[e.operation])return gn.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case Ze.OPERATIONS_ENUM.CSV_FILE_LOAD:n=gE.fileObject(e);break;case Ze.OPERATIONS_ENUM.CSV_URL_LOAD:n=gE.urlObject(e);break;case Ze.OPERATIONS_ENUM.CSV_DATA_LOAD:n=gE.dataObject(e);break;case Ze.OPERATIONS_ENUM.IMPORT_FROM_S3:n=gE.s3FileObject(e);break;case Ze.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case Ze.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=TB(e,"date");break;case Ze.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=TB(e,"timestamp");break;case Ze.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=Ore(e);break;case Ze.OPERATIONS_ENUM.RESTART_SERVICE:if(Ze.PROCESS_DESCRIPTORS_VALIDATE[e.service]===void 0)throw gB(new Error,"Invalid service",RB.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw gB(n,n.message,RB.BAD_REQUEST,void 0,void 0,!0);let s=new Sre;s.type=e.operation===Ze.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?Ze.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user?.username;let i=new hre(Ze.SYSTEM_SCHEMA_NAME,Ze.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await AB(i))}catch(l){let d=`There was an error inserting a new job: ${l}`;return gn.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Ere();try{o=await AB(i)}catch(l){let d=`There was an error inserting a new job: ${l}`;return gn.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return gn.error("Error creating a job, could not find a unique job id."),t}s.request=e;let u=new gre(Ze.SYSTEM_SCHEMA_NAME,Ze.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),_;try{_=await Nre(u)}catch(l){return gn.error(`There was an error inserting a job for job type: ${e.operation} -- ${l}`),t.success=!1,t}if(_.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let l=`Created a job with type ${s.type} and id ${s.id}`;t.message=l,t.createdJob=s,t.success=!0,gn.trace(l)}return t}a(Lre,"addJob");async function Mre(e){let t=Do(e.from_date,Do.ISO_8601),r=Do(e.to_date,Do.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 pre(n,e.hdb_user);try{return await Ire(s)}catch(i){throw gn.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(Mre,"getJobsInDateRange");async function yB(e){if(Ya.isEmptyOrZeroLength(e))return Ya.errorizeMessage("Invalid job ID specified.");let t=new mre(Ze.SYSTEM_SCHEMA_NAME,Ze.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await yre(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return gn.error(n),Ya.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(yB,"getJobById");async function Pre(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(Ya.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===Ze.JOB_STATUS_ENUM.COMPLETE||e.status===Ze.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Do().valueOf());let t=new Tre(Ze.SYSTEM_SCHEMA_NAME,Ze.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await wre(t),r}a(Pre,"updateJob")});var UB=g((Lpe,PB)=>{"use strict";var IB=J(),Mt=P(),Ure=require("moment"),RE=OR(),Al=$(),wB=IR(),CB=Xf(),DB=ci(),LB=Qe(),vre=$f(),Bre=Xu(),{parentPort:xre,isMainThread:MB}=require("worker_threads"),{onMessageByType:Hre}=Qe(),wR=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function Gre(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(IB.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(IB.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Mt.JOB_TYPE_ENUM.csv_file_load:await Es(e,RE.csvFileLoad);break;case Mt.JOB_TYPE_ENUM.csv_url_load:await Es(e,RE.csvURLLoad);break;case Mt.JOB_TYPE_ENUM.csv_data_load:await Es(e,RE.csvDataLoad);break;case Mt.JOB_TYPE_ENUM.import_from_s3:await Es(e,RE.importFromS3);break;case Mt.JOB_TYPE_ENUM.empty_trash:break;case Mt.JOB_TYPE_ENUM.export_local:await Es(e,CB.export_local);break;case Mt.JOB_TYPE_ENUM.export_to_s3:await Es(e,CB.export_to_s3);break;case Mt.JOB_TYPE_ENUM.delete_files_before:case Mt.JOB_TYPE_ENUM.delete_records_before:await Es(e,DB.deleteFilesBefore);break;case Mt.JOB_TYPE_ENUM.delete_audit_logs_before:await Es(e,DB.deleteAuditLogsBefore);break;case Mt.JOB_TYPE_ENUM.delete_transaction_logs_before:await Es(e,vre.deleteTransactionLogsBefore);break;case Mt.JOB_TYPE_ENUM.restart_service:return await Es(e,Bre.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(Gre,"parseMessage");async function Es(e,t){try{e.job.status=Mt.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=Ure().valueOf(),await wB.updateJob(e.job),await qre(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):Al.error(`There was an error running ${t.name} job with id ${e.job.id}`),Al.error(n),e.job.message=n,e.job.status=Mt.JOB_STATUS_ENUM.ERROR;try{await wB.updateJob(e.job)}catch(s){throw Al.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Es,"runJob");async function qre(e){Al.trace("launching job thread:",e),MB?LB.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:Object.assign({},process.env,{[Mt.PROCESS_NAME_ENV_PROP]:`JOB-${e}`})}):xre.postMessage({type:Mt.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(qre,"launchJobThread");MB&&Hre(Mt.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{LB.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:Object.assign({},process.env,{[Mt.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`})})}catch(r){Al.error(r)}});PB.exports={parseMessage:Gre,RunnerMessage:wR}});var BB=g((Ppe,vB)=>{"use strict";var CR=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};vB.exports=CR});var ZB=g((vpe,vR)=>{"use strict";var NE=qr(),MR=Jf(),AE=OR(),ks=bu(),OE=bs(),bl=ci(),Fre=KS(),Ol=_n(),bE=tT(),Xt=Ng(),yE=$(),kre=sT(),Vre=af(),xB=xT(),$re=uf(),Yre=GT(),Kre=qT(),Wre=VT(),Qre=YT(),DR=QT(),HB=Xf(),zre=Qf(),PR=IR(),k=P(),{hdb_errors:Nl,handleHDBError:yl}=se(),{HTTP_STATUS_CODES:GB}=Nl,LR=ZT(),qB=Xu(),zB=require("util"),Ka=Fr(),Jre=ys(),Xre=Ra(),FB=UB(),kB=Du(),VB=(Uf(),ie(tl)),$B=pr(),YB=$f(),KB=Gf(),{setServerUtilities:jre}=(TE(),ie(bR)),{CONTEXT:Zre}=(cn(),ie(Kp)),{_assignPackageExport:ene}=require("../index"),{transformReq:tne}=J(),{server:rne}=(fr(),ie(Gi)),ur=yE.loggerWithTag("operation"),nne=ER(),WB=NE.searchByHash,sne=NE.searchByValue,ine=zB.promisify(NE.search),one=zB.promisify(MR.evaluateSQL),ane={[k.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[k.OPERATIONS_ENUM.CREATE_TABLE]:!0,[k.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[k.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[k.OPERATIONS_ENUM.DROP_TABLE]:!0,[k.OPERATIONS_ENUM.DROP_SCHEMA]:!0},Y=BB();async function JB(e,t){try{if(e.body.operation!=="read_log"&&(yE.log_level===k.LOG_LEVELS.INFO||yE.log_level===k.LOG_LEVELS.DEBUG||yE.log_level===k.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,...o}=e.body;ur.info(o)}}catch(n){ur.error(n)}let r=await nne.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return ane[e.body.operation]&&Jre.setSchemaDataToGlobal(n=>{n&&ur.error(n)}),r}a(JB,"processLocalTransaction");var QB=une();vR.exports={chooseOperation:XB,getOperationFunction:jB,operation:UR,processLocalTransaction:JB};jre(vR.exports);rne.operation=UR;function XB(e){let t;try{t=jB(e)}catch(s){throw ur.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=MR.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=MR.checkASTPermissions(e,i);if(o)throw ur.error(`${GB.FORBIDDEN} from operation ${e.operation}`),ur.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),yl(new Error,o,Nl.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==k.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==k.OPERATIONS_ENUM.LOGIN&&e.operation!==k.OPERATIONS_ENUM.LOGOUT){let s=n===void 0?r:n,i=e.search_operation?e.search_operation:e;i.hdb_user||(i.hdb_user=e.hdb_user);let o=zre.verifyPerms(i,s);if(o)throw ur.error(`${GB.FORBIDDEN} from operation ${e.operation}`),ur.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),yl(new Error,o,Nl.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw yl(s,"There was an error when trying to choose an operation path")}return r}a(XB,"chooseOperation");function jB(e){if(ur.trace(`getOperationFunction with operation: ${e.operation}`),QB.has(e.operation))return QB.get(e.operation);throw yl(new Error,Nl.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),Nl.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(jB,"getOperationFunction");ene("operation",UR);function UR(e,t){e.hdb_user=this[Zre]?.user,e.bypass_auth=!t;let r=XB(e);return JB({body:e},r)}a(UR,"operation");async function cne(e){ur.trace("In serverUtils.catchup");let t=e.transaction,r=t.channel.split(":"),n=r[0],s=r[1];for(let i of t.transactions)try{i.schema=n,i.table=s,i[k.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case k.OPERATIONS_ENUM.INSERT:o=await Ka.insert(i);break;case k.OPERATIONS_ENUM.UPDATE:o=await Ka.update(i);break;case k.OPERATIONS_ENUM.UPSERT:o=await Ka.upsert(i);break;case k.OPERATIONS_ENUM.DELETE:o=await bl.deleteRecord(i);break;default:ur.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){ur.info("Invalid operation in transaction"),ur.error(o)}}a(cne,"catchup");async function Vn(e){tne(e);let t,r;try{r=await PR.addJob(e),t=r.createdJob,ur.info("addJob result",r);let n=new FB.RunnerMessage(t,e);return{message:await FB.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 ur.error(s),yl(n,s)}}a(Vn,"executeJob");function une(){let e=new Map;return e.set(k.OPERATIONS_ENUM.INSERT,new Y(Ka.insert)),e.set(k.OPERATIONS_ENUM.UPDATE,new Y(Ka.update)),e.set(k.OPERATIONS_ENUM.UPSERT,new Y(Ka.upsert)),e.set(k.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new Y(NE.searchByConditions)),e.set(k.OPERATIONS_ENUM.SEARCH_BY_HASH,new Y(WB)),e.set(k.OPERATIONS_ENUM.SEARCH_BY_ID,new Y(WB)),e.set(k.OPERATIONS_ENUM.SEARCH_BY_VALUE,new Y(sne)),e.set(k.OPERATIONS_ENUM.SEARCH,new Y(ine)),e.set(k.OPERATIONS_ENUM.SQL,new Y(one)),e.set(k.OPERATIONS_ENUM.CSV_DATA_LOAD,new Y(Vn,AE.csvDataLoad)),e.set(k.OPERATIONS_ENUM.CSV_FILE_LOAD,new Y(Vn,AE.csvFileLoad)),e.set(k.OPERATIONS_ENUM.CSV_URL_LOAD,new Y(Vn,AE.csvURLLoad)),e.set(k.OPERATIONS_ENUM.IMPORT_FROM_S3,new Y(Vn,AE.importFromS3)),e.set(k.OPERATIONS_ENUM.CREATE_SCHEMA,new Y(ks.createSchema)),e.set(k.OPERATIONS_ENUM.CREATE_DATABASE,new Y(ks.createSchema)),e.set(k.OPERATIONS_ENUM.CREATE_TABLE,new Y(ks.createTable)),e.set(k.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new Y(ks.createAttribute)),e.set(k.OPERATIONS_ENUM.DROP_SCHEMA,new Y(ks.dropSchema)),e.set(k.OPERATIONS_ENUM.DROP_DATABASE,new Y(ks.dropSchema)),e.set(k.OPERATIONS_ENUM.DROP_TABLE,new Y(ks.dropTable)),e.set(k.OPERATIONS_ENUM.DROP_ATTRIBUTE,new Y(ks.dropAttribute)),e.set(k.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new Y(OE.describeSchema)),e.set(k.OPERATIONS_ENUM.DESCRIBE_DATABASE,new Y(OE.describeSchema)),e.set(k.OPERATIONS_ENUM.DESCRIBE_TABLE,new Y(OE.describeTable)),e.set(k.OPERATIONS_ENUM.DESCRIBE_ALL,new Y(OE.describeAll)),e.set(k.OPERATIONS_ENUM.DELETE,new Y(bl.deleteRecord)),e.set(k.OPERATIONS_ENUM.ADD_USER,new Y(Ol.addUser)),e.set(k.OPERATIONS_ENUM.ALTER_USER,new Y(Ol.alterUser)),e.set(k.OPERATIONS_ENUM.DROP_USER,new Y(Ol.dropUser)),e.set(k.OPERATIONS_ENUM.LIST_USERS,new Y(Ol.listUsersExternal)),e.set(k.OPERATIONS_ENUM.LIST_ROLES,new Y(bE.listRoles)),e.set(k.OPERATIONS_ENUM.ADD_ROLE,new Y(bE.addRole)),e.set(k.OPERATIONS_ENUM.ALTER_ROLE,new Y(bE.alterRole)),e.set(k.OPERATIONS_ENUM.DROP_ROLE,new Y(bE.dropRole)),e.set(k.OPERATIONS_ENUM.USER_INFO,new Y(Ol.userInfo)),e.set(k.OPERATIONS_ENUM.READ_LOG,new Y(kre)),e.set(k.OPERATIONS_ENUM.ADD_NODE,new Y(Vre)),e.set(k.OPERATIONS_ENUM.UPDATE_NODE,new Y(xB)),e.set(k.OPERATIONS_ENUM.SET_NODE_REPLICATION,new Y(xB)),e.set(k.OPERATIONS_ENUM.REMOVE_NODE,new Y($re)),e.set(k.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new Y(Yre)),e.set(k.OPERATIONS_ENUM.PURGE_STREAM,new Y(Kre)),e.set(k.OPERATIONS_ENUM.SET_CONFIGURATION,new Y($B.setConfiguration)),e.set(k.OPERATIONS_ENUM.CLUSTER_STATUS,new Y(Wre.clusterStatus)),e.set(k.OPERATIONS_ENUM.CLUSTER_NETWORK,new Y(Qre)),e.set(k.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new Y(DR.setRoutes)),e.set(k.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new Y(DR.getRoutes)),e.set(k.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new Y(DR.deleteRoutes)),e.set(k.OPERATIONS_ENUM.EXPORT_TO_S3,new Y(Vn,HB.export_to_s3)),e.set(k.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new Y(Vn,bl.deleteFilesBefore)),e.set(k.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new Y(Vn,bl.deleteFilesBefore)),e.set(k.OPERATIONS_ENUM.EXPORT_LOCAL,new Y(Vn,HB.export_local)),e.set(k.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new Y(PR.handleGetJobsByStartDate)),e.set(k.OPERATIONS_ENUM.GET_JOB,new Y(PR.handleGetJob)),e.set(k.OPERATIONS_ENUM.GET_FINGERPRINT,new Y(LR.getFingerprint)),e.set(k.OPERATIONS_ENUM.SET_LICENSE,new Y(LR.setLicense)),e.set(k.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new Y(LR.getRegistrationInfo)),e.set(k.OPERATIONS_ENUM.RESTART,new Y(qB.restart)),e.set(k.OPERATIONS_ENUM.RESTART_SERVICE,new Y(Vn,qB.restartService)),e.set(k.OPERATIONS_ENUM.CATCHUP,new Y(cne)),e.set(k.OPERATIONS_ENUM.SYSTEM_INFORMATION,new Y(Xre.systemInformation)),e.set(k.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new Y(Vn,bl.deleteAuditLogsBefore)),e.set(k.OPERATIONS_ENUM.READ_AUDIT_LOG,new Y(Fre)),e.set(k.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new Y(kB.createTokens)),e.set(k.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new Y(kB.refreshOperationToken)),e.set(k.OPERATIONS_ENUM.LOGIN,new Y(VB.login)),e.set(k.OPERATIONS_ENUM.LOGOUT,new Y(VB.logout)),e.set(k.OPERATIONS_ENUM.GET_CONFIGURATION,new Y($B.getConfiguration)),e.set(k.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new Y(Xt.customFunctionsStatus)),e.set(k.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new Y(Xt.getCustomFunctions)),e.set(k.OPERATIONS_ENUM.GET_COMPONENT_FILE,new Y(Xt.getComponentFile)),e.set(k.OPERATIONS_ENUM.GET_COMPONENTS,new Y(Xt.getComponents)),e.set(k.OPERATIONS_ENUM.SET_COMPONENT_FILE,new Y(Xt.setComponentFile)),e.set(k.OPERATIONS_ENUM.DROP_COMPONENT,new Y(Xt.dropComponent)),e.set(k.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new Y(Xt.getCustomFunction)),e.set(k.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new Y(Xt.setCustomFunction)),e.set(k.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new Y(Xt.dropCustomFunction)),e.set(k.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new Y(Xt.addComponent)),e.set(k.OPERATIONS_ENUM.ADD_COMPONENT,new Y(Xt.addComponent)),e.set(k.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new Y(Xt.dropCustomFunctionProject)),e.set(k.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new Y(Xt.packageComponent)),e.set(k.OPERATIONS_ENUM.PACKAGE_COMPONENT,new Y(Xt.packageComponent)),e.set(k.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new Y(Xt.deployComponent)),e.set(k.OPERATIONS_ENUM.DEPLOY_COMPONENT,new Y(Xt.deployComponent)),e.set(k.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new Y(YB.readTransactionLog)),e.set(k.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new Y(Vn,YB.deleteTransactionLogsBefore)),e.set(k.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new Y(KB.installModules)),e.set(k.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new Y(KB.auditModules)),e.set(k.OPERATIONS_ENUM.GET_BACKUP,new Y(ks.getBackup)),e}a(une,"initializeOperationFunctionMap")});var wE=g((xpe,rx)=>{"use strict";var BR=P(),lne=J(),Il=$(),{handleHDBError:xR,hdb_errors:IE}=se(),{isMainThread:_ne}=require("worker_threads"),{Readable:dne}=require("stream"),ex=require("os"),fne=require("util"),Ene=ET(),hne=fne.promisify(Ene.authorize),tx=ZB(),{createGzip:mne,constants:pne}=require("zlib");function Sne(e){let t=`Found an uncaught exception with message: ${e.message}. ${ex.EOL}Stack: ${e.stack} ${ex.EOL}Terminating ${_ne?"HDB":"thread"}.`;console.error(t),Il.fatal(t),process.exit(1)}a(Sne,"handleServerUncaughtException");function Tne(e,t,r){if(Il[e.logLevel||"error"](e),e.statusCode)return typeof e.http_resp_msg!="object"?r.code(e.statusCode).send({error:e.http_resp_msg||e.message}):r.code(e.statusCode).send(e.http_resp_msg);let n=e.statusCode?e.statusCode:IE.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(Tne,"serverErrorHandler");function gne(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=xR(new Error,"Invalid JSON.",IE.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(lne.isEmpty(e.body.operation)){let n=xR(new Error,"Request body must include an 'operation' property.",IE.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(gne,"reqBodyValidationHandler");function Rne(e,t,r){let n;e.body.operation!==BR.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==BR.OPERATIONS_ENUM.LOGIN&&e.body.operation!==BR.OPERATIONS_ENUM.LOGOUT?hne(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{Il.warn(s),Il.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r(xR(s,i,IE.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(Rne,"authHandler");async function Ane(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=tx.chooseOperation(e.body);let s=await tx.processLocalTransaction(e,n);if(s instanceof dne&&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(mne({level:pne.Z_BEST_SPEED})))}return s}catch(s){throw Il.error(s),s}}a(Ane,"handlePostRequest");rx.exports={authHandler:Rne,handlePostRequest:Ane,handleServerUncaughtException:Sne,serverErrorHandler:Tne,reqBodyValidationHandler:gne}});var ox=g((Gpe,ix)=>{"use strict";var One=require("fastify-plugin"),{handlePostRequest:nx,authHandler:bne,reqBodyValidationHandler:yne}=wE();async function Nne(e){e.decorate("hdbCore",{preValidation:[yne,bne],request:t=>sx(nx(t,response)),requestWithoutAuthentication:(t,r)=>sx(nx(t,r,!0))})}a(Nne,"hdbCore");async function sx(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(sx,"convertAsyncIterators");ix.exports=One(Nne)});var cx=g((kpe,ax)=>{"use strict";var Fpe=require("fs"),CE=ee();CE.initSync();var{CONFIG_PARAMS:HR}=P(),Ine=1024*1024*1024;function wne(e){let t=CE.get(HR.HTTP_TIMEOUT),r=CE.get(HR.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:Ine,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:CE.get(HR.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(wne,"getServerOptions");ax.exports=wne});var _x=g(($pe,lx)=>{"use strict";var GR=ee();GR.initSync();var{CONFIG_PARAMS:ux}=P();function Cne(){let e=GR.get(ux.HTTP_CORSACCESSLIST),t=GR.get(ux.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(Cne,"getCORSOptions");lx.exports=Cne});var Ex=g((Kpe,fx)=>{"use strict";var dx=ee();dx.initSync();var Dne=P();function Lne(){return dx.get(Dne.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(Lne,"getHeaderTimeoutConfig");fx.exports=Lne});var FR={};Fe(FR,{customFunctionsServer:()=>Une,ready:()=>Cx,start:()=>Pne});function Pne(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){Vs||(Vs=wx(t),at.http((await Vs).server));let o=await Vs,c=(0,qR.dirname)(s),u=(0,qR.dirname)(n);if(u.startsWith("/")&&(u=u.slice(1)),!hx.has(c)){hx.add(c);try{o.register(Bne(c,u))}catch(_){if(_.message==="Root plugin has already booted")Ye.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw _}}},ready:Cx}}async function Une(){try{Ye.info("In Custom Functions Fastify server"+process.cwd()),Ye.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Ye.debug(`Custom Functions server process ${process.pid} starting up.`),await vne();let e=Rx.get(Ax.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=Vs=await wx(e)}catch(r){throw Ye.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw Ye.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){Ye.error(`Custom Functions ${process.pid} Error: ${e}`),Ye.error(e),process.exit(1)}}async function vne(){try{Ye.info("Custom Functions starting configuration."),await Ox.setUsersToGlobal(),Ye.info("Custom Functions completed configuration.")}catch(e){Ye.error(e)}}function Bne(e,t){return async function(r){try{Ye.info("Custom Functions starting buildRoutes"),Ye.trace("Loading fastify routes folder "+e),(0,mx.existsSync)(e)&&r.register(gx.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:Ye.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?Ye.error(s.message):s&&Ye.error(s),o()})}catch(n){Ye.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function wx(e){Ye.info("Custom Functions starting buildServer.");let t=(0,bx.default)(e),r=(0,px.default)(t);r.server.headersTimeout=(0,Nx.default)(),r.setErrorHandler(Ix.serverErrorHandler);let n=(0,yx.default)();return n&&r.register(Sx.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,u){r.server.emit("unhandled",c.raw,u.raw)}),o()}),r.register(Tx.default),await r.register(Mne),await r.after(),zg(r),Ye.info("Custom Functions completed buildServer."),r}function Cx(){if(Vs)return Vs.then?Vs.then(e=>e.ready()):Vs.ready()}var qR,mx,px,Sx,Tx,gx,Rx,Ax,Ye,Mne,Ox,bx,yx,Nx,Ix,Vs,hx,Dx=Re(()=>{qR=require("path"),mx=require("fs"),px=H(require("fastify")),Sx=H(require("@fastify/cors")),Tx=H(aR()),gx=H(require("@fastify/autoload")),Rx=H(ee()),Ax=H(P()),Ye=H($()),Mne=H(ox()),Ox=H(_n()),bx=H(cx()),yx=H(_x()),Nx=H(Ex()),Ix=H(wE());Da();fr();hx=new Set;a(Pne,"start");a(Une,"customFunctionsServer");a(vne,"setUp");a(Bne,"buildRouteFolder");a(wx,"buildServer");a(Cx,"ready")});var kR={};Fe(kR,{start:()=>xne});function xne(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,vx.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){Mx||(Mx=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=Lx.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,Px.default)(s,(0,Ux.realpathSync)(o))}}return i(s)},{runFirst:!0})),Lx.set(r,n)}}}var Px,Ux,vx,Lx,Mx,Bx=Re(()=>{Px=H(require("send")),Ux=require("fs"),vx=H(require("serve-static")),Lx=new Map;a(xne,"start")});function qne(){let e=(0,qx.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),$R=setInterval(()=>{ME.notify(e)},Gne).unref())}function Fne(e,t=1,r){if(VR++,(0,$s.startWorker)("server/threads/threadServer.js",{name:Xa.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function u(_){_.type===Xa.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",u),o(n))}a(u,"onMessage"),n.on("message",u),n.on("error",c)});Hne.push(s),await s,Wa.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=LE.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Wa.indexOf(n);o>-1&&Wa.splice(o,1)}if(a(i,"removeWorker"),Qa){let o=Qa;Qa=[];for(let c of o)Fx[c.localPort](null,c)}}}),r){let n=setInterval(()=>{YR?YR=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,$s.shutdownWorkers)(),VR=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function kx(e=0,t){if(typeof e=="string")try{(0,PE.existsSync)(e)&&(0,PE.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=kne:r=Vne(t):r=KR;let n=(0,za.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=Fx[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),YR=!0,r(o,(c,u)=>{if(!c){if(xx){let l=o._socket||new za.Socket({handle:o,writable:!0,readable:!0});xx.deliverSocket(l,e,u),l.resume()}else VR>0?(Qa.length===0&&setTimeout(()=>{Qa.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,Qa.push(o)):(console.log("start up a dynamic thread to handle request"),Fne(0));nr(!1,"socket-routed");return}c.requests++;let _=o.fd;if(_>=0)c.postMessage({port:e,fd:_,data:u});else{let l=o._socket||new za.Socket({handle:o,writable:!0,readable:!0});Wne(l,c,e)}nr(!0,"socket-routed")})};let s=du();ME.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 KR(e,t){let r,n=0;for(let s of Wa){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=DE)return DE=i,t(r);n=i}DE=0,t(r)}function kne(e,t){let r={};e.getpeername(r);let n=r.address,s=Ja.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);KR(e,o=>{Ja.set(n,{worker:o,lastUsed:i}),t(o)})}function Vne(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new za.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let u=o.toString("latin1").match(t)?.[1],_=Ja.get(u),l=Date.now();if(_&&_.worker.threadId!==-1)return _.lastUsed=l,s(_.worker);KR(n,d=>{Ja.set(u,{worker:d,lastUsed:l}),s(d,o)})})}a(r,"findByHeaderAffinity")}function Yne(){DE=0;for(let e of Wa)e.expectedIdle=e.recentELU.idle+$ne,e.requests=1;Wa.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function Wne(e,t,r){let n=Kne++;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(),LE.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")),LE.delete(n)),s.event=="destroy"&&(e.destroy(),LE.delete(n))})}var $s,za,Xa,ME,PE,Gx,qx,Wa,Qa,Fx,xx,VR,Hne,$R,Gne,YR,DE,Hx,Ja,$ne,LE,Kne,Vx=Re(()=>{$s=H(Qe()),za=require("net"),Xa=H(P()),ME=H($()),PE=require("fs");Ds();Gx=require("worker_threads"),qx=H(ji()),Wa=[],Qa=[],Fx=[],VR=0,Hne=[];Gx.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,$s.onMessageFromWorkers)(e=>{e.type===Xa.ITC_EVENT_TYPES.RESTART&&$R&&(clearInterval($R),qne())}));Gne=6e5;a(qne,"licenseWarning");a(Fne,"startHTTPWorker");a(kx,"startSocketServer");DE=0;a(KR,"findMostIdleWorker");Hx=36e5,Ja=new Map;a(kne,"findByRemoteAddressAffinity");a(Vne,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of Ja)r.lastUsed+Hx<e&&Ja.delete(t)},Hx).unref();$ne=1e3;a(Yne,"updateWorkerIdleness");(0,$s.setMonitorListener)(Yne);LE=new Map,Kne=1;a(Wne,"proxySocket")});var JR={};Fe(JR,{Request:()=>WR,createReuseportFd:()=>UE});var $x,WR,QR,zR,UE,vE=Re(()=>{$x=require("os"),WR=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 zR(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 QR(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},QR=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)}},zR=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,$x.platform)()!="win32"&&(UE=require("node-unix-socket").createReuseportFd)});var Qx=g((aSe,Wx)=>{"use strict";var Qne=require("cluster"),Lo=ee();Lo.initSync();var Kx=P(),rSe=require("util"),Ys=$(),nSe=require("fs"),zne=require("fastify"),sSe=du(),Jne=require("@fastify/cors"),Xne=require("@fastify/compress"),jne=require("@fastify/static"),Zne=aR(),ese=require("path"),{PACKAGE_ROOT:tse}=P(),rse=ys(),nse=J(),sse=_n(),ise=ji(),{server:ose}=(fr(),ie(Gi)),{node_request_key:iSe}=(vE(),ie(JR)),{authHandler:ase,handlePostRequest:cse,serverErrorHandler:use,reqBodyValidationHandler:lse}=wE(),oSe=require("net"),{registerContentHandlers:_se}=(Da(),ie(N0)),dse=6e4,fse=1024*1024*1024,Ese="TRUE",{CONFIG_PARAMS:wl}=Kx,ja;Wx.exports={hdbServer:Yx,start:Yx};async function Yx(e){try{Ys.info("In Fastify server"+process.cwd()),Ys.info(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Ys.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=Qne.isMaster,await hse();let t=e.securePort>0;ja=mse(t),await ja.ready(),e||(e={}),e.isOperationsServer=!0;try{ose.http(ja.server,e),ja.server.closeIdleConnections||await ja.listen({port:0,host:"::"})}catch(r){throw ja.close(),Ys.error(r),Ys.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Ys.fatal(t),process.exit(1)}}a(Yx,"operationsServer");async function hse(){Ys.trace("Configuring HarperDB process."),rse.setSchemaDataToGlobal(),await sse.setUsersToGlobal(),await ise.getLicense()}a(hse,"setUp");function mse(e){Ys.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=pse(e),r=zne(t);r.server.headersTimeout=Tse(),r.setErrorHandler(use);let n=Sse();n&&r.register(Jne,n),r.register(function(i,o,c){i.setNotFoundHandler(function(u,_){r.server.emit("unhandled",u.raw,_.raw)}),c()}),r.register(Zne),r.register(Xne),r.register(jne,{root:ese.join(tse,"studio/build-local")}),_se(r);let s=Lo.get(Kx.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!nse.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[lse,ase],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),cse(i,o)}),r.get("/health",()=>"HarperDB is running."),Ys.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(mse,"buildServer");function pse(e){let t=Lo.get(wl.OPERATIONSAPI_NETWORK_TIMEOUT),r=Lo.get(wl.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:fse,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(pse,"getServerOptions");function Sse(){let e=Lo.get(wl.OPERATIONSAPI_NETWORK_CORS),t=Lo.get(wl.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===Ese)&&(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(Sse,"getCORSOpts");function Tse(){return Lo.get(wl.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??dse}a(Tse,"getHeaderTimeoutConfig")});var rA={};Fe(rA,{disableNATS:()=>Rse,publishToStream:()=>HE,setNATSReplicator:()=>XR,setPublishToStream:()=>Ase,setSubscription:()=>tA,start:()=>gse});function gse(){Cl.default.get(Dl.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&bse()}function Rse(e=!0){Zx=e}function Ase(e,t){HE=e,tA=t}function bse(){if(Zx||process.env._DISABLE_NATS)return;let e=Tr(),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];XR(s,r,i)}}nA((r,n)=>{XR(r.tableName,r.databaseName,r),n&&tH(r)}),!zx&&(zx=!0)}function XR(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 Yt{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){tH(i)}static subscribe(){let i=new In;return tA(t,e,i),i}static subscribeOnThisThread(i){return i<(Cl.default.get(Dl.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??Ose)}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 BE(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=eH;return i}a(n,"getNATSTransaction")}function tH(e){let t=Cl.default.get(Dl.default.CONFIG_PARAMS.CLUSTERING_NODENAME);HE(`${ZR.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,eA.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 Jx,ZR,eA,Xx,jx,Cl,Dl,xE,Zx,HE,tA,Ose,eH,zx,BE,jR,rH=Re(()=>{Ae();cn();Jx=H(ut()),ZR=H(Ve()),eA=H(Os());Cc();Xx=H(US()),jx=H(Br()),Cl=H(ee()),Dl=H(P()),xE=H($());a(gse,"start");a(Rse,"disableNATS");HE=Jx.publishToStream,tA=Xx.setSubscription;a(Ase,"setPublishToStream");Ose=2;a(bse,"assignReplicationSource");a(XR,"setNATSReplicator");a(tH,"publishSchema");BE=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=Cl.default.get(Dl.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],u,_;for(let l of i){let d=l.table,E=l.operation=="put"?"upsert":l.operation;u||(xE.trace(`Sending transaction event ${E}`),_=u={operation:E,schema:s,table:d,__origin:{user:this.user?.username,timestamp:t,node_name:r}},u.hash_values=c,E!=="delete"&&E!=="invalidate"&&(u.records=o)),u.table===d&&u.operation===E?(o.push(l.record),c.push(l.id)):_=_.next={operation:E,table:d,id:l.id,record:l.record},l.expiresAt&&(_.expiresAt=l.expiresAt)}u&&n.push(HE(`${ZR.SUBJECT_PREFIXES.TXN}.${s}.${u.table}`,(0,eA.createNatsTableStreamName)(s,u.table),void 0,u)?.catch(l=>{throw xE.error("An error has occurred trying to replicate transaction",u,l),l.statusCode=504,l}))}return Promise.all(n)}},jR=class extends BE{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,jx.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};eH=new jR});var pH=g(Mi=>{"use strict";var{isMainThread:oA,parentPort:Ml,threadId:GE}=require("worker_threads"),{Socket:yse,createServer:Nse}=require("net"),{createServer:Ise,IncomingMessage:wse}=require("http"),{createServer:Cse}=require("https"),{readFileSync:Dse,unlinkSync:nH,existsSync:Lse}=require("fs"),Pt=$(),qe=ee(),_t=P(),{server:kE}=(fr(),ie(Gi)),{WebSocketServer:Mse}=require("ws"),{createSecureContext:Pse,createServer:Use}=require("node:tls"),{getTicketKeys:cH,restartNumber:vse,getWorkerIndex:Pl}=Qe(),{Headers:uH,appendHeader:Bse}=(el(),ie(zU)),{recordAction:Ll,recordActionBinary:sH}=(Ds(),ie(pu)),{Request:lH,createReuseportFd:iH}=(vE(),ie(JR)),{checkMemoryLimit:xse}=ji(),{X509Certificate:Hse}=require("crypto"),_H=require("tls"),Gse=_H.createSecureContext,Za;_H.createSecureContext=function(e){return Za||Gse(e)};var dH=qe.get(_t.CONFIG_PARAMS.THREADS_DEBUG);if(dH){let e;if(oA)e=qe.get(_t.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=qe.get(_t.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&Pl()>=0&&(e=t+Pl())}if(e){let t=qe.get(_t.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=qe.get(_t.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&&oA)try{require("inspector").open(9229)}catch(e){vse<=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:ESe,CONFIG_PARAMS:qse}=_t;qe.initSync();var Fse=qe.get(qse.HTTP_SESSIONAFFINITY),hs={};Mi.registerServer=lA;Mi.httpServer=_A;Mi.deliverSocket=uA;Mi.startServers=fH;Mi.when_components_loaded=null;Mi.createSNICallback=dA;kE.http=_A;kE.request=Yse;kE.socket=Kse;kE.ws=Wse;var sA={},qE={},kse,Ks={},FE={},Vse=[],aA=[];function fH(){return Mi.when_components_loaded=fA().loadRootComponents(!0).then(()=>{Ml?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)uA(n,r,s);else if(t.requestId)$se(t);else if(t.type===_t.ITC_EVENT_TYPES.SHUTDOWN){Pt.trace("received shutdown request",GE);for(let i in hs){let o=hs[i],c;if(o.closeIdleConnections){let _=Object.getOwnPropertySymbols(o).find(E=>E.description.includes("connections")),l=0,d=setInterval(()=>{l++;let E=l>=100,f=o[_][E?"all":"idle"]();if(f.length===0){E&&clearInterval(d);return}l===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
|
|
30
|
+
`},compressible:!1,q:.8});kt.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()}});N0={type:"application/json",serializeStream:Mc,serialize:ml,deserialize:ate,q:.5};kt.set("*/*",N0);kt.set("",N0);a(ate,"tryJSONParse");a(Xg,"registerContentHandlers");cte=require("fastify-plugin"),ute=cte(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=eE(n.raw);s.type(c),s.serializer(function(u){return(o.serializeStream||o.serialize)(u,{headers:{set:(_,l)=>{s.header(_,l)}}})})}),r()},{name:"content-type-negotiation"});a(eE,"findBestSerializer");g0=Wg.default.get(Qg.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(tE,"serialize");a(Ro,"serializeMessage");a(lte,"streamToBuffer");a(yo,"getDeserializer");a(R0,"deserializerUnknownType");a(_te,"transformIterable")});function eR(e,t,r,n,s,i,o,c){let u=e[0];if(t==="or"){let d=_(u);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=_(u),E=l(e.slice(1),!0,u.estimated_count);return E.length>0?o(d,E):d}function _(d){return d.conditions?eR(d.conditions,d.operator,r,n,s,i,o,c):Ga(d,n,d.descending||s.reverse===!0,r,s.allowFullScan,c)}a(_,"executeCondition");function l(d,E,f){return d.map((h,p)=>{if(h.conditions){let A=h.operator==="or",y=l(h.conditions,!A,f);return A?(I,B)=>y.some(U=>U(I,B)):(I,B)=>y.every(U=>U(I,B))}let S=(h.attribute||h[0])===r.primaryKey,T=gl(h,r,i,c,S,f);return E&&p<d.length-1&&f&&(f=gte(r.primaryStore,h.estimated_count,f)),T}).filter(Boolean)}a(l,"mapConditionsToFilters")}function Ga(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,u=e.comparator;if(Array.isArray(o)){let A=o[0],y=Fs(n.attributes,A);if(y.relationship){if(o.length<2)throw new Zr.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let I=y.definition?.tableClass||y.elements?.definition?.tableClass,B=new Map,U=Ga({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:u},t,r,I,s,B);if(y.relationship.to){i[o[0]]=B;let F=!!Fs(I.attributes,y.relationship.to)?.elements;U=mte(U,y,I.primaryStore,F,B)}if(y.relationship.from){let F=a(M=>Ga({attribute:y.relationship.from,value:M},t,r,n,s,B),"searchEntry");y.elements?(i[o[0]]=B,U=pte(U,y,I.primaryStore,B,F)):U=U.flatMap(F)}return U}else if(o.length===1)o=o[0];else throw new Zr.ClientError("Unable to query by attribute "+JSON.stringify(o))}let _,l,d,E;c instanceof Date&&(c=c.getTime());let f;switch(tR[u]||u){case"lt":_=!0,l=c;break;case"le":_=!0,l=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,l=c.slice(0),l[l.length-1]=ds.MAXIMUM_KEY;break;case"starts_with":_=c.toString(),l=c+"\uFFFF";break;case"between":_=c[0],_ instanceof Date&&(_=_.getTime()),l=c[1],l instanceof Date&&(l=l.getTime()),d=!0;break;case"equals":case void 0:_=c,l=c,d=!0;break;case"ne":if(c===null){_=c,E=!0;break}case"sort":case"contains":case"ends_with":_=!0,f=!0;break;default:throw new Zr.ClientError(`Unknown query comparator "${u}"`)}let h,p=o===n.primaryKey||o==null;if(typeof _=="string"&&_.length>Tn.MAX_SEARCH_KEY_LENGTH&&(_=_.slice(0,Tn.MAX_SEARCH_KEY_LENGTH)+Tn.OVERFLOW_MARKER,E=!1,h=gl(e,n,null,i,p)),typeof l=="string"&&l.length>Tn.MAX_SEARCH_KEY_LENGTH&&(l=l.slice(0,Tn.MAX_SEARCH_KEY_LENGTH)+Tn.OVERFLOW_MARKER,d=!0,h=h??gl(e,n,null,i,p)),r){let A=_;_=l,l=A,A=!E,E=!d,d=A}let S=p?n.primaryStore:n.indices[o];if(!S||S.isIndexing||f||c===null&&!S.indexNulls){if(s===!1&&!S)throw new Zr.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&f)throw new Zr.ClientError(`Can not use ${u||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(S?.isIndexing)throw new Zr.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&!S.indexNulls)throw new Zr.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(h=h??gl(e,n,null,i,p),!h)throw new Zr.ClientError(`Unknown search operator ${e.comparator}`)}let T={start:_,end:l,inclusiveEnd:d,exclusiveStart:E,values:!0,versions:p,transaction:t,reverse:r};if(p){let A=S.getRange(T).map(h?function({key:y,value:I}){return this.isSync?I&&h(I)?y:Ci.SKIP:new Promise((B,U)=>setImmediate(()=>{try{B(I&&h(I)?y:Ci.SKIP)}catch(F){U(F)}}))}:y=>y.value==null?Ci.SKIP:y);return A.hasEntries=!0,A}else return S?S.getRange(T).map(h?function({key:A,value:y}){let I;return typeof A=="string"&&A.length>Tn.MAX_SEARCH_KEY_LENGTH?I=n.primaryStore.get(y):I={[o]:A},this.isSync?h(I)?y:Ci.SKIP:new Promise((B,U)=>setImmediate(()=>{try{B(h(I)?y:Ci.SKIP)}catch(F){U(F)}}))}:({value:A})=>A):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:A,value:y}){return this.isSync?y&&h(y)?A:Ci.SKIP:new Promise((I,B)=>setImmediate(()=>{try{I(y&&h(y)?A:Ci.SKIP)}catch(U){B(U)}}))})}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 mte(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;s.hasMappings=!0;let o;return{next(){if(!i){let u=t.relationship.to,_=a((l,d)=>{let E=l;Array.isArray(l)&&(E=qn(l),o=!0);let f=s.get(E);f?f.push(d):s.set(E,f=[d]),l!==E&&(f.key=l)},"add_entry");for(let l of e){let d=l.value??r.get(l.key??l),E=d?.[u];if(E!=null&&!s.filters?.some(f=>!f(d)))if(n)for(let f=0;f<E.length;f++)_(E[f],l);else _(E,l)}return i=(o?s:s.keys())[Symbol.iterator](),this.next()}let c=i.next();return c.done?c:{value:o?c.value[1].key||c.value[0]:c.value}},return(){if(i?.return)return i.return()}}}})}function pte(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let u;if(o)for(;u=o.next(),!u.done;){let _=qn(u.value);if(!c.has(_))return c.add(_),u}if(!i){let _=new Map;n.fromRecord=l=>l[t.relationship.from]?.filter?.(d=>_.has(qn(d)));for(let l of e){if(n.filters){let d=r.get(l);if(n.filters.some(E=>!E(d)))continue}_.set(qn(l),l)}return i=_.values()[Symbol.iterator](),this.next()}do{let _=i.next();return _.done?_:(o=s(_.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function gl(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,u=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let l=c[0],d=Fs(t.attributes,l),E=d.definition?.tableClass||d.elements.definition?.tableClass,f=n?.[l],h=gl({attribute:c.length>2?c.slice(1):c[1],value:u,comparator:o},E,r,f?.[l]?.joined,c[1]===E.primaryKey,i);if(!h)return;if(f){f.filters||(f.filters=[]),f.filters.push(h);return}let p=t.propertyResolvers?.[l],S,T=a((A,y)=>{let I,B;if(p){if(p.from&&h.idFilter){if(!S)if(h.idFilter.idSet?.size===1){for(let F of h.idFilter.idSet)e={attribute:p.from,value:F};S=_(p.from,h.idFilter,!0,!0)}else S=_(p.from,h.idFilter,!1,!0);let U=S(A);return S.idFilter&&(T.idFilter=S.idFilter),U}B=p(A,r,y),I=B?.value}else I=A[l];return I?Array.isArray(I)?I.some(h):h(I,B):!1},"recordFilter");return T}}switch(u instanceof Date&&(u=u.getTime()),tR[o]||o){case Tn.SEARCH_TYPES.EQUALS:case void 0:return _(c,l=>l===u,!0);case"contains":return _(c,l=>l?.toString().includes(u));case"ends_with":return _(c,l=>l?.toString().endsWith(u));case"starts_with":return _(c,l=>typeof l=="string"&&l.startsWith(u),!0);case"prefix":return Array.isArray(u)?u[u.length-1]==null&&(u=u.slice(0,-1)):u=[u],_(c,l=>{if(!Array.isArray(l))return!1;for(let d=0,E=u.length;d<E;d++)if(l[d]!==u[d])return!1;return!0},!0);case"between":return u[0]instanceof Date&&(u[0]=u[0].getTime()),u[1]instanceof Date&&(u[1]=u[1].getTime()),_(c,l=>(0,ds.compareKeys)(l,u[0])>=0&&(0,ds.compareKeys)(l,u[1])<=0,!0);case"gt":return _(c,l=>(0,ds.compareKeys)(l,u)>0);case"ge":return _(c,l=>(0,ds.compareKeys)(l,u)>=0);case"lt":return _(c,l=>(0,ds.compareKeys)(l,u)<0);case"le":return _(c,l=>(0,ds.compareKeys)(l,u)<=0);case"ne":return _(c,l=>(0,ds.compareKeys)(l,u)!==0);case"sort":return()=>!0;default:throw new Zr.ClientError(`Unknown query comparator "${o}"`)}function _(l,d,E,f){let h;E=E&&!s&&t?.indices[l]&&i>3,E&&(e.estimated_count==null&&nE(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(E=!1));let p=0,S=3;function T(A){let y=A[l],I;if(typeof y!="object"||!y||f?I=d(y):Array.isArray(y)?I=y.some(d):y instanceof Date&&(I=d(y.getTime())),E&&(S++,!I&&!T.idFilter&&++p/S*(i-S)>h)){let B=Ga(e,r.transaction.getReadTxn(),!1,t).map(qn),U=new Set(B);T.idFilter=F=>U.has(qn(F)),T.idFilter.idSet=U}return I}return a(T,"recordFilter"),s&&(T.idFilter=d),T}a(_,"attributeComparator")}function nE(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/qs(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=tR[n]||n,n===Tn.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=nE(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),u=e.indices[i.relationship.from];r.estimated_count=c+(u?c*qs(e.indices[i.relationship.from])/(qs(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=qs(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=Ete*qs(e.primaryStore)+1:n==="between"?r.estimated_count=fte*qs(e.primaryStore)+1:n==="sort"?r.estimated_count=qs(e.primaryStore)+1:r.estimated_count=dte*qs(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function sE(e){if(e)if(Di=e,xa.lastIndex=0,Ste.test(e))try{let t=Sl(new Ha,"");if(Dr!==Di.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 '${Di}'`,t}else{let t=new URLSearchParams(e);return t.conditions=t,t}}function Sl(e,t){let r=xa,n,s,i,o,c,u=decodeURIComponent,_;for(;n=r.exec(Di);){Dr=r.lastIndex;let[,l,d]=n;if(o){if(l)throw new SyntaxError(`expected operator, but encountered '${l}'`);o=!1,c=!1}else c=!0;let E;switch(d){case"=":if(s){if(l.length<=2)i=l;else throw new SyntaxError(`invalid FIQL operator ${l}`);u=jg}else{if(u=decodeURIComponent,i="equals",!l)throw new SyntaxError("attribute must be specified before equality comparator");s=Tl(l)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=hte[d],u=Zg[i]?jg:decodeURIComponent,!l)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=Tl(l);break;case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${d[0]?"'"+d[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${d?"'"+d+"'":"end of string"}`)}else{if(!e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");let h={comparator:i,attribute:s,value:u(l)};i==="eq"&&w0(h,l),rE(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(Tl(l)),s=void 0;break;case"(":xa.lastIndex=Dr;let f=Sl(l?[]:new Ha,")");switch(l){case"":rE(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=C0(f);break;default:throw new SyntaxError(`unknown query function call ${l}`)}Di[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(!l)throw new SyntaxError("property sets must have a defined parent property name");xa.lastIndex=Dr,E=Sl([],"}"),E.name=l,e.push(E),Di[Dr]===","?r.lastIndex=++Dr:o=!0;break;case"[":xa.lastIndex=Dr,l?(E=Sl(new Ha,"]"),E.name=l):E=Sl(e.conditions?new Ha:[],"]"),e.conditions?(rE(e,_),e.conditions.push(E),s=null):e.push(E),Di[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:u(l)};i==="eq"&&w0(h,l),rE(e,_),e.conditions.push(h)}else if(l)throw new SyntaxError("no attribute or comparison specified")}else(l||e.length>0&&c)&&e.push(Tl(l));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${d[0]}'`):new SyntaxError(`unexpected token '${d[0]}'`);default:throw new SyntaxError(`unexpected operator '${d}'`)}if(t!==")"&&(r=s?Tte:xa,r.lastIndex=Dr),Dr===Di.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function rE(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 Tl(e){return e.indexOf(".")>-1?e.split(".").map(Tl):decodeURIComponent(e)}function jg(e){if(e==="null")return null;if(e.indexOf("/")>-1){let t=e.split("/"),r=new qa(t.length);for(let n=0,s=t.length;n<s;n++)r[n]=jg(t[n]);return r}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 Zr.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function w0(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new Zr.ClientError("wildcard can only be used at the end of a string")}function C0(e){let t=D0(e[0]);return e.length>1&&(t.next=C0(e.slice(1))),t}function D0(e){if(Array.isArray(e)){let t=D0(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 qn(e){return Array.isArray(e)?e.join("\0"):e}function qs(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function gte(e,t,r){return t*r/qs(e)}var Zr,Tn,ds,Ci,dte,fte,Ete,hte,Zg,tR,Ste,xa,Tte,Dr,Di,Ha,iE=Re(()=>{Zr=H(se()),Tn=H(ft()),ds=require("ordered-binary"),Ci=require("lmdb");cn();dte=.3,fte=.1,Ete=.05,hte={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},Zg={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(eR,"executeConditions");a(Ga,"searchByIndex");a(Fs,"findAttribute");a(mte,"joinTo");a(pte,"joinFrom");tR={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(gl,"filterByType");a(nE,"estimateCondition");Ste=/[()[\]|!<>.]|(=\w*=)/,xa=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,Tte=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(sE,"parseQuery");a(Sl,"parseBlock");a(rE,"assignOperator");a(Tl,"decodeProperty");a(jg,"typedDecoding");a(w0,"wildcardDecoding");a(C0,"toSortObject");a(D0,"toSortEntry");Ha=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(qn,"flattenKey");a(qs,"estimatedEntryCount");a(gte,"intersectionEstimate")});function v0(e){let t={openapi:Rte,info:{title:"HarperDB HTTP REST interface",version:(0,U0.version)()},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:u}=n.Resource;if(c=c??"id",!c)continue;let _={},l=[];if(o)for(let{type:y,name:I,elements:B,relationship:U,definition:F}of o){if(U)y==="array"?_[I]={type:"array",items:{$ref:Li+B.type}}:_[I]={$ref:Li+y};else{let M=F??B?.definition;if(M){if(!t.components.schemas[M.type]){let Q={};M.properties.forEach(z=>{Q[z.name]=new iR(rR[z.type],z.type)}),t.components.schemas[M.type]=new P0(Q)}y==="array"?_[I]={type:"array",items:{$ref:Li+M.type}}:_[I]={$ref:Li+M.type}}else y==="array"?B.type==="Any"||B.type=="ID"?_[I]={type:"array",items:{format:B.type}}:_[I]={type:"array",items:new iR(rR[B.type],B.type)}:y==="Any"||y=="ID"?_[I]={format:y}:_[I]=new iR(rR[y],y)}l.push(new oR(I,"query",_[I]))}let d=Object.keys(_),E=new oR(c,"path",{format:"ID"});E.required=!0,E.description="primary key of record";let f=new oR("property","path",{enum:d});f.required=!0,t.components.schemas[i]=new P0(_);let h=u.post!==Resource.prototype.post||u.update,p=typeof u.put=="function",S=typeof u.get=="function",T=typeof u.delete=="function",A="/"+s+"/";h&&(t.paths[A]={},t.paths[A].post=new Ate(i,r,"create a new record auto-assigning a primary key")),S&&(t.paths[A]||(t.paths[A]={}),t.paths[A].get=new nR(l,r,{200:new sR({$ref:Li+i})},"search for records by the specified property name and value pairs")),T&&(t.paths[A]||(t.paths[A]={}),t.paths[A].delete=new M0(l,r,"delete all the records that match the provided query",{204:new L0})),A="/"+s+"/{"+c+"}",S&&(t.paths[A]={},t.paths[A].get=new nR([E],r,{200:new sR({$ref:Li+i})},"retrieve a record by its primary key")),p&&(t.paths[A]||(t.paths[A]={}),t.paths[A].put=new Ote([E],r,i,"create or update the record with the URL path that maps to the record's primary key")),T&&(t.paths[A]||(t.paths[A]={}),t.paths[A].delete=new M0([E],r,"delete a record with the given primary key",{204:new L0})),S&&f.schema.enum.length>0&&(A="/"+s+"/{"+c+"}.{property}",t.paths[A]={},t.paths[A].get=new nR([E,f],r,{200:new sR({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function Ate(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Li+e}}}},this.security=t,this.responses={200:{description:aR,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function nR(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function sR(e){this.description=aR,this.content={"application/json":{schema:e}}}function L0(){this.description="successfully processed request, no content returned to client"}function Ote(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Li+r}}}},this.responses={200:{description:aR}}}function M0(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function P0(e){this.type="object",this.properties=e}function iR(e,t){this.type=e,this.format=t}function oR(e,t,r){this.name=e,this.in=t,this.schema=r}var U0,Rte,rR,Li,aR,B0=Re(()=>{U0=H(ef()),Rte="3.0.3",rR={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Li="#/components/schemas/",aR="successful operation";a(v0,"generateJsonApi");a(Ate,"Post");a(nR,"Get");a(sR,"Response200");a(L0,"Response204");a(Ote,"Put");a(M0,"Delete");a(P0,"ResourceSchema");a(iR,"Type");a(oR,"Parameter")});var aE={};Fe(aE,{start:()=>Nte});async function yte(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream"?"CONNECT":e.method;e.search&&sE(e);let s=new Ni;try{e.responseHeaders=s;let i=e.url.slice(1),o,c;if(i!==x0){let f=oE.getMatch(i);if(!f)return t(e);e.handlerPath=f.path,o={url:f.relativeURL,async:!0},c=f.Resource}if(c.isCaching){let f=r["cache-control"];if(f){f=f.toLowerCase();let h=f.match(/max-age=(\d+)/)?.[1];h&&(e.expiresAt=h*1e3+Date.now()),f.includes("only-if-cached")&&(e.onlyIfCached=!0),f.includes("no-cache")&&(e.noCache=!0),f.includes("no-store")&&(e.noCacheStore=!0),f.includes("stale-if-error")&&(e.staleIfError=!0),f.includes("must-revalidate")&&(e.mustRevalidate=!0)}}let u=await rt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=yo(r["content-type"],!0)(e.body,e.headers)}catch(f){throw new Fa.ClientError(f,400)}if(e.authorize=!0,i===x0&&n==="GET"){if(e?.user?.role?.permission?.super_user)return v0(oE);throw new Fa.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 Fa.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Fa.ServerError(`Method ${n} is not recognized`,501)}}),_=200,l;if(u==null)_=n==="GET"||n==="HEAD"?404:204,cR.lastModified&&e.lastModified&&s.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(l=e.lastModified){bte[0]=l;let f=String.fromCharCode(34,(zt[0]&63)+62,(zt[0]>>6)+(zt[1]<<2&63)+62,(zt[1]>>4)+(zt[2]<<4&63)+62,(zt[2]>>2)+62,(zt[3]&63)+62,(zt[3]>>6)+(zt[4]<<2&63)+62,(zt[4]>>4)+(zt[5]<<4&63)+62,(zt[5]>>2)+62,(zt[6]&63)+62,(zt[6]>>6)+(zt[7]<<2&63)+62,34),h=r["if-none-match"];h&&f==h?(u?.onDone&&u.onDone(),_=304,u=void 0):s.setIfNone("ETag",f),cR.lastModified&&s.setIfNone("Last-Modified",new Date(l).toUTCString())}e.createdResource&&(_=201),e.newLocation&&s.setIfNone("Location",e.newLocation);let d={status:_,headers:s,body:void 0},E=u?.wasLoadedFromSource?.();return E!==void 0&&(d.wasCacheMiss=E,!E&&l&&s.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||l))/1e3))),u!==void 0&&(d.body=tE(u,e,d),n==="HEAD"&&(d.body=void 0)),d}catch(i){i.statusCode?i.statusCode===500?No.warn(i):No.info(i):No.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=tE(i.contentType?i:i.toString(),e,o),o}}function Nte(e){cR=e,!H0&&(H0=!0,oE=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return yte(t,r)},e),e.server.ws(async(t,r,n)=>{Rl++;let s=new In;G0||(G0=!0,pu(u=>{Rl>0&&u.push({metric:"ws-connections",connections:Rl,byThread:!0})}));let i;t.on("error",u=>{i=!0,No.warn(u)});let o;t.on("message",a(function(_){o||(o=yo(r.requestedContentType??r.headers.asObject["content-type"],!1));let l=o(_);s.push(l)},"message"));let c;t.on("close",()=>{Rl--,Qr(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let u=r.url.slice(1),_=oE.getMatch(u);if(Qr(!!_,"connection","ws","connect"),_){r.handlerPath=_.path,nr(h=>({count:h.count,total:Rl}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let l={url:_.relativeURL,async:!0},d=_.Resource;c=(await rt(r,()=>d.connect(l,s,r)))[Symbol.asyncIterator]();let f;for(;!(f=await c.next()).done;){let h=Ro(f.value,r);t.send(h),nr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(u){t.close(Ite[u.statusCode]||1011,u.toString()),t.close("login failed")}t.close()},e))}var No,Fa,zt,bte,cR,x0,H0,oE,G0,Rl,Ite,q0=Re(()=>{Da();Ds();No=H($()),Fa=H(se());iE();Dc();so();tl();B0();zt=new Uint8Array(8),bte=new Float64Array(zt.buffer,0,1),cR={},x0="openapi";a(yte,"http");Rl=0;a(Nte,"start");Ite={401:3e3,403:3003}});var uR=g((lpe,k0)=>{var{recordAction:cE,recordActionBinary:F0}=(Ds(),ie(Su)),wte=require("fastify-plugin"),Cte=200;k0.exports=wte(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(),u=s.request.routeOptions,_,l,d;u.config?.isOperation?(_=n.body?.operation,l="operation"):(_=u.url,l="fastify-route",d=u.method),cE(o,"duration",_,d,l),F0(s.raw.statusCode<400,"success",_,d,l),F0(1,"response_"+s.raw.statusCode,_,d,l);let E=Cte;i?.pipe?(i.on("data",S=>{E+=S.length}),i.on("end",()=>{cE(performance.now()-c,"transfer",_,d,l),cE(E,"bytes-sent",_,d,l)})):(E+=i?.length||0,cE(E,"bytes-sent",_,d,l));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 hR=g((fpe,K0)=>{var dE=require("clone"),fE=je(),Dte=J(),lE=P(),_pe=$(),lR=require("fs"),dR=require("joi"),{string:_E}=dR.types(),{hdb_errors:Lte,handleHDBError:uE}=se(),{HDB_ERROR_MSGS:dpe,HTTP_STATUS_CODES:_R}=Lte,{common_validators:ka}=jn(),V0=" is required",Mte=["insert","update","upsert"],fR={database:{presence:!1,format:ka.schema_format,length:ka.schema_length},schema:{presence:!1,format:ka.schema_format,length:ka.schema_length},table:{presence:!0,format:ka.schema_format,length:ka.schema_length},action:{inclusion:{within:Mte,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},Pte={schema:_E.required(),table:_E.required(),action:_E.valid("insert","update","upsert")},{AWS_ACCESS_KEY:Ute,AWS_SECRET:vte,AWS_BUCKET:Bte,AWS_FILE_KEY:xte,REGION:Hte}=lE.S3_BUCKET_AUTH_KEYS,Gte={s3:{presence:!0},[`s3.${Ute}`]:{presence:!0,type:"String"},[`s3.${vte}`]:{presence:!0,type:"String"},[`s3.${Bte}`]:{presence:!0,type:"String"},[`s3.${xte}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${Hte}`]:{presence:!0,type:"String"}},$0=dE(fR);$0.data.presence={message:V0};var Y0=dE(fR);Y0.file_path.presence={message:V0};var qte=Object.assign(dE(fR),Gte),ER=dE(Pte);ER.csv_url=_E.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();ER.passthrough_headers=dR.object();function Fte(e){let t=fE.validateObject(e,$0);return EE(e,t)}a(Fte,"dataObject");function kte(e){let t=fE.validateBySchema(e,dR.object(ER));return EE(e,t)}a(kte,"urlObject");function Vte(e){let t=fE.validateObject(e,Y0);return EE(e,t)}a(Vte,"fileObject");function $te(e){let t=fE.validateObject(e,qte);return EE(e,t)}a($te,"s3FileObject");function EE(e,t){if(!t){let r=Dte.checkGlobalSchemaTable(e.schema,e.table);if(r)return uE(new Error,r,_R.BAD_REQUEST);if(e.operation===lE.OPERATIONS_ENUM.CSV_FILE_LOAD)try{lR.accessSync(e.file_path,lR.constants.R_OK|lR.constants.F_OK)}catch(n){return n.code===lE.NODE_ERROR_CODES.ENOENT?uE(n,`No such file or directory ${n.path}`,_R.BAD_REQUEST):n.code===lE.NODE_ERROR_CODES.EACCES?uE(n,`Permission denied ${n.path}`,_R.BAD_REQUEST):uE(n)}}return t}a(EE,"postValidateChecks");K0.exports={dataObject:Fte,urlObject:kte,fileObject:Vte,s3FileObject:$te}});var mR=g((hpe,W0)=>{"use strict";var Al=$(),hE=P();async function Yte(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===hE.OPERATIONS_ENUM.INSERT||t.operation===hE.OPERATIONS_ENUM.UPDATE||t.operation===hE.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===hE.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(Al.info(i.message),i):i.http_resp_msg?(Al.error(`Error calling operation: ${e.name}`),Al.error(i.http_resp_msg),i):(Al.error(`Error calling operation: ${e.name}`),Al.error(i),i)}}a(Yte,"callOperationFunctionAsAwait");W0.exports={callOperationFunctionAsAwait:Yte}});var z0=g((ppe,Q0)=>{"use strict";var pR=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}},SR=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};Q0.exports={BulkLoadFileObject:pR,BulkLoadDataObject:SR}});var X0=g((Tpe,J0)=>{"use strict";var TR=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};J0.exports=TR});var yR=g((ype,EB)=>{"use strict";var mE=Fr(),SE=hR(),Kte=require("needle"),Fn=P(),Rpe=Ve(),Va=J(),{handleHDBError:lt,hdb_errors:oB}=se(),{HTTP_STATUS_CODES:Jt,HDB_ERROR_MSGS:Lt,CHECK_LOGS_WRAPPER:wo}=oB,$a=$(),gR=require("papaparse");Va.promisifyPapaParse();var kn=require("fs-extra"),Wte=require("path"),{chain:j0}=require("stream-chain"),Z0=require("stream-json/streamers/StreamArray"),eB=require("stream-json/utils/Batch"),tB=require("stream-chain/utils/comp"),{finished:rB}=require("stream"),Qte=ee(),aB=mR(),zte=$g(),{BulkLoadFileObject:AR,BulkLoadDataObject:Jte}=z0(),OR=Ug(),{verifyBulkLoadAttributePerms:cB}=Qf(),Ape=X0(),Ope=ut(),bpe=Os(),{databases:Xte}=(Ae(),ie(ke)),{coerceType:jte}=(TE(),ie(NR)),nB="No records parsed from csv file.",Io=`${Qte.get("HDB_ROOT")}/tmp`,{schema_regex:Zte}=jn(),sB=1024*1024*2,iB=5e3,ere={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};EB.exports={csvDataLoad:tre,csvURLLoad:rre,csvFileLoad:nre,importFromS3:sre};async function tre(e,t){let r=SE.dataObject(e);if(r)throw lt(r,r.message,Jt.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=_B(e.schema,e.table),i=gR.parse(e.data,{header:!0,skipEmptyLines:!0,transform:RR.bind(null,s),dynamicTyping:!1}),o=new OR;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&cB(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,Jt.BAD_REQUEST,void 0,void 0,!0);let u=new Jte(e.action,e.schema,e.table,i.data);return n=await aB.callOperationFunctionAsAwait(dB,u,null),n.message===nB?nB:fB(n.records,n.number_written)}catch(s){throw Co(s)}}a(tre,"csvDataLoad");async function rre(e){let t=SE.urlObject(e);if(t)throw lt(t,t.message,Jt.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Io}/${r}`;try{await ire(e,r)}catch(s){throw $a.error(Lt.DOWNLOAD_FILE_ERR(r)+" - "+s),lt(s,wo(Lt.DOWNLOAD_FILE_ERR(r)))}try{let s=new AR(this.job_operation_function.name,e.action,e.schema,e.table,n,Fn.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await bR(s);return await pE(n),i}catch(s){throw await pE(n),Co(s)}}a(rre,"csvURLLoad");async function nre(e){let t=SE.fileObject(e);if(t)throw lt(t,t.message,Jt.BAD_REQUEST,void 0,void 0,!0);let r=new AR(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,Fn.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await bR(r)}catch(n){throw Co(n)}}a(nre,"csvFileLoad");async function sre(e){let t=SE.s3FileObject(e);if(t)throw lt(t,t.message,Jt.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=Wte.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Io}/${s}`;let i=new AR(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await ore(s,e);let o=await bR(i);return await pE(r),o}catch(n){throw await pE(r),Co(n)}}a(sre,"importFromS3");async function ire(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await Kte("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,Fn.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}cre(r,e.csv_url),await are(t,r.raw)}a(ire,"downloadCSVFile");async function ore(e,t){try{let r=`${Io}/${e}`;await kn.mkdirp(Io),await kn.writeFile(`${Io}/${e}`,"",{flag:"a+"});let n=await kn.createWriteStream(r),s=await zte.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(){$a.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw $a.error(Lt.S3_DOWNLOAD_ERR+" - "+r),lt(r,wo(Lt.S3_DOWNLOAD_ERR))}}a(ore,"downloadFileFromS3");async function are(e,t){try{await kn.mkdirp(Io),await kn.writeFile(`${Io}/${e}`,t)}catch(r){throw $a.error(Lt.WRITE_TEMP_FILE_ERR),lt(r,wo(Lt.DEFAULT_BULK_LOAD_ERR))}}a(are,"writeFileToTempFolder");async function pE(e){if(e)try{await kn.access(e),await kn.unlink(e)}catch{$a.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(pE,"deleteTempFile");function cre(e,t){if(e.statusCode!==oB.HTTP_STATUS_CODES.OK)throw lt(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Jt.BAD_REQUEST);if(!ere[e.headers["content-type"]])throw lt(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Jt.BAD_REQUEST);if(!e.raw)throw lt(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Jt.BAD_REQUEST)}a(cre,"validateURLResponse");async function bR(e){try{let t;switch(e.file_type){case Fn.VALID_S3_FILE_TYPES.CSV:t=await ure(e);break;case Fn.VALID_S3_FILE_TYPES.JSON:t=await lre(e);break;default:throw lt(new Error,Lt.DEFAULT_BULK_LOAD_ERR,Jt.BAD_REQUEST,Fn.LOG_LEVELS.ERROR,Lt.INVALID_FILE_EXT_ERR(e))}return fB(t.records,t.number_written)}catch(t){throw Co(t)}}a(bR,"fileLoad");async function uB(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 mE.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&cB(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let u=lt(c);r(u)}}a(uB,"validateChunk");async function lB(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Va.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Va.isEmpty(c)&&!Va.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(u=>{Object.keys(u).forEach(_=>c.add(_))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},u=await aB.callOperationFunctionAsAwait(dB,c,null);t.records+=u.records,t.number_written+=u.number_written,s&&s.resume()}catch(c){let u=lt(c,wo(Lt.INSERT_CSV_ERR),Jt.INTERNAL_SERVER_ERROR,Fn.LOG_LEVELS.ERROR,Lt.INSERT_CSV_ERR+" - "+c);r(u)}}a(lB,"insertChunk");async function ure(e){let t={records:0,number_written:0},r=_B(e.schema,e.table);try{let n=new OR,s=kn.createReadStream(e.file_path,{highWaterMark:sB});s.setEncoding("utf8"),await gR.parsePromise(s,uB.bind(null,e,n),RR.bind(null,r));let i=n.getPermsResponse();if(i)throw lt(new Error,i,Jt.BAD_REQUEST);return s=kn.createReadStream(e.file_path,{highWaterMark:sB}),s.setEncoding("utf8"),await gR.parsePromise(s,lB.bind(null,e,t),RR.bind(null,r)),s.destroy(),t}catch(n){throw lt(n,wo(Lt.PAPA_PARSE_ERR),Jt.INTERNAL_SERVER_ERROR,Fn.LOG_LEVELS.ERROR,Lt.PAPA_PARSE_ERR+n)}}a(ure,"callPapaParse");function _B(e,t){let r=Xte[e][t].attributes,n=new Map;for(let s of r)s.type&&n.set(s.name,i=>jte(i,s));return n}a(_B,"createTransformMap");function RR(e,t,r){let n=e.get(r);return n?n(t):Va.autoCast(t)}a(RR,"typeFunction");async function lre(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new OR,s=j0([kn.createReadStream(e.file_path,{encoding:"utf-8"}),Z0.withParser(),c=>c.value,new eB({batchSize:iB}),tB(async c=>{await uB(e,n,r,c)})]);await new Promise((c,u)=>{rB(s,_=>{_?u(_):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw lt(new Error,i,Jt.BAD_REQUEST);let o=j0([kn.createReadStream(e.file_path,{encoding:"utf-8"}),Z0.withParser(),c=>c.value,new eB({batchSize:iB}),tB(async c=>{await lB(e,t,r,c)})]);return await new Promise((c,u)=>{rB(o,_=>{_?u(_):c()}),o.resume()}),t}catch(n){throw lt(n,wo(Lt.INSERT_JSON_ERR),Jt.INTERNAL_SERVER_ERROR,Fn.LOG_LEVELS.ERROR,Lt.INSERT_JSON_ERR+n)}}a(lre,"insertJson");async function dB(e){let t={};try{e.data&&e.data.length>0&&_re(e.data[0])?t=await dre(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",$a.info(t.message))}catch(r){throw Co(r)}return t}a(dB,"callBulkFileLoad");function _re(e){let t=Object.keys(e);for(let r of t)if(!Zte.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(_re,"validateColumnNames");async function dre(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=mE.insert;break;case"update":i=mE.update;break;case"upsert":i=mE.upsert;break;default:throw lt(new Error,Lt.INVALID_ACTION_PARAM_ERR(n),Jt.BAD_REQUEST,Fn.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 l=global.hdb_schema[t][r].hash_attribute,d=e.length;for(;d--;)o.skipped_hashes.indexOf(e[d][l])>=0&&e.splice(d,1)}let u=Va.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:u,new_attributes:o.new_attributes}}catch(o){throw Co(o)}}a(dre,"bulkFileLoad");function fB(e,t){return`successfully loaded ${t} of ${e} records`}a(fB,"buildResponseMsg");function Co(e){return lt(e,wo(Lt.DEFAULT_BULK_LOAD_ERR),Jt.INTERNAL_SERVER_ERROR,Fn.LOG_LEVELS.ERROR,Lt.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(Co,"buildTopLevelErrMsg")});var mB=g((Ipe,hB)=>{"use strict";var IR=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};hB.exports=IR});var TB=g((Cpe,SB)=>{"use strict";var fre=P(),pB=require("moment"),Ere=require("uuid").v4,wR=class{static{a(this,"JobObject")}constructor(){this.id=Ere(),this.type=void 0,this.start_datetime=pB().valueOf(),this.created_datetime=pB().valueOf(),this.end_datetime=void 0,this.status=fre.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};SB.exports=wR});var CR=g((Lpe,IB)=>{"use strict";var hre=require("uuid").v4,bB=Fr(),yB=qr(),mre=ns(),pre=oa(),Sre=mB(),Ze=P(),Tre=TB(),gre=Wd(),gn=$(),Rre=wc(),Ya=J(),{promisify:Are}=require("util"),Do=require("moment"),Ore=Jf(),gE=hR(),gB=tp(),{deleteTransactionLogsBeforeValidator:bre}=Cg(),{handleHDBError:RB,hdb_errors:yre}=se(),{HTTP_STATUS_CODES:AB}=yre,OB=yB.searchByValue,Nre=yB.searchByHash,Ire=bB.insert,wre=Are(Ore.evaluateSQL),Cre=bB.update;IB.exports={addJob:Mre,updateJob:Ure,handleGetJob:Dre,handleGetJobsByStartDate:Lre,getJobById:NB};async function Dre(e){try{let t=await NB(e.id);return Ya.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 gn.error("There was an error getting job",t),new Error(r)}}a(Dre,"handleGetJob");async function Lre(e){try{let t=await Pre(e);if(gn.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=Do(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Do(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 gn.error(r),new Error(r)}}a(Lre,"handleGetJobsByStartDate");async function Mre(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||Ya.isEmptyOrZeroLength(e.operation)){let l="job parameter is invalid";return gn.info(l),t.error=l,t}if(!Ze.JOB_TYPE_ENUM[e.operation])return gn.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case Ze.OPERATIONS_ENUM.CSV_FILE_LOAD:n=gE.fileObject(e);break;case Ze.OPERATIONS_ENUM.CSV_URL_LOAD:n=gE.urlObject(e);break;case Ze.OPERATIONS_ENUM.CSV_DATA_LOAD:n=gE.dataObject(e);break;case Ze.OPERATIONS_ENUM.IMPORT_FROM_S3:n=gE.s3FileObject(e);break;case Ze.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case Ze.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=gB(e,"date");break;case Ze.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=gB(e,"timestamp");break;case Ze.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=bre(e);break;case Ze.OPERATIONS_ENUM.RESTART_SERVICE:if(Ze.PROCESS_DESCRIPTORS_VALIDATE[e.service]===void 0)throw RB(new Error,"Invalid service",AB.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw RB(n,n.message,AB.BAD_REQUEST,void 0,void 0,!0);let s=new Tre;s.type=e.operation===Ze.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?Ze.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user?.username;let i=new mre(Ze.SYSTEM_SCHEMA_NAME,Ze.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await OB(i))}catch(l){let d=`There was an error inserting a new job: ${l}`;return gn.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=hre();try{o=await OB(i)}catch(l){let d=`There was an error inserting a new job: ${l}`;return gn.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return gn.error("Error creating a job, could not find a unique job id."),t}s.request=e;let u=new Rre(Ze.SYSTEM_SCHEMA_NAME,Ze.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),_;try{_=await Ire(u)}catch(l){return gn.error(`There was an error inserting a job for job type: ${e.operation} -- ${l}`),t.success=!1,t}if(_.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let l=`Created a job with type ${s.type} and id ${s.id}`;t.message=l,t.createdJob=s,t.success=!0,gn.trace(l)}return t}a(Mre,"addJob");async function Pre(e){let t=Do(e.from_date,Do.ISO_8601),r=Do(e.to_date,Do.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 Sre(n,e.hdb_user);try{return await wre(s)}catch(i){throw gn.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(Pre,"getJobsInDateRange");async function NB(e){if(Ya.isEmptyOrZeroLength(e))return Ya.errorizeMessage("Invalid job ID specified.");let t=new pre(Ze.SYSTEM_SCHEMA_NAME,Ze.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await Nre(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return gn.error(n),Ya.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(NB,"getJobById");async function Ure(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(Ya.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===Ze.JOB_STATUS_ENUM.COMPLETE||e.status===Ze.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Do().valueOf());let t=new gre(Ze.SYSTEM_SCHEMA_NAME,Ze.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await Cre(t),r}a(Ure,"updateJob")});var vB=g((Ppe,UB)=>{"use strict";var wB=J(),Mt=P(),vre=require("moment"),RE=yR(),Ol=$(),CB=CR(),DB=Xf(),LB=ci(),MB=Qe(),Bre=$f(),xre=ju(),{parentPort:Hre,isMainThread:PB}=require("worker_threads"),{onMessageByType:Gre}=Qe(),DR=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function qre(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(wB.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(wB.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Mt.JOB_TYPE_ENUM.csv_file_load:await Es(e,RE.csvFileLoad);break;case Mt.JOB_TYPE_ENUM.csv_url_load:await Es(e,RE.csvURLLoad);break;case Mt.JOB_TYPE_ENUM.csv_data_load:await Es(e,RE.csvDataLoad);break;case Mt.JOB_TYPE_ENUM.import_from_s3:await Es(e,RE.importFromS3);break;case Mt.JOB_TYPE_ENUM.empty_trash:break;case Mt.JOB_TYPE_ENUM.export_local:await Es(e,DB.export_local);break;case Mt.JOB_TYPE_ENUM.export_to_s3:await Es(e,DB.export_to_s3);break;case Mt.JOB_TYPE_ENUM.delete_files_before:case Mt.JOB_TYPE_ENUM.delete_records_before:await Es(e,LB.deleteFilesBefore);break;case Mt.JOB_TYPE_ENUM.delete_audit_logs_before:await Es(e,LB.deleteAuditLogsBefore);break;case Mt.JOB_TYPE_ENUM.delete_transaction_logs_before:await Es(e,Bre.deleteTransactionLogsBefore);break;case Mt.JOB_TYPE_ENUM.restart_service:return await Es(e,xre.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(qre,"parseMessage");async function Es(e,t){try{e.job.status=Mt.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=vre().valueOf(),await CB.updateJob(e.job),await Fre(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):Ol.error(`There was an error running ${t.name} job with id ${e.job.id}`),Ol.error(n),e.job.message=n,e.job.status=Mt.JOB_STATUS_ENUM.ERROR;try{await CB.updateJob(e.job)}catch(s){throw Ol.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Es,"runJob");async function Fre(e){Ol.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}`})}):Hre.postMessage({type:Mt.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(Fre,"launchJobThread");PB&&Gre(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){Ol.error(r)}});UB.exports={parseMessage:qre,RunnerMessage:DR}});var xB=g((vpe,BB)=>{"use strict";var LR=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};BB.exports=LR});var ex=g((xpe,xR)=>{"use strict";var NE=qr(),UR=Jf(),AE=yR(),ks=yu(),OE=bs(),yl=ci(),kre=QS(),bl=_n(),bE=nT(),Xt=wg(),yE=$(),Vre=oT(),$re=af(),HB=GT(),Yre=uf(),Kre=FT(),Wre=kT(),Qre=YT(),zre=WT(),MR=JT(),GB=Xf(),Jre=Qf(),vR=CR(),k=P(),{hdb_errors:Il,handleHDBError:Nl}=se(),{HTTP_STATUS_CODES:qB}=Il,PR=tg(),FB=ju(),JB=require("util"),Ka=Fr(),Xre=ys(),jre=Ra(),kB=vB(),VB=Lu(),$B=(Uf(),ie(rl)),YB=pr(),KB=$f(),WB=Gf(),{setServerUtilities:Zre}=(TE(),ie(NR)),{CONTEXT:ene}=(cn(),ie(Qp)),{_assignPackageExport:tne}=require("../index"),{transformReq:rne}=J(),{server:nne}=(fr(),ie(Gi)),ur=yE.loggerWithTag("operation"),sne=mR(),QB=NE.searchByHash,ine=NE.searchByValue,one=JB.promisify(NE.search),ane=JB.promisify(UR.evaluateSQL),cne={[k.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[k.OPERATIONS_ENUM.CREATE_TABLE]:!0,[k.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[k.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[k.OPERATIONS_ENUM.DROP_TABLE]:!0,[k.OPERATIONS_ENUM.DROP_SCHEMA]:!0},Y=xB();async function XB(e,t){try{if(e.body.operation!=="read_log"&&(yE.log_level===k.LOG_LEVELS.INFO||yE.log_level===k.LOG_LEVELS.DEBUG||yE.log_level===k.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,...o}=e.body;ur.info(o)}}catch(n){ur.error(n)}let r=await sne.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return cne[e.body.operation]&&Xre.setSchemaDataToGlobal(n=>{n&&ur.error(n)}),r}a(XB,"processLocalTransaction");var zB=lne();xR.exports={chooseOperation:jB,getOperationFunction:ZB,operation:BR,processLocalTransaction:XB};Zre(xR.exports);nne.operation=BR;function jB(e){let t;try{t=ZB(e)}catch(s){throw ur.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=UR.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=UR.checkASTPermissions(e,i);if(o)throw ur.error(`${qB.FORBIDDEN} from operation ${e.operation}`),ur.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),Nl(new Error,o,Il.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==k.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==k.OPERATIONS_ENUM.LOGIN&&e.operation!==k.OPERATIONS_ENUM.LOGOUT){let s=n===void 0?r:n,i=e.search_operation?e.search_operation:e;i.hdb_user||(i.hdb_user=e.hdb_user);let o=Jre.verifyPerms(i,s);if(o)throw ur.error(`${qB.FORBIDDEN} from operation ${e.operation}`),ur.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),Nl(new Error,o,Il.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw Nl(s,"There was an error when trying to choose an operation path")}return r}a(jB,"chooseOperation");function ZB(e){if(ur.trace(`getOperationFunction with operation: ${e.operation}`),zB.has(e.operation))return zB.get(e.operation);throw Nl(new Error,Il.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),Il.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(ZB,"getOperationFunction");tne("operation",BR);function BR(e,t){e.hdb_user=this[ene]?.user,e.bypass_auth=!t;let r=jB(e);return XB({body:e},r)}a(BR,"operation");async function une(e){ur.trace("In serverUtils.catchup");let t=e.transaction,r=t.channel.split(":"),n=r[0],s=r[1];for(let i of t.transactions)try{i.schema=n,i.table=s,i[k.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case k.OPERATIONS_ENUM.INSERT:o=await Ka.insert(i);break;case k.OPERATIONS_ENUM.UPDATE:o=await Ka.update(i);break;case k.OPERATIONS_ENUM.UPSERT:o=await Ka.upsert(i);break;case k.OPERATIONS_ENUM.DELETE:o=await yl.deleteRecord(i);break;default:ur.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){ur.info("Invalid operation in transaction"),ur.error(o)}}a(une,"catchup");async function Vn(e){rne(e);let t,r;try{r=await vR.addJob(e),t=r.createdJob,ur.info("addJob result",r);let n=new kB.RunnerMessage(t,e);return{message:await kB.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 ur.error(s),Nl(n,s)}}a(Vn,"executeJob");function lne(){let e=new Map;return e.set(k.OPERATIONS_ENUM.INSERT,new Y(Ka.insert)),e.set(k.OPERATIONS_ENUM.UPDATE,new Y(Ka.update)),e.set(k.OPERATIONS_ENUM.UPSERT,new Y(Ka.upsert)),e.set(k.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new Y(NE.searchByConditions)),e.set(k.OPERATIONS_ENUM.SEARCH_BY_HASH,new Y(QB)),e.set(k.OPERATIONS_ENUM.SEARCH_BY_ID,new Y(QB)),e.set(k.OPERATIONS_ENUM.SEARCH_BY_VALUE,new Y(ine)),e.set(k.OPERATIONS_ENUM.SEARCH,new Y(one)),e.set(k.OPERATIONS_ENUM.SQL,new Y(ane)),e.set(k.OPERATIONS_ENUM.CSV_DATA_LOAD,new Y(Vn,AE.csvDataLoad)),e.set(k.OPERATIONS_ENUM.CSV_FILE_LOAD,new Y(Vn,AE.csvFileLoad)),e.set(k.OPERATIONS_ENUM.CSV_URL_LOAD,new Y(Vn,AE.csvURLLoad)),e.set(k.OPERATIONS_ENUM.IMPORT_FROM_S3,new Y(Vn,AE.importFromS3)),e.set(k.OPERATIONS_ENUM.CREATE_SCHEMA,new Y(ks.createSchema)),e.set(k.OPERATIONS_ENUM.CREATE_DATABASE,new Y(ks.createSchema)),e.set(k.OPERATIONS_ENUM.CREATE_TABLE,new Y(ks.createTable)),e.set(k.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new Y(ks.createAttribute)),e.set(k.OPERATIONS_ENUM.DROP_SCHEMA,new Y(ks.dropSchema)),e.set(k.OPERATIONS_ENUM.DROP_DATABASE,new Y(ks.dropSchema)),e.set(k.OPERATIONS_ENUM.DROP_TABLE,new Y(ks.dropTable)),e.set(k.OPERATIONS_ENUM.DROP_ATTRIBUTE,new Y(ks.dropAttribute)),e.set(k.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new Y(OE.describeSchema)),e.set(k.OPERATIONS_ENUM.DESCRIBE_DATABASE,new Y(OE.describeSchema)),e.set(k.OPERATIONS_ENUM.DESCRIBE_TABLE,new Y(OE.describeTable)),e.set(k.OPERATIONS_ENUM.DESCRIBE_ALL,new Y(OE.describeAll)),e.set(k.OPERATIONS_ENUM.DELETE,new Y(yl.deleteRecord)),e.set(k.OPERATIONS_ENUM.ADD_USER,new Y(bl.addUser)),e.set(k.OPERATIONS_ENUM.ALTER_USER,new Y(bl.alterUser)),e.set(k.OPERATIONS_ENUM.DROP_USER,new Y(bl.dropUser)),e.set(k.OPERATIONS_ENUM.LIST_USERS,new Y(bl.listUsersExternal)),e.set(k.OPERATIONS_ENUM.LIST_ROLES,new Y(bE.listRoles)),e.set(k.OPERATIONS_ENUM.ADD_ROLE,new Y(bE.addRole)),e.set(k.OPERATIONS_ENUM.ALTER_ROLE,new Y(bE.alterRole)),e.set(k.OPERATIONS_ENUM.DROP_ROLE,new Y(bE.dropRole)),e.set(k.OPERATIONS_ENUM.USER_INFO,new Y(bl.userInfo)),e.set(k.OPERATIONS_ENUM.READ_LOG,new Y(Vre)),e.set(k.OPERATIONS_ENUM.ADD_NODE,new Y($re)),e.set(k.OPERATIONS_ENUM.UPDATE_NODE,new Y(HB)),e.set(k.OPERATIONS_ENUM.SET_NODE_REPLICATION,new Y(HB)),e.set(k.OPERATIONS_ENUM.REMOVE_NODE,new Y(Yre)),e.set(k.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new Y(Kre)),e.set(k.OPERATIONS_ENUM.PURGE_STREAM,new Y(Wre)),e.set(k.OPERATIONS_ENUM.SET_CONFIGURATION,new Y(YB.setConfiguration)),e.set(k.OPERATIONS_ENUM.CLUSTER_STATUS,new Y(Qre.clusterStatus)),e.set(k.OPERATIONS_ENUM.CLUSTER_NETWORK,new Y(zre)),e.set(k.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new Y(MR.setRoutes)),e.set(k.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new Y(MR.getRoutes)),e.set(k.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new Y(MR.deleteRoutes)),e.set(k.OPERATIONS_ENUM.EXPORT_TO_S3,new Y(Vn,GB.export_to_s3)),e.set(k.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new Y(Vn,yl.deleteFilesBefore)),e.set(k.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new Y(Vn,yl.deleteFilesBefore)),e.set(k.OPERATIONS_ENUM.EXPORT_LOCAL,new Y(Vn,GB.export_local)),e.set(k.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new Y(vR.handleGetJobsByStartDate)),e.set(k.OPERATIONS_ENUM.GET_JOB,new Y(vR.handleGetJob)),e.set(k.OPERATIONS_ENUM.GET_FINGERPRINT,new Y(PR.getFingerprint)),e.set(k.OPERATIONS_ENUM.SET_LICENSE,new Y(PR.setLicense)),e.set(k.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new Y(PR.getRegistrationInfo)),e.set(k.OPERATIONS_ENUM.RESTART,new Y(FB.restart)),e.set(k.OPERATIONS_ENUM.RESTART_SERVICE,new Y(Vn,FB.restartService)),e.set(k.OPERATIONS_ENUM.CATCHUP,new Y(une)),e.set(k.OPERATIONS_ENUM.SYSTEM_INFORMATION,new Y(jre.systemInformation)),e.set(k.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new Y(Vn,yl.deleteAuditLogsBefore)),e.set(k.OPERATIONS_ENUM.READ_AUDIT_LOG,new Y(kre)),e.set(k.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new Y(VB.createTokens)),e.set(k.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new Y(VB.refreshOperationToken)),e.set(k.OPERATIONS_ENUM.LOGIN,new Y($B.login)),e.set(k.OPERATIONS_ENUM.LOGOUT,new Y($B.logout)),e.set(k.OPERATIONS_ENUM.GET_CONFIGURATION,new Y(YB.getConfiguration)),e.set(k.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new Y(Xt.customFunctionsStatus)),e.set(k.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new Y(Xt.getCustomFunctions)),e.set(k.OPERATIONS_ENUM.GET_COMPONENT_FILE,new Y(Xt.getComponentFile)),e.set(k.OPERATIONS_ENUM.GET_COMPONENTS,new Y(Xt.getComponents)),e.set(k.OPERATIONS_ENUM.SET_COMPONENT_FILE,new Y(Xt.setComponentFile)),e.set(k.OPERATIONS_ENUM.DROP_COMPONENT,new Y(Xt.dropComponent)),e.set(k.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new Y(Xt.getCustomFunction)),e.set(k.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new Y(Xt.setCustomFunction)),e.set(k.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new Y(Xt.dropCustomFunction)),e.set(k.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new Y(Xt.addComponent)),e.set(k.OPERATIONS_ENUM.ADD_COMPONENT,new Y(Xt.addComponent)),e.set(k.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new Y(Xt.dropCustomFunctionProject)),e.set(k.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new Y(Xt.packageComponent)),e.set(k.OPERATIONS_ENUM.PACKAGE_COMPONENT,new Y(Xt.packageComponent)),e.set(k.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new Y(Xt.deployComponent)),e.set(k.OPERATIONS_ENUM.DEPLOY_COMPONENT,new Y(Xt.deployComponent)),e.set(k.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new Y(KB.readTransactionLog)),e.set(k.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new Y(Vn,KB.deleteTransactionLogsBefore)),e.set(k.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new Y(WB.installModules)),e.set(k.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new Y(WB.auditModules)),e.set(k.OPERATIONS_ENUM.GET_BACKUP,new Y(ks.getBackup)),e}a(lne,"initializeOperationFunctionMap")});var wE=g((Gpe,nx)=>{"use strict";var HR=P(),_ne=J(),wl=$(),{handleHDBError:GR,hdb_errors:IE}=se(),{isMainThread:dne}=require("worker_threads"),{Readable:fne}=require("stream"),tx=require("os"),Ene=require("util"),hne=mT(),mne=Ene.promisify(hne.authorize),rx=ex(),{createGzip:pne,constants:Sne}=require("zlib");function Tne(e){let t=`Found an uncaught exception with message: ${e.message}. ${tx.EOL}Stack: ${e.stack} ${tx.EOL}Terminating ${dne?"HDB":"thread"}.`;console.error(t),wl.fatal(t),process.exit(1)}a(Tne,"handleServerUncaughtException");function gne(e,t,r){if(wl[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:IE.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(gne,"serverErrorHandler");function Rne(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=GR(new Error,"Invalid JSON.",IE.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(_ne.isEmpty(e.body.operation)){let n=GR(new Error,"Request body must include an 'operation' property.",IE.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Rne,"reqBodyValidationHandler");function Ane(e,t,r){let n;e.body.operation!==HR.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==HR.OPERATIONS_ENUM.LOGIN&&e.body.operation!==HR.OPERATIONS_ENUM.LOGOUT?mne(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{wl.warn(s),wl.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r(GR(s,i,IE.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(Ane,"authHandler");async function One(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=rx.chooseOperation(e.body);let s=await rx.processLocalTransaction(e,n);if(s instanceof fne&&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(pne({level:Sne.Z_BEST_SPEED})))}return s}catch(s){throw wl.error(s),s}}a(One,"handlePostRequest");nx.exports={authHandler:Ane,handlePostRequest:One,handleServerUncaughtException:Tne,serverErrorHandler:gne,reqBodyValidationHandler:Rne}});var ax=g((Fpe,ox)=>{"use strict";var bne=require("fastify-plugin"),{handlePostRequest:sx,authHandler:yne,reqBodyValidationHandler:Nne}=wE();async function Ine(e){e.decorate("hdbCore",{preValidation:[Nne,yne],request:t=>ix(sx(t,response)),requestWithoutAuthentication:(t,r)=>ix(sx(t,r,!0))})}a(Ine,"hdbCore");async function ix(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(ix,"convertAsyncIterators");ox.exports=bne(Ine)});var ux=g(($pe,cx)=>{"use strict";var Vpe=require("fs"),CE=ee();CE.initSync();var{CONFIG_PARAMS:qR}=P(),wne=1024*1024*1024;function Cne(e){let t=CE.get(qR.HTTP_TIMEOUT),r=CE.get(qR.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:wne,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:CE.get(qR.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(Cne,"getServerOptions");cx.exports=Cne});var dx=g((Kpe,_x)=>{"use strict";var FR=ee();FR.initSync();var{CONFIG_PARAMS:lx}=P();function Dne(){let e=FR.get(lx.HTTP_CORSACCESSLIST),t=FR.get(lx.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(Dne,"getCORSOptions");_x.exports=Dne});var hx=g((Qpe,Ex)=>{"use strict";var fx=ee();fx.initSync();var Lne=P();function Mne(){return fx.get(Lne.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(Mne,"getHeaderTimeoutConfig");Ex.exports=Mne});var VR={};Fe(VR,{customFunctionsServer:()=>vne,ready:()=>Dx,start:()=>Une});function Une(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){Vs||(Vs=Cx(t),at.http((await Vs).server));let o=await Vs,c=(0,kR.dirname)(s),u=(0,kR.dirname)(n);if(u.startsWith("/")&&(u=u.slice(1)),!mx.has(c)){mx.add(c);try{o.register(xne(c,u))}catch(_){if(_.message==="Root plugin has already booted")Ye.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw _}}},ready:Dx}}async function vne(){try{Ye.info("In Custom Functions Fastify server"+process.cwd()),Ye.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Ye.debug(`Custom Functions server process ${process.pid} starting up.`),await Bne();let e=Ax.get(Ox.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=Vs=await Cx(e)}catch(r){throw Ye.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw Ye.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){Ye.error(`Custom Functions ${process.pid} Error: ${e}`),Ye.error(e),process.exit(1)}}async function Bne(){try{Ye.info("Custom Functions starting configuration."),await bx.setUsersToGlobal(),Ye.info("Custom Functions completed configuration.")}catch(e){Ye.error(e)}}function xne(e,t){return async function(r){try{Ye.info("Custom Functions starting buildRoutes"),Ye.trace("Loading fastify routes folder "+e),(0,px.existsSync)(e)&&r.register(Rx.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:Ye.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?Ye.error(s.message):s&&Ye.error(s),o()})}catch(n){Ye.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function Cx(e){Ye.info("Custom Functions starting buildServer.");let t=(0,yx.default)(e),r=(0,Sx.default)(t);r.server.headersTimeout=(0,Ix.default)(),r.setErrorHandler(wx.serverErrorHandler);let n=(0,Nx.default)();return n&&r.register(Tx.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,u){r.server.emit("unhandled",c.raw,u.raw)}),o()}),r.register(gx.default),await r.register(Pne),await r.after(),Xg(r),Ye.info("Custom Functions completed buildServer."),r}function Dx(){if(Vs)return Vs.then?Vs.then(e=>e.ready()):Vs.ready()}var kR,px,Sx,Tx,gx,Rx,Ax,Ox,Ye,Pne,bx,yx,Nx,Ix,wx,Vs,mx,Lx=Re(()=>{kR=require("path"),px=require("fs"),Sx=H(require("fastify")),Tx=H(require("@fastify/cors")),gx=H(uR()),Rx=H(require("@fastify/autoload")),Ax=H(ee()),Ox=H(P()),Ye=H($()),Pne=H(ax()),bx=H(_n()),yx=H(ux()),Nx=H(dx()),Ix=H(hx()),wx=H(wE());Da();fr();mx=new Set;a(Une,"start");a(vne,"customFunctionsServer");a(Bne,"setUp");a(xne,"buildRouteFolder");a(Cx,"buildServer");a(Dx,"ready")});var $R={};Fe($R,{start:()=>Hne});function Hne(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,Bx.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){Px||(Px=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=Mx.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,Ux.default)(s,(0,vx.realpathSync)(o))}}return i(s)},{runFirst:!0})),Mx.set(r,n)}}}var Ux,vx,Bx,Mx,Px,xx=Re(()=>{Ux=H(require("send")),vx=require("fs"),Bx=H(require("serve-static")),Mx=new Map;a(Hne,"start")});function Fne(){let e=(0,Fx.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),KR=setInterval(()=>{ME.notify(e)},qne).unref())}function kne(e,t=1,r){if(YR++,(0,$s.startWorker)("server/threads/threadServer.js",{name:Xa.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function u(_){_.type===Xa.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",u),o(n))}a(u,"onMessage"),n.on("message",u),n.on("error",c)});Gne.push(s),await s,Wa.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=LE.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Wa.indexOf(n);o>-1&&Wa.splice(o,1)}if(a(i,"removeWorker"),Qa){let o=Qa;Qa=[];for(let c of o)kx[c.localPort](null,c)}}}),r){let n=setInterval(()=>{WR?WR=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,$s.shutdownWorkers)(),YR=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function Vx(e=0,t){if(typeof e=="string")try{(0,PE.existsSync)(e)&&(0,PE.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=Vne:r=$ne(t):r=QR;let n=(0,za.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=kx[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),WR=!0,r(o,(c,u)=>{if(!c){if(Hx){let l=o._socket||new za.Socket({handle:o,writable:!0,readable:!0});Hx.deliverSocket(l,e,u),l.resume()}else YR>0?(Qa.length===0&&setTimeout(()=>{Qa.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,Qa.push(o)):(console.log("start up a dynamic thread to handle request"),kne(0));nr(!1,"socket-routed");return}c.requests++;let _=o.fd;if(_>=0)c.postMessage({port:e,fd:_,data:u});else{let l=o._socket||new za.Socket({handle:o,writable:!0,readable:!0});Qne(l,c,e)}nr(!0,"socket-routed")})};let s=fu();ME.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 QR(e,t){let r,n=0;for(let s of Wa){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=DE)return DE=i,t(r);n=i}DE=0,t(r)}function Vne(e,t){let r={};e.getpeername(r);let n=r.address,s=Ja.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);QR(e,o=>{Ja.set(n,{worker:o,lastUsed:i}),t(o)})}function $ne(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new za.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let u=o.toString("latin1").match(t)?.[1],_=Ja.get(u),l=Date.now();if(_&&_.worker.threadId!==-1)return _.lastUsed=l,s(_.worker);QR(n,d=>{Ja.set(u,{worker:d,lastUsed:l}),s(d,o)})})}a(r,"findByHeaderAffinity")}function Kne(){DE=0;for(let e of Wa)e.expectedIdle=e.recentELU.idle+Yne,e.requests=1;Wa.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function Qne(e,t,r){let n=Wne++;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(),LE.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")),LE.delete(n)),s.event=="destroy"&&(e.destroy(),LE.delete(n))})}var $s,za,Xa,ME,PE,qx,Fx,Wa,Qa,kx,Hx,YR,Gne,KR,qne,WR,DE,Gx,Ja,Yne,LE,Wne,$x=Re(()=>{$s=H(Qe()),za=require("net"),Xa=H(P()),ME=H($()),PE=require("fs");Ds();qx=require("worker_threads"),Fx=H(ji()),Wa=[],Qa=[],kx=[],YR=0,Gne=[];qx.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,$s.onMessageFromWorkers)(e=>{e.type===Xa.ITC_EVENT_TYPES.RESTART&&KR&&(clearInterval(KR),Fne())}));qne=6e5;a(Fne,"licenseWarning");a(kne,"startHTTPWorker");a(Vx,"startSocketServer");DE=0;a(QR,"findMostIdleWorker");Gx=36e5,Ja=new Map;a(Vne,"findByRemoteAddressAffinity");a($ne,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of Ja)r.lastUsed+Gx<e&&Ja.delete(t)},Gx).unref();Yne=1e3;a(Kne,"updateWorkerIdleness");(0,$s.setMonitorListener)(Kne);LE=new Map,Wne=1;a(Qne,"proxySocket")});var jR={};Fe(jR,{Request:()=>zR,createReuseportFd:()=>UE});var Yx,zR,JR,XR,UE,vE=Re(()=>{Yx=require("os"),zR=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 XR(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 JR(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},JR=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)}},XR=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,Yx.platform)()!="win32"&&(UE=require("node-unix-socket").createReuseportFd)});var zx=g((uSe,Qx)=>{"use strict";var zne=require("cluster"),Lo=ee();Lo.initSync();var Wx=P(),sSe=require("util"),Ys=$(),iSe=require("fs"),Jne=require("fastify"),oSe=fu(),Xne=require("@fastify/cors"),jne=require("@fastify/compress"),Zne=require("@fastify/static"),ese=uR(),tse=require("path"),{PACKAGE_ROOT:rse}=P(),nse=ys(),sse=J(),ise=_n(),ose=ji(),{server:ase}=(fr(),ie(Gi)),{node_request_key:aSe}=(vE(),ie(jR)),{authHandler:cse,handlePostRequest:use,serverErrorHandler:lse,reqBodyValidationHandler:_se}=wE(),cSe=require("net"),{registerContentHandlers:dse}=(Da(),ie(I0)),fse=6e4,Ese=1024*1024*1024,hse="TRUE",{CONFIG_PARAMS:Cl}=Wx,ja;Qx.exports={hdbServer:Kx,start:Kx};async function Kx(e){try{Ys.info("In Fastify server"+process.cwd()),Ys.info(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Ys.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=zne.isMaster,await mse();let t=e.securePort>0;ja=pse(t),await ja.ready(),e||(e={}),e.isOperationsServer=!0;try{ase.http(ja.server,e),ja.server.closeIdleConnections||await ja.listen({port:0,host:"::"})}catch(r){throw ja.close(),Ys.error(r),Ys.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Ys.fatal(t),process.exit(1)}}a(Kx,"operationsServer");async function mse(){Ys.trace("Configuring HarperDB process."),nse.setSchemaDataToGlobal(),await ise.setUsersToGlobal(),await ose.getLicense()}a(mse,"setUp");function pse(e){Ys.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=Sse(e),r=Jne(t);r.server.headersTimeout=gse(),r.setErrorHandler(lse);let n=Tse();n&&r.register(Xne,n),r.register(function(i,o,c){i.setNotFoundHandler(function(u,_){r.server.emit("unhandled",u.raw,_.raw)}),c()}),r.register(ese),r.register(jne),r.register(Zne,{root:tse.join(rse,"studio/build-local")}),dse(r);let s=Lo.get(Wx.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!sse.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[_se,cse],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),use(i,o)}),r.get("/health",()=>"HarperDB is running."),Ys.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(pse,"buildServer");function Sse(e){let t=Lo.get(Cl.OPERATIONSAPI_NETWORK_TIMEOUT),r=Lo.get(Cl.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:Ese,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(Sse,"getServerOptions");function Tse(){let e=Lo.get(Cl.OPERATIONSAPI_NETWORK_CORS),t=Lo.get(Cl.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===hse)&&(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(Tse,"getCORSOpts");function gse(){return Lo.get(Cl.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??fse}a(gse,"getHeaderTimeoutConfig")});var sA={};Fe(sA,{disableNATS:()=>Ase,publishToStream:()=>HE,setNATSReplicator:()=>ZR,setPublishToStream:()=>Ose,setSubscription:()=>nA,start:()=>Rse});function Rse(){Dl.default.get(Ll.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&yse()}function Ase(e=!0){eH=e}function Ose(e,t){HE=e,nA=t}function yse(){if(eH||process.env._DISABLE_NATS)return;let e=Tr(),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];ZR(s,r,i)}}iA((r,n)=>{ZR(r.tableName,r.databaseName,r),n&&rH(r)}),!Jx&&(Jx=!0)}function ZR(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 Yt{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){rH(i)}static subscribe(){let i=new In;return nA(t,e,i),i}static subscribeOnThisThread(i){return i<(Dl.default.get(Ll.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??bse)}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 BE(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=tH;return i}a(n,"getNATSTransaction")}function rH(e){let t=Dl.default.get(Ll.default.CONFIG_PARAMS.CLUSTERING_NODENAME);HE(`${tA.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,rA.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 Xx,tA,rA,jx,Zx,Dl,Ll,xE,eH,HE,nA,bse,tH,Jx,BE,eA,nH=Re(()=>{Ae();cn();Xx=H(ut()),tA=H(Ve()),rA=H(Os());Dc();jx=H(BS()),Zx=H(Br()),Dl=H(ee()),Ll=H(P()),xE=H($());a(Rse,"start");a(Ase,"disableNATS");HE=Xx.publishToStream,nA=jx.setSubscription;a(Ose,"setPublishToStream");bse=2;a(yse,"assignReplicationSource");a(ZR,"setNATSReplicator");a(rH,"publishSchema");BE=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=Dl.default.get(Ll.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],u,_;for(let l of i){let d=l.table,E=l.operation=="put"?"upsert":l.operation;u||(xE.trace(`Sending transaction event ${E}`),_=u={operation:E,schema:s,table:d,__origin:{user:this.user?.username,timestamp:t,node_name:r}},u.hash_values=c,E!=="delete"&&E!=="invalidate"&&(u.records=o)),u.table===d&&u.operation===E?(o.push(l.record),c.push(l.id)):_=_.next={operation:E,table:d,id:l.id,record:l.record},l.expiresAt&&(_.expiresAt=l.expiresAt)}u&&n.push(HE(`${tA.SUBJECT_PREFIXES.TXN}.${s}.${u.table}`,(0,rA.createNatsTableStreamName)(s,u.table),void 0,u)?.catch(l=>{throw xE.error("An error has occurred trying to replicate transaction",u,l),l.statusCode=504,l}))}return Promise.all(n)}},eA=class extends BE{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,Zx.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};tH=new eA});var SH=g(Mi=>{"use strict";var{isMainThread:cA,parentPort:Pl,threadId:GE}=require("worker_threads"),{Socket:Nse,createServer:Ise}=require("net"),{createServer:wse,IncomingMessage:Cse}=require("http"),{createServer:Dse}=require("https"),{readFileSync:Lse,unlinkSync:sH,existsSync:Mse}=require("fs"),Pt=$(),qe=ee(),_t=P(),{server:kE}=(fr(),ie(Gi)),{WebSocketServer:Pse}=require("ws"),{createSecureContext:Use,createServer:vse}=require("node:tls"),{getTicketKeys:uH,restartNumber:Bse,getWorkerIndex:Ul}=Qe(),{Headers:lH,appendHeader:xse}=(tl(),ie(JU)),{recordAction:Ml,recordActionBinary:iH}=(Ds(),ie(Su)),{Request:_H,createReuseportFd:oH}=(vE(),ie(jR)),{checkMemoryLimit:Hse}=ji(),{X509Certificate:Gse}=require("crypto"),dH=require("tls"),qse=dH.createSecureContext,Za;dH.createSecureContext=function(e){return Za||qse(e)};var fH=qe.get(_t.CONFIG_PARAMS.THREADS_DEBUG);if(fH){let e;if(cA)e=qe.get(_t.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=qe.get(_t.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&Ul()>=0&&(e=t+Ul())}if(e){let t=qe.get(_t.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=qe.get(_t.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&&cA)try{require("inspector").open(9229)}catch(e){Bse<=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:mSe,CONFIG_PARAMS:Fse}=_t;qe.initSync();var kse=qe.get(Fse.HTTP_SESSIONAFFINITY),hs={};Mi.registerServer=dA;Mi.httpServer=fA;Mi.deliverSocket=_A;Mi.startServers=EH;Mi.when_components_loaded=null;Mi.createSNICallback=EA;kE.http=fA;kE.request=Kse;kE.socket=Wse;kE.ws=Qse;var oA={},qE={},Vse,Ks={},FE={},$se=[],uA=[];function EH(){return Mi.when_components_loaded=hA().loadRootComponents(!0).then(()=>{Pl?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)_A(n,r,s);else if(t.requestId)Yse(t);else if(t.type===_t.ITC_EVENT_TYPES.SHUTDOWN){Pt.trace("received shutdown request",GE);for(let i in hs){let o=hs[i],c;if(o.closeIdleConnections){let _=Object.getOwnPropertySymbols(o).find(E=>E.description.includes("connections")),l=0,d=setInterval(()=>{l++;let E=l>=100,f=o[_][E?"all":"idle"]();if(f.length===0){E&&clearInterval(d);return}l===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
|
|
31
31
|
Connection: close\r
|
|
32
32
|
\r
|
|
33
|
-
`))}},25).unref()}o.close?.(()=>{if(qe.get(_t.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&
|
|
34
|
-
`)}a(aH,"defaultNotFound");function iA(e){return e.startsWith("-----BEGIN")?e:Dse(e)}a(iA,"readPEM");function dA(e){let t=[];for(let i=0;e[i];i++)t.push(e[i]);t.length||t.push(e);let r=new Map,n,s=!1;for(let i of t){let o=iA(i.privateKey),c=iA(i.certificate),u=i.certificateAuthority&&iA(i.certificateAuthority);if(!o||!c)throw new Error("Missing private key or certificate for secure server");let _={ciphers:i.ciphers,ca:u,ticketKeys:cH()},l=Pse(_);l.options=_,_.instantiatedContext=l,l.context.setCert(c),l.context.setKey(o,void 0),_.cert=c,_.key=o,l.certStart=c.slice(0,100).toString(),n||(n=l);let d=new Hse(c),E=i.hostname??i.host??i.hostnames??i.hosts??(d.subjectAltName?d.subjectAltName.split(",").map(f=>{let h=f.indexOf(":");return f.slice(h+1)}):[d.subject.match(/CN=(.*)/)?.[1]]);Array.isArray(E)||(E=[E]);for(let f of E)f?(f[0]==="*"&&(s=!0,f=f.slice(1)),r.has(f)||r.set(f,l)):Pt.error("No hostname found for certificate at",i.certificate)}return(i,o)=>{let c=i;for(;;){let u=r.get(c);if(u)return Pt.debug("Found certificate for",i,u.certStart),o(null,u);if(s&&c){let _=c.indexOf(".",1);_<0?c="":c=c.slice(_)}else break}Pt.debug("No certificate found to match",i,"using the first certificate"),o(null,n)}}a(dA,"createSNICallback")});async function AH({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await EA.get(e,{returnNonexistent:!0});i=new pA(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await EA.get(e);o&&o.delete()}i=new $E(e,t)}return n&&(n.id=e,n.user={username:t?.username},Ul.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function hA(){return VE++,VE>65500&&(VE=1),VE}function mA(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=yi.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 rt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var TH,Pi,gH,RH,SH,EA,Ul,VE,$E,pA,OH=Re(()=>{Ae();Zu();TH=H(Br()),Pi=H($());so();gH=H(Qe()),RH=H(pH());fr();SH=100,EA=Et({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),Ul=Et({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,gH.getWorkerIndex)()===0&&(async()=>{await RH.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of Ul.search({})){let t=e.data,r=Object.assign({},e);r.user?.username&&(r.user=await at.getUser(r.user.username));try{await mA(r,t,r)}catch{(0,Pi.warn)("Failed to publish will",t)}Ul.delete(e.id)}})();a(AH,"getSession");VE=1;a(hA,"getNextMessageId");$E=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("?"),u,_;if(c>-1?(u=s.slice(c),_=s.slice(0,c)):_=s,!_)throw new Error("No topic provided");if(_.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let l=this.subscriptions.find(T=>T.topic===s),d;l?(d=i>0,l.end(),this.subscriptions.splice(this.subscriptions.indexOf(l),1)):d=i===2;let E={search:u,async:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,Pi.trace)("Resuming subscription from",s,"from",o);let f=yi.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 A=T.split("/"),b;for(let U=0;U<A.length;U++)if(A[U].indexOf("+")>-1)if(A[U]==="+")b=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&b)throw new Error("Filters can not be combined");let I=!0;A[A.length-1]==="#"&&(A.length--,I=!1),b&&(n=a(U=>{let F=U.id;if(!Array.isArray(F)||I&&F.length!==A.length)return!1;for(let M=0;M<A.length;M++)if(A[M]!=="+"&&A[M]!==F[M])return!1;return!0},"filter"));let B=A.indexOf("+");E.url="/"+(B>-1?A.slice(0,B):A).concat("").join("/")}}let h=f.path,p=f.Resource,S=await rt(E,async()=>{let T=this.createContext();T.topic=s,T.retainHandling=i;let A=await p.subscribe(E,T);if(!A)return;if(!A[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let b=(async()=>{for await(let I of A)try{let B;if(I.type&&I.type!=="put"&&I.type!=="delete"&&I.type!=="message"&&I.type!=="patch"||n&&!n(I))continue;r?(I.topic=s,B=this.needsAcknowledge(I)):(I.acknowledge?.(),B=hA());let U=I.id;if(Array.isArray(U)&&(U=wa(U)),U==null&&(U=""),await this.listener(h+"/"+U,I.value,B,t)===!1)break;this.awaitingAcks?.size>SH?await new Promise(M=>setTimeout(M,this.awaitingAcks.size-SH)):await new Promise(setImmediate)}catch(B){(0,Pi.warn)(B)}})();return A});return S.topic=s,S.qos=t.qos,this.subscriptions.push(S),S}resume(){}needsAcknowledge(t){let r=hA();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 mA(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();rt(r,async()=>{try{if(!t){let n=await Ul.get(this.sessionId);n?.doesExist()&&await mA(n,n.data,r)}}finally{await Ul.delete(this.sessionId)}}).catch(n=>{(0,Pi.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(mA,"publish");pA=class extends $E{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=hA(),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);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,Pi.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,TH.getNextMonotonicTime)()),(0,Pi.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),EA.put(this.sessionRecord)}}});var TA={};Fe(TA,{bypassAuth:()=>Qse,start:()=>zse});function Qse(){wH=!0}function zse({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new IH.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c,u=r?.mtls;return n&&(c=e.ws((_,l,d)=>{if(_.protocol==="mqtt"){o.events.emit("connection",_),Ut.debug("Received WebSocket connection for MQTT from",_._socket.remoteAddress);let{onMessage:E,onClose:f}=yH(_,h=>{_.send(h)},l,Promise.resolve(d).then(()=>l?.user),o);_.on("message",E),_.on("close",f),_.on("error",h=>{Ut.info("WebSocket error",h)})}},Object.assign({subProtocol:"mqtt"},n))),(t||s)&&(c=e.socket(async _=>{let l;if(o.events.emit("connection",_),Ut.debug(`Received ${_.getCertificate?"SSL":"TCP"} connection for MQTT from ${_.remoteAddress}`),u){if(_.authorized)try{let f=u.user;if(f!==null){(f===void 0||f==="Common Name"||f==="CN")&&(f=_.getPeerCertificate().subject.CN);try{l=await e.getUser(f,null,null),(0,ec.get)(jt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&KE.notify({username:l?.username,status:jt.AUTH_AUDIT_STATUS.SUCCESS,type:jt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:_.remoteAddress})}catch(h){throw(0,ec.get)(jt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&KE.error({username:f,status:jt.AUTH_AUDIT_STATUS.FAILURE,type:jt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:_.remoteAddress}),h}}else Ut.debug("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",_.remoteAddress)}catch(f){o.events.emit("error",f,_),Ut.error(f)}else if(u.required)return Ut.info(`Unauthorized connection attempt, no authorized client certificate provided, error: ${_.authorizationError}`),_.end()}!l&&wH&&_.remoteAddress.includes("127.0.0.1")&&(l=await(0,NH.getSuperUser)(),Ut.debug("Auto-authorizing local connection",l?.username));let{onMessage:d,onClose:E}=yH(_,f=>_.write(f),null,l,o);_.on("data",d),_.on("close",E),_.on("error",f=>{Ut.info("Socket error",f)})},{port:t,securePort:s,mtls:u})),c}function yH(e,t,r,n,s){bH||(bH=!0,mu(d=>{YE>0&&d.push({metric:"mqtt-connections",connections:YE,byThread:!0})}));let i;YE++;let o,c={protocolVersion:4},u=(0,WE.parser)({protocolVersion:5});function _(d){u.parse(d)}a(_,"onMessage");function l(){YE--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),Qr(!1,"connection","mqtt","disconnect"),Ut.debug("MQTT connection was closed",e.remoteAddress))}return a(l,"onClose"),u.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;nr(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 at.getUser(d.username,d.password.toString(),r),(0,ec.get)(jt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&KE.notify({username:n?.username,status:jt.AUTH_AUDIT_STATUS.SUCCESS,type:jt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(M){return(0,ec.get)(jt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&KE.error({username:d.username,status:jt.AUTH_AUDIT_STATUS.FAILURE,type:jt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,M),Qr(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),Qr(!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=yo(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?M(d.will.payload):void 0,delete d.will.payload}o=AH({user:n,...d}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(M){return Ut.error(M),s.events.emit("auth-failed",d,e,M),Qr(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:M.code||5,returnCode:M.code||128})}s.events.emit("connected",o,e),Qr(!0,"connection","mqtt","connect"),p({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((M,Q,z,j)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",M);let oe=M.indexOf("/",1),ue=oe>0?M.slice(0,oe):M;p({cmd:"publish",topic:M,payload:T(Q),messageId:z||Math.floor(Math.random()*1e8),qos:j.qos},ue);let le=e._socket??e;return le.writableNeedDrain?new Promise(Be=>le.once("drain",Be)):!le.closed}catch(oe){return Ut.error(oe),o?.disconnect(),s.sessions.delete(o),!1}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let A=[];for(let M of d.subscriptions){let Q;try{let z=await o.addSubscription(M,M.qos>=1);Q=z?z.qos||0:c.protocolVersion<5?128:143}catch(z){s.events.emit("error",z,e,M,o),z.statusCode?z.statusCode===500?Ut.warn(z):Ut.info(z):Ut.error(z),Q=c.protocolVersion<5?128:z.statusCode===403?135:z.statusCode===404?143:128}A.push(Q)}await o.committed,p({cmd:"suback",granted:A,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",I=e.deserialize||(e.deserialize=yo(r?.headers.get?.("content-type"))),U=(d.payload?.length||0)>0?I(d.payload):void 0,F;try{F=await o.publish(d,U)}catch(M){s.events.emit("error",M,e,d,o),Ut.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:F===!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),Qr(!0,"connection","mqtt","disconnect"),Ut.debug("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(A){s.events.emit("error",A,e,d,o),Ut.error(A),p({cmd:"disconnect"})}function p(A,b){let I=(0,WE.generate)(A,c);t(I),nr(I.length,"bytes-sent",b,S(A),"mqtt")}a(p,"sendPacket");function S(A){return A.qos>0?A.cmd+",qos="+A.qos:A.cmd}a(S,"packetMethodName");function T(A){return Ro(A,r)}a(T,"serialize")}),u.on("error",d=>{Ut.warn("MQTT parsing error, closing connection:",d.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:_,onClose:l}}var WE,NH,ec,jt,SA,IH,KE,Ut,wH,bH,YE,CH=Re(()=>{WE=require("mqtt-packet");OH();NH=H(_n());Da();Ds();fr();ec=H(ee()),jt=H(P()),SA=H($()),IH=require("events"),KE=(0,SA.loggerWithTag)("auth-event"),Ut=(0,SA.loggerWithTag)("mqtt"),wH=(0,ec.get)(jt.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(Qse,"bypassAuth");a(zse,"start");YE=0;a(yH,"onSocket")});var kf={};Fe(kf,{component_errors:()=>rc,loadComponent:()=>QE,loadComponentDirectories:()=>HH,setErrorReporter:()=>Zse});function HH(e,t){t&&(RA=t),e&&(AA=e);let r=[];if((0,et.existsSync)(gA)){let s=(0,et.readdirSync)(gA,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,st.join)(gA,o);r.push(QE(c,RA,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(QE(n,RA,n,!1,null,process.env.DEV_MODE)),Promise.all(r).then(()=>{xH=!0})}function Zse(e){vl=e}async function QE(e,t,r,n,s,i){let o=(0,et.realpathSync)(e);if(!LH.has(o)){LH.set(o,!0),s&&(AA=s);try{let c;n&&(rc=new Map);let u=(0,st.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,et.existsSync)(u)?c=n?(0,BH.getConfigObj)():(0,MH.parseDocument)((0,et.readFileSync)(u,"utf8"),{simpleKeys:!0}).toJSON():c=OA;let _=(0,st.join)(e,"node_modules","harperdb");try{Mo.isMainThread&&(n||(0,et.existsSync)(_)&&(0,et.realpathSync)(sc.PACKAGE_ROOT)!==(0,et.realpathSync)(_))&&((0,et.rmSync)(_,{recursive:!0,force:!0}),(0,et.existsSync)((0,st.join)(e,"node_modules"))||(0,et.mkdirSync)((0,st.join)(e,"node_modules")),(0,et.symlinkSync)(sc.PACKAGE_ROOT,_,"dir"))}catch(E){tc.default.error("Error symlinking harperdb module",E)}let l=[],d=n;for(let E in c){let f=c[E];if(rc.set(n?E:(0,st.basename)(e),!1),!f)continue;let h,p=f.package;try{if(p){let I=e,B;for(;!(0,et.existsSync)(B=(0,st.join)(I,"node_modules",E));)if(I=(0,st.dirname)(I),I.length<(0,vH.getHdbBasePath)().length){B=null;break}if(B)h=await QE(B,t,r,!1),d=!0;else throw new Error(`Unable to find package ${E}:${p}`)}else h=jse[E];if(!h)continue;l.push(h);let S=a(I=>(I.origin=r,Et(I)),"ensureTable"),T=f.network||(f.port||f.securePort)&&f,A=T?.securePort||T?.https&&T.port,b=!T?.https&&T?.port;if(Mo.isMainThread&&(h=await h.startOnMainThread?.({server:at,ensureTable:S,port:b,securePort:A,resources:t,...f})||h,n&&T))for(let I of[b,A])try{if(+I&&!DH.includes(I)){let B=bA.get(sc.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);B&&tc.default.warn("Session affinity is not recommended and may cause memory leaks"),(B||!UE)&&(DH.push(I),kx(I,B))}}catch(B){console.error("Error listening on socket",I,B,E)}if(t.isWorker&&(h=await h.start?.({server:at,ensureTable:S,port:b,securePort:A,resources:t,...f})||h),AA.set(h,!0),(h.handleFile||h.handleDirectory)&&f.files){if(f.files.includes(".."))throw(0,UH.handleHDBError)("Can not reference parent directories");let I=(0,st.join)(e,f.files).replace(/\\/g,"/"),B=I.indexOf("/*");if(B>-1&&f.files!==OA[E]?.files&&!(0,et.existsSync)(I.slice(0,B)))throw new Error(`The path '${I.slice(0,B)}' does not exist and cannot be used as the base of the resolved 'files' path value '${f.files}'`);let U=(0,st.basename)(e),F=f.path||"/";F=F.startsWith("/")?F:F.startsWith("./")?"/"+U+F.slice(2):F==="."?"/"+U:"/"+U+"/"+F;let M,Q,z;if(f.root){let oe=f.root;oe.startsWith("/")&&(oe=oe.slice(1)),oe.endsWith("/")&&(oe=oe.slice(0,-1)),oe+="/",Q=(0,st.join)(e,oe)}else(z=I.indexOf("/*"))>-1&&(Q=I.slice(0,z+1),M=(0,st.relative)(e,Q));let j=!1;if(Mo.isMainThread&&h.setupDirectory&&(j=await h.setupDirectory?.(F,Q,t)),t.isWorker&&h.handleDirectory&&(j=await h.handleDirectory?.(F,Q,t)),j)continue;for(let oe of await(0,PH.default)(I,{onlyFiles:!1,objectMode:!0})){let{path:ue,dirent:le}=oe;d=!0;let Be=(0,st.relative)(e,ue).replace(/\\/g,"/");if(M)if(Be.startsWith(M))Be=Be.slice(M.length+1);else throw new Error(`The root path '${f.root}' does not reference a valid part of the file path '${Be}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Ne=F+(F.endsWith("/")?"":"/")+Be;try{if(le.isFile()){let xe=await Xse(ue);Mo.isMainThread&&await h.setupFile?.(xe,Ne,ue,t),t.isWorker&&await h.handleFile?.(xe,Ne,ue,t)}else Mo.isMainThread&&await h.setupDirectory?.(Ne,ue,t),t.isWorker&&await h.handleDirectory?.(Ne,ue,t)}catch(xe){xe.message=`Could not load ${le.isFile()?"file":"directory"} '${ue}'${f.module?" using '"+f.module+"'":""} for application '${e}' due to: ${xe.message}`,vl?.(xe),((0,nc.getWorkerIndex)()===0?console:tc.default).error(xe),t.set(f.path||"/",new Bl(xe)),rc.set(n?E:(0,st.basename)(e),xe.message)}}}}catch(S){S.message=`Could not load component '${E}' for application '${(0,st.basename)(e)}' due to: ${S.message}`,vl?.(S),((0,nc.getWorkerIndex)()===0?console:tc.default).error(S),t.set(f.path||"/",new Bl(S),null,!0),rc.set(n?E:(0,st.basename)(e),S.message)}}if(Mo.isMainThread&&!xH&&i&&(0,nc.watchDir)(e,async()=>HH()),c.extensionModule)return await b_((0,st.join)(e,c.extensionModule));if(!d&&t.isWorker){let E=`${e} did not load any modules, resources, or files, is this a valid component?`;vl?.(new Error(E)),((0,nc.getWorkerIndex)()===0?console:tc.default).error(E),rc.set((0,st.basename)(e),E)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,vl?.(c),t.set("",new Bl(c))}}}var et,st,Mo,MH,bA,sc,PH,nc,tc,UH,vH,Jse,BH,Xse,gA,AA,xH,RA,rc,jse,OA,DH,LH,vl,Bl,Vf=Re(()=>{et=require("fs"),st=require("path"),Mo=require("worker_threads"),MH=require("yaml"),bA=H(ee()),sc=H(P());wb();Mb();Pb();G0();Dx();Bx();PH=H(require("fast-glob")),nc=H(Qe()),tc=H($());nm();fr();UH=H(se());cn();Ae();Vx();vH=H(ee()),Jse=H(Qx());Uf();rH();CH();BH=H(pr());vE();({readFile:Xse}=et.promises),gA=bA.get(sc.CONFIG_PARAMS.COMPONENTSROOT),AA=new Map,rc=new Map;a(HH,"loadComponentDirectories");jse={REST:aE,rest:aE,graphqlSchema:rm,jsResource:im,fastifyRoutes:FR,login:am,static:kR,operationsApi:Jse,customFunctions:{},http:{},clustering:rA,authentication:tl,mqtt:TA},OA={rest:!0,graphqlSchema:{files:"*.graphql"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(OA,"static",{value:{files:"web/**"}});DH=[],LH=new Map;a(Zse,"setErrorReporter");a(QE,"loadComponent");Bl=class extends Yt{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 fA=g((xSe,qH)=>{var{isMainThread:GH}=require("worker_threads"),{getTables:eie}=(Ae(),ie(ke)),{loadComponentDirectories:tie,loadComponent:rie}=(Vf(),ie(kf)),{resetResources:nie}=(Zu(),ie(QU)),sie=Og(),iie=pr(),{dirname:oie}=require("path"),{getConnection:aie}=ut(),cie=ee(),uie=P(),yA=new Map;async function lie(e=!1){!GH&&cie.get(uie.CONFIG_PARAMS.CLUSTERING_ENABLED)&&aie();try{GH&&await sie()}catch(n){console.error(n)}let t=nie();eie(),t.isWorker=e,await rie(oie(iie.getConfigFilePath()),t,"hdb",!0,yA),await tie(yA,t);let r=[];for(let[n]of yA)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(lie,"loadRootComponents");qH.exports.loadRootComponents=lie});var Qe=g((GSe,vi)=>{"use strict";var{Worker:_ie,MessageChannel:die,parentPort:ms,isMainThread:DA,threadId:fie,workerData:Ws}=require("worker_threads"),{PACKAGE_ROOT:Eie}=P(),{join:$H,isAbsolute:hie,extname:mie}=require("path"),{server:YH}=(fr(),ie(Gi)),{watch:pie,readdir:Sie}=require("fs/promises"),{totalmem:FH}=require("os"),xl=P(),KH=ee(),Qs=$(),{randomBytes:Tie}=require("crypto"),{_assignPackageExport:gie}=require("../index"),Rie=P(),kH=1024*1024,Ui=[],Rn=[],Aie=50,LA=1e4,Oie="restart",WH="request_thread_info",QH="resource_report",zH="thread_info",JH="added-port",bie="ack",NA;gie("threads",Rn);vi.exports={startWorker:IA,restartWorkers:PA,shutdownWorkers:Cie,workers:Ui,setMonitorListener:xie,onMessageFromWorkers:Die,onMessageByType:nG,broadcast:Mie,broadcastWithAcknowledgement:Uie,setChildListenerByType:wie,getWorkerIndex:XH,getWorkerCount:jH,getTicketKeys:eG,setMainIsWorker:Nie,setTerminateTimeout:yie,restartNumber:Ws?.restartNumber||1};Rn.onMessageByType=nG;Rn.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Rn.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};var MA;function yie(e){LA=e}a(yie,"setTerminateTimeout");function XH(){return Ws?Ws.workerIndex:MA?0:void 0}a(XH,"getWorkerIndex");function jH(){return Ws?Ws.workerCount:MA?1:void 0}a(jH,"getWorkerCount");function Nie(e){MA=e}a(Nie,"setMainIsWorker");var ZH=1,zE;function eG(){return zE||(zE=DA?Tie(48):Ws.ticketKeys,zE)}a(eG,"getTicketKeys");Object.defineProperty(YH,"workerIndex",{get(){return XH()}});Object.defineProperty(YH,"workerCount",{get(){return jH()}});var tG={[WH](e,t){vie(t)},[QH](e,t){Bie(t,e)}};function IA(e,t={}){let r=process.constrainedMemory?.()||FH();r=Math.min(r,FH(),2e4*kH);let n=KH.get(xl.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/kH/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let u of Rn){let _=new die;_.existingPort=u,i.push(_),o.push(_.port2)}mie(e)||(e+=".js");let c=new _ie(hie(e)?e:$H(Eie,e),Object.assign({resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(u=>u.existingPort.threadId),workerIndex:t.workerIndex,workerCount:ZH=t.threadCount,name:t.name,restartNumber:vi.exports.restartNumber,ticketKeys:eG()},transferList:o},t));for(let{port1:u,existingPort:_}of i)_.postMessage({type:JH,port:u,threadId:c.threadId},[u]);return XE(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>IA(e,t),c.on("error",u=>{Qs.error(`Worker index ${t.workerIndex} error:`,u)}),c.on("exit",u=>{Ui.splice(Ui.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<Aie?(t.unexpectedRestarts=c.unexpectedRestarts+1,IA(e,t)):Qs.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",u=>{tG[u.type]?.(u,c)}),Ui.push(c),Gie(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(IA,"startWorker");var Iie=[xl.THREAD_TYPES.HTTP];async function PA(e=null,t=Math.max(ZH>3,1),r=!0){if(DA){if(r){let{loadRootComponents:o}=fA();await o()}vi.exports.restartNumber++,t<1&&(t=t*Ui.length);let n=[],s=[];for(let o of Ui.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Qs.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:vi.exports.restartNumber,type:xl.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=Iie.indexOf(o.name)>-1,u=new Promise(_=>{let l=setTimeout(()=>o.terminate(),LA*2).unref();o.on("exit",()=>{clearTimeout(l),n.splice(n.indexOf(u)),!c&&r&&o.startCopy(),_()})});if(n.push(u),c&&r){let _=o.startCopy(),l=new Promise(d=>{let E=a(f=>{f.type===Rie.ITC_EVENT_TYPES.CHILD_STARTED&&(Qs.trace("Worker has started",_.threadId),d(),s.splice(s.indexOf(l)),_.off("message",E))},"startListener");Qs.trace("Waiting for worker to start",_.threadId),_.on("message",E)});s.push(l),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=Xu();r&&(e==="http"||!e)&&KH.get(xl.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else ms.postMessage({type:Oie,workerType:e})}a(PA,"restartWorkers");function wie(e,t){tG[e]=t}a(wie,"setChildListenerByType");function Cie(e){return PA(e,1/0,!1)}a(Cie,"shutdownWorkers");var rG=[];function Die(e){rG.push(e)}a(Die,"onMessageFromWorkers");var wA=new Map;function nG(e,t){let r=wA.get(e);r||wA.set(e,r=[]),r.push(t)}a(nG,"onMessageByType");var Lie=10;async function Mie(e){let t=0;for(let r of Rn)try{r.postMessage(e),t++>Lie&&(t=0,await new Promise(setImmediate))}catch(n){Qs.error("Unable to send message to worker",n)}}a(Mie,"broadcast");var JE=new Map,Pie=1;function Uie(e){return new Promise(t=>{let r=0;for(let n of Rn)try{let s=Pie++,i=a(()=>{JE.delete(s),--r===0&&t(),n!==ms&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,JE.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of JE)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Qs.error("Unable to send message to worker",s)}r===0&&t()})}a(Uie,"broadcastWithAcknowledgement");function vie(e){e.postMessage({type:zH,workers:sG()})}a(vie,"sendThreadInfo");function sG(){let e=Date.now();return Ui.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(sG,"getChildWorkerInfo");function Bie(e,t){e.resources=t,e.resources.updated=Date.now()}a(Bie,"recordResourceReport");var CA;function xie(e){CA=e}a(xie,"setMonitorListener");var Hie=1e3,VH=!1;function Gie(){VH||(VH=!0,setInterval(()=>{for(let e of Ui){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}CA&&CA()},Hie).unref())}a(Gie,"startMonitoring");var qie=1e3;if(ms){XE(ms);for(let e=0,t=Ws.addPorts.length;e<t;e++){let r=Ws.addPorts[e];r.threadId=Ws.addThreadIds[e],XE(r)}setInterval(()=>{let e=process.memoryUsage();ms.postMessage({type:QH,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},qie).unref(),NA=a(()=>new Promise((e,t)=>{ms.on("message",r),ms.postMessage({type:WH});function r(n){n.type===zH&&(ms.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else NA=sG;vi.exports.getThreadInfo=NA;function XE(e,t){Rn.push(e),e.on("message",r=>{if(r.type===JH)r.port.threadId=r.threadId,XE(r.port);else if(r.type===bie){let n=JE.get(r.id);n&&n()}else{for(let s of rG)s(r,e);let n=wA.get(r.type);if(n)for(let s of n)try{s(r,e)}catch(i){Qs.error(i)}}}).on("close",()=>{Rn.splice(Rn.indexOf(e),1)}).on("exit",()=>{Rn.splice(Rn.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(XE,"addPort");if(DA){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await Sie(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n($H(s,o.name));try{for await(let{filename:o}of pie(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await PA(),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");vi.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else ms.on("message",async e=>{let{type:t}=e;t===xl.ITC_EVENT_TYPES.SHUTDOWN&&(vi.exports.restartNumber=e.restartNumber,ms.unref(),setTimeout(()=>{Qs.warn("Thread did not voluntarily terminate",fie),process.exit(0)},LA).unref())})});var xC={};Fe(xC,{AUDIT_STORE_OPTIONS:()=>yf,createAuditEntry:()=>C_,openAuditStore:()=>th,readAuditEntry:()=>Bt,setAuditRetention:()=>kie,transactionKeyEncoder:()=>fG});function th(e){let t=e.auditStore=e.openDB(lG.AUDIT_STORE_NAME,yf);t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,{remove(){delete r[i]}}};let n=null;function s(i=jE){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let o=0,c;try{for(let{key:u,value:_}of t.getRange({start:0,snapshot:!1,end:Date.now()-UA})){if((_[0]&15)===xA){let l=Bt(_),d=l.tableId;r[d]?.(l.recordId)}if(c=t.remove(u),await new Promise(setImmediate),++o>=Fie){i=10;break}}await c}finally{o===0&&(i=Math.min(i<<1,UA/10)),s(i)}},i).unref()}return a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,eh.getWorkerIndex)()===(0,eh.getWorkerCount)()-1&&s(jE),t}function kie(e,t=jE){UA=e,jE=t}function C_(e,t,r,n,s,i,o){let c=EG[i];if(!c)throw new Error(`Invalid audit entry type ${i}`);let u=1;n&&(n>1?ic.setFloat64(0,n):An.set(Om),u=9),E(0),E(t),d(r),ic.setFloat64(u,e),u+=8,s?d(s):An[u++]=0,An[n?8:0]=c;let l=An.subarray(0,u);if(o)return Buffer.concat([l,o]);return l;function d(f){let h=u;u+=1,u=(0,oc.writeKey)(f,An,u);let p=u-h-1;p>127?p>16383?(GA.error("Key or username was too large for audit entry",f),u=h+1,An[h]=0):(An.copyWithin(h+2,h+1,u),ic.setUint16(h,p|32768),u++):An[h]=p}function E(f){f<128?An[u++]=f:f<16384?(ic.setUint16(u,f|32768),u+=2):f<1056964608?(ic.setUint32(u,f|3221225472),u+=4):(An[u]=255,ic.setUint32(u+1,f),u+=5)}}function Bt(e){try{let t=e.dataView||(e.dataView=new HA(e.buffer,e.byteOffset,e.byteLength)),r;e[0]==66&&(r=t.readFloat64());let n=t.readInt(),s=t.readInt(),i=t.readInt(),o=t.readInt(),c=t.position,u=t.position+=o,_=t.readFloat64();o=t.readInt();let l=t.position,d=t.position+=o;return{type:EG[n&7],tableId:i,get recordId(){return uG(e,c,u)},version:_,previousLocalTime:r,get user(){return d>l?uG(e,l,d):void 0},getValue(E,f,h){if(n&vA||n&BA&&!f)return E.decoder.decode(e.subarray(t.position));if(n&BA&&h)return qA(E.getEntry(this.recordId),h,E)}}}catch(t){return GA.error("Reading audit entry error",t,e),{}}}function uG(e,t,r){let n=e.subarray(t,r);return(0,oc.readKey)(n,0,r-t)}var oc,ZE,lG,_G,eh,dG,GA,An,ic,fG,yf,UA,Fie,jE,vA,BA,iG,xA,oG,aG,cG,EG,HA,ni=Re(()=>{oc=require("ordered-binary"),ZE=H(ee()),lG=H(ft()),_G=H(P()),eh=H(Qe()),dG=H(J());Bc();GA=H($());rh();(0,ZE.initSync)();An=Buffer.alloc(1024),ic=new DataView(An.buffer,An.byteOffset,1024),fG={writeKey(e,t,r){return e===vc?(t.set(vc,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,oc.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,oc.readKey)(e,t,r)}},yf={encoding:"binary",keyEncoder:fG},UA=(0,dG.convertToMS)((0,ZE.get)(_G.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,Fie=1e3,jE=1e4;a(th,"openAuditStore");a(kie,"setAuditRetention");vA=16,BA=32,iG=1,xA=2,oG=3,aG=4,cG=5,EG={put:iG|vA,[iG]:"put",delete:xA,[xA]:"delete",message:oG|vA,[oG]:"message",invalidate:aG,[aG]:"invalidate",patch:cG|BA,[cG]:"patch"};a(C_,"createAuditEntry");a(Bt,"readAuditEntry");HA=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(uG,"readKeySafely")});var FA={};Fe(FA,{add:()=>nh,applyReverse:()=>hG,getRecordAtTime:()=>qA,rebuildUpdateBefore:()=>sh});function nh(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 sh(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,nh(r,n,s)}}else r||(r={}),r[n]=e[n];return r}function hG(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Vie[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=mG}}function qA(e,t,r){let n=r.rootStore.auditStore,s=Object.assign({},e.value),i=e.localTime;for(;i>t;){let u=n.get(i),_=Bt(u);switch(_.type){case"put":s=_.getValue(r);break;case"patch":hG(s,_.getValue(r));break;case"delete":s=null}i=_.previousLocalTime}let o={},c=0;for(let u in s)s[u]===mG&&(o[u]=!0,c++);for(;c>0&&i>0;){let u=n.get(i),_=Bt(u),l;switch(_.type){case"put":l=_.getValue(r);break;case"patch":l=_.getValue(r);break}for(let d in l)o[d]&&(s[d]=l[d],o[d]=!1,c--);i=_.previousLocalTime}if(c>0)for(let u in o)s[u]=null;return s}var Vie,mG,rh=Re(()=>{ni();a(nh,"add");nh.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)};Vie={add:nh};a(sh,"rebuildUpdateBefore");a(hG,"applyReverse");mG={};a(qA,"getRecordAtTime")});function en(e){return e[Nt]||(e[Nt]=Object.create(null))}function uh(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,u,_;if(o.resolve)_={get(){return o.resolve(this,this[ye])},set(l){return o.set(this,l)},configurable:!0};else{switch(o.type){case"String":u=a(function(l){if(!(typeof l=="string"||l==null&&o.nullable!==!1))throw new On.ClientError(`${c} must be a string, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"ID":u=a(function(l){if(!(typeof l=="string"||l?.length>0&&l.every?.(d=>typeof d=="string")||l==null&&o.nullable!==!1))throw new On.ClientError(`${c} must be a string, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"Float":case"Number":u=a(function(l){let d=l?.__op__?l.value:l;if(!(typeof d=="number"||l==null&&o.nullable!==!1))throw new On.ClientError(`${c} must be a number, attempt to assign ${d}`);en(this)[c]=l},"set");break;case"Int":u=a(function(l){let d=l?.__op__?l.value:l;if(!(d>>0===d||l==null&&o.nullable!==!1))if(typeof d=="number"&&Math.abs((d>>0)-d)<=1)d=Math.round(d),l?.__op__?l.value=d:l=d;else throw new On.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"Long":u=a(function(l){let d=l?.__op__?l.value:l;if(!(Math.round(d)===l&&Math.abs(d)<=9007199254740992||l==null&&o.nullable!==!1))if(typeof d=="number"&&Math.abs(d)<=9007199254740992)d=Math.round(d),l?.__op__?l.value=d:l=d;else throw new On.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"BigInt":u=a(function(l){let d=l?.__op__?l.value:l;if(!(typeof d=="bigint"||l==null&&o.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=BigInt(d),l?.__op__?l.value=d:l=d;else throw new On.ClientError(`${c} must be a number, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"Boolean":u=a(function(l){if(!(typeof l=="boolean"||l==null&&o.nullable!==!1))throw new On.ClientError(`${c} must be a boolean, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"Date":u=a(function(l){if(!(l instanceof Date||l==null&&o.nullable!==!1))if(typeof l=="string"||typeof l=="number")l=new Date(l);else throw new On.ClientError(`${c} must be a Date, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"Bytes":u=a(function(l){if(!(l instanceof Uint8Array||l==null&&o.nullable!==!1))throw new On.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"Any":case void 0:u=a(function(l){en(this)[c]=l},"set");break;default:u=a(function(l){if(!(typeof l=="object"||l==null&&o.nullable!==!1))throw new On.ClientError(`${c} must be an object, attempt to assign ${l}`);en(this)[c]=l},"set")}_={get(){let l=this[Nt];if(l&&c in l){let E=l[c];if(E?.__op__){let f=this[Ee]?.[c];return E.update(f)}return E}let d=this[Ee]?.[c];if(d&&typeof d=="object"){let E=SG(d,o);if(E)return l||(l=this[Nt]=Object.create(null)),l[c]=E}return d},set:u,enumerable:!0,configurable:!0}}_.get.isAttribute=!0,n[c]=_,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,_)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let u=this[Nt];return u?.[o]!==void 0?u[o]:this[Ee]?.[o]}),i("set",function(o,c){let u=n[o];if(u)return u.set.call(this,c);if(t.sealed)throw new On.ClientError("Can not add a property to a sealed table schema");en(this)[o]=c}),i("deleteProperty",function(o){en(this)[o]=void 0}),i("toJSON",function(){let o=this[Nt],c;for(let _ in o){c||(c=Object.assign({},this[Ee]));let l=o[_];if(l?.__op__){let d=c[_];l=l.update(d)}c[_]=l}return Object.keys(this).length>0&&(c||(c=Object.assign({},this[Ee])),Object.assign(c,this)),c||this[Ee]}),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 SG(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?.[Ee])throw new Error("Can not track an already tracked object, check for circular references");this[Ee]=s}},uh(r,t)),new r(e)):new ih(e);case Array:let n=new ah(e.length);n[Ee]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=SG(o,t?.elements)),n[s]=o}return n;default:return e}}function Rd(e){let t=e[Nt],r;for(let s in t){r||(r=Object.assign({},e[Ee]));let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=Rd(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=Object.assign({},e[Ee])),Object.assign(r,e)),r||e[Ee]}function Uo(e,t=e[Nt]){let r;if(pG.call(e,Ee)&&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=Uo(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[Ee]));let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=FA[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Uo(s);r[n]=s}return r?Object.freeze(r):pG.call(e,Ee)?e[Ee]:e}function oh(e){let t=e[Ee];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[Po]||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?.[Ee]===s){if(oh(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[Ee]===i){if(oh(s))return!0}else return!0}else return!0}}return!1}var On,Nt,ih,pG,Po,ah,ch,Ad=Re(()=>{cn();On=H(se());rh();Nt=Symbol("own-data");a(en,"getChanges");a(uh,"assignTrackedAccessors");a(SG,"trackObject");ih=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[Ee])throw new Error("Can not track an already tracked object, check for circular references");this[Ee]=t}};uh(ih,{});a(Rd,"collapseData");pG=Object.prototype.hasOwnProperty;a(Uo,"deepFreeze");a(oh,"hasChanges");Po=Symbol.for("has-array-changes"),ah=class extends Array{static{a(this,"TrackedArray")}[Po];constructor(t){super(t)}splice(...t){return this[Po]=!0,super.splice(...t)}push(...t){return this[Po]=!0,super.push(...t)}pop(){return this[Po]=!0,super.pop()}unshift(...t){return this[Po]=!0,super.unshift(...t)}shift(){return this[Po]=!0,super.shift()}};ah.prototype.constructor=Array;ch=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var Kp={};Fe(Kp,{CONTEXT:()=>ye,ID_PROPERTY:()=>Me,IS_COLLECTION:()=>$n,MultiPartId:()=>qa,RECORD_PROPERTY:()=>Ee,Resource:()=>Yt,snake_case:()=>Yie,transformForSelect:()=>_h});function Yie(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(Hl=!1,e==="")return null;if(e=e.slice(1),e.indexOf("/")===-1)return e===""?(Hl=!0,null):(e.startsWith("$")&&(e=parseInt(e,36)),t.coerceId(decodeURIComponent(e)));let r=e.split("/"),n=new qa;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Hl=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}function tn(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,u,_,l;if(r?(o?(l=i,o=o[ye]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(l=s,c=l[this.primaryKey]??null,o=i[ye]||i):l=i:(l=s,c=l[Me]??l[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(u=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]),u.slice&&(u=u.slice(c.length,u.length),u.length===0&&(u=null,_=!1)))}else{if(typeof(c=s.url)=="string"){let f=c.indexOf("?");if(f>-1){let p=this.parseQuery(c.slice(f+1));u?u=Object.assign(p,u):u=p,c=c.slice(0,f)}let h=this.parsePath(c,o,u);h?.id!==void 0?(h.query&&(u?u=Object.assign(h.query,u):u=h.query),_=h.isCollection,c=h.id):c=h}c===void 0&&(c=s.id??null,c==null&&(_=!0))}else c=s??null,c==null&&(_=!0);o||(o={});let d;if(u?.ensureLoaded!=null||u?.async||_?(d=Object.assign({},t),u?.ensureLoaded!=null&&(d.ensureLoaded=u.ensureLoaded),u?.async&&(d.async=u.async),_&&(d.isCollection=!0)):d=t,o.transaction){let f=this.getResource(c,o,d);return f.then?f.then(E):E(f)}else return rt(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,u,o):t.type==="update"?f.doesExist?.()===!1?f.allowCreate(o.user,l,o):f.allowUpdate(o.user,l,o):t.type==="create"?f.allowCreate(o.user,l,o):f.allowDelete(o.user,u,o);if(h?.then)return h.then(p=>{if(!p)throw new lh(o.user);return typeof l?.then=="function"?l.then(S=>e(f,u,o,S)):e(f,u,o,l)});if(!h)throw new lh(o.user)}return typeof l?.then=="function"?l.then(h=>e(f,u,o,h)):e(f,u,o,l)}a(E,"authorizeActionOnResource")}}function rn(e,t){let r=new AG.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 kA(e,t,r){let n=e[Ee];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 _h(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):kA(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(u){if(u.then)return u.then(c);if(Array.isArray(u))return u.map(c);let _=[],l=i(kA(u,r,n));for(let d of e)_.push(l(d));return _},"transform");let o=e.forceNulls;return a(function c(u){if(u.then)return u.then(c);if(Array.isArray(u))return u.map(E=>E&&typeof E=="object"?c(E):E);let _={},l=i(kA(u,r,n)),d;for(let E of e){let f=l(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 u=s[c.name];if(!u){let l=r[c.name]?.definition?.tableClass;u=s[c.name]=_h(c.select||c,l)}let _=o(c.name);return u(_)}else return o(c);else return c}}a(i,"handleProperty")}var gG,RG,AG,ye,Me,$n,Ee,$ie,Yt,lh,Hl,qa,cn=Re(()=>{gG=require("crypto");Cc();RG=require("../index"),AG=H(se());Ad();so();iE();ye=Symbol.for("context"),Me=Symbol.for("primary-key"),$n=Symbol("is-collection"),Ee=Symbol("stored-record"),$ie={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Yt=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=tn(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let u;if((u=r?.select)&&c!=null&&!c.selectApplied){let _=_h(u,t.constructor);return typeof c?.map=="function"?c.map(_):_(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=tn(function(t,r,n,s){if(Array.isArray(s)&&t[$n]){let i=[],o=n.authorize;for(let c of s){let u=t.constructor,_=u.getResource(c[u.primaryKey],n,{async:!0});_.then?i.push(_.then(l=>l.put(c,n))):i.push(_.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):rn(t,"put")},{hasContent:!0,type:"update"});static patch=tn(function(t,r,n,s){return t.patch?t.patch(s,r):rn(t,"patch")},{hasContent:!0,type:"update"});static delete=tn(function(t,r,n,s){return t.delete?t.delete(r):rn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,gG.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={}),rt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):rn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>s):s})}static invalidate=tn(function(t,r,n,s){return t.invalidate?t.invalidate(r):rn(t,"delete")},{hasContent:!1,type:"update"});static post=tn(function(t,r,n,s){return t[Me]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=tn(function(t,r,n,s){return t.connect?t.connect(s,r):rn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=tn(function(t,r,n,s){return t.subscribe?t.subscribe(r):rn(t,"subscribe")},{type:"read"});static publish=tn(function(t,r,n,s){return t[Me]!=null&&t.update?.(),t.publish?t.publish(s,r):rn(t,"publish")},{hasContent:!0,type:"create"});static search=tn(function(t,r,n,s){let i=t.search?t.search(r):rn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=_h(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=tn(function(t,r,n,s){return t.search?t.search(s,r):rn(t,"search")},{hasContent:!0,type:"read"});static copy=tn(function(t,r,n,s){return t.copy?t.copy(s,r):rn(t,"copy")},{type:"create"});static move=tn(function(t,r,n,s){return t.move?t.move(s,r):rn(t,"move")},{type:"delete"});post(t){if(this[$n])return this.constructor.create(this[Me],t,this[ye]);rn(this,"post")}static isCollection(t){return t?.[$n]}static coerceId(t){return t}static parseQuery(t){return sE(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.requestedContentType=c;else if(n)n.property=o;else return{query:{property:o},id:TG(t,this),isCollection:Hl}}let i=TG(t,this);return Hl?{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 u;if(i.resourceCache?u=i.resourceCache:u=i.resourceCache=[],u.asMap){let _=u.asMap.get(t);if(s=_?.find(l=>l.constructor===c),s)return s;_||u.asMap.set(t,_=[]),_.push(s=new c(t,i))}else{if(s=u.find(_=>_[Me]===t&&_.constructor===c),s)return s;if(u.push(s=new c(t,i)),u.length>10){let _=new Map;for(let l of u){let d=l[Me],E=_.get(d);E?E.push(l):_.set(d,[l])}i.resourceCache.length=0,i.resourceCache.asMap=_}}}else s=new c(t,i);return o&&(s[$n]=!0),s}subscribe(t){return new In}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new In}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]}};Yt.prototype[ye]=null;(0,RG._assignPackageExport)("Resource",Yt);a(Yie,"snake_case");lh=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");qa=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(tn,"transactional");a(rn,"missingMethod");a(kA,"selectFromObject");a(_h,"transformForSelect")});function yG(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=bG,Kie(e.primaryStore,e.auditStore)):(c=OG,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{NG(OG[i])})));let u=c[i]||(c[i]=[]);u.auditStore=e.auditStore,u.lastTxnTime==null&&(u.lastTxnTime=Date.now());let _=u[o];_||(_=u[o]=new Map,_.envs=u,_.tableId=o,_.store=e.primaryStore),t=wa(t);let l=new $A(r);l.startTime=n;let d=_.get(t);return d?d.push(l):(_.set(t,d=[l]),d.tables=_,d.key=t),l.subscriptions=d,l}function NG(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,u,_=wa(i.recordId),l=0;do{let d=o.get(_);if(d){for(let f of d)if(!(l>0&&!(f.includeDescendants&&!(f.onlyChildren&&l>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,l++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function Kie(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 u=bG[s];if(!u)return;let _=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),u.txnTime=r.threadLocalWrites[0]||Date.now(),NG(u),r.threadLocalWrites[0]=u.lastTxnTime,r.unlock("thread-local-writes")},"acquiredLock");r.attemptLock("thread-local-writes",_)&&_()})}}var VA,OG,bG,$A,IG=Re(()=>{VA=H($());Cc();Zu();ni();OG=Object.create(null),bG=Object.create(null);a(yG,"addSubscription");$A=class extends In{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(NG,"notifyFromTransactionData");a(Kie,"listenToCommits")});var bR={};Fe(bR,{coerceType:()=>dh,makeTable:()=>hh,setServerUtilities:()=>toe,updateResource:()=>fh});function hh(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:u,schemaDefined:_,dbisDB:l,sealed:d}=e,{expirationMS:E,evictionMS:f,audit:h,trackDeletes:p}=e,{attributes:S}=e;S||(S=[]);let T=Nm(i,n,u),A=0,b,I,B={},U=Promise.resolve(),F,M,Q;for(let K of S)(K.assignCreatedTime||K.name==="__createdtime__")&&(F=K),(K.assignUpdatedTime||K.name==="__updatedtime__")&&(M=K),K.expiresAt&&(Q=K),K.isPrimaryKey&&(B=K);let z,j=[],oe=[],ue=1,le=2,Be={},Ne={},xe=864e5,n_,s_,Xs,_O=!1,Lh,Mh,Pq=i.getRange({start:!1,end:!1}).constructor,Uq=10,vq=6;h&&EO();class Ke extends Yt{static name=s;static primaryStore=i;static auditStore=u;static primaryKey=t;static tableName=s;static indices=r;static audit=h;static databasePath=o;static databaseName=c;static attributes=S;static expirationTimer;static createdTimeProperty=F;static updatedTimeProperty=M;static propertyResolvers;static sources=[];static get expirationMS(){return E}static dbisDB=l;static schemaDefined=_;static sourcedFrom(m,R){R&&(this.sourceOptions=R,(R.expiration||R.eviction||R.scanInterval)&&this.setTTLExpiration(R)),R?.intermediateSource?(m.intermediateSource=!0,this.sources.unshift(m)):this.sources.push(m),I=m.get&&(!m.get.reliesOnPrototype||m.prototype.get);let D=a(L=>{let y=this.sources.slice(0,-1);if(y=y.filter(v=>v[L]&&(!v[L].reliesOnPrototype||v.prototype[L])),y.length>0)if(y.length===1){let v=y[0];return(q,C,G)=>{if(q?.source!==v)return v[L](C,G,q)}}else return(v,q,C)=>{let G=[];for(let x of y){if(v?.source===x)break;G.push(x[L](q,C,v))}return Promise.all(G)}},"getApplyToIntermediateSource"),O=this.sources[this.sources.length-1],N=a(L=>{if(O[L]&&(!O[L].reliesOnPrototype||O.prototype[L]))return(y,v,q)=>{if(!y?.source)return O[L](v,q,y)}},"getApplyToCanonicalSource");return Be={put:N("put"),patch:N("patch"),delete:N("delete"),publish:N("publish")},Ne={put:D("put"),patch:D("patch"),delete:D("delete"),publish:D("publish"),invalidate:D("invalidate")},(async()=>{let L=!1,y=a(async(v,q)=>{let C=v.value,G=v.table?ct[c][v.table]:Ke;if(c===Kn.SYSTEM_SCHEMA_NAME&&(v.table===Kn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||v.table===Kn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(L=!0),v.id===void 0&&(v.id=C[G.primaryKey],v.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(v));v.source=m;let x=await G.getResource(v.id,q,ac);switch(v.type){case"put":return x._writeUpdate(C,!0,ac);case"patch":return x._writeUpdate(C,!1,ac);case"delete":return x._writeDelete(ac);case"publish":return x._writePublish(C,ac);case"invalidate":return x.invalidate(ac);default:it.error("Unknown operation",v.type,v.id)}},"writeUpdate");try{let v=m.subscribe;v&&p==null&&(p=!0);let q=m.subscribeOnThisThread?m.subscribeOnThisThread((0,Bo.getWorkerIndex)()):(0,Bo.getWorkerIndex)()===0,C=v&&q&&await m.subscribe?.({crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0});if(C){let G;for await(let x of C)try{if(!(x.type==="transaction"?x.writes[0]:x)){it.error("Bad subscription event",x);continue}if(x.source=m,G)if(x.beginTxn)G.resolve();else{y(x,G);continue}if(x.type==="end_txn")continue;let _e=rt(x,()=>{if(x.type==="transaction"){let ne=[];for(let Ue of x.writes)try{ne.push(y(Ue,x))}catch(ce){throw ce.message+=" writing "+JSON.stringify(Ue)+" of event "+JSON.stringify(x),ce}return Promise.all(ne)}else if(x.type==="define_schema"){let ne=this.attributes.slice(0),Ue;for(let ce of x.attributes)ne.find(De=>De.name===ce.name)||(ne.push(ce),Ue=!0);Ue&&(Et({table:s,database:c,attributes:ne,origin:"cluster"}),Yl.signalSchemaChange(new Kl.SchemaEventMsg(process.pid,Kn.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return x.beginTxn?(G=x,y(x,x),new Promise(ne=>{G.resolve=ne})):y(x,x)});L&&(await _e,Yl.signalUserChange(new Kl.UserEventMsg(process.pid))),x.onCommit&&(_e?.then?_e.then(x.onCommit):x.onCommit())}catch(Z){it.error("error in subscription handler",Z)}}}catch(v){it.error(v)}})(),this}static get isCaching(){return I}static getResource(m,R,D){let O=super.getResource(m,R,D);if(m!=null){dc(m);try{if(O.hasOwnProperty(Ee))return O;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let N=!D?.async||i.cache?.get(m),L=yn(R),y=L.getReadTxn();if(y?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return Ph(m,R,{transaction:y},N,v=>{if(v?fh(O,v):O[Ee]=null,R.onlyIfCached&&R.noCacheStore){if(!O.doesExist())throw new Mr.ServerError("Entry is not cached",504)}else if(D?.ensureLoaded){let q=Uh(m,v,R,O);if(q)return L?.disregardReadTxn(),O[YA]=!0,WA(q,C=>(fh(O,C),O))}return O})}catch(N){throw N.message.includes("Unable to serialize object")&&(N.message+=": "+JSON.stringify(m)),N}}return O}ensureLoaded(){let m=Uh(this[Me],this[Lr],this[ye]);if(m)return this[YA]=!0,WA(m,R=>{this[Lr]=R,this[Ee]=R.value,this[Vl]=R.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,xe=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(E<0)throw new Error("Expiration can not be negative");xe=xe||(E+f)/4,a_()}static enableAuditing(m=!0){h=m,m&&EO(),Ke.audit=m}static coerceId(m){return m===""?null:dh(m,B)}static async dropTable(){if(delete ct[c][s],c===o){for(let m of S)l.remove(Ke.tableName+"/"+m.name),r[m.name]?.drop();l.remove(Ke.tableName+"/"),i.drop(),await l.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));Yl.signalSchemaChange(new Kl.SchemaEventMsg(process.pid,Kn.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this[$n])return this.search(m);if(this[Me]===null){if(m?.conditions)return this.search(m);let R=Ke.getRecordCount();return{recordCount:R.recordCount,estimatedRecordRange:R.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,R){let D=o_(m);if(D?.read){if(D.isSuperUser)return!0;let O=D.attribute_permissions,N=R?.select;if(O?.length>0||_O&&N){if(R||(R={}),N){let L=O?.length>0&&KA(O,"read");R.select=N.map(y=>{let v=y.name||y;if(!L||L[v]){let q=Xs[v]?.definition?.tableClass;if(q){if(y.name||(y={name:y}),!q.prototype.allowRead.call(null,m,y))return!1;if(!y.select)return y.name}return y}}).filter(Boolean)}else R.select=O.filter(L=>L.read&&!Xs[L.attribute_name]).map(L=>L.attribute_name);return R}else return!0}}allowUpdate(m,R){let D=o_(m);if(D?.update){let O=D.attribute_permissions;if(O?.length>0){let N=KA(O,"update");for(let L in R)if(!N[L])return!1;for(let L of O){let y=L.attribute_name;!L.update&&!(y in R)&&(R[y]=this.getProperty(y))}}return!0}}allowCreate(m,R){if(this[$n]){let D=o_(m);if(D?.insert){let O=D.attribute_permissions;if(O?.length>0){let N=KA(O,"insert");for(let L in R)if(!N[L])return!1}else return!0}}else return this.allowUpdate(m,{})}allowDelete(m){return o_(m)?.delete}update(m,R){if(!yn(this[ye]))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let O;return typeof m=="object"&&m&&(R?(Object.isFrozen(m)&&(m=Object.assign({},m)),this[Ee]={},this[Nt]=m):(O=this[Nt],O&&(m=Object.assign(O,m)),this[Nt]=O=m)),this._writeUpdate(this[Nt],R),this}addTo(m,R){if(typeof R=="number"||typeof R=="bigint")this[Gl]===CG?this.set(m,(+this.getProperty(m)||0)+R):(this[Gl]||this.update(),this.set(m,new ch(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[Lr]}invalidate(m){let R=this[ye],D=this[Me];dc(D),yn(this[ye]).addWrite({key:D,store:i,invalidated:!0,entry:this[Lr],nodeName:this[ye]?.nodeName,before:Be.invalidate?.bind(this,R,D),beforeIntermediate:Ne.invalidate?.bind(this,R,D),commit:(N,L)=>{if(L?.version>N)return;let y=null;for(let v in r)y||(y={}),y[v]=this.getProperty(v);T(D,y,this[Lr],N,ql,h,this[ye],0,"invalidate")}})}static evict(m,R,D){let O=this.Source,N;if(!((I||h)&&(!R||(N=i.getEntry(m),!N||!R)||N.version!==D))){if(I){if(i.hasLock(m,N.version))return;let L;for(let y in r)L||(L={}),L[y]=R[y];if(L)return T(m,L,N,D,Fl,null,null,0,null,!0)}return i.ifVersion(m,D,()=>{i_(m,R,null)}),h?T(m,null,N,D,Fl,null,null,0,null,!0):i.remove(m,D)}}lock(){throw new Error("Not yet implemented")}static operation(m,R){return m.table||=s,m.schema||=c,xG.operation(m,R)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,R,D){let O=this[ye],N=yn(O),L=this[Me];dc(L);let y=this[Lr];this[Gl]=R?CG:jie;let v={key:L,store:i,entry:y,nodeName:O?.nodeName,validate:q=>{m||(m=this[Nt]),R||m&&oh(this[Nt]===m?this:m)?O?.source||(N.checkOverloaded(),this.validate(m,!R),M&&(m[M.name]=M.type==="Date"?new Date(q):M.type==="String"?new Date(q).toISOString():q),R&&(t&&m[t]!==L&&(m[t]=L),F&&(y?.value?m[F.name]=y?.value[F.name]:m[F.name]=F.type==="Date"?new Date(q):F.type==="String"?new Date(q).toISOString():q),m=Uo(m))):N.removeWrite(v)},before:R?Be.put?()=>Be.put(O,L,m):null:Be.patch?()=>Be.patch(O,L,m):Be.put?()=>Be.put(O,L,Uo(this)):null,beforeIntermediate:R?Ne.put?()=>Ne.put(O,L,m):null:Ne.patch?()=>Ne.patch(O,L,m):Ne.put?()=>Ne.put(O,L,Uo(this)):null,commit:(q,C,G)=>{if(G){if(O&&C?.version>(O.lastModified||0)&&(O.lastModified=C.version),this[Lr]=C,C?.value?.[Ee])throw new Error("Can not assign a record to a record, check for circular references");R||(this[Ee]=C?.value??null)}this[Nt]=void 0,this[Vl]=q;let x=C?.value,Z=m;if(this[Gl]=0,C?.version>=q)if(h){let ce=C.localTime,De=C.version;for(;Z&&(ce>q||De>=q&&ce>0);){let re=u.get(ce);if(!re)break;let X=Bt(re);if(De=X.version,De>q){if(X.type==="patch"){let Se=X.getValue(i);Z=sh(Z,Se)}else if(X.type==="put"||X.type==="delete")return}else if(De===q)return;ce=X.previousLocalTime}}else{if(R)return;Z=sh(Z,x)}let _e;if(R?_e=Z:(this[Ee]=x,_e=R?Z:Uo(this,Z)),this[Ee]=_e,_e?.[Ee])throw new Error("Can not assign a record to a record, check for circular references");let ne;R||(ne=m),i_(L,x,_e);let Ue=R?"put":"patch";T(L,_e,C,q,0,h,O,O.expiresAt||(E?E+Date.now():0),Ue,!1,ne),O.expiresAt&&a_()}};N.addWrite(v)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this[$n]){for await(let R of this.search(m))(await Ke.getResource(R[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this[Ee]?this._writeDelete(m):!1}_writeDelete(m){let R=yn(this[ye]),D=this[Me];dc(D);let O=this[ye];return R.addWrite({key:D,store:i,resource:this,nodeName:O?.nodeName,before:Be.delete?.bind(this,O,D),beforeIntermediate:Ne.delete?.bind(this,O,D),commit:(N,L,y)=>{let v=L?.value;y&&(O&&L?.version>(O.lastModified||0)&&(O.lastModified=L.version),fh(this,L)),!(L?.version>N)&&(i_(this[Me],v),it.trace("Write delete entry",D,N),h||p?(T(D,null,this[Lr],N,0,h,this[ye],0,"delete"),h||a_()):i.remove(this[Me]))}}),!0}search(m){let R=this[ye],D=yn(R);if(!m)throw new Error("No query provided");let O=m.conditions;O?O.length===void 0&&(O=O[Symbol.iterator]?Array.from(O):[O]):O=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this[Me]&&(O=[{attribute:null,comparator:"prefix",value:this[Me]}].concat(O));let N,L={};function y(X,Se){let He;switch(Se){case"and":case void 0:if(X.length<1)throw new Error('An "and" operator requires at least one condition');He=!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 "+Se)}let Wn=He&&{},js;for(let We of X){if(We.conditions){We.conditions=y(We.conditions,We.operator);continue}let Vt=We[0]??We.attribute,on=Vt==null?B:Fs(S,Vt);if(on){if(He){let Qn=qn(Vt),$t=Wn[Qn];$t?($t.push(We),js=!0):Wn[Qn]=[We]}(on.type||Xg[We.comparator])&&(We[1]===void 0?We.value=q(We.value,on):We[1]=q(We[1],on))}else if(Vt!=null)throw(0,Mr.handleHDBError)(new Error,`${Vt} is not a defined attribute`,404)}if(m.enforceExecutionOrder)return X;if(js)for(let We in Wn){let Vt=Wn[We],on=Vt.length;if(on>1)for(let Qn=0;Qn<on;Qn++){let $t=Vt[Qn];if($t.comparator==="ge"||$t.comparator==="greater_than_equal")for(let Zs=0;Zs<on;Zs++){let Fo=Vt[Zs];(Fo.comparator==="le"||Fo.comparator==="less_than_equal")&&($t.comparator="between",$t.value=[$t.value,Fo.value],X.splice(X.indexOf(Fo),1))}if($t.comparator==="equals"||!$t.comparator){for(let Zs=0;Zs<on;Zs++)if(Zs!==Qn){let Fo=Vt[Zs];X.splice(X.indexOf(Fo),1)}break}}}return X}a(y,"prepareConditions");function v(X,Se){if(m.enforceExecutionOrder)return X;for(let He of X)He.conditions&&(He.conditions=v(He.conditions,He.operator));return X.length>1&&Se!=="or"?(0,vG.sortBy)(X,nE(Ke)):X}a(v,"orderConditions");function q(X,Se){return Array.isArray(X)?X.map(He=>dh(He,Se)):dh(X,Se)}a(q,"coerceTypedValues");let C=m.operator;(O.length>0||C)&&(O=y(O,C));let G=typeof m.sort=="object"&&m.sort,x;if(G&&C!=="or"){let X=G.attribute;if(X==null)throw new Mr.ClientError("Sort requires an attribute");if(N=O.find(Se=>qn(Se.attribute)===qn(X)),!N){let Se=Fs(S,X);if(!Se)throw(0,Mr.handleHDBError)(new Error,`${Array.isArray(X)?X.join("."):X} is not a defined attribute`,404);if(Se.indexed)N={attribute:X,comparator:"sort"},O.push(N);else if(O.length===0&&!m.allowFullScan)throw(0,Mr.handleHDBError)(new Error,`${Array.isArray(X)?X.join("."):X} is not indexed and not combined with any other conditions`,404)}N&&(N.descending=!!G.descending)}O=v(O,C),G&&(N&&O[0]===N?G.next&&(x={dbOrderedAttribute:G.attribute,attribute:G.next.attribute,descending:G.next.descending,next:G.next.next}):(N&&O.splice(O.indexOf(N),1),x=G));let Z=m.select;if(O.length===0&&(O=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:O,operator:C,postOrdering:x,selectApplied:!!Z};let _e=D.useReadTxn(),ne=jg(O,C,Ke,_e,m,R,(X,Se)=>dO(X,Z,R,_e,Se),L),Ue=m.ensureLoaded!==!1;x||(ne=re(ne));let ce=Ke.transformEntryForSelect(Z,R,_e,L,Ue,!0),De=Ke.transformToOrderedSelect(ne,Z,x,_e,R,ce);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"),x&&(De=re(De)),De.onDone=()=>{De.onDone=null,D.doneReadTxn()},De.selectApplied=!0,De.getColumns=()=>{if(Z){let X=[];for(let Se of Z)Se==="*"?X.push(...S.map(He=>He.name)):X.push(Se.name||Se);return X}return S.map(X=>X.name)},De}static transformToOrderedSelect(m,R,D,O,N,L){let y=new Pq;if(D){m=dO(m,R,O,N,null);let v;y.iterate=function(){let C,G=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),x,Z=D.dbOrderedAttribute,_e,ne,Ue=!0;function ce(re){let X=re.next&&ce(re.next),Se=re.descending;return(He,Wn)=>{let js=vh(He,re.attribute,O),We=vh(Wn,re.attribute,O),Vt=Se?(0,xo.compareKeys)(We,js):(0,xo.compareKeys)(js,We);return Vt===0?X?.(He,Wn)||0:Vt}}a(ce,"createComparator");let De=ce(D);return{async next(){let re;if(C)if(re=C.next(),re.done){if(x)return y.onDone&&y.onDone(),re}else return{value:await L.call(this,re.value)};v=[],_e&&v.push(_e);do if(re=await G.next(),re.done){if(x=!0,v.length)break;return y.onDone&&y.onDone(),re}else{let X=re.value;if(X?.then&&(X=await X),Z){let Se=vh(X,Z,O);if(Ue)Ue=!1,ne=Se;else if(Se!==ne){ne=Se,_e=X;break}}v.push(X)}while(!0);return D.isGrouped,v.sort(De),C=v[Symbol.iterator](),re=C.next(),re.done?(y.onDone&&y.onDone(),re):{value:await L.call(this,re.value)}},return(){y.onDone&&y.onDone(),G.return()},throw(){y.onDone&&y.onDone(),G.throw()}}};let q=a(C=>{if(typeof R=="object"&&Array.isArray(C.attribute))for(let G=0;G<R.length;G++){let x=R[G],Z;if(x.name===C.attribute[0]){for(Z=x.sort||(x.sort={});Z.next;)Z=Z.next;Z.attribute=C.attribute.slice(1),Z.descending=C.descending}else x===C.attribute[0]&&(R[G]=Z={name:x,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&q(C.next)},"applySortingOnSelect");q(D)}else y.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),y=y.map(L);return y}static transformEntryForSelect(m,R,D,O,N,L){if(m&&(m===t||m?.length===1&&m[0]===t)){let C=a(G=>(R?.transaction?.stale&&(R.transaction.stale=!1),G?.key??G),"transform");return m===t?C:m.asArray?G=>[C(G)]:G=>({[t]:C(G)})}let y;N&&I&&!m?.every(C=>{let G;return typeof C=="object"?G=C.name:G=C,r[G]||G===t})&&(y=!0);let v,q=a(function(C){let G;if(R?.transaction?.stale&&(R.transaction.stale=!1),C!=null){if(Lh=C,G=C.value||C.deref?.(),!G&&(C.key===void 0||C.deref)){if(C=Ph(C.key??C,R,{transaction:D,lazy:m?.length<4},this?.isSync,x=>x),C?.then)return C.then(q.bind(this));G=C?.value}if(y&&C?.metadataFlags&(ql|Fl)||C?.expiresAt&&C?.expiresAt<Date.now()){if(R.onlyIfCached&&R.noCacheStore)return{[t]:C.key,message:"This entry has expired"};let x=Uh(C.key??C,C,R);if(x?.then)return x.then(q)}}if(G==null)return L?vo.SKIP:G;if(m&&!(m[0]==="*"&&m.length===1)){let x,Z=a((ne,Ue)=>{let ce;typeof ne=="object"?ce=ne.name:ce=ne;let De=Xs?.[ce],re;if(De){let X=O?.[ce];if(X)if(X.hasMappings){let He=De.from?G[De.from]:qn(C.key);re=X.get(He),re||(re=[])}else re=X.fromRecord?.(G);else re=De(G,R,C);let Se=a(He=>{if(He&&typeof He=="object"){let Wn=De.definition?.tableClass||Ke;v||(v={});let js=v[ce]||(v[ce]=Wn.transformEntryForSelect(ce===ne?null:ne.select||(Array.isArray(ne)?ne:null),R,D,X,N));if(Array.isArray(He)){let We=[],Vt=Wn.transformToOrderedSelect(He,ne.select,typeof ne.sort=="object"&&ne.sort,R,D,js)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),on=a($t=>{for(;!$t.done;){if($t?.then)return $t.then(on);We.push($t.value),$t=Vt.next()}Ue(We,ce)},"nextValue"),Qn=on(Vt.next());Qn&&(x||(x=[]),x.push(Qn));return}else if(He=js.call(this,He),He?.then){x||(x=[]),x.push(He.then(We=>Ue(We,ce)));return}}Ue(He,ce)},"handleResolvedValue");re?.then?(x||(x=[]),x.push(re.then(Se))):Se(re);return}else re=G[ce],re&&typeof re=="object"&&ce!==ne&&(re=Ke.transformEntryForSelect(ne.select||ne,R,D,null)({value:re}));Ue(re,ce)},"selectAttribute"),_e;if(typeof m=="string")Z(m,ne=>{_e=ne});else if(Array.isArray(m))if(m.asArray)_e=[],m.forEach((ne,Ue)=>{ne==="*"?m[Ue]=G:Z(ne,ce=>_e[Ue]=ce)});else{_e={};let ne=m.forceNulls;for(let Ue of m)if(Ue==="*")for(let ce in G)_e[ce]=G[ce];else Z(Ue,(ce,De)=>{ce===void 0&&ne&&(ce=null),_e[De]=ce})}else throw new Mr.ClientError("Invalid select"+m);return x?Promise.all(x).then(()=>_e):_e}return G},"transform");return q}async subscribe(m){if(!u)throw new Error("Can not subscribe to a table without an audit log");h||Et({table:s,database:c,schemaDefined:_,attributes:S,audit:!0}),m||(m={});let R=!m.rawEvents,D=[],O=yG(Ke,this[Me]??null,function(L,y,v,q){try{let C=y.getValue?.(i,R);if(!C&&y.type==="patch"&&R){let x=i.getEntry(L);x?.version===y.version?C=x.value:C=y.getValue?.(i,!0,v),y.type="put"}let G={id:L,timestamp:v,value:C,version:y.version,type:y.type,beginTxn:q};D?D.push(G):this.send(G)}catch(C){it.error(C)}},m.startTime||0,m),N=(async()=>{this[$n]&&(O.includeDescendants=!0,m.onlyChildren&&(O.onlyChildren=!0)),m.supportsTransactions&&(O.supportsTransactions=!0);let L=this[Me],y=m.previousCount;y>1e3&&(y=1e3);let v=m.startTime;if(this[$n]){if(v){if(y)throw new Mr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:q,value:C}of u.getRange({start:v,exclusiveStart:!0,snapshot:!1})){let G=Bt(C);if(G.tableId!==n)continue;let x=G.recordId;if(L==null||PG(L,x)){let Z=G.getValue(i,R,q);if(O.send({id:x,timestamp:q,value:Z,version:G.version,type:G.type}),O.queue?.length>LG&&await O.waitForDrain()===!1)return}O.startTime=q}}else if(y){let q=[];for(let{key:C,value:G}of u.getRange({start:"z",end:!1,reverse:!0}))try{let x=Bt(G);if(x.tableId!==n)continue;let Z=x.recordId;if(L==null||PG(L,Z)){let _e=x.getValue(i,R,C);if(q.push({id:Z,timestamp:C,value:_e,version:x.version,type:x.type}),--y<=0)break}}catch(x){it.error("Error getting history entry",C,x)}for(let C=q.length;C>0;)O.send(q[--C]);q[0]&&(O.startTime=q[0].timestamp)}else if(!m.omitCurrent){for(let{key:q,value:C,version:G,localTime:x}of i.getRange({start:L??!1,end:L==null?void 0:[L,xo.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(C&&(O.send({id:q,timestamp:x,value:C,version:G,type:"put"}),O.queue?.length>LG&&await O.waitForDrain()===!1))return}}else{y&&!v&&(v=0);let q=this[Lr]?.localTime;if(q===ym&&(i.cache?.delete(L),this[Lr]=i.getEntry(L),it.trace("re-retrieved record",q,this[Lr]?.localTime),q=this[Lr]?.localTime),it.trace("Subscription from",v,"from",L,q),v<q){let C=[],G=q;do{let x=u.get(G);if(x){m.omitCurrent=!0;let Z=Bt(x),_e=Z.getValue(i,R,G);R&&(Z.type="put"),C.push({id:L,value:_e,timestamp:G,...Z}),G=Z.previousLocalTime}else break;y&&y--}while(G>v&&y!==0);for(let x=C.length;x>0;)O.send(C[--x]);O.startTime=q}!m.omitCurrent&&this.doesExist()&&O.send({id:L,timestamp:q,value:this[Ee],version:this[Vl],type:"put"})}for(let q of D)O.send(q);D=null})();return m.listener&&O.on("data",m.listener),O}doesExist(){return!!(this[Ee]||this[Gl])}publish(m,R){this._writePublish(m,R)}_writePublish(m,R){let D=yn(this[ye]),O=this[Me]||null;dc(O);let N=this[ye];D.addWrite({key:O,store:i,entry:this[Lr],nodeName:N?.nodeName,validate:()=>{N?.source||(D.checkOverloaded(),this.validate(m))},before:Be.publish?.bind(this,N,O,m),beforeIntermediate:Ne.publish?.bind(this,N,O,m),commit:(L,y,v)=>{y===void 0&&p&&!h&&a_(),T(O,y?.value??null,y,y?.version||L,0,!0,N,y?.expiresAt,"message",!1,m)}})}validate(m,R){let D,O=a((N,L,y)=>{if(L.type&&N!=null)if(R&&N.__op__&&(N=N.value),L.properties){typeof N!="object"&&(D||(D=[])).push(`Value ${Yn(N)} in property ${y} must be an object${L.type?" ("+L.type+")":""}`);let v=L.properties;for(let q=0,C=v.length;q<C;q++){let G=v[q],x=O(N[G.name],G,y+"."+G.name);x&&(N[G.name]=x)}if(L.sealed&&N!=null&&typeof N=="object")for(let q in N)v.find(C=>C.name===q)||(D||(D=[])).push(`Property ${q} is not allowed within object in property ${y}`)}else switch(L.type){case"Int":(typeof N!="number"||N>>0!==N)&&(D||(D=[])).push(`Value ${Yn(N)} in property ${y} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof N!="number"||!(Math.floor(N)===N&&Math.abs(N)<=9007199254740992))&&(D||(D=[])).push(`Value ${Yn(N)} in property ${y} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof N!="number"&&(D||(D=[])).push(`Value ${Yn(N)} in property ${y} must be a number`);break;case"ID":typeof N=="string"||N?.length>0&&N.every?.(v=>typeof v=="string")||(D||(D=[])).push(`Value ${Yn(N)} in property ${y} must be a string, or an array of strings`);break;case"String":typeof N!="string"&&(D||(D=[])).push(`Value ${Yn(N)} in property ${y} must be a string`);break;case"Boolean":typeof N!="boolean"&&(D||(D=[])).push(`Value ${Yn(N)} in property ${y} must be a boolean`);break;case"Date":if(!(N instanceof Date)){if(typeof N=="string"||typeof N=="number")return new Date(N);(D||(D=[])).push(`Value ${Yn(N)} in property ${y} must be a Date`)}break;case"BigInt":if(typeof N!="bigint"){if(typeof N=="string"||typeof N=="number")return BigInt(N);(D||(D=[])).push(`Value ${Yn(N)} in property ${y} must be a bigint`)}break;case"Bytes":N instanceof Uint8Array||(D||(D=[])).push(`Value ${Yn(N)} in property ${y} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(N)){if(L.elements)for(let v=0,q=N.length;v<q;v++){let C=N[v],G=O(C,L.elements,y+"[*]");G&&(N[v]=G)}}else(D||(D=[])).push(`Value ${Yn(N)} in property ${y} must be a Buffer or Uint8Array`);break}L.nullable===!1&&N==null&&(D||(D=[])).push(`Property ${y} is required (and not does not allow null values)`)},"validateValue");for(let N=0,L=S.length;N<L;N++){let y=S[N];if(!y.relationship&&(!R||y.name in m)){let v=O(m[y.name],y,y.name);v&&(m[y.name]=v)}}if(d)for(let N in m)S.find(L=>L.name===N)||(D||(D=[])).push(`Property ${N} is not allowed`);if(D)throw new Mr.ClientError(D.join(". "))}getUpdatedTime(){return this[Vl]}wasLoadedFromSource(){return I?!!this[YA]:void 0}static async addAttributes(m){let R=S.slice(0);for(let D of m){if(!D.name)throw new Mr.ClientError("Attribute name is required");if(D.name.match(/[`/]/))throw new Mr.ClientError("Attribute names cannot include backticks or forward slashes");(0,BG.validateAttribute)(D.name),R.push(D)}return Et({table:s,database:c,schemaDefined:_,attributes:R}),Ke.indexingOperation}static async removeAttributes(m){let R=S.filter(D=>!m.includes(D.name));return Et({table:s,database:c,schemaDefined:_,attributes:R}),Ke.indexingOperation}static getRecordCount(m){let R=i.getStats().entryCount,D=1e3/2,O=performance.now(),N=Math.floor(R/2),L=m?.exactCount,y=0,v=0,q;for(let{value:C}of i.getRange({start:!0,lazy:!0}))if(C!=null&&y++,v++,!L&&v<N&&performance.now()-O>D){q=v;break}if(q){let C=y;y=0;for(let{value:re}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:q}))re!=null&&y++;let G=q*2,x=(y+C)/G,Z=Math.pow((y-C+1)/q/2,2)+x*(1-x)/G,_e=Math.max(Math.sqrt(Z)*R,1),ne=Math.round(x*R),Ue=Math.max(ne-1.96*_e,y+C),ce=Math.min(ne+1.96*_e,R),De=Math.pow(10,Math.round(Math.log10(_e)));return De>ne&&(De=De/10),y=Math.round(ne/De)*De,{recordCount:y,estimatedRange:[Math.round(Ue),Math.round(ce)]}}return{recordCount:y}}static updatedAttributes(){Xs=this.propertyResolvers={$id:(m,R,D)=>({value:D.key}),$updatedtime:(m,R,D)=>D.version,$record:(m,R,D)=>D?{value:m}:m};for(let m of this.attributes){m.resolve=null;let R=m.relationship;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)"),_O=!0,R.to)m.elements?.definition?(Xs[m.name]=m.resolve=(D,O,N)=>{let L=D[R.from?R.from:t],y=m.elements.definition.tableClass;return N?Ga({attribute:R.to,value:L},yn(O).getReadTxn(),!1,y,!1).asArray:y.search([{attribute:R.to,value:L}],O).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 D=m.definition||m.elements?.definition;D?(Xs[m.name]=m.resolve=(O,N,L)=>{let y=O[R.from];if(y!==void 0){if(m.elements){let v,q=y.map(C=>{let G=L?D.tableClass.primaryStore.getEntry(C,{transaction:yn(N).getReadTxn()}):D.tableClass.get(C,N);return G?.then&&(v=!0),G});return R.filterMissing?v?Promise.all(q).then(C=>C.filter(UG)):q.filter(UG):v?Promise.all(q):q}return L?D.tableClass.primaryStore.getEntry(y,{transaction:yn(N).getReadTxn()}):D.tableClass.get(y,N)}},m.set=(O,N)=>{if(Array.isArray(N)){let L=N.map(y=>y[Me]||y[D.tableClass.primaryKey]);O[R.from]=L}else{let L=N[Me]||N[D.tableClass.primaryKey];O[R.from]=L}},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`)}uh(this,this)}static async deleteHistory(m=0){let R;for(let{key:D,value:O}of u.getRange({start:0,end:m}))await kl(),Bt(O).tableId===n&&(R=u.remove(D));await R}static async*getHistory(m=0,R=1/0){for(let{key:D,value:O}of u.getRange({start:m,end:R})){await kl();let N=Bt(O);N.tableId===n&&(yield{id:N.recordId,localTime:D,version:N.version,type:N.type,value:N.getValue(i,!0,D),user:N.user})}}static async getHistoryOfRecord(m){let R=[];if(m==null)throw new Error("An id is required");let D=i.getEntry(m);if(!D)return R;let O=D.localTime;if(!O)throw new Error("The entry does not have a local audit time");let N=0;do{await kl();let L=u.get(O);if(L){let y=Bt(L);R.push({id:y.recordId,localTime:O,version:y.version,type:y.type,value:y.getValue(i,!0,O),user:y.user}),O=y.previousLocalTime}else break}while(N<1e3&&O);return R.reverse()}static cleanup(){z?.remove()}}Ke.updatedAttributes();let Bq=Ke.prototype;return Bq[Xie]=!0,E&&Ke.setTTLExpiration(E/1e3),Q&&xq(),Ke;function i_(K,m,R){let D;for(let O in r){let N=r[O],L=N.isIndexing,y=R?.[O],v=m?.[O];if(y===v&&!L)continue;D=!0;let q=N.indexNulls,C=(0,$l.getIndexedValues)(y,q),G=(0,$l.getIndexedValues)(v,q);if(G?.length>0){let x=new Set(G);if(C=C?C.filter(Z=>{if(x.has(Z))x.delete(Z);else return!0}):[],G=Array.from(x),(G.length>0||C.length>0)&&wG){let Z=G.concat(C).map(_e=>({key:_e,value:K}));N.prefetch(Z,MG)}for(let Z=0,_e=G.length;Z<_e;Z++)N.remove(G[Z],K)}else C?.length>0&&wG&&N.prefetch(C.map(x=>({key:x,value:K})),MG);if(C)for(let x=0,Z=C.length;x<Z;x++)N.put(C[x],K)}return D}a(i_,"updateIndices");function dc(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,xo.writeKey)(K,Zie,0)>DG)throw new Error("Primary key size is too large: "+K.length);return!0}a(dc,"checkValidId");function Ph(K,m,R,D,O){let N=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),R.transaction?.isDone)return O(null,K);let L=i.getEntry(K,R);return L&&m&&(L?.version>(m.lastModified||0)&&(m.lastModified=L.version),L?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=L.localTime)),O(L,K)},"whenPrefetched");return D?N():ue>0?(ue--,N()):new Promise((L,y)=>{ue===0?(ue--,i.prefetch([K],()=>{v(),q()})):(j.push(K),oe.push(q),j.length>vq&&(ue--,v()));function v(){if(j.length>0){let C=oe;i.prefetch(j,()=>{ue===-1?v():ue++;for(let G of C)G()}),j=[],oe=[],le>2&&le--}else ue=le,le<Uq&&le++}a(v,"prefetch");function q(){try{L(N())}catch(C){y(C)}}a(q,"load")})}a(Ph,"loadLocalRecord");function o_(K){if(!K?.role)return;let m=K.role.permission;if(m.super_user)return eoe;let R=m[c],D,O=R?.tables;if(O)return O[s];if(c==="data"&&(D=m[s])&&!D.tables)return D}a(o_,"getTablePermissions");function Uh(K,m,R,D){if(I){let O;if(R.noCache?O=!0:(m?(!m.value||m.metadataFlags&(ql|Fl)||m.expiresAt&&m.expiresAt<Date.now())&&(O=!0):O=!0,Qr(!O,"cache-hit",s)),O){let N=fO(K,m,R).then(L=>(L?.value?.[Ee]&&it.error("Can not assign a record with a record property"),R&&(L?.version>(R.lastModified||0)&&(R.lastModified=L.version),R.lastRefreshed=Date.now()),L));if(R?.onlyIfCached||m?.value&&D?.allowStaleWhileRevalidate?.(m,K)){if(N.catch(L=>it.warn(L)),R?.onlyIfCached&&!D.doesExist())throw new Mr.ServerError("Entry is not cached",504);return}else return N}}else if(m?.value&&m.expiresAt&&m.expiresAt<Date.now())return Ke.evict(m.key,m.value,m.version),m.value=null,{then(O){return O(m)}}}a(Uh,"ensureLoadedFromSource");function yn(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 R=m.next;if(!R)return m=m.next=new no,m.lmdbDb=i,m;m=R}while(!0)}else return new Td}a(yn,"txnForContext");function vh(K,m,R){if(!K)return;Lh=K;let D=K.value||K.deref?.()||(Lh=i.getEntry(K.key))?.value;if(typeof m=="object"){let N=Xs,L=D;for(let y=0,v=m.length;y<v;y++){let q=m[y],C=N?.[q];L=C&&L?C(L,R,!0)?.value:L?.[q],N=C?.definition?.tableClass?.propertyResolvers}return L}let O=Xs[m];return O?O(D,R):D[m]}a(vh,"getAttributeValue");function dO(K,m,R,D,O){let N=O?.length,L={transaction:D,lazy:N>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},y;function v(q,C){let G=q?.value;if(!G)return vo.SKIP;for(let x=0;x<N;x++)if(!y?.includes(x)&&!O[x](G,q))return vo.SKIP;return C!==void 0&&(q.key=C),q}if(a(v,"processEntry"),N>0||!K.hasEntries){let q=K.map(C=>{if(y=null,typeof C=="object"&&C?.key!==void 0)return N>0?v(C):C;if(C==null)return vo.SKIP;for(let G=0;G<N;G++){let Z=O[G].idFilter;if(Z){if(!Z(C))return vo.SKIP;y||(y=[]),y.push(G)}}return Ph(C,R,L,!1,v)});return Array.isArray(K)&&(q=q.filter(C=>C!==vo.SKIP)),q.hasEntries=!0,q}return K}a(dO,"transformToEntries");async function fO(K,m,R){let D=m?.metadataFlags,O=m?.version,N,L;if(!i.attemptLock(K,O,()=>{clearTimeout(L);let C=i.getEntry(K);!C||!C.value||C.metadataFlags&(ql|Fl)?N(fO(K,i.getEntry(K),R)):N(C)}))return new Promise(C=>{N=C,L=setTimeout(()=>{i.unlock(K,O)},Jie)});let y=m?.value,v={requestContext:R,replacingRecord:y,replacingVersion:O,noCacheStore:!1,source:null,resourceCache:R?.resourceCache},q=R?.responseHeaders;return new Promise((C,G)=>{let x;WA(rt(v,async Z=>{let _e=performance.now(),ne,Ue,ce;try{for(let Se of Ke.sources)if(Se.get&&(!Se.get.reliesOnPrototype||Se.prototype.get)&&(v.source=Se,ne=await Se.get(K,v),ne))break;ce=D&ql;let re=v.lastModified||ce&&O;Ue=ce||re>O||!y,re||(re=(0,$l.getNextMonotonicTime)());let X=performance.now()-_e;if(nr(X,"cache-resolution",s,null,"success"),q&&Lf(q,"Server-Timing",`cache-resolve;dur=${X.toFixed(2)}`,!0),Z.timestamp=re,E&&!v.expiresAt&&(v.expiresAt=Date.now()+E),ne){if(typeof ne!="object")throw new Error("Only objects can be cached and stored in tables");typeof ne.toJSON=="function"&&(ne=ne.toJSON()),t&&ne[t]!==K&&(ne[t]=K)}x=!0,C({version:re,value:ne})}catch(re){re.message+=` while resolving record ${K} for ${s}`,y&&((re.code==="ECONNRESET"||re.code==="ECONNREFUSED"||re.code==="EAI_AGAIN")&&!R?.mustRevalidate||R?.staleIfError&&(re.statusCode===500||re.statusCode===502||re.statusCode===503||re.statusCode===504))?(C({version:O,value:y}),it.trace(re.message,"(returned stale record)")):G(re);let X=performance.now()-_e;nr(X,"cache-resolution",s,null,"fail"),q&&Lf(q,"Server-Timing",`cache-resolve;dur=${X.toFixed(2)}`,!0),v.transaction.abort();return}if(R?.noCacheStore||v.noCacheStore){v.transaction.abort();return}yn(v).addWrite({key:K,store:i,entry:m,nodeName:"source",commit:(re,X)=>{if(X?.version!==O)return;let Se=i_(K,y,ne);ne?(Ne.put?.(v,K,ne),T(K,ne,X,re,0,h&&Ue||null,v,v.expiresAt,"put",!!ce)):(Ne.delete?.(v,K),h||p?T(K,null,X,re,0,h&&Ue||null,v,0,"delete",!!ce):i.remove(K,O))}})}),()=>{i.unlock(K,O)},Z=>{i.unlock(K,O),x&&it.error("Error committing cache update",Z)})})}a(fO,"getFromSource");function a_(){if(xe!==n_&&(n_=xe,(0,Bo.getWorkerIndex)()===(0,Bo.getWorkerCount)()-1)){if(s_&&clearTimeout(s_),!xe)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())/xe)*xe+K.getTime(),R=a(D=>{it.trace(`Scheduled next cleanup scan at ${new Date(D)}ms`),s_=setTimeout(()=>U=U.then(async()=>{if(R(Math.max(D+xe,Date.now())),i.rootStore.status!=="open"){clearTimeout(s_);return}let O=50,N=new Array(O),L=0;it.trace(`Starting cleanup scan for ${s}`);try{let y=0;for(let{key:v,value:q,version:C,expiresAt:G}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let x;q===null&&!h&&C+zie<Date.now()?x=i.remove(v,C):G&&G+f<Date.now()&&(x=Ke.evict(v,q,C),y++),x&&(await N[L],N[L]=x.catch(Z=>{it.error("Cleanup error",Z)}),++L>=O&&(L=0)),await kl()}it.trace(`Finished cleanup scan for ${s}, evicted ${y} entries`)}catch(y){it.trace(`Error in cleanup scan for ${s}:`,y)}}),Math.min(D-Date.now(),2147483647)).unref()},"startNextTimer");R(m)}}a(a_,"scheduleCleanup");function EO(){z=u?.addDeleteRemovalCallback(n,K=>{let m=i.getEntry(K);m?.value===null&&i.remove(K,m.version)})}a(EO,"addDeleteRemoval");function xq(){(0,Bo.getWorkerIndex)()===0&&setInterval(async()=>{if(!Mh){Mh=!0;try{let K=Q.name,m=r[K];if(!m)throw new Error(`expiresAt attribute ${Q} must be indexed`);for(let R of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let D of m.getValues(R)){let O=i.getEntry(D);O?.value?O.value[K]<Date.now()&&Ke.evict(D,O.value,O.version):i.ifVersion(D,O?.version,()=>m.remove(R,D))}await kl()}}catch(K){it.error("Error in evicting old records",K)}finally{Mh=!1}}},Qie).unref()}a(xq,"runRecordExpirationEviction")}function KA(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 MG(){}function toe(e){xG=e}function dh(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;switch(r){case"Int":case"Long":return e==="null"?null:parseInt(e);case"Float":return e==="null"?null:parseFloat(e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":return isNaN(e)?e==="null"?null:(roe.test(e)||(e+="Z"),new Date(e)):new Date(+e);case void 0:case"Any":return(0,Eh.autoCast)(e);default:return e}}function PG(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 WA(e,t,r){return e?.then?e.then(t,r):t(e)}function fh(e,t){e[Lr]=t,e[Ee]=t?.value??null,e[Vl]=t?.version}function UG(e){return e!=null}function Yn(e){try{return JSON.stringify(e)}catch{return e}}var Kn,vo,$l,vG,BG,Wl,Mr,Yl,Kl,it,xo,Bo,Eh,Wie,xG,Qie,zie,wG,Jie,Vl,Xie,Lr,Gl,CG,jie,YA,ac,ql,Fl,Zie,DG,LG,eoe,OTe,roe,kl,TE=Re(()=>{Kn=H(P()),vo=require("lmdb"),$l=H(Br()),vG=require("lodash"),BG=H(wc());cn();fS();Wl=H(ee());IG();Mr=H(se()),Yl=H(Ns()),Kl=H(Pn());Ae();iE();it=H($());Ad();so();xo=require("ordered-binary"),Bo=H(Qe());ni();Eh=H(J());Bc();Ds();rh();el();Wie=new Uint8Array(9);Wie[8]=192;Qie=6e4,zie=864e5;Wl.initSync();wG=Wl.get(Kn.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),Jie=1e4,Vl=Symbol.for("version"),Xie=Symbol.for("incremental-update"),Lr=Symbol("entry"),Gl=Symbol("is-saving"),CG=1,jie=2,YA=Symbol("loaded-from-source"),ac={isNotification:!0,ensureLoaded:!1},ql=1,Fl=8,Zie=Buffer.allocUnsafeSlow(8192),DG=1978,LG=100,eoe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},OTe=(0,Eh.convertToMS)(Wl.get(Kn.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(hh,"makeTable");a(KA,"attributesAsObject");a(MG,"noop");a(toe,"setServerUtilities");roe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(dh,"coerceType");a(PG,"isDescendantId");kl=a(()=>new Promise(setImmediate),"rest");a(WA,"when");a(fh,"updateResource");a(UG,"exists");a(Yn,"stringify")});var ke={};Fe(ke,{database:()=>ua,databases:()=>ct,dropDatabase:()=>SS,dropTableMeta:()=>aoe,getDatabases:()=>Tr,getDefaultCompression:()=>Nf,getTables:()=>noe,onUpdatedTable:()=>nA,readMetaDb:()=>Ql,resetDatabases:()=>Ku,table:()=>Et,tables:()=>xr});function noe(){return gh||Tr(),xr||{}}function Tr(){if(gh)return ct;gh=!0,lc=new Map;let e=(0,St.getHdbBasePath)()&&(0,ot.join)((0,St.getHdbBasePath)(),vt.DATABASES_DIR_NAME),t=(0,St.get)(vt.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,St.get)(vt.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,nn.existsSync)(e)?e:(0,ot.join)((0,St.getHdbBasePath)(),vt.LEGACY_DATABASES_DIR_NAME)),!!e){if((0,nn.existsSync)(e))for(let r of(0,nn.readdirSync)(e,{withFileTypes:!0})){let n=(0,ot.basename)(r.name,".mdb");r.isFile()&&(0,ot.extname)(r.name).toLowerCase()===".mdb"&&!t[n]?.path&&Ql((0,ot.join)(e,r.name),null,n)}if((0,nn.existsSync)((0,uc.getBaseSchemaPath)())){for(let r of(0,nn.readdirSync)((0,uc.getBaseSchemaPath)(),{withFileTypes:!0}))if(!r.isFile()){let n=(0,ot.join)((0,uc.getBaseSchemaPath)(),r.name),s=(0,ot.join)((0,uc.getTransactionAuditStoreBasePath)(),r.name);for(let i of(0,nn.readdirSync)(n,{withFileTypes:!0}))if(i.isFile()&&(0,ot.extname)(i.name).toLowerCase()===".mdb"){let o=(0,ot.join)(s,i.name);Ql((0,ot.join)(n,i.name),(0,ot.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,ot.extname)(o.name).toLowerCase()===".mdb"&&Ql((0,ot.join)(s,o.name),(0,ot.basename)(o.name,".mdb"),r);let i=n.tables;if(i)for(let o in i){let c=i[o],u=(0,ot.join)(c.path,(0,ot.basename)(o+".mdb"));(0,nn.existsSync)(u)&&Ql(u,o,r,null,!0)}}for(let r in ct){let n=lc.get(r);if(n){let s=ct[r];r.includes("delete")&&bn.trace(`defined tables ${Array.from(n.keys())}`);for(let i in s)n.has(i)||(bn.trace(`delete table class ${i}`),delete s[i])}else if(delete ct[r],r==="data"){for(let s in xr)delete xr[s];delete xr[Rh]}}return lc=null,ct}}function Ku(){gh=!1;for(let[,e]of Bi)e.needsDeletion=!0;Tr();for(let[e,t]of Bi)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),Bi.delete(e));return ct}function Ql(e,t,r=JA,n,s){let i=new QA.default(e,!1);try{let o=Bi.get(e);o?o.needsDeletion=!1:(o=(0,ph.open)(i),Bi.set(e,o));let c=new Ho.default(!1),u=o.dbisDb||(o.dbisDb=o.openDB(mh.INTERNAL_DBIS_NAME,c)),_=o.auditStore;_||(n?(0,nn.existsSync)(n)&&(i.path=n,_=(0,ph.open)(i),_.isLegacy=!0):_=th(o));let l=FG(r),d=l[Rh],E=new Map;for(let{key:f,value:h}of u.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){bn.warn(`Unable to find a primary key attribute on table ${f}, with attributes: ${JSON.stringify(p)}`);continue}}let T=l[f],A={},b=[],I,B,U=typeof S.audit=="boolean"?S.audit:(0,St.get)(vt.CONFIG_PARAMS.LOGGING_AUDITLOG),F=S.trackDeletes,M=S.expiration,Q=S.eviction,z=S.sealed;if(T)A=T.indices,b=T.attributes,T.schemaVersion++;else{I=S.tableId,I?I>=(u.get(cc)||0)&&u.putSync(cc,I+1):(S.tableId=I=u.get(cc),I||(I=1),u.putSync(cc,I+1),u.putSync(S.key,S));let j=new Ho.default(!S.is_hash_attribute,S.is_hash_attribute);if(j.compression=S.compression,j.compression){let oe=(0,St.get)(vt.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||qG;j.compression.threshold=oe}B=D_(o.openDB(S.key,j)),B.rootStore=o,B.tableId=I}for(let j of p){j.attribute=j.name;try{if(!j.is_hash_attribute&&(j.indexed||j.attribute&&!j.name)){if(!A[j.name]){let ue=new Ho.default(!j.is_hash_attribute,j.is_hash_attribute);A[j.name]=o.openDB(j.key,ue),A[j.name].indexNulls=j.indexNulls}let oe=b.find(ue=>ue.name===j.name);oe?b.splice(b.indexOf(oe),1,j):b.push(j)}}catch(oe){bn.error("Error trying to update attribute",j,b,A,oe)}}if(!T){T=kG(l,f,hh({primaryStore:B,auditStore:_,audit:U,sealed:z,expirationMS:M&&M*1e3,evictionMS:Q&&Q*1e3,trackDeletes:F,tableName:f,tableId:I,primaryKey:S.name,databasePath:s?r+"/"+f:r,databaseName:r,indices:A,attributes:p,schemaDefined:S.schemaDefined,dbisDB:u})),T.schemaVersion=1;for(let j of XA)j(T)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function FG(e){let t=ct[e];if(t||(e==="data"?t=ct[e]=xr:e==="system"?Object.defineProperty(ct,"system",{value:t=Object.create(null),configurable:!0}):t=ct[e]=Object.create(null)),lc&&!lc.has(e)){let r=new Set;t[Rh]=r,lc.set(e,r)}return t}function kG(e,t,r){return e[t]=r,r}function ua({database:e,table:t}){e||(e=JA),Tr();let r=FG(e),n=(0,ot.join)((0,St.getHdbBasePath)(),vt.DATABASES_DIR_NAME),s=(0,St.get)(vt.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,St.get)(vt.CONFIG_PARAMS.STORAGE_PATH)||((0,nn.existsSync)(n)?n:(0,ot.join)((0,St.getHdbBasePath)(),vt.LEGACY_DATABASES_DIR_NAME));let o=(0,ot.join)(n,(i?t:e)+".mdb"),c=Bi.get(o);if(!c){let u=new QA.default(o,!1);c=(0,ph.open)(u),Bi.set(o,c)}return c}async function SS(e){if(!ct[e])throw new Error("Schema does not exist");let t=ct[e],r;for(let n in t)r=t[n].primaryStore.rootStore,Bi.delete(r.path),r.status==="open"&&(await r.close(),await zl.remove(r.path));if(r||(r=ua({database:e,table:null}),r.status==="open"&&(await r.close(),await zl.remove(r.path))),e==="data"){for(let n in xr)delete xr[n];delete xr[Rh]}delete ct[e]}function Et({table:e,database:t,expiration:r,eviction:n,scanInterval:s,attributes:i,audit:o,sealed:c,trackDeletes:u,schemaDefined:_,origin:l}){t||(t=JA);let d=ua({database:t,table:e}),E=ct[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 A=new Ho.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,I;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=th(d)),p=i.find(oe=>oe.isPrimaryKey)||{},h=p.name,p.is_hash_attribute=p.isPrimaryKey=!0,p.schemaDefined=_,p.compression=Nf(),u&&(p.trackDeletes=!0),o=p.audit=typeof o=="boolean"?o:(0,St.get)(vt.CONFIG_PARAMS.LOGGING_AUDITLOG),r&&(p.expiration=r),n&&(p.eviction=n),typeof c=="boolean"&&(p.sealed=c),l&&(p.origins?p.origins.includes(l)||p.origins.push(l):p.origins=[l]),bn.trace(`${e} table loading, opening primary store`);let Q=new Ho.default(!1,!0);Q.compression=p.compression;let z=e+"/",j=D_(d.openDB(z,Q));j.rootStore=d,T=d.dbisDb=d.openDB(mh.INTERNAL_DBIS_NAME,A),j.tableId=T.get(cc),j.tableId||(j.tableId=1),T.putSync(cc,j.tableId+1),p.tableId=j.tableId,f=kG(E,e,hh({primaryStore:j,auditStore:M,audit:o,sealed:c,trackDeletes:u,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,F(),T.put(z,p)}S=f.indices,T=T||(d.dbisDb=d.openDB(mh.INTERNAL_DBIS_NAME,A)),f.dbisDB=T;let B=[];for(let{key:M,value:Q}of T.getRange({start:!0})){let[z,j]=M.toString().split("/");if(j===""&&(j=Q.name),j){if(z!==e)continue}else continue;let oe=i.find(le=>le.name===j),ue=!oe?.indexed&&Q.indexed&&!Q.isPrimaryKey;if((!oe||ue)&&(F(),b=!0,oe||T.remove(M),ue)){let le=f.indices[z];le&&B.push(le)}}let U=[];try{for(let M of i||[]){if(M.relationship)continue;let Q=e+"/"+(M.name||"");Object.defineProperty(M,"key",{value:Q,configurable:!0});let z=T.get(Q);if(M.isPrimaryKey){if(z=z||T.get(Q=e+"/")||{},o!==f.audit||c!==c||(+r||void 0)!==(+z.expiration||void 0)||(+n||void 0)!==(+z.eviction||void 0)){let oe=Object.assign({},z);typeof o=="boolean"&&(o&&f.enableAuditing(o),oe.audit=o),r&&(oe.expiration=+r),n&&(oe.eviction=+n),c!==void 0&&(oe.sealed=c),b=!0,F(),T.put(Q,oe)}continue}z?.attribute&&!z.name&&(z.indexed=!0);let j=!z||z.type!==M.type||z.indexed!==M.indexed||z.nullable!==M.nullable||JSON.stringify(z.properties)!==JSON.stringify(M.properties)||JSON.stringify(z.elements)!==JSON.stringify(M.elements);if(M.indexed){let oe=new Ho.default(!0,!1),ue=d.openDB(Q,oe);(j||z.indexingPID&&z.indexingPID!==process.pid||z.restartNumber<Jl.workerData?.restartNumber)&&(b=!0,F(),z=T.get(Q),(j||z.indexingPID&&z.indexingPID!==process.pid||z.restartNumber<Jl.workerData?.restartNumber)&&(b=!0,M.indexNulls===void 0&&(M.indexNulls=!0),f.primaryStore.getStats().entryCount>0&&(M.lastIndexedKey=z?.lastIndexedKey||!1,M.indexingPID=process.pid,ue.isIndexing=!0,Object.defineProperty(M,"dbi",{value:ue}),U.push(M))),T.put(Q,M)),z?.indexNulls&&M.indexNulls===void 0&&(M.indexNulls=!0),ue.indexNulls=M.indexNulls,S[M.name]=ue}else j&&(b=!0,F(),T.put(Q,M))}}finally{I&&I()}if(b&&(f.schemaVersion++,f.updatedAttributes()),bn.trace(`${e} table loading, running index`),U.length>0||B.length>0?f.indexingOperation=ooe(f,U,B):b&&Sh.signalSchemaChange(new Th.SchemaEventMsg(process.pid,"schema-change",f.databaseName,f.tableName)),f.origin=l,b)for(let M of XA)M(f,l!=="cluster");return(r||n||s)&&f.setTTLExpiration({expiration:r,eviction:n,scanInterval:s}),bn.trace(`${e} table loaded`),f;function F(){I||d.transactionSync(()=>({then(M){I=M}}))}a(F,"startTxn")}async function ooe(e,t,r){try{let n=e.schemaVersion;await Sh.signalSchemaChange(new Th.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o=0,c=t.length;if(await new Promise(u=>setImmediate(u)),c>0){let u=0;for(let{key:_,value:l,version:d}of e.primaryStore.getRange({start:t[0].lastIndexedKey,lazy:c<4,versions:!0,snapshot:!1}))if(l){if(u++,s=e.primaryStore.ifVersion(_,d,()=>{for(let E=0;E<c;E++){let f=t[E],h=f.name,p=(0,HG.getIndexedValues)(l[h]);if(p)for(let S=0,T=p.length;S<T;S++)f.dbi.put(p[S],_)}}),s.then(()=>u--,E=>{u--,bn.error(E)}),Jl.workerData&&Jl.workerData.restartNumber!==GG.restartNumber&&(i=!0),++o%100===0||i){for(let E of t)E.lastIndexedKey=_,e.dbisDB.put(E.key,E);if(i)return}u>soe?await s:u>ioe&&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 Sh.signalSchemaChange(new Th.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName))}catch(n){bn.error("Error in indexing",n)}}function aoe({table:e,database:t}){let r=ua({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 nA(e){XA.push(e)}function Nf(){let e=(0,St.get)(vt.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,St.get)(vt.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,St.get)(vt.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||qG,n={startingOffset:32};return t&&(n.dictionary=zl.readFileSync(t)),r&&(n.threshold=r),e&&n}var St,mh,ph,ot,nn,uc,Ho,QA,vt,zl,zA,HG,Sh,Th,Jl,bn,GG,JA,Rh,qG,xr,ct,cc,XA,gh,Bi,lc,soe,ioe,Ae=Re(()=>{St=H(ee()),mh=H(ft()),ph=require("lmdb"),ot=require("path"),nn=require("fs"),uc=H(Xe());TE();Ho=H(xc()),QA=H(Hc()),vt=H(P()),zl=H(require("fs-extra")),zA=require("../index"),HG=H(Br()),Sh=H(Ns()),Th=H(Pn()),Jl=require("worker_threads"),bn=H($()),GG=H(Qe());ni();Bc();JA="data",Rh=Symbol("defined-tables"),qG=((0,St.get)(vt.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,St.initSync)();xr=Object.create(null),ct=Object.create(null);(0,zA._assignPackageExport)("databases",ct);(0,zA._assignPackageExport)("tables",xr);cc=Symbol.for("next-table-id"),XA=[],Bi=new Map;a(noe,"getTables");a(Tr,"getDatabases");a(Ku,"resetDatabases");a(Ql,"readMetaDb");a(FG,"ensureDB");a(kG,"setTable");a(ua,"database");a(SS,"dropDatabase");a(Et,"table");soe=1e3,ioe=10;a(ooe,"runIndexing");a(aoe,"dropTableMeta");a(nA,"onUpdatedTable");a(Nf,"getDefaultCompression")});var J=g((MTe,rq)=>{"use strict";var xi=require("path"),WG=require("fs-extra"),Pr=$(),VG=require("fs-extra"),Ah=require("os"),coe=require("net"),uoe=require("recursive-iterator"),dt=P(),loe=WO(),$G=require("papaparse"),Oh=require("moment"),{inspect:_oe}=require("util"),YG=require("is-number"),LTe=require("lodash"),doe=require("minimist"),foe=require("https"),Eoe=require("http"),{hdb_errors:bh}=se(),hoe=/^((\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)))$/,QG=require("util").promisify(setTimeout),moe=100,poe=5,Soe="",Toe=4,KG={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};rq.exports={isEmpty:sn,isEmptyOrZeroLength:ps,arrayHasEmptyValues:Aoe,arrayHasEmptyOrZeroLengthValues:Ooe,buildFolderPath:boe,isBoolean:zG,errorizeMessage:goe,stripFileExtension:Noe,autoCast:Ioe,autoCastJSON:JG,autoCastJSONDeep:ZA,removeDir:woe,compareVersions:Coe,isCompatibleDataVersion:Doe,escapeRawValue:Loe,unescapeValue:Moe,stringifyProps:Poe,timeoutPromise:voe,isClusterOperation:xoe,getClusterUser:Goe,checkGlobalSchemaTable:Hoe,getHomeDir:jG,getPropsFilePath:Uoe,promisifyPapaParse:qoe,removeBOM:ZG,createEventPromise:Foe,checkProcessRunning:koe,checkSchemaTableExist:Voe,checkSchemaExists:eq,checkTableExists:tq,getStartOfTomorrowInSeconds:$oe,getLimitKey:Yoe,isObject:yoe,isNotEmptyAndHasValue:Roe,autoCasterIsNumberCheck:XG,backtickASTSchemaItems:Koe,isPortTaken:Boe,createForkArgs:Woe,autoCastBoolean:Qoe,async_set_timeout:QG,getTableHashAttribute:zoe,doesSchemaExist:Joe,doesTableExist:Xoe,stringifyObj:joe,ms_to_time:Zoe,changeExtension:eae,getEnvCliRootPath:eO,noBootFile:tae,httpRequest:rae,transformReq:nae,convertToMS:sae,PACKAGE_ROOT:dt.PACKAGE_ROOT};function goe(e){return e instanceof Error?e:new Error(e)}a(goe,"errorizeMessage");function sn(e){return e==null}a(sn,"isEmpty");function Roe(e){return!sn(e)&&(e||e===0||e===""||zG(e))}a(Roe,"isNotEmptyAndHasValue");function ps(e){return sn(e)||e.length===0||e.size===0}a(ps,"isEmptyOrZeroLength");function Aoe(e){if(sn(e))return!0;for(let t=0;t<e.length;t++)if(sn(e[t]))return!0;return!1}a(Aoe,"arrayHasEmptyValues");function Ooe(e){if(ps(e))return!0;for(let t=0;t<e.length;t++)if(ps(e[t]))return!0;return!1}a(Ooe,"arrayHasEmptyOrZeroLengthValues");function boe(...e){try{return e.join(xi.sep)}catch{console.error(e)}}a(boe,"buildFolderPath");function zG(e){return sn(e)?!1:e===!0||e===!1}a(zG,"isBoolean");function yoe(e){return sn(e)?!1:typeof e=="object"}a(yoe,"isObject");function Noe(e){return ps(e)?Soe:e.slice(0,-Toe)}a(Noe,"stripFileExtension");function Ioe(e){return sn(e)||e===""||typeof e!="string"?e:KG[e]!==void 0?KG[e]:XG(e)===!0?Number(e):hoe.test(e)?new Date(e):e}a(Ioe,"autoCast");function JG(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(JG,"autoCastJSON");function ZA(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=ZA(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=ZA(r);n!==r&&(e[t]=n)}return e}else return JG(e)}a(ZA,"autoCastJSONDeep");function XG(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(XG,"autoCasterIsNumberCheck");async function woe(e){if(ps(e))throw new Error(`Directory path: ${e} does not exist`);try{await VG.emptyDir(e),await VG.remove(e)}catch(t){throw Pr.error(`Error removing files in ${e} -- ${t}`),t}}a(woe,"removeDir");function Coe(e,t){if(ps(e)){Pr.info("Invalid current version sent as parameter.");return}if(ps(t)){Pr.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),u=Math.min(o.length,c.length);for(let _=0;_<u;_++)if(r=parseInt(o[_],10)-parseInt(c[_],10),r)return r;return o.length-c.length}a(Coe,"compareVersions");function Doe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(Doe,"isCompatibleDataVersion");function Loe(e){if(sn(e))return e;let t=String(e);return t==="."?dt.UNICODE_PERIOD:t===".."?dt.UNICODE_PERIOD+dt.UNICODE_PERIOD:t.replace(dt.FORWARD_SLASH_REGEX,dt.UNICODE_FORWARD_SLASH)}a(Loe,"escapeRawValue");function Moe(e){if(sn(e))return e;let t=String(e);return t===dt.UNICODE_PERIOD?".":t===dt.UNICODE_PERIOD+dt.UNICODE_PERIOD?"..":String(e).replace(dt.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(Moe,"unescapeValue");function Poe(e,t){if(sn(e))return Pr.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+Ah.EOL}!ps(n)&&n[0]===";"?r+=" "+n+s+Ah.EOL:ps(n)||(r+=n+"="+s+Ah.EOL)}catch{Pr.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(Poe,"stringifyProps");function jG(){let e;try{e=Ah.homedir()}catch{e=process.env.HOME}return e||(e="~/"),e}a(jG,"getHomeDir");function Uoe(){let e=xi.join(jG(),dt.HDB_HOME_DIR_NAME,dt.BOOT_PROPS_FILE_NAME);return WG.existsSync(e)||(e=xi.join(__dirname,"../","hdb_boot_properties.file")),e}a(Uoe,"getPropsFilePath");function voe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:function(){clearTimeout(r)}}}a(voe,"timeoutPromise");async function Boe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=coe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(Boe,"isPortTaken");function xoe(e){try{return dt.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Pr.error(`Error checking operation against cluster ops ${t}`)}return!1}a(xoe,"isClusterOperation");function Hoe(e,t){let r=(Ae(),ie(ke)).getDatabases();if(!r[e])return bh.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return bh.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Hoe,"checkGlobalSchemaTable");function Goe(e,t){if(sn(t)){Pr.warn("No CLUSTERING_USER defined, clustering disabled");return}if(sn(e)||ps(e)){Pr.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){Pr.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){Pr.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(Goe,"getClusterUser");function qoe(){$G.parsePromise=function(e,t,r){return new Promise(function(n,s){$G.parse(e,{header:!0,transformHeader:ZG,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(qoe,"promisifyPapaParse");function ZG(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(ZG,"removeBOM");function Foe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;Pr.info(`Got cluster status event response: ${_oe(s)}`);try{i.cancel()}catch{Pr.error("Error trying to cancel timeout.")}n(s)})})}a(Foe,"createEventPromise");async function koe(e){let t=!0,r=0;do await QG(moe*r++),(await loe.findPs(e)).length>0&&(t=!1);while(t&&r<poe);if(t)throw new Error(`process ${e} was not started`)}a(koe,"checkProcessRunning");function Voe(e,t){let r=eq(e);if(r)return r;let n=tq(e,t);if(n)return n}a(Voe,"checkSchemaTableExist");function eq(e){let{getDatabases:t}=(Ae(),ie(ke));if(!t()[e])return bh.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(eq,"checkSchemaExists");function tq(e,t){let{getDatabases:r}=(Ae(),ie(ke));if(!r()[e][t])return bh.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(tq,"checkTableExists");function $oe(){let e=Oh().utc().add(1,dt.MOMENT_DAYS_TAG).startOf(dt.MOMENT_DAYS_TAG).unix(),t=Oh().utc().unix();return e-t}a($oe,"getStartOfTomorrowInSeconds");function Yoe(){return Oh().utc().format("DD-MM-YYYY")}a(Yoe,"getLimitKey");function Koe(e){try{let t=new uoe(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){Pr.error("Got an error back ticking items."),Pr.error(t)}}a(Koe,"backtickASTSchemaItems");function Woe(e){return[e]}a(Woe,"createForkArgs");function Qoe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(Qoe,"autoCastBoolean");function zoe(e,t){let{getDatabases:r}=(Ae(),ie(ke)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(zoe,"getTableHashAttribute");function Joe(e){let{getDatabases:t}=(Ae(),ie(ke));return t()[e]!==void 0}a(Joe,"doesSchemaExist");function Xoe(e,t){let{getDatabases:r}=(Ae(),ie(ke));return r()[e]?.[t]!==void 0}a(Xoe,"doesTableExist");function joe(e){try{return JSON.stringify(e)}catch{return e}}a(joe,"stringifyObj");function Zoe(e){let t=Oh.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(Zoe,"ms_to_time");function eae(e,t){let r=xi.basename(e,xi.extname(e));return xi.join(xi.dirname(e),r+t)}a(eae,"changeExtension");function eO(){if(process.env[dt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[dt.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=doe(process.argv);if(e[dt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[dt.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(eO,"getEnvCliRootPath");var jA;function tae(){if(jA)return jA;let e=eO();if(eO()&&WG.pathExistsSync(xi.join(e,dt.HDB_CONFIG_FILE)))return jA=!0,!0}a(tae,"noBootFile");function rae(e,t){let r;return e.protocol==="http:"?r=Eoe:r=foe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8");let c={body:"",headers:o.headers};o.on("data",u=>{c.body+=u}),o.on("end",()=>{n(c)})});i.on("error",o=>{s(o)}),i.write(JSON.stringify(t)),i.end()})}a(rae,"httpRequest");function nae(e){if(!e.schema&&!e.database){e.schema=dt.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(nae,"transformReq");function sae(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(sae,"convertToMS")});var ee=g((UTe,aq)=>{"use strict";var tO=require("fs-extra"),Go=require("path"),nq=require("os"),iae=require("properties-reader"),jl=$(),Xl=J(),de=P(),yh=pr(),oae="Error initializing environment manager",Nh="BOOT_PROPS_FILE_PATH",sq=!1,aae={[de.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},zs={};aq.exports={BOOT_PROPS_FILE_PATH:Nh,getHdbBasePath:cae,setHdbBasePath:uae,get:iq,initSync:_ae,setProperty:Pe,initTestEnvironment:fae,setCloneVar:dae};function cae(){return zs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(cae,"getHdbBasePath");function uae(e){zs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(uae,"setHdbBasePath");function iq(e){let t=yh.getConfigValue(e);return t===void 0?zs[e]:t}a(iq,"get");function Pe(e,t){aae[e]&&(zs[e]=t),yh.updateConfigObject(e,t)}a(Pe,"setProperty");function lae(){let e;try{e=Xl.getPropsFilePath(),tO.accessSync(e,tO.constants.F_OK|tO.constants.R_OK),sq=!0;let t=iae(e);return zs[de.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(de.HDB_SETTINGS_NAMES.INSTALL_USER),zs[de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),zs[Nh]=e,!0}catch{return jl.trace(`Environment manager found no properties file at ${e}`),!1}}a(lae,"doesPropFileExist");function _ae(e=!1){try{(sq||lae()||Xl.noBootFile())&&!oq&&(yh.initConfig(e),zs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=yh.getConfigValue(de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){jl.error(oae),jl.error(t),console.error(t),process.exit(1)}}a(_ae,"initSync");var oq=!1;function dae(e){oq=e}a(dae,"setCloneVar");function fae(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,u=Go.join(__dirname,"../../","unitTests");zs[Nh]=Go.join(u,"hdb_boot_properties.file"),Pe(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Go.join(u,"settings.test")),Pe(de.HDB_SETTINGS_NAMES.INSTALL_USER,nq.userInfo()?nq.userInfo().username:void 0),Pe(de.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Pe(de.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Go.join(u,"envDir","log")),Pe(de.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Pe(de.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Pe(de.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Pe(de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Go.join(u,"envDir")),Pe(de.CONFIG_PARAMS.STORAGE_PATH,Go.join(u,"envDir")),s&&(Pe(de.CONFIG_PARAMS.HTTP_SECUREPORT,iq(de.CONFIG_PARAMS.HTTP_PORT)),Pe(de.CONFIG_PARAMS.HTTP_PORT,null)),Pe(de.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Pe(de.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Pe(de.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Xl.isEmpty(i)?!1:i),Pe(de.CONFIG_PARAMS.HTTP_CORS,Xl.isEmpty(i)?!1:i),Pe(de.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Pe(de.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Pe(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Pe(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Pe(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Go.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Pe(de.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Xl.isEmpty(c)?!1:c),o&&(Pe("CORS_ACCESSLIST",o),Pe(de.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Pe(de.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Pe(de.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Pe(de.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Pe(de.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Pe(de.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Pe(de.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${Nh}. Please check your boot props and settings files`;jl.fatal(r),jl.error(t)}}a(fae,"initTestEnvironment")});var dq=g((BTe,_q)=>{"use strict";var lq=require("joi"),{string:Zl,boolean:cq,array:Eae}=lq.types(),uq=P(),hae=je();_q.exports=mae;function mae(e){let t=lq.object({operation:Zl.valid(uq.OPERATIONS_ENUM.ADD_NODE,uq.OPERATIONS_ENUM.UPDATE_NODE).required(),node_name:Zl.required(),subscriptions:Eae.items({schema:Zl.required(),table:Zl.optional(),hash_attribute:Zl.optional(),subscribe:cq.required(),publish:cq.required()}).min(1).required()});return hae.validateBySchema(e,t)}a(mae,"updateRemoteSourceValidator")});var e_=g((HTe,fq)=>{"use strict";var rO=class{static{a(this,"UpdateRemoteResponseObject")}constructor(t,r,n=void 0){this.status=t,this.message=r,this.system_info=n}};fq.exports=rO});var pq=g((qTe,mq)=>{"use strict";var pae=dq(),Js=$(),nO=Ve(),Sae=P(),sO=fn(),qo=ut(),Eq=bu(),Tae=md(),{Node:gae,NodeSubscription:hq}=Ti(),iO=e_(),oO=J(),Rae=ee(),{cloneDeep:Aae}=require("lodash"),{broadcast:Oae}=Qe();mq.exports=bae;async function bae(e){try{let t=pae(e);if(t)return Js.error(`Validation error in updateRemoteSource: ${t.message}`),new iO(nO.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,t.message);let{subscriptions:r,node_name:n,system_info:s}=e,i=[],o=Aae(await sO.getNodeRecord(n)),c=!oO.isEmptyOrZeroLength(o);o=c?o[0]:o,c&&Js.trace(`Existing record found for ${n}, updating records subscriptions`);for(let _=0,l=r.length;_<l;_++){let d=r[_],E=d.schema,f=d.table;if(!oO.doesSchemaExist(E)){Js.trace(`updateRemoteSource creating schema: ${E}`);try{await Eq.createSchema({operation:"create_schema",schema:E})}catch(h){Js.error(h)}}if(f&&!oO.doesTableExist(E,f)){let h=new Tae(E,f,d.hash_attribute);d.attributes&&(h.attributes=d.attributes),Js.trace(`updateRemoteSource creating table: ${f} in schema: ${E} with attributes: ${JSON.stringify(d.attributes)}`);try{await Eq.createTable(h)}catch(p){Js.error(p)}}if(Js.trace(`Creating local stream for ${E}.${f}`),await qo.createLocalTableStream(E,f),c?(await qo.updateConsumerIterator(E,f,n,"stop"),await qo.updateRemoteConsumer(d,n),d.subscribe===!0&&await qo.updateConsumerIterator(E,f,n,"start")):(await qo.updateRemoteConsumer(d,n),d.subscribe===!0?await qo.updateConsumerIterator(E,f,n,"start"):await qo.updateConsumerIterator(E,f,n,"stop")),c){let h=!1;for(let p=0,S=o.subscriptions.length;p<S;p++){let T=o.subscriptions[p];if(T.schema===E&&T.table===f){T.publish=d.publish,T.subscribe=d.subscribe,h=!0;break}}h||o.subscriptions.push(new hq(E,f,d.publish,d.subscribe))}else i.push(new hq(E,f,d.publish,d.subscribe))}c||(o=new gae(n,i,void 0),Js.trace(`No record found for ${n}, creating a new one`));let u=Object.create({});return Object.assign(u,o),u.system_info=s,await sO.upsertNodeRecord(u),Oae({type:"nats_update"}),new iO(nO.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,`Node ${Rae.get(Sae.CONFIG_PARAMS.CLUSTERING_NODENAME)} successfully updated remote source`,await sO.getSystemInfo())}catch(t){Js.error(t);let r=t.message?t.message:t;return new iO(nO.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(bae,"updateRemoteSource")});var Rq=g((kTe,gq)=>{"use strict";var Tq=require("joi"),{string:Sq}=Tq.types(),yae=P(),Nae=je();gq.exports=Iae;function Iae(e){let t=Tq.object({operation:Sq.valid(yae.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:Sq.required()});return Nae.validateBySchema(e,t)}a(Iae,"removeRemoteSourceValidator")});var bq=g(($Te,Oq)=>{"use strict";var wae=Rq(),Ih=$(),wh=Ve(),aO=P(),Cae=fn(),Dae=J(),Aq=ut(),Lae=ee(),Ch=e_(),{NodeSubscription:Mae}=Ti(),Pae=aa(),Uae=ci(),{broadcast:vae}=Qe(),Bae=Lae.get(aO.CONFIG_PARAMS.CLUSTERING_NODENAME);Oq.exports=xae;async function xae(e){try{let t=wae(e);if(t)return Ih.error(`Validation error in removeRemoteSource: ${t.message}`),new Ch(wh.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,t.message);let r=e.node_name,n=await Cae.getNodeRecord(r);if(Dae.isEmptyOrZeroLength(n)){let i=`No record found for node '${r}'`;return Ih.error(i),new Ch(wh.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,i)}n=n[0];for(let i=0,o=n.subscriptions.length;i<o;i++){let c=n.subscriptions[i];Ih.trace(`remove remote source removing subscription: ${c.schema}.${c.table} for node: ${r}`);let u=new Mae(c.schema,c.table,!1,!1);await Aq.updateConsumerIterator(c.schema,c.table,r,"stop"),await Aq.updateRemoteConsumer(u,r)}let s=new Pae(aO.SYSTEM_SCHEMA_NAME,aO.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Uae.deleteRecord(s),vae({type:"nats_update"}),new Ch(wh.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,`Node ${Bae} successfully removed node '${r}'.`)}catch(t){Ih.error(t);let r=t.message?t.message:t;return new Ch(wh.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(xae,"removeRemoteSource")});var wq=g((KTe,Iq)=>{"use strict";var Dh=$(),t_=P(),yq=Ve(),cO=ee(),Hae=J(),Nq=e_(),Gae=fn(),qae=Wd(),Fae=Fr();Iq.exports=kae;async function kae(e){try{Dh.trace("getRemoteSourceConfig called");let t=process.uptime()*1e3,r=Hae.ms_to_time(t),n=new Vae(cO.get(t_.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),cO.get(t_.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)??cO.get(t_.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT),r,await Gae.getSystemInfo());try{let s={name:e.node_name,system_info:e.system_info},i=new qae(t_.SYSTEM_SCHEMA_NAME,t_.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[s]);await Fae.update(i)}catch(s){Dh.error("Get remote config encountered an error updating system info for node:",e.node_name,s)}return Dh.trace("getRemoteSourceConfig response:",n),new Nq(yq.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,n)}catch(t){Dh.error(t);let r=t.message?t.message:t;return new Nq(yq.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(kae,"getRemoteSourceConfig");function Vae(e,t,r,n){this.uptime=r,this.ports={clustering:e,operations_api:t},this.system_info=n}a(Vae,"ConfigResponseObject")});var Mq=g((QTe,Lq)=>{"use strict";var Cq=ee();Cq.initSync();var Dq=ut(),r_=$(),_c=P(),uO=Ve(),$ae=pq(),Yae=bq(),Kae=wq(),Wae=e_(),{encode:Qae,decode:zae}=require("msgpackr"),Jae=ys(),Xae=bs(),jae=require("util"),Zae=P(),{isMainThread:ece,parentPort:tce}=require("worker_threads");Qe();var rce=jae.promisify(Jae.setSchemaDataToGlobal),lO=Cq.get(_c.CONFIG_PARAMS.CLUSTERING_NODENAME);Lq.exports=nce;async function nce(){try{r_.notify("Starting reply service."),await rce();let e=await Dq.getConnection(),t=`${lO}.__request__`,r=e.subscribe(t,{queue:lO});await sce(r)}catch(e){r_.error(e)}}a(nce,"initialize");async function sce(e){for await(let t of e){let r=zae(t.data),n;switch(r.operation){case _c.OPERATIONS_ENUM.ADD_NODE:case _c.OPERATIONS_ENUM.UPDATE_NODE:n=await $ae(r);break;case _c.OPERATIONS_ENUM.REMOVE_NODE:n=await Yae(r);break;case _c.OPERATIONS_ENUM.CLUSTER_STATUS:n=await Kae(r);break;case _c.OPERATIONS_ENUM.DESCRIBE_ALL:n=await ice();break;default:let s=`node '${lO}' reply service received unrecognized request operation`;r_.error(s),n=new Wae(uO.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,s)}r_.trace(n),t.respond(Qae(n))}}a(sce,"handleRequest");async function ice(){try{return{status:uO.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,message:await Xae.describeAll({bypass_auth:!0})}}catch(e){return r_.error(e),{status:uO.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,message:e.message}}}a(ice,"getRemoteDescribeAll");ece||tce.on("message",async e=>{let{type:t}=e;t===Zae.ITC_EVENT_TYPES.SHUTDOWN&&Dq.closeConnection()})});var oce=Mq();(async()=>{try{await oce()}catch(e){console.error("Error launching Nats reply service."),console.error(e)}})();
|
|
33
|
+
`))}},25).unref()}o.close?.(()=>{if(qe.get(_t.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&Ul()==0)try{sH(qe.get(_t.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,GE),o.cantCleanupProperly||Pt.warn("Had to forcefully exit the thread",GE),process.exit(0)},5e3).unref()})}if(fH||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Pt.info("Could not close debugger",i)}}}).ref();let e=[];if(oH&&!kse)for(let t in hs){let r=hs[t];if(isNaN(t)&&Ul()==0){Mse(t)&&sH(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=qe.get(_t.CONFIG_PARAMS.HTTP_THREADRANGE);if(n){let i=typeof n=="string"?n.split("-"):n,o=Ul();if(o<i[0]||o>i[1])continue}let s;try{s=oH(+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,GE)}).on("error",o)}))}Promise.all(e).then(()=>{Pl?.postMessage({type:_t.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(EH,"startServers");cA||EH();function _A(e,t,r){let n=e?.read?e:new Nse({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=hs[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=hs[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(_A,"deliverSocket");var aH=new Map;function Yse(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=aH.get(s),r){case"connection":i=_A(void 0,t),aH.set(s,i),i.write=(c,u,_)=>(Pl.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),_&&_(),!0),i.end=(c,u,_)=>(Pl.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),_&&_(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),Pl.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(Yse,"proxyRequest");function dA(e,t,r=!0){!+t&&t!==qe.get(_t.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&(t=parseInt(qe.get(_t.CONFIG_PARAMS.HTTP_PORT),10));let n=hs[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",cH),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else hs[t]=e;e.on("unhandled",cH)}a(dA,"registerServer");function hH(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=[],qe.get(_t.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:qe.get(_t.CONFIG_PARAMS.HTTP_PORT),secure:qe.get(_t.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),qe.get(_t.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:qe.get(_t.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&qe.get(_t.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:qe.get(_t.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),secure:!1}),t}a(hH,"getPorts");function fA(e,t){for(let{port:r,secure:n}of hH(t))mH(r,n,t?.isOperationsServer),typeof e=="function"?uA[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||r}):(e.isSecure=n,dA(e,r,!1)),FE[r]=lA(uA,r),Vse=lA($se,r)}a(fA,"httpServer");function mH(e,t,r){if(!Ks[e]){let n=r?"operationsApi_network":"http",s={noDelay:!0,keepAliveTimeout:qe.get(n+"_keepAliveTimeout"),headersTimeout:qe.get(n+"_headersTimeout"),requestTimeout:qe.get(n+"_timeout")},i=qe.get(n+"_mtls"),o=qe.get(n+"_mtls_required");if(t){n=r?"operationsApi_":"";let u=qe.get(n+"tls");Object.assign(s,{allowHTTP1:!0,rejectUnauthorized:!!o,requestCert:!!i,ticketKeys:uH(),maxHeaderSize:qe.get(_t.CONFIG_PARAMS.HTTP_MAXHEADERSIZE),SNICallback:EA(u)})}let c=Hse();Ks[e]=(t?Dse:wse)(s,async(u,_)=>{try{let d=performance.now(),E=new _H(u,_);r&&(E.isOperationsServer=!0);let f=await FE[e](E);if(!f){if(E._nodeResponse.statusCode)return;f=pH(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 B of f.headers||[])_.setHeader(B[0],B[1]);return u.baseRequest=E,_.baseResponse=f,Ks[e].emit("unhandled",u,_)}let h=f.status||200,p=performance.now(),S=p-d,T=f.body,A;if(!f.handlesHeaders){let B=f.headers||new lH;T?T.length>=0&&(typeof T=="string"?B.set("Content-Length",Buffer.byteLength(T)):B.set("Content-Length",T.length),A=!0):(B.set("Content-Length","0"),A=!0);let U=`hdb;dur=${S.toFixed(2)}`;f.wasCacheMiss&&(U+=", miss"),xse(B,"Server-Timing",U,!0),_.writeHead(h,B&&(B[Symbol.iterator]?Array.from(B):B)),A&&_.end(T)}let y=E.handlerPath,I=E.method;if(Ml(S,"duration",y,I,f.wasCacheMiss==null?void 0:f.wasCacheMiss?"cache-miss":"cache-hit"),iH(h<400,"success",y,I),iH(1,"response_"+h,y,I),!A)if(T?.pipe){T.pipe(_),T.destroy&&_.on("close",()=>{T.destroy()});let B=0;T.on("data",U=>{B+=U.length}),T.on("end",()=>{Ml(performance.now()-p,"transfer",y,I),Ml(B,"bytes-sent",y,I)})}else T?.then?T.then(B=>{_.end(B)},l):_.end(T)}catch(d){l(d)}function l(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(l,"onError")}),i&&(Ks[e].mtlsConfig=i),t&&(Ks[e].on("secureConnection",u=>{u._parent.startTime&&Ml(performance.now()-u._parent.startTime,"tls-handshake",e),Ml(u.isSessionReused(),"tls-reused",e)}),Ks[e].isSecure=!0,s.SNICallback(null,(u,_)=>{try{Za=_,_&&Ks[e].setSecureContext(_.options)}finally{Za=null}})),dA(Ks[e],e)}return Ks[e]}a(mH,"getHTTPServer");function lA(e,t){let r=pH;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(lA,"makeCallbackChain");function pH(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new lH}}a(pH,"unhandled");function Kse(e,t){fA(e,{requestOnly:!0,...t})}a(Kse,"onRequest");function Wse(e,t){let r;if(t.securePort){let n=Object.assign({},qe.get("tls"));t.mtls?.certificateAuthority&&(n.certificateAuthority=t.mtls.certificateAuthority);let s={noDelay:!0,rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,SNICallback:EA(n)};r=vse(s,e),s.SNICallback(null,(i,o)=>{try{Za=o,o&&r.setSecureContext(o.options)}finally{Za=null}}),hs[t.securePort]=r}return t.port&&(r=Ise({noDelay:!0},e),hs[t.port]=r),r}a(Wse,"onSocket");Object.defineProperty(Cse.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.includes("Upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});function Qse(e,t){let r;for(let{port:n,secure:s}of hH(t)){qE[n]||(qE[n]=new Pse({server:r=mH(n,s)}),qE[n].on("connection",async(c,u)=>{try{let _=new _H(u);_.isWebSocket=!0;let l=FE[n](_),d=u.headers["sec-websocket-protocol"]||"",E=oA[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,_,l))}if(f)return}for(let f=0;f<E.length;f++){let h=E[f];h.protocol||h.listener(c,_,l)}}catch(_){Pt.warn("Error handling WebSocket connection",_)}}),qE[n].on("error",c=>{console.log("Error in setting up WebSocket server",c)}));let i=t?.subProtocol||"",o=oA[n];o||(o=oA[n]=[]),o.push({listener:e,protocol:i}),FE[n]=lA(uA,n)}return r}a(Qse,"onWebSocket");function cH(e,t){t.writeHead(404),t.end(`Not found
|
|
34
|
+
`)}a(cH,"defaultNotFound");function aA(e){return e.startsWith("-----BEGIN")?e:Lse(e)}a(aA,"readPEM");function EA(e){let t=[];for(let i=0;e[i];i++)t.push(e[i]);t.length||t.push(e);let r=new Map,n,s=!1;for(let i of t){let o=aA(i.privateKey),c=aA(i.certificate),u=i.certificateAuthority&&aA(i.certificateAuthority);if(!o||!c)throw new Error("Missing private key or certificate for secure server");let _={ciphers:i.ciphers,ca:u,ticketKeys:uH()},l=Use(_);l.options=_,_.instantiatedContext=l,l.context.setCert(c),l.context.setKey(o,void 0),_.cert=c,_.key=o,l.certStart=c.slice(0,100).toString(),n||(n=l);let d=new Gse(c),E=i.hostname??i.host??i.hostnames??i.hosts??(d.subjectAltName?d.subjectAltName.split(",").map(f=>{let h=f.indexOf(":");return f.slice(h+1)}):[d.subject.match(/CN=(.*)/)?.[1]]);Array.isArray(E)||(E=[E]);for(let f of E)f?(f[0]==="*"&&(s=!0,f=f.slice(1)),r.has(f)||r.set(f,l)):Pt.error("No hostname found for certificate at",i.certificate)}return(i,o)=>{let c=i;for(;;){let u=r.get(c);if(u)return Pt.debug("Found certificate for",i,u.certStart),o(null,u);if(s&&c){let _=c.indexOf(".",1);_<0?c="":c=c.slice(_)}else break}Pt.debug("No certificate found to match",i,"using the first certificate"),o(null,n)}}a(EA,"createSNICallback")});async function OH({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await mA.get(e,{returnNonexistent:!0});i=new TA(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await mA.get(e);o&&o.delete()}i=new $E(e,t)}return n&&(n.id=e,n.user={username:t?.username},vl.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function pA(){return VE++,VE>65500&&(VE=1),VE}function SA(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=yi.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 rt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var gH,Pi,RH,AH,TH,mA,vl,VE,$E,TA,bH=Re(()=>{Ae();el();gH=H(Br()),Pi=H($());so();RH=H(Qe()),AH=H(SH());fr();TH=100,mA=Et({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),vl=Et({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,RH.getWorkerIndex)()===0&&(async()=>{await AH.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of vl.search({})){let t=e.data,r=Object.assign({},e);r.user?.username&&(r.user=await at.getUser(r.user.username));try{await SA(r,t,r)}catch{(0,Pi.warn)("Failed to publish will",t)}vl.delete(e.id)}})();a(OH,"getSession");VE=1;a(pA,"getNextMessageId");$E=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("?"),u,_;if(c>-1?(u=s.slice(c),_=s.slice(0,c)):_=s,!_)throw new Error("No topic provided");if(_.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let l=this.subscriptions.find(T=>T.topic===s),d;l?(d=i>0,l.end(),this.subscriptions.splice(this.subscriptions.indexOf(l),1)):d=i===2;let E={search:u,async:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,Pi.trace)("Resuming subscription from",s,"from",o);let f=yi.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 A=T.split("/"),y;for(let U=0;U<A.length;U++)if(A[U].indexOf("+")>-1)if(A[U]==="+")y=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&y)throw new Error("Filters can not be combined");let I=!0;A[A.length-1]==="#"&&(A.length--,I=!1),y&&(n=a(U=>{let F=U.id;if(!Array.isArray(F)||I&&F.length!==A.length)return!1;for(let M=0;M<A.length;M++)if(A[M]!=="+"&&A[M]!==F[M])return!1;return!0},"filter"));let B=A.indexOf("+");E.url="/"+(B>-1?A.slice(0,B):A).concat("").join("/")}}let h=f.path,p=f.Resource,S=await rt(E,async()=>{let T=this.createContext();T.topic=s,T.retainHandling=i;let A=await p.subscribe(E,T);if(!A)return;if(!A[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let y=(async()=>{for await(let I of A)try{let B;if(I.type&&I.type!=="put"&&I.type!=="delete"&&I.type!=="message"&&I.type!=="patch"||n&&!n(I))continue;r?(I.topic=s,B=this.needsAcknowledge(I)):(I.acknowledge?.(),B=pA());let U=I.id;if(Array.isArray(U)&&(U=wa(U)),U==null&&(U=""),await this.listener(h+"/"+U,I.value,B,t)===!1)break;this.awaitingAcks?.size>TH?await new Promise(M=>setTimeout(M,this.awaitingAcks.size-TH)):await new Promise(setImmediate)}catch(B){(0,Pi.warn)(B)}})();return A});return S.topic=s,S.qos=t.qos,this.subscriptions.push(S),S}resume(){}needsAcknowledge(t){let r=pA();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 SA(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();rt(r,async()=>{try{if(!t){let n=await vl.get(this.sessionId);n?.doesExist()&&await SA(n,n.data,r)}}finally{await vl.delete(this.sessionId)}}).catch(n=>{(0,Pi.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(SA,"publish");TA=class extends $E{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=pA(),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);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,Pi.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,gH.getNextMonotonicTime)()),(0,Pi.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),mA.put(this.sessionRecord)}}});var RA={};Fe(RA,{bypassAuth:()=>zse,start:()=>Jse});function zse(){CH=!0}function Jse({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new wH.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c,u=r?.mtls;return n&&(c=e.ws((_,l,d)=>{if(_.protocol==="mqtt"){o.events.emit("connection",_),Ut.debug("Received WebSocket connection for MQTT from",_._socket.remoteAddress);let{onMessage:E,onClose:f}=NH(_,h=>{_.send(h)},l,Promise.resolve(d).then(()=>l?.user),o);_.on("message",E),_.on("close",f),_.on("error",h=>{Ut.info("WebSocket error",h)})}},Object.assign({subProtocol:"mqtt"},n))),(t||s)&&(c=e.socket(async _=>{let l;if(o.events.emit("connection",_),Ut.debug(`Received ${_.getCertificate?"SSL":"TCP"} connection for MQTT from ${_.remoteAddress}`),u){if(_.authorized)try{let f=u.user;if(f!==null){(f===void 0||f==="Common Name"||f==="CN")&&(f=_.getPeerCertificate().subject.CN);try{l=await e.getUser(f,null,null),(0,ec.get)(jt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&KE.notify({username:l?.username,status:jt.AUTH_AUDIT_STATUS.SUCCESS,type:jt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:_.remoteAddress})}catch(h){throw(0,ec.get)(jt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&KE.error({username:f,status:jt.AUTH_AUDIT_STATUS.FAILURE,type:jt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:_.remoteAddress}),h}}else Ut.debug("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",_.remoteAddress)}catch(f){o.events.emit("error",f,_),Ut.error(f)}else if(u.required)return Ut.info(`Unauthorized connection attempt, no authorized client certificate provided, error: ${_.authorizationError}`),_.end()}!l&&CH&&_.remoteAddress.includes("127.0.0.1")&&(l=await(0,IH.getSuperUser)(),Ut.debug("Auto-authorizing local connection",l?.username));let{onMessage:d,onClose:E}=NH(_,f=>_.write(f),null,l,o);_.on("data",d),_.on("close",E),_.on("error",f=>{Ut.info("Socket error",f)})},{port:t,securePort:s,mtls:u})),c}function NH(e,t,r,n,s){yH||(yH=!0,pu(d=>{YE>0&&d.push({metric:"mqtt-connections",connections:YE,byThread:!0})}));let i;YE++;let o,c={protocolVersion:4},u=(0,WE.parser)({protocolVersion:5});function _(d){u.parse(d)}a(_,"onMessage");function l(){YE--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),Qr(!1,"connection","mqtt","disconnect"),Ut.debug("MQTT connection was closed",e.remoteAddress))}return a(l,"onClose"),u.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;nr(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 at.getUser(d.username,d.password.toString(),r),(0,ec.get)(jt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&KE.notify({username:n?.username,status:jt.AUTH_AUDIT_STATUS.SUCCESS,type:jt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(M){return(0,ec.get)(jt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&KE.error({username:d.username,status:jt.AUTH_AUDIT_STATUS.FAILURE,type:jt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,M),Qr(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),Qr(!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=yo(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?M(d.will.payload):void 0,delete d.will.payload}o=OH({user:n,...d}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(M){return Ut.error(M),s.events.emit("auth-failed",d,e,M),Qr(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:M.code||5,returnCode:M.code||128})}s.events.emit("connected",o,e),Qr(!0,"connection","mqtt","connect"),p({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((M,Q,z,j)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",M);let oe=M.indexOf("/",1),ue=oe>0?M.slice(0,oe):M;p({cmd:"publish",topic:M,payload:T(Q),messageId:z||Math.floor(Math.random()*1e8),qos:j.qos},ue);let le=e._socket??e;return le.writableNeedDrain?new Promise(Be=>le.once("drain",Be)):!le.closed}catch(oe){return Ut.error(oe),o?.disconnect(),s.sessions.delete(o),!1}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let A=[];for(let M of d.subscriptions){let Q;try{let z=await o.addSubscription(M,M.qos>=1);Q=z?z.qos||0:c.protocolVersion<5?128:143}catch(z){s.events.emit("error",z,e,M,o),z.statusCode?z.statusCode===500?Ut.warn(z):Ut.info(z):Ut.error(z),Q=c.protocolVersion<5?128:z.statusCode===403?135:z.statusCode===404?143:128}A.push(Q)}await o.committed,p({cmd:"suback",granted:A,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 y=d.qos===2?"pubrec":"puback",I=e.deserialize||(e.deserialize=yo(r?.headers.get?.("content-type"))),U=(d.payload?.length||0)>0?I(d.payload):void 0,F;try{F=await o.publish(d,U)}catch(M){s.events.emit("error",M,e,d,o),Ut.warn(M),d.qos>0&&p({cmd:y,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&p({cmd:y,messageId:d.messageId,reasonCode:F===!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),Qr(!0,"connection","mqtt","disconnect"),Ut.debug("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(A){s.events.emit("error",A,e,d,o),Ut.error(A),p({cmd:"disconnect"})}function p(A,y){let I=(0,WE.generate)(A,c);t(I),nr(I.length,"bytes-sent",y,S(A),"mqtt")}a(p,"sendPacket");function S(A){return A.qos>0?A.cmd+",qos="+A.qos:A.cmd}a(S,"packetMethodName");function T(A){return Ro(A,r)}a(T,"serialize")}),u.on("error",d=>{Ut.warn("MQTT parsing error, closing connection:",d.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:_,onClose:l}}var WE,IH,ec,jt,gA,wH,KE,Ut,CH,yH,YE,DH=Re(()=>{WE=require("mqtt-packet");bH();IH=H(_n());Da();Ds();fr();ec=H(ee()),jt=H(P()),gA=H($()),wH=require("events"),KE=(0,gA.loggerWithTag)("auth-event"),Ut=(0,gA.loggerWithTag)("mqtt"),CH=(0,ec.get)(jt.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(zse,"bypassAuth");a(Jse,"start");YE=0;a(NH,"onSocket")});var kf={};Fe(kf,{component_errors:()=>rc,loadComponent:()=>QE,loadComponentDirectories:()=>GH,setErrorReporter:()=>eie});function GH(e,t){t&&(OA=t),e&&(bA=e);let r=[];if((0,et.existsSync)(AA)){let s=(0,et.readdirSync)(AA,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,st.join)(AA,o);r.push(QE(c,OA,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(QE(n,OA,n,!1,null,process.env.DEV_MODE)),Promise.all(r).then(()=>{HH=!0})}function eie(e){Bl=e}async function QE(e,t,r,n,s,i){let o=(0,et.realpathSync)(e);if(!MH.has(o)){MH.set(o,!0),s&&(bA=s);try{let c;n&&(rc=new Map);let u=(0,st.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,et.existsSync)(u)?c=n?(0,xH.getConfigObj)():(0,PH.parseDocument)((0,et.readFileSync)(u,"utf8"),{simpleKeys:!0}).toJSON():c=yA;let _=(0,st.join)(e,"node_modules","harperdb");try{Mo.isMainThread&&(n||(0,et.existsSync)(_)&&(0,et.realpathSync)(sc.PACKAGE_ROOT)!==(0,et.realpathSync)(_))&&((0,et.rmSync)(_,{recursive:!0,force:!0}),(0,et.existsSync)((0,st.join)(e,"node_modules"))||(0,et.mkdirSync)((0,st.join)(e,"node_modules")),(0,et.symlinkSync)(sc.PACKAGE_ROOT,_,"dir"))}catch(E){tc.default.error("Error symlinking harperdb module",E)}let l=[],d=n;for(let E in c){let f=c[E];if(rc.set(n?E:(0,st.basename)(e),!1),!f)continue;let h,p=f.package;try{if(p){let I=e,B;for(;!(0,et.existsSync)(B=(0,st.join)(I,"node_modules",E));)if(I=(0,st.dirname)(I),I.length<(0,BH.getHdbBasePath)().length){B=null;break}if(B)h=await QE(B,t,r,!1),d=!0;else throw new Error(`Unable to find package ${E}:${p}`)}else h=Zse[E];if(!h)continue;l.push(h);let S=a(I=>(I.origin=r,Et(I)),"ensureTable"),T=f.network||(f.port||f.securePort)&&f,A=T?.securePort||T?.https&&T.port,y=!T?.https&&T?.port;if(Mo.isMainThread&&(h=await h.startOnMainThread?.({server:at,ensureTable:S,port:y,securePort:A,resources:t,...f})||h,n&&T))for(let I of[y,A])try{if(+I&&!LH.includes(I)){let B=NA.get(sc.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);B&&tc.default.warn("Session affinity is not recommended and may cause memory leaks"),(B||!UE)&&(LH.push(I),Vx(I,B))}}catch(B){console.error("Error listening on socket",I,B,E)}if(t.isWorker&&(h=await h.start?.({server:at,ensureTable:S,port:y,securePort:A,resources:t,...f})||h),bA.set(h,!0),(h.handleFile||h.handleDirectory)&&f.files){if(f.files.includes(".."))throw(0,vH.handleHDBError)("Can not reference parent directories");let I=(0,st.join)(e,f.files).replace(/\\/g,"/"),B=I.indexOf("/*");if(B>-1&&f.files!==yA[E]?.files&&!(0,et.existsSync)(I.slice(0,B)))throw new Error(`The path '${I.slice(0,B)}' does not exist and cannot be used as the base of the resolved 'files' path value '${f.files}'`);let U=(0,st.basename)(e),F=f.path||"/";F=F.startsWith("/")?F:F.startsWith("./")?"/"+U+F.slice(2):F==="."?"/"+U:"/"+U+"/"+F;let M,Q,z;if(f.root){let oe=f.root;oe.startsWith("/")&&(oe=oe.slice(1)),oe.endsWith("/")&&(oe=oe.slice(0,-1)),oe+="/",Q=(0,st.join)(e,oe)}else(z=I.indexOf("/*"))>-1&&(Q=I.slice(0,z+1),M=(0,st.relative)(e,Q));let j=!1;if(Mo.isMainThread&&h.setupDirectory&&(j=await h.setupDirectory?.(F,Q,t)),t.isWorker&&h.handleDirectory&&(j=await h.handleDirectory?.(F,Q,t)),j)continue;for(let oe of await(0,UH.default)(I,{onlyFiles:!1,objectMode:!0})){let{path:ue,dirent:le}=oe;d=!0;let Be=(0,st.relative)(e,ue).replace(/\\/g,"/");if(M)if(Be.startsWith(M))Be=Be.slice(M.length+1);else throw new Error(`The root path '${f.root}' does not reference a valid part of the file path '${Be}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Ne=F+(F.endsWith("/")?"":"/")+Be;try{if(le.isFile()){let xe=await jse(ue);Mo.isMainThread&&await h.setupFile?.(xe,Ne,ue,t),t.isWorker&&await h.handleFile?.(xe,Ne,ue,t)}else Mo.isMainThread&&await h.setupDirectory?.(Ne,ue,t),t.isWorker&&await h.handleDirectory?.(Ne,ue,t)}catch(xe){xe.message=`Could not load ${le.isFile()?"file":"directory"} '${ue}'${f.module?" using '"+f.module+"'":""} for application '${e}' due to: ${xe.message}`,Bl?.(xe),((0,nc.getWorkerIndex)()===0?console:tc.default).error(xe),t.set(f.path||"/",new xl(xe)),rc.set(n?E:(0,st.basename)(e),xe.message)}}}}catch(S){S.message=`Could not load component '${E}' for application '${(0,st.basename)(e)}' due to: ${S.message}`,Bl?.(S),((0,nc.getWorkerIndex)()===0?console:tc.default).error(S),t.set(f.path||"/",new xl(S),null,!0),rc.set(n?E:(0,st.basename)(e),S.message)}}if(Mo.isMainThread&&!HH&&i&&(0,nc.watchDir)(e,async()=>GH()),c.extensionModule)return await b_((0,st.join)(e,c.extensionModule));if(!d&&t.isWorker){let E=`${e} did not load any modules, resources, or files, is this a valid component?`;Bl?.(new Error(E)),((0,nc.getWorkerIndex)()===0?console:tc.default).error(E),rc.set((0,st.basename)(e),E)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,Bl?.(c),t.set("",new xl(c))}}}var et,st,Mo,PH,NA,sc,UH,nc,tc,vH,BH,Xse,xH,jse,AA,bA,HH,OA,rc,Zse,yA,LH,MH,Bl,xl,Vf=Re(()=>{et=require("fs"),st=require("path"),Mo=require("worker_threads"),PH=require("yaml"),NA=H(ee()),sc=H(P());Cb();Pb();Ub();q0();Lx();xx();UH=H(require("fast-glob")),nc=H(Qe()),tc=H($());im();fr();vH=H(se());cn();Ae();$x();BH=H(ee()),Xse=H(zx());Uf();nH();DH();xH=H(pr());vE();({readFile:jse}=et.promises),AA=NA.get(sc.CONFIG_PARAMS.COMPONENTSROOT),bA=new Map,rc=new Map;a(GH,"loadComponentDirectories");Zse={REST:aE,rest:aE,graphqlSchema:sm,jsResource:am,fastifyRoutes:VR,login:um,static:$R,operationsApi:Xse,customFunctions:{},http:{},clustering:sA,authentication:rl,mqtt:RA},yA={rest:!0,graphqlSchema:{files:"*.graphql"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(yA,"static",{value:{files:"web/**"}});LH=[],MH=new Map;a(eie,"setErrorReporter");a(QE,"loadComponent");xl=class extends Yt{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 hA=g((GSe,FH)=>{var{isMainThread:qH}=require("worker_threads"),{getTables:tie}=(Ae(),ie(ke)),{loadComponentDirectories:rie,loadComponent:nie}=(Vf(),ie(kf)),{resetResources:sie}=(el(),ie(zU)),iie=yg(),oie=pr(),{dirname:aie}=require("path"),{getConnection:cie}=ut(),uie=ee(),lie=P(),IA=new Map;async function _ie(e=!1){!qH&&uie.get(lie.CONFIG_PARAMS.CLUSTERING_ENABLED)&&cie();try{qH&&await iie()}catch(n){console.error(n)}let t=sie();tie(),t.isWorker=e,await nie(aie(oie.getConfigFilePath()),t,"hdb",!0,IA),await rie(IA,t);let r=[];for(let[n]of IA)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(_ie,"loadRootComponents");FH.exports.loadRootComponents=_ie});var Qe=g((FSe,vi)=>{"use strict";var{Worker:die,MessageChannel:fie,parentPort:ms,isMainThread:MA,threadId:Eie,workerData:Ws}=require("worker_threads"),{PACKAGE_ROOT:hie}=P(),{join:YH,isAbsolute:mie,extname:pie}=require("path"),{server:KH}=(fr(),ie(Gi)),{watch:Sie,readdir:Tie}=require("fs/promises"),{totalmem:kH}=require("os"),Hl=P(),WH=ee(),Qs=$(),{randomBytes:gie}=require("crypto"),{_assignPackageExport:Rie}=require("../index"),Aie=P(),VH=1024*1024,Ui=[],Rn=[],Oie=50,PA=1e4,bie="restart",QH="request_thread_info",zH="resource_report",JH="thread_info",XH="added-port",yie="ack",wA;Rie("threads",Rn);vi.exports={startWorker:CA,restartWorkers:vA,shutdownWorkers:Die,workers:Ui,setMonitorListener:Hie,onMessageFromWorkers:Lie,onMessageByType:sG,broadcast:Pie,broadcastWithAcknowledgement:vie,setChildListenerByType:Cie,getWorkerIndex:jH,getWorkerCount:ZH,getTicketKeys:tG,setMainIsWorker:Iie,setTerminateTimeout:Nie,restartNumber:Ws?.restartNumber||1};Rn.onMessageByType=sG;Rn.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Rn.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};var UA;function Nie(e){PA=e}a(Nie,"setTerminateTimeout");function jH(){return Ws?Ws.workerIndex:UA?0:void 0}a(jH,"getWorkerIndex");function ZH(){return Ws?Ws.workerCount:UA?1:void 0}a(ZH,"getWorkerCount");function Iie(e){UA=e}a(Iie,"setMainIsWorker");var eG=1,zE;function tG(){return zE||(zE=MA?gie(48):Ws.ticketKeys,zE)}a(tG,"getTicketKeys");Object.defineProperty(KH,"workerIndex",{get(){return jH()}});Object.defineProperty(KH,"workerCount",{get(){return ZH()}});var rG={[QH](e,t){Bie(t)},[zH](e,t){xie(t,e)}};function CA(e,t={}){let r=process.constrainedMemory?.()||kH();r=Math.min(r,kH(),2e4*VH);let n=WH.get(Hl.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/VH/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let u of Rn){let _=new fie;_.existingPort=u,i.push(_),o.push(_.port2)}pie(e)||(e+=".js");let c=new die(mie(e)?e:YH(hie,e),Object.assign({resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(u=>u.existingPort.threadId),workerIndex:t.workerIndex,workerCount:eG=t.threadCount,name:t.name,restartNumber:vi.exports.restartNumber,ticketKeys:tG()},transferList:o},t));for(let{port1:u,existingPort:_}of i)_.postMessage({type:XH,port:u,threadId:c.threadId},[u]);return XE(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>CA(e,t),c.on("error",u=>{Qs.error(`Worker index ${t.workerIndex} error:`,u)}),c.on("exit",u=>{Ui.splice(Ui.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<Oie?(t.unexpectedRestarts=c.unexpectedRestarts+1,CA(e,t)):Qs.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",u=>{rG[u.type]?.(u,c)}),Ui.push(c),qie(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(CA,"startWorker");var wie=[Hl.THREAD_TYPES.HTTP];async function vA(e=null,t=Math.max(eG>3,1),r=!0){if(MA){if(r){let{loadRootComponents:o}=hA();await o()}vi.exports.restartNumber++,t<1&&(t=t*Ui.length);let n=[],s=[];for(let o of Ui.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Qs.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:vi.exports.restartNumber,type:Hl.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=wie.indexOf(o.name)>-1,u=new Promise(_=>{let l=setTimeout(()=>o.terminate(),PA*2).unref();o.on("exit",()=>{clearTimeout(l),n.splice(n.indexOf(u)),!c&&r&&o.startCopy(),_()})});if(n.push(u),c&&r){let _=o.startCopy(),l=new Promise(d=>{let E=a(f=>{f.type===Aie.ITC_EVENT_TYPES.CHILD_STARTED&&(Qs.trace("Worker has started",_.threadId),d(),s.splice(s.indexOf(l)),_.off("message",E))},"startListener");Qs.trace("Waiting for worker to start",_.threadId),_.on("message",E)});s.push(l),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=ju();r&&(e==="http"||!e)&&WH.get(Hl.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else ms.postMessage({type:bie,workerType:e})}a(vA,"restartWorkers");function Cie(e,t){rG[e]=t}a(Cie,"setChildListenerByType");function Die(e){return vA(e,1/0,!1)}a(Die,"shutdownWorkers");var nG=[];function Lie(e){nG.push(e)}a(Lie,"onMessageFromWorkers");var DA=new Map;function sG(e,t){let r=DA.get(e);r||DA.set(e,r=[]),r.push(t)}a(sG,"onMessageByType");var Mie=10;async function Pie(e){let t=0;for(let r of Rn)try{r.postMessage(e),t++>Mie&&(t=0,await new Promise(setImmediate))}catch(n){Qs.error("Unable to send message to worker",n)}}a(Pie,"broadcast");var JE=new Map,Uie=1;function vie(e){return new Promise(t=>{let r=0;for(let n of Rn)try{let s=Uie++,i=a(()=>{JE.delete(s),--r===0&&t(),n!==ms&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,JE.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of JE)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Qs.error("Unable to send message to worker",s)}r===0&&t()})}a(vie,"broadcastWithAcknowledgement");function Bie(e){e.postMessage({type:JH,workers:iG()})}a(Bie,"sendThreadInfo");function iG(){let e=Date.now();return Ui.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(iG,"getChildWorkerInfo");function xie(e,t){e.resources=t,e.resources.updated=Date.now()}a(xie,"recordResourceReport");var LA;function Hie(e){LA=e}a(Hie,"setMonitorListener");var Gie=1e3,$H=!1;function qie(){$H||($H=!0,setInterval(()=>{for(let e of Ui){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}LA&&LA()},Gie).unref())}a(qie,"startMonitoring");var Fie=1e3;if(ms){XE(ms);for(let e=0,t=Ws.addPorts.length;e<t;e++){let r=Ws.addPorts[e];r.threadId=Ws.addThreadIds[e],XE(r)}setInterval(()=>{let e=process.memoryUsage();ms.postMessage({type:zH,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},Fie).unref(),wA=a(()=>new Promise((e,t)=>{ms.on("message",r),ms.postMessage({type:QH});function r(n){n.type===JH&&(ms.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else wA=iG;vi.exports.getThreadInfo=wA;function XE(e,t){Rn.push(e),e.on("message",r=>{if(r.type===XH)r.port.threadId=r.threadId,XE(r.port);else if(r.type===yie){let n=JE.get(r.id);n&&n()}else{for(let s of nG)s(r,e);let n=DA.get(r.type);if(n)for(let s of n)try{s(r,e)}catch(i){Qs.error(i)}}}).on("close",()=>{Rn.splice(Rn.indexOf(e),1)}).on("exit",()=>{Rn.splice(Rn.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(XE,"addPort");if(MA){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await Tie(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(YH(s,o.name));try{for await(let{filename:o}of Sie(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await vA(),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");vi.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else ms.on("message",async e=>{let{type:t}=e;t===Hl.ITC_EVENT_TYPES.SHUTDOWN&&(vi.exports.restartNumber=e.restartNumber,ms.unref(),setTimeout(()=>{Qs.warn("Thread did not voluntarily terminate",Eie),process.exit(0)},PA).unref())})});var HC={};Fe(HC,{AUDIT_STORE_OPTIONS:()=>yf,createAuditEntry:()=>C_,openAuditStore:()=>rh,readAuditEntry:()=>Bt,removeAuditEntry:()=>nh,setAuditRetention:()=>Vie,transactionKeyEncoder:()=>EG});function rh(e){let t=e.auditStore=e.openDB(_G.AUDIT_STORE_NAME,yf);t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,t.deleteCallbacks=r,{remove(){delete r[i]}}};let n=null;function s(i=jE){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let o=0,c;try{for(let{key:u,value:_}of t.getRange({start:0,snapshot:!1,end:Date.now()-BA}))if(c=nh(t,u,_),await new Promise(setImmediate),++o>=kie){i=10;break}await c}finally{o===0&&(i=Math.min(i<<1,BA/10)),s(i)}},i).unref()}return a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,th.getWorkerIndex)()===(0,th.getWorkerCount)()-1&&s(jE),t}function nh(e,t,r){if(($ie(r)&15)===GA){let n=Bt(r),s=n.tableId;e.deleteCallbacks[s]?.(n.recordId)}return e.remove(t)}function Vie(e,t=jE){BA=e,jE=t}function C_(e,t,r,n,s,i,o){let c=hG[i];if(!c)throw new Error(`Invalid audit entry type ${i}`);let u=1;n&&(n>1?ic.setFloat64(0,n):An.set(ym),u=9),E(0),E(t),d(r),ic.setFloat64(u,e),u+=8,s?d(s):An[u++]=0,An[n?8:0]=c;let l=An.subarray(0,u);if(o)return Buffer.concat([l,o]);return l;function d(f){let h=u;u+=1,u=(0,oc.writeKey)(f,An,u);let p=u-h-1;p>127?p>16383?(qA.error("Key or username was too large for audit entry",f),u=h+1,An[h]=0):(An.copyWithin(h+2,h+1,u),ic.setUint16(h,p|32768),u++):An[h]=p}function E(f){f<128?An[u++]=f:f<16384?(ic.setUint16(u,f|32768),u+=2):f<1056964608?(ic.setUint32(u,f|3221225472),u+=4):(An[u]=255,ic.setUint32(u+1,f),u+=5)}}function $ie(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new ZE(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function Bt(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new ZE(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),u=n.readInt(),_=n.position,l=n.position+=u,d=n.readFloat64();u=n.readInt();let E=n.position,f=n.position+=u;return{type:hG[i&7],tableId:c,get recordId(){return lG(e,_,l)},version:d,previousLocalTime:s,get user(){return f>E?lG(e,E,f):void 0},getValue(h,p,S){if(i&xA||i&HA&&!p)return h.decoder.decode(e.subarray(n.position));if(i&HA&&S)return FA(h.getEntry(this.recordId),S,h)}}}catch(n){return qA.error("Reading audit entry error",n,e),{}}}function lG(e,t,r){let n=e.subarray(t,r);return(0,oc.readKey)(n,0,r-t)}var oc,eh,_G,dG,th,fG,qA,An,ic,EG,yf,BA,kie,jE,xA,HA,oG,GA,aG,cG,uG,hG,ZE,ni=Re(()=>{oc=require("ordered-binary"),eh=H(ee()),_G=H(ft()),dG=H(P()),th=H(Qe()),fG=H(J());xc();qA=H($());sh();(0,eh.initSync)();An=Buffer.alloc(1024),ic=new DataView(An.buffer,An.byteOffset,1024),EG={writeKey(e,t,r){return e===Bc?(t.set(Bc,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,oc.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,oc.readKey)(e,t,r)}},yf={encoding:"binary",keyEncoder:EG},BA=(0,fG.convertToMS)((0,eh.get)(dG.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,kie=1e3,jE=1e4;a(rh,"openAuditStore");a(nh,"removeAuditEntry");a(Vie,"setAuditRetention");xA=16,HA=32,oG=1,GA=2,aG=3,cG=4,uG=5,hG={put:oG|xA,[oG]:"put",delete:GA,[GA]:"delete",message:aG|xA,[aG]:"message",invalidate:cG,[cG]:"invalidate",patch:uG|HA,[uG]:"patch"};a(C_,"createAuditEntry");a($ie,"readAction");a(Bt,"readAuditEntry");ZE=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(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}};a(lG,"readKeySafely")});var kA={};Fe(kA,{add:()=>ih,applyReverse:()=>mG,getRecordAtTime:()=>FA,rebuildUpdateBefore:()=>oh});function ih(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 oh(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,ih(r,n,s)}}else r||(r={}),r[n]=e[n];return r}function mG(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Yie[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=pG}}function FA(e,t,r){let n=r.rootStore.auditStore,s=Object.assign({},e.value),i=e.localTime;for(;i>t;){let u=n.get(i),_=Bt(u);switch(_.type){case"put":s=_.getValue(r);break;case"patch":mG(s,_.getValue(r));break;case"delete":s=null}i=_.previousLocalTime}let o={},c=0;for(let u in s)s[u]===pG&&(o[u]=!0,c++);for(;c>0&&i>0;){let u=n.get(i),_=Bt(u),l;switch(_.type){case"put":l=_.getValue(r);break;case"patch":l=_.getValue(r);break}for(let d in l)o[d]&&(s[d]=l[d],o[d]=!1,c--);i=_.previousLocalTime}if(c>0)for(let u in o)s[u]=null;return s}var Yie,pG,sh=Re(()=>{ni();a(ih,"add");ih.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)};Yie={add:ih};a(oh,"rebuildUpdateBefore");a(mG,"applyReverse");pG={};a(FA,"getRecordAtTime")});function en(e){return e[Nt]||(e[Nt]=Object.create(null))}function _h(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,u,_;if(o.resolve)_={get(){return o.resolve(this,this[ye])},set(l){return o.set(this,l)},configurable:!0};else{switch(o.type){case"String":u=a(function(l){if(!(typeof l=="string"||l==null&&o.nullable!==!1))throw new On.ClientError(`${c} must be a string, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"ID":u=a(function(l){if(!(typeof l=="string"||l?.length>0&&l.every?.(d=>typeof d=="string")||l==null&&o.nullable!==!1))throw new On.ClientError(`${c} must be a string, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"Float":case"Number":u=a(function(l){let d=l?.__op__?l.value:l;if(!(typeof d=="number"||l==null&&o.nullable!==!1))throw new On.ClientError(`${c} must be a number, attempt to assign ${d}`);en(this)[c]=l},"set");break;case"Int":u=a(function(l){let d=l?.__op__?l.value:l;if(!(d>>0===d||l==null&&o.nullable!==!1))if(typeof d=="number"&&Math.abs((d>>0)-d)<=1)d=Math.round(d),l?.__op__?l.value=d:l=d;else throw new On.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"Long":u=a(function(l){let d=l?.__op__?l.value:l;if(!(Math.round(d)===l&&Math.abs(d)<=9007199254740992||l==null&&o.nullable!==!1))if(typeof d=="number"&&Math.abs(d)<=9007199254740992)d=Math.round(d),l?.__op__?l.value=d:l=d;else throw new On.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"BigInt":u=a(function(l){let d=l?.__op__?l.value:l;if(!(typeof d=="bigint"||l==null&&o.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=BigInt(d),l?.__op__?l.value=d:l=d;else throw new On.ClientError(`${c} must be a number, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"Boolean":u=a(function(l){if(!(typeof l=="boolean"||l==null&&o.nullable!==!1))throw new On.ClientError(`${c} must be a boolean, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"Date":u=a(function(l){if(!(l instanceof Date||l==null&&o.nullable!==!1))if(typeof l=="string"||typeof l=="number")l=new Date(l);else throw new On.ClientError(`${c} must be a Date, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"Bytes":u=a(function(l){if(!(l instanceof Uint8Array||l==null&&o.nullable!==!1))throw new On.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${l}`);en(this)[c]=l},"set");break;case"Any":case void 0:u=a(function(l){en(this)[c]=l},"set");break;default:u=a(function(l){if(!(typeof l=="object"||l==null&&o.nullable!==!1))throw new On.ClientError(`${c} must be an object, attempt to assign ${l}`);en(this)[c]=l},"set")}_={get(){let l=this[Nt];if(l&&c in l){let E=l[c];if(E?.__op__){let f=this[Ee]?.[c];return E.update(f)}return E}let d=this[Ee]?.[c];if(d&&typeof d=="object"){let E=TG(d,o);if(E)return l||(l=this[Nt]=Object.create(null)),l[c]=E}return d},set:u,enumerable:!0,configurable:!0}}_.get.isAttribute=!0,n[c]=_,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,_)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let u=this[Nt];return u?.[o]!==void 0?u[o]:this[Ee]?.[o]}),i("set",function(o,c){let u=n[o];if(u)return u.set.call(this,c);if(t.sealed)throw new On.ClientError("Can not add a property to a sealed table schema");en(this)[o]=c}),i("deleteProperty",function(o){en(this)[o]=void 0}),i("toJSON",function(){let o=this[Nt],c;for(let _ in o){c||(c=Object.assign({},this[Ee]));let l=o[_];if(l?.__op__){let d=c[_];l=l.update(d)}c[_]=l}return Object.keys(this).length>0&&(c||(c=Object.assign({},this[Ee])),Object.assign(c,this)),c||this[Ee]}),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 TG(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?.[Ee])throw new Error("Can not track an already tracked object, check for circular references");this[Ee]=s}},_h(r,t)),new r(e)):new ah(e);case Array:let n=new uh(e.length);n[Ee]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=TG(o,t?.elements)),n[s]=o}return n;default:return e}}function Rd(e){let t=e[Nt],r;for(let s in t){r||(r=Object.assign({},e[Ee]));let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=Rd(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=Object.assign({},e[Ee])),Object.assign(r,e)),r||e[Ee]}function Uo(e,t=e[Nt]){let r;if(SG.call(e,Ee)&&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=Uo(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[Ee]));let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=kA[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Uo(s);r[n]=s}return r?Object.freeze(r):SG.call(e,Ee)?e[Ee]:e}function ch(e){let t=e[Ee];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[Po]||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?.[Ee]===s){if(ch(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[Ee]===i){if(ch(s))return!0}else return!0}else return!0}}return!1}var On,Nt,ah,SG,Po,uh,lh,Ad=Re(()=>{cn();On=H(se());sh();Nt=Symbol("own-data");a(en,"getChanges");a(_h,"assignTrackedAccessors");a(TG,"trackObject");ah=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[Ee])throw new Error("Can not track an already tracked object, check for circular references");this[Ee]=t}};_h(ah,{});a(Rd,"collapseData");SG=Object.prototype.hasOwnProperty;a(Uo,"deepFreeze");a(ch,"hasChanges");Po=Symbol.for("has-array-changes"),uh=class extends Array{static{a(this,"TrackedArray")}[Po];constructor(t){super(t)}splice(...t){return this[Po]=!0,super.splice(...t)}push(...t){return this[Po]=!0,super.push(...t)}pop(){return this[Po]=!0,super.pop()}unshift(...t){return this[Po]=!0,super.unshift(...t)}shift(){return this[Po]=!0,super.shift()}};uh.prototype.constructor=Array;lh=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var Qp={};Fe(Qp,{CONTEXT:()=>ye,ID_PROPERTY:()=>Me,IS_COLLECTION:()=>$n,MultiPartId:()=>qa,RECORD_PROPERTY:()=>Ee,Resource:()=>Yt,snake_case:()=>Wie,transformForSelect:()=>fh});function Wie(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function gG(e,t){if(Gl=!1,e==="")return null;if(e=e.slice(1),e.indexOf("/")===-1)return e===""?(Gl=!0,null):(e.startsWith("$")&&(e=parseInt(e,36)),t.coerceId(decodeURIComponent(e)));let r=e.split("/"),n=new qa;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Gl=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}function tn(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,u,_,l;if(r?(o?(l=i,o=o[ye]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(l=s,c=l[this.primaryKey]??null,o=i[ye]||i):l=i:(l=s,c=l[Me]??l[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(u=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]),u.slice&&(u=u.slice(c.length,u.length),u.length===0&&(u=null,_=!1)))}else{if(typeof(c=s.url)=="string"){let f=c.indexOf("?");if(f>-1){let p=this.parseQuery(c.slice(f+1));u?u=Object.assign(p,u):u=p,c=c.slice(0,f)}let h=this.parsePath(c,o,u);h?.id!==void 0?(h.query&&(u?u=Object.assign(h.query,u):u=h.query),_=h.isCollection,c=h.id):c=h}c===void 0&&(c=s.id??null,c==null&&(_=!0))}else c=s??null,c==null&&(_=!0);o||(o={});let d;if(u?.ensureLoaded!=null||u?.async||_?(d=Object.assign({},t),u?.ensureLoaded!=null&&(d.ensureLoaded=u.ensureLoaded),u?.async&&(d.async=u.async),_&&(d.isCollection=!0)):d=t,o.transaction){let f=this.getResource(c,o,d);return f.then?f.then(E):E(f)}else return rt(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,u,o):t.type==="update"?f.doesExist?.()===!1?f.allowCreate(o.user,l,o):f.allowUpdate(o.user,l,o):t.type==="create"?f.allowCreate(o.user,l,o):f.allowDelete(o.user,u,o);if(h?.then)return h.then(p=>{if(!p)throw new dh(o.user);return typeof l?.then=="function"?l.then(S=>e(f,u,o,S)):e(f,u,o,l)});if(!h)throw new dh(o.user)}return typeof l?.then=="function"?l.then(h=>e(f,u,o,h)):e(f,u,o,l)}a(E,"authorizeActionOnResource")}}function rn(e,t){let r=new OG.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 VA(e,t,r){let n=e[Ee];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 fh(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):VA(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(u){if(u.then)return u.then(c);if(Array.isArray(u))return u.map(c);let _=[],l=i(VA(u,r,n));for(let d of e)_.push(l(d));return _},"transform");let o=e.forceNulls;return a(function c(u){if(u.then)return u.then(c);if(Array.isArray(u))return u.map(E=>E&&typeof E=="object"?c(E):E);let _={},l=i(VA(u,r,n)),d;for(let E of e){let f=l(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 u=s[c.name];if(!u){let l=r[c.name]?.definition?.tableClass;u=s[c.name]=fh(c.select||c,l)}let _=o(c.name);return u(_)}else return o(c);else return c}}a(i,"handleProperty")}var RG,AG,OG,ye,Me,$n,Ee,Kie,Yt,dh,Gl,qa,cn=Re(()=>{RG=require("crypto");Dc();AG=require("../index"),OG=H(se());Ad();so();iE();ye=Symbol.for("context"),Me=Symbol.for("primary-key"),$n=Symbol("is-collection"),Ee=Symbol("stored-record"),Kie={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Yt=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=tn(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let u;if((u=r?.select)&&c!=null&&!c.selectApplied){let _=fh(u,t.constructor);return typeof c?.map=="function"?c.map(_):_(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=tn(function(t,r,n,s){if(Array.isArray(s)&&t[$n]){let i=[],o=n.authorize;for(let c of s){let u=t.constructor,_=u.getResource(c[u.primaryKey],n,{async:!0});_.then?i.push(_.then(l=>l.put(c,n))):i.push(_.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):rn(t,"put")},{hasContent:!0,type:"update"});static patch=tn(function(t,r,n,s){return t.patch?t.patch(s,r):rn(t,"patch")},{hasContent:!0,type:"update"});static delete=tn(function(t,r,n,s){return t.delete?t.delete(r):rn(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={}),rt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):rn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>s):s})}static invalidate=tn(function(t,r,n,s){return t.invalidate?t.invalidate(r):rn(t,"delete")},{hasContent:!1,type:"update"});static post=tn(function(t,r,n,s){return t[Me]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=tn(function(t,r,n,s){return t.connect?t.connect(s,r):rn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=tn(function(t,r,n,s){return t.subscribe?t.subscribe(r):rn(t,"subscribe")},{type:"read"});static publish=tn(function(t,r,n,s){return t[Me]!=null&&t.update?.(),t.publish?t.publish(s,r):rn(t,"publish")},{hasContent:!0,type:"create"});static search=tn(function(t,r,n,s){let i=t.search?t.search(r):rn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=fh(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=tn(function(t,r,n,s){return t.search?t.search(s,r):rn(t,"search")},{hasContent:!0,type:"read"});static copy=tn(function(t,r,n,s){return t.copy?t.copy(s,r):rn(t,"copy")},{type:"create"});static move=tn(function(t,r,n,s){return t.move?t.move(s,r):rn(t,"move")},{type:"delete"});post(t){if(this[$n])return this.constructor.create(this[Me],t,this[ye]);rn(this,"post")}static isCollection(t){return t?.[$n]}static coerceId(t){return t}static parseQuery(t){return sE(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&&Kie[o];if(c)r.requestedContentType=c;else if(n)n.property=o;else return{query:{property:o},id:gG(t,this),isCollection:Gl}}let i=gG(t,this);return Gl?{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 u;if(i.resourceCache?u=i.resourceCache:u=i.resourceCache=[],u.asMap){let _=u.asMap.get(t);if(s=_?.find(l=>l.constructor===c),s)return s;_||u.asMap.set(t,_=[]),_.push(s=new c(t,i))}else{if(s=u.find(_=>_[Me]===t&&_.constructor===c),s)return s;if(u.push(s=new c(t,i)),u.length>10){let _=new Map;for(let l of u){let d=l[Me],E=_.get(d);E?E.push(l):_.set(d,[l])}i.resourceCache.length=0,i.resourceCache.asMap=_}}}else s=new c(t,i);return o&&(s[$n]=!0),s}subscribe(t){return new In}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new In}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]}};Yt.prototype[ye]=null;(0,AG._assignPackageExport)("Resource",Yt);a(Wie,"snake_case");dh=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(gG,"pathToId");qa=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(tn,"transactional");a(rn,"missingMethod");a(VA,"selectFromObject");a(fh,"transformForSelect")});function NG(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=yG,Qie(e.primaryStore,e.auditStore)):(c=bG,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{IG(bG[i])})));let u=c[i]||(c[i]=[]);u.auditStore=e.auditStore,u.lastTxnTime==null&&(u.lastTxnTime=Date.now());let _=u[o];_||(_=u[o]=new Map,_.envs=u,_.tableId=o,_.store=e.primaryStore),t=wa(t);let l=new YA(r);l.startTime=n;let d=_.get(t);return d?d.push(l):(_.set(t,d=[l]),d.tables=_,d.key=t),l.subscriptions=d,l}function IG(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,u,_=wa(i.recordId),l=0;do{let d=o.get(_);if(d){for(let f of d)if(!(l>0&&!(f.includeDescendants&&!(f.onlyChildren&&l>1)))){if(f.startTime>=n){(0,$A.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,$A.info)(h)}}}if(_==null)break;let E=_.lastIndexOf?.("/",_.length-2);E>-1?_=_.slice(0,E):_=null,l++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function Qie(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 u=yG[s];if(!u)return;let _=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),u.txnTime=r.threadLocalWrites[0]||Date.now(),IG(u),r.threadLocalWrites[0]=u.lastTxnTime,r.unlock("thread-local-writes")},"acquiredLock");r.attemptLock("thread-local-writes",_)&&_()})}}var $A,bG,yG,YA,wG=Re(()=>{$A=H($());Dc();el();ni();bG=Object.create(null),yG=Object.create(null);a(NG,"addSubscription");YA=class extends In{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(IG,"notifyFromTransactionData");a(Qie,"listenToCommits")});var NR={};Fe(NR,{coerceType:()=>Eh,makeTable:()=>ph,setServerUtilities:()=>noe,updateResource:()=>hh});function ph(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:u,schemaDefined:_,dbisDB:l,sealed:d}=e,{expirationMS:E,evictionMS:f,audit:h,trackDeletes:p}=e,{attributes:S}=e;S||(S=[]);let T=wm(i,n,u),A=0,y,I,B={},U=Promise.resolve(),F,M,Q;for(let K of S)(K.assignCreatedTime||K.name==="__createdtime__")&&(F=K),(K.assignUpdatedTime||K.name==="__updatedtime__")&&(M=K),K.expiresAt&&(Q=K),K.isPrimaryKey&&(B=K);let z,j=[],oe=[],ue=1,le=2,Be={},Ne={},xe=864e5,n_,s_,Xs,dO=!1,Ph,Uh,Uq=i.getRange({start:!1,end:!1}).constructor,vq=10,Bq=6;h&&hO();class Ke extends Yt{static name=s;static primaryStore=i;static auditStore=u;static primaryKey=t;static tableName=s;static indices=r;static audit=h;static databasePath=o;static databaseName=c;static attributes=S;static expirationTimer;static createdTimeProperty=F;static updatedTimeProperty=M;static propertyResolvers;static sources=[];static get expirationMS(){return E}static dbisDB=l;static schemaDefined=_;static sourcedFrom(m,O){O&&(this.sourceOptions=O,(O.expiration||O.eviction||O.scanInterval)&&this.setTTLExpiration(O)),O?.intermediateSource?(m.intermediateSource=!0,this.sources.unshift(m)):this.sources.push(m),I=m.get&&(!m.get.reliesOnPrototype||m.prototype.get);let D=a(L=>{let N=this.sources.slice(0,-1);if(N=N.filter(v=>v[L]&&(!v[L].reliesOnPrototype||v.prototype[L])),N.length>0)if(N.length===1){let v=N[0];return(q,C,G)=>{if(q?.source!==v)return v[L](C,G,q)}}else return(v,q,C)=>{let G=[];for(let x of N){if(v?.source===x)break;G.push(x[L](q,C,v))}return Promise.all(G)}},"getApplyToIntermediateSource"),R=this.sources[this.sources.length-1],b=a(L=>{if(R[L]&&(!R[L].reliesOnPrototype||R.prototype[L]))return(N,v,q)=>{if(!N?.source)return R[L](v,q,N)}},"getApplyToCanonicalSource");return Be={put:b("put"),patch:b("patch"),delete:b("delete"),publish:b("publish")},Ne={put:D("put"),patch:D("patch"),delete:D("delete"),publish:D("publish"),invalidate:D("invalidate")},(async()=>{let L=!1,N=a(async(v,q)=>{let C=v.value,G=v.table?ct[c][v.table]:Ke;if(c===Kn.SYSTEM_SCHEMA_NAME&&(v.table===Kn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||v.table===Kn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(L=!0),v.id===void 0&&(v.id=C[G.primaryKey],v.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(v));v.source=m;let x=await G.getResource(v.id,q,ac);switch(v.type){case"put":return x._writeUpdate(C,!0,ac);case"patch":return x._writeUpdate(C,!1,ac);case"delete":return x._writeDelete(ac);case"publish":return x._writePublish(C,ac);case"invalidate":return x.invalidate(ac);default:it.error("Unknown operation",v.type,v.id)}},"writeUpdate");try{let v=m.subscribe;v&&p==null&&(p=!0);let q=m.subscribeOnThisThread?m.subscribeOnThisThread((0,Bo.getWorkerIndex)()):(0,Bo.getWorkerIndex)()===0,C=v&&q&&await m.subscribe?.({crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0});if(C){let G;for await(let x of C)try{if(!(x.type==="transaction"?x.writes[0]:x)){it.error("Bad subscription event",x);continue}if(x.source=m,G)if(x.beginTxn)G.resolve();else{N(x,G);continue}if(x.type==="end_txn")continue;let _e=rt(x,()=>{if(x.type==="transaction"){let ne=[];for(let Ue of x.writes)try{ne.push(N(Ue,x))}catch(ce){throw ce.message+=" writing "+JSON.stringify(Ue)+" of event "+JSON.stringify(x),ce}return Promise.all(ne)}else if(x.type==="define_schema"){let ne=this.attributes.slice(0),Ue;for(let ce of x.attributes)ne.find(De=>De.name===ce.name)||(ne.push(ce),Ue=!0);Ue&&(Et({table:s,database:c,attributes:ne,origin:"cluster"}),Yl.signalSchemaChange(new Kl.SchemaEventMsg(process.pid,Kn.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return x.beginTxn?(G=x,N(x,x),new Promise(ne=>{G.resolve=ne})):N(x,x)});L&&(await _e,Yl.signalUserChange(new Kl.UserEventMsg(process.pid))),x.onCommit&&(_e?.then?_e.then(x.onCommit):x.onCommit())}catch(Z){it.error("error in subscription handler",Z)}}}catch(v){it.error(v)}})(),this}static get isCaching(){return I}static getResource(m,O,D){let R=super.getResource(m,O,D);if(m!=null){fc(m);try{if(R.hasOwnProperty(Ee))return R;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let b=!D?.async||i.cache?.get(m),L=yn(O),N=L.getReadTxn();if(N?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return vh(m,O,{transaction:N},b,v=>{if(v?hh(R,v):R[Ee]=null,O.onlyIfCached&&O.noCacheStore){if(!R.doesExist())throw new Mr.ServerError("Entry is not cached",504)}else if(D?.ensureLoaded){let q=Bh(m,v,O,R);if(q)return L?.disregardReadTxn(),R[KA]=!0,QA(q,C=>(hh(R,C),R))}return R})}catch(b){throw b.message.includes("Unable to serialize object")&&(b.message+=": "+JSON.stringify(m)),b}}return R}ensureLoaded(){let m=Bh(this[Me],this[Lr],this[ye]);if(m)return this[KA]=!0,QA(m,O=>{this[Lr]=O,this[Ee]=O.value,this[Vl]=O.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,xe=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(E<0)throw new Error("Expiration can not be negative");xe=xe||(E+f)/4,a_()}static enableAuditing(m=!0){h=m,m&&hO(),Ke.audit=m}static coerceId(m){return m===""?null:Eh(m,B)}static async dropTable(){if(delete ct[c][s],c===o){for(let m of S)l.remove(Ke.tableName+"/"+m.name),r[m.name]?.drop();l.remove(Ke.tableName+"/"),i.drop(),await l.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));Yl.signalSchemaChange(new Kl.SchemaEventMsg(process.pid,Kn.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this[$n])return this.search(m);if(this[Me]===null){if(m?.conditions)return this.search(m);let O=Ke.getRecordCount();return{recordCount:O.recordCount,estimatedRecordRange:O.estimatedRange,records:"./",name:s,database:c,attributes:S}}if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this[ye]?.returnNonexistent)return this}allowRead(m,O){let D=o_(m);if(D?.read){if(D.isSuperUser)return!0;let R=D.attribute_permissions,b=O?.select;if(R?.length>0||dO&&b){if(O||(O={}),b){let L=R?.length>0&&WA(R,"read");O.select=b.map(N=>{let v=N.name||N;if(!L||L[v]){let q=Xs[v]?.definition?.tableClass;if(q){if(N.name||(N={name:N}),!q.prototype.allowRead.call(null,m,N))return!1;if(!N.select)return N.name}return N}}).filter(Boolean)}else O.select=R.filter(L=>L.read&&!Xs[L.attribute_name]).map(L=>L.attribute_name);return O}else return!0}}allowUpdate(m,O){let D=o_(m);if(D?.update){let R=D.attribute_permissions;if(R?.length>0){let b=WA(R,"update");for(let L in O)if(!b[L])return!1;for(let L of R){let N=L.attribute_name;!L.update&&!(N in O)&&(O[N]=this.getProperty(N))}}return!0}}allowCreate(m,O){if(this[$n]){let D=o_(m);if(D?.insert){let R=D.attribute_permissions;if(R?.length>0){let b=WA(R,"insert");for(let L in O)if(!b[L])return!1}else return!0}}else return this.allowUpdate(m,{})}allowDelete(m){return o_(m)?.delete}update(m,O){if(!yn(this[ye]))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let R;return typeof m=="object"&&m&&(O?(Object.isFrozen(m)&&(m=Object.assign({},m)),this[Ee]={},this[Nt]=m):(R=this[Nt],R&&(m=Object.assign(R,m)),this[Nt]=R=m)),this._writeUpdate(this[Nt],O),this}addTo(m,O){if(typeof O=="number"||typeof O=="bigint")this[ql]===DG?this.set(m,(+this.getProperty(m)||0)+O):(this[ql]||this.update(),this.set(m,new lh(O)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,O){if(typeof O=="number")return this.addTo(m,-O);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this[Lr]}invalidate(m){let O=this[ye],D=this[Me];fc(D),yn(this[ye]).addWrite({key:D,store:i,invalidated:!0,entry:this[Lr],nodeName:this[ye]?.nodeName,before:Be.invalidate?.bind(this,O,D),beforeIntermediate:Ne.invalidate?.bind(this,O,D),commit:(b,L)=>{if(L?.version>b)return;let N=null;for(let v in r)N||(N={}),N[v]=this.getProperty(v);T(D,N,this[Lr],b,Fl,h,this[ye],0,"invalidate")}})}static evict(m,O,D){let R=this.Source,b;if(!((I||h)&&(!O||(b=i.getEntry(m),!b||!O)||b.version!==D))){if(I){if(i.hasLock(m,b.version))return;let L;for(let N in r)L||(L={}),L[N]=O[N];if(L)return T(m,L,b,D,kl,null,null,0,null,!0)}return i.ifVersion(m,D,()=>{i_(m,O,null)}),h?T(m,null,b,D,kl,null,null,0,null,!0):i.remove(m,D)}}lock(){throw new Error("Not yet implemented")}static operation(m,O){return m.table||=s,m.schema||=c,HG.operation(m,O)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,O,D){let R=this[ye],b=yn(R),L=this[Me];fc(L);let N=this[Lr];this[ql]=O?DG:eoe;let v={key:L,store:i,entry:N,nodeName:R?.nodeName,validate:q=>{m||(m=this[Nt]),O||m&&ch(this[Nt]===m?this:m)?R?.source||(b.checkOverloaded(),this.validate(m,!O),M&&(m[M.name]=M.type==="Date"?new Date(q):M.type==="String"?new Date(q).toISOString():q),O&&(t&&m[t]!==L&&(m[t]=L),F&&(N?.value?m[F.name]=N?.value[F.name]:m[F.name]=F.type==="Date"?new Date(q):F.type==="String"?new Date(q).toISOString():q),m=Uo(m))):b.removeWrite(v)},before:O?Be.put?()=>Be.put(R,L,m):null:Be.patch?()=>Be.patch(R,L,m):Be.put?()=>Be.put(R,L,Uo(this)):null,beforeIntermediate:O?Ne.put?()=>Ne.put(R,L,m):null:Ne.patch?()=>Ne.patch(R,L,m):Ne.put?()=>Ne.put(R,L,Uo(this)):null,commit:(q,C,G)=>{if(G){if(R&&C?.version>(R.lastModified||0)&&(R.lastModified=C.version),this[Lr]=C,C?.value?.[Ee])throw new Error("Can not assign a record to a record, check for circular references");O||(this[Ee]=C?.value??null)}this[Nt]=void 0,this[Vl]=q;let x=C?.value,Z=m;if(this[ql]=0,C?.version>=q)if(h){let ce=C.localTime,De=C.version;for(;Z&&(ce>q||De>=q&&ce>0);){let re=u.get(ce);if(!re)break;let X=Bt(re);if(De=X.version,De>q){if(X.type==="patch"){let Se=X.getValue(i);Z=oh(Z,Se)}else if(X.type==="put"||X.type==="delete")return}else if(De===q)return;ce=X.previousLocalTime}}else{if(O)return;Z=oh(Z,x)}let _e;if(O?_e=Z:(this[Ee]=x,_e=O?Z:Uo(this,Z)),this[Ee]=_e,_e?.[Ee])throw new Error("Can not assign a record to a record, check for circular references");let ne;O||(ne=m),i_(L,x,_e);let Ue=O?"put":"patch";T(L,_e,C,q,0,h,R,R.expiresAt||(E?E+Date.now():0),Ue,!1,ne),R.expiresAt&&a_()}};b.addWrite(v)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this[$n]){for await(let O of this.search(m))(await Ke.getResource(O[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this[Ee]?this._writeDelete(m):!1}_writeDelete(m){let O=yn(this[ye]),D=this[Me];fc(D);let R=this[ye];return O.addWrite({key:D,store:i,resource:this,nodeName:R?.nodeName,before:Be.delete?.bind(this,R,D),beforeIntermediate:Ne.delete?.bind(this,R,D),commit:(b,L,N)=>{let v=L?.value;N&&(R&&L?.version>(R.lastModified||0)&&(R.lastModified=L.version),hh(this,L)),!(L?.version>b)&&(i_(this[Me],v),it.trace("Write delete entry",D,b),h||p?(T(D,null,this[Lr],b,0,h,this[ye],0,"delete"),h||a_()):i.remove(this[Me]))}}),!0}search(m){let O=this[ye],D=yn(O);if(!m)throw new Error("No query provided");let R=m.conditions;R?R.length===void 0&&(R=R[Symbol.iterator]?Array.from(R):[R]):R=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this[Me]&&(R=[{attribute:null,comparator:"prefix",value:this[Me]}].concat(R));let b,L={};function N(X,Se){let He;switch(Se){case"and":case void 0:if(X.length<1)throw new Error('An "and" operator requires at least one condition');He=!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 "+Se)}let Wn=He&&{},js;for(let We of X){if(We.conditions){We.conditions=N(We.conditions,We.operator);continue}let Vt=We[0]??We.attribute,on=Vt==null?B:Fs(S,Vt);if(on){if(He){let Qn=qn(Vt),$t=Wn[Qn];$t?($t.push(We),js=!0):Wn[Qn]=[We]}(on.type||Zg[We.comparator])&&(We[1]===void 0?We.value=q(We.value,on):We[1]=q(We[1],on))}else if(Vt!=null)throw(0,Mr.handleHDBError)(new Error,`${Vt} is not a defined attribute`,404)}if(m.enforceExecutionOrder)return X;if(js)for(let We in Wn){let Vt=Wn[We],on=Vt.length;if(on>1)for(let Qn=0;Qn<on;Qn++){let $t=Vt[Qn];if($t.comparator==="ge"||$t.comparator==="greater_than_equal")for(let Zs=0;Zs<on;Zs++){let Fo=Vt[Zs];(Fo.comparator==="le"||Fo.comparator==="less_than_equal")&&($t.comparator="between",$t.value=[$t.value,Fo.value],X.splice(X.indexOf(Fo),1))}if($t.comparator==="equals"||!$t.comparator){for(let Zs=0;Zs<on;Zs++)if(Zs!==Qn){let Fo=Vt[Zs];X.splice(X.indexOf(Fo),1)}break}}}return X}a(N,"prepareConditions");function v(X,Se){if(m.enforceExecutionOrder)return X;for(let He of X)He.conditions&&(He.conditions=v(He.conditions,He.operator));return X.length>1&&Se!=="or"?(0,BG.sortBy)(X,nE(Ke)):X}a(v,"orderConditions");function q(X,Se){return Array.isArray(X)?X.map(He=>Eh(He,Se)):Eh(X,Se)}a(q,"coerceTypedValues");let C=m.operator;(R.length>0||C)&&(R=N(R,C));let G=typeof m.sort=="object"&&m.sort,x;if(G&&C!=="or"){let X=G.attribute;if(X==null)throw new Mr.ClientError("Sort requires an attribute");if(b=R.find(Se=>qn(Se.attribute)===qn(X)),!b){let Se=Fs(S,X);if(!Se)throw(0,Mr.handleHDBError)(new Error,`${Array.isArray(X)?X.join("."):X} is not a defined attribute`,404);if(Se.indexed)b={attribute:X,comparator:"sort"},R.push(b);else if(R.length===0&&!m.allowFullScan)throw(0,Mr.handleHDBError)(new Error,`${Array.isArray(X)?X.join("."):X} is not indexed and not combined with any other conditions`,404)}b&&(b.descending=!!G.descending)}R=v(R,C),G&&(b&&R[0]===b?G.next&&(x={dbOrderedAttribute:G.attribute,attribute:G.next.attribute,descending:G.next.descending,next:G.next.next}):(b&&R.splice(R.indexOf(b),1),x=G));let Z=m.select;if(R.length===0&&(R=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:R,operator:C,postOrdering:x,selectApplied:!!Z};let _e=D.useReadTxn(),ne=eR(R,C,Ke,_e,m,O,(X,Se)=>fO(X,Z,O,_e,Se),L),Ue=m.ensureLoaded!==!1;x||(ne=re(ne));let ce=Ke.transformEntryForSelect(Z,O,_e,L,Ue,!0),De=Ke.transformToOrderedSelect(ne,Z,x,_e,O,ce);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"),x&&(De=re(De)),De.onDone=()=>{De.onDone=null,D.doneReadTxn()},De.selectApplied=!0,De.getColumns=()=>{if(Z){let X=[];for(let Se of Z)Se==="*"?X.push(...S.map(He=>He.name)):X.push(Se.name||Se);return X}return S.map(X=>X.name)},De}static transformToOrderedSelect(m,O,D,R,b,L){let N=new Uq;if(D){m=fO(m,O,R,b,null);let v;N.iterate=function(){let C,G=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),x,Z=D.dbOrderedAttribute,_e,ne,Ue=!0;function ce(re){let X=re.next&&ce(re.next),Se=re.descending;return(He,Wn)=>{let js=xh(He,re.attribute,R),We=xh(Wn,re.attribute,R),Vt=Se?(0,xo.compareKeys)(We,js):(0,xo.compareKeys)(js,We);return Vt===0?X?.(He,Wn)||0:Vt}}a(ce,"createComparator");let De=ce(D);return{async next(){let re;if(C)if(re=C.next(),re.done){if(x)return N.onDone&&N.onDone(),re}else return{value:await L.call(this,re.value)};v=[],_e&&v.push(_e);do if(re=await G.next(),re.done){if(x=!0,v.length)break;return N.onDone&&N.onDone(),re}else{let X=re.value;if(X?.then&&(X=await X),Z){let Se=xh(X,Z,R);if(Ue)Ue=!1,ne=Se;else if(Se!==ne){ne=Se,_e=X;break}}v.push(X)}while(!0);return D.isGrouped,v.sort(De),C=v[Symbol.iterator](),re=C.next(),re.done?(N.onDone&&N.onDone(),re):{value:await L.call(this,re.value)}},return(){N.onDone&&N.onDone(),G.return()},throw(){N.onDone&&N.onDone(),G.throw()}}};let q=a(C=>{if(typeof O=="object"&&Array.isArray(C.attribute))for(let G=0;G<O.length;G++){let x=O[G],Z;if(x.name===C.attribute[0]){for(Z=x.sort||(x.sort={});Z.next;)Z=Z.next;Z.attribute=C.attribute.slice(1),Z.descending=C.descending}else x===C.attribute[0]&&(O[G]=Z={name:x,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&q(C.next)},"applySortingOnSelect");q(D)}else N.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),N=N.map(L);return N}static transformEntryForSelect(m,O,D,R,b,L){if(m&&(m===t||m?.length===1&&m[0]===t)){let C=a(G=>(O?.transaction?.stale&&(O.transaction.stale=!1),G?.key??G),"transform");return m===t?C:m.asArray?G=>[C(G)]:G=>({[t]:C(G)})}let N;b&&I&&!m?.every(C=>{let G;return typeof C=="object"?G=C.name:G=C,r[G]||G===t})&&(N=!0);let v,q=a(function(C){let G;if(O?.transaction?.stale&&(O.transaction.stale=!1),C!=null){if(Ph=C,G=C.value||C.deref?.(),!G&&(C.key===void 0||C.deref)){if(C=vh(C.key??C,O,{transaction:D,lazy:m?.length<4},this?.isSync,x=>x),C?.then)return C.then(q.bind(this));G=C?.value}if(N&&C?.metadataFlags&(Fl|kl)||C?.expiresAt&&C?.expiresAt<Date.now()){if(O.onlyIfCached&&O.noCacheStore)return{[t]:C.key,message:"This entry has expired"};let x=Bh(C.key??C,C,O);if(x?.then)return x.then(q)}}if(G==null)return L?vo.SKIP:G;if(m&&!(m[0]==="*"&&m.length===1)){let x,Z=a((ne,Ue)=>{let ce;typeof ne=="object"?ce=ne.name:ce=ne;let De=Xs?.[ce],re;if(De){let X=R?.[ce];if(X)if(X.hasMappings){let He=De.from?G[De.from]:qn(C.key);re=X.get(He),re||(re=[])}else re=X.fromRecord?.(G);else re=De(G,O,C);let Se=a(He=>{if(He&&typeof He=="object"){let Wn=De.definition?.tableClass||Ke;v||(v={});let js=v[ce]||(v[ce]=Wn.transformEntryForSelect(ce===ne?null:ne.select||(Array.isArray(ne)?ne:null),O,D,X,b));if(Array.isArray(He)){let We=[],Vt=Wn.transformToOrderedSelect(He,ne.select,typeof ne.sort=="object"&&ne.sort,O,D,js)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),on=a($t=>{for(;!$t.done;){if($t?.then)return $t.then(on);We.push($t.value),$t=Vt.next()}Ue(We,ce)},"nextValue"),Qn=on(Vt.next());Qn&&(x||(x=[]),x.push(Qn));return}else if(He=js.call(this,He),He?.then){x||(x=[]),x.push(He.then(We=>Ue(We,ce)));return}}Ue(He,ce)},"handleResolvedValue");re?.then?(x||(x=[]),x.push(re.then(Se))):Se(re);return}else re=G[ce],re&&typeof re=="object"&&ce!==ne&&(re=Ke.transformEntryForSelect(ne.select||ne,O,D,null)({value:re}));Ue(re,ce)},"selectAttribute"),_e;if(typeof m=="string")Z(m,ne=>{_e=ne});else if(Array.isArray(m))if(m.asArray)_e=[],m.forEach((ne,Ue)=>{ne==="*"?m[Ue]=G:Z(ne,ce=>_e[Ue]=ce)});else{_e={};let ne=m.forceNulls;for(let Ue of m)if(Ue==="*")for(let ce in G)_e[ce]=G[ce];else Z(Ue,(ce,De)=>{ce===void 0&&ne&&(ce=null),_e[De]=ce})}else throw new Mr.ClientError("Invalid select"+m);return x?Promise.all(x).then(()=>_e):_e}return G},"transform");return q}async subscribe(m){if(!u)throw new Error("Can not subscribe to a table without an audit log");h||Et({table:s,database:c,schemaDefined:_,attributes:S,audit:!0}),m||(m={});let O=!m.rawEvents,D=[],R=NG(Ke,this[Me]??null,function(L,N,v,q){try{let C=N.getValue?.(i,O);if(!C&&N.type==="patch"&&O){let x=i.getEntry(L);x?.version===N.version?C=x.value:C=N.getValue?.(i,!0,v),N.type="put"}let G={id:L,timestamp:v,value:C,version:N.version,type:N.type,beginTxn:q};D?D.push(G):this.send(G)}catch(C){it.error(C)}},m.startTime||0,m),b=(async()=>{this[$n]&&(R.includeDescendants=!0,m.onlyChildren&&(R.onlyChildren=!0)),m.supportsTransactions&&(R.supportsTransactions=!0);let L=this[Me],N=m.previousCount;N>1e3&&(N=1e3);let v=m.startTime;if(this[$n]){if(v){if(N)throw new Mr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:q,value:C}of u.getRange({start:v,exclusiveStart:!0,snapshot:!1})){let G=Bt(C);if(G.tableId!==n)continue;let x=G.recordId;if(L==null||UG(L,x)){let Z=G.getValue(i,O,q);if(R.send({id:x,timestamp:q,value:Z,version:G.version,type:G.type}),R.queue?.length>MG&&await R.waitForDrain()===!1)return}R.startTime=q}}else if(N){let q=[];for(let{key:C,value:G}of u.getRange({start:"z",end:!1,reverse:!0}))try{let x=Bt(G);if(x.tableId!==n)continue;let Z=x.recordId;if(L==null||UG(L,Z)){let _e=x.getValue(i,O,C);if(q.push({id:Z,timestamp:C,value:_e,version:x.version,type:x.type}),--N<=0)break}}catch(x){it.error("Error getting history entry",C,x)}for(let C=q.length;C>0;)R.send(q[--C]);q[0]&&(R.startTime=q[0].timestamp)}else if(!m.omitCurrent){for(let{key:q,value:C,version:G,localTime:x}of i.getRange({start:L??!1,end:L==null?void 0:[L,xo.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(C&&(R.send({id:q,timestamp:x,value:C,version:G,type:"put"}),R.queue?.length>MG&&await R.waitForDrain()===!1))return}}else{N&&!v&&(v=0);let q=this[Lr]?.localTime;if(q===Im&&(i.cache?.delete(L),this[Lr]=i.getEntry(L),it.trace("re-retrieved record",q,this[Lr]?.localTime),q=this[Lr]?.localTime),it.trace("Subscription from",v,"from",L,q),v<q){let C=[],G=q;do{let x=u.get(G);if(x){m.omitCurrent=!0;let Z=Bt(x),_e=Z.getValue(i,O,G);O&&(Z.type="put"),C.push({id:L,value:_e,timestamp:G,...Z}),G=Z.previousLocalTime}else break;N&&N--}while(G>v&&N!==0);for(let x=C.length;x>0;)R.send(C[--x]);R.startTime=q}!m.omitCurrent&&this.doesExist()&&R.send({id:L,timestamp:q,value:this[Ee],version:this[Vl],type:"put"})}for(let q of D)R.send(q);D=null})();return m.listener&&R.on("data",m.listener),R}doesExist(){return!!(this[Ee]||this[ql])}publish(m,O){this._writePublish(m,O)}_writePublish(m,O){let D=yn(this[ye]),R=this[Me]||null;fc(R);let b=this[ye];D.addWrite({key:R,store:i,entry:this[Lr],nodeName:b?.nodeName,validate:()=>{b?.source||(D.checkOverloaded(),this.validate(m))},before:Be.publish?.bind(this,b,R,m),beforeIntermediate:Ne.publish?.bind(this,b,R,m),commit:(L,N,v)=>{N===void 0&&p&&!h&&a_(),T(R,N?.value??null,N,N?.version||L,0,!0,b,N?.expiresAt,"message",!1,m)}})}validate(m,O){let D,R=a((b,L,N)=>{if(L.type&&b!=null)if(O&&b.__op__&&(b=b.value),L.properties){typeof b!="object"&&(D||(D=[])).push(`Value ${Yn(b)} in property ${N} must be an object${L.type?" ("+L.type+")":""}`);let v=L.properties;for(let q=0,C=v.length;q<C;q++){let G=v[q],x=R(b[G.name],G,N+"."+G.name);x&&(b[G.name]=x)}if(L.sealed&&b!=null&&typeof b=="object")for(let q in b)v.find(C=>C.name===q)||(D||(D=[])).push(`Property ${q} is not allowed within object in property ${N}`)}else switch(L.type){case"Int":(typeof b!="number"||b>>0!==b)&&(D||(D=[])).push(`Value ${Yn(b)} in property ${N} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof b!="number"||!(Math.floor(b)===b&&Math.abs(b)<=9007199254740992))&&(D||(D=[])).push(`Value ${Yn(b)} in property ${N} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof b!="number"&&(D||(D=[])).push(`Value ${Yn(b)} in property ${N} must be a number`);break;case"ID":typeof b=="string"||b?.length>0&&b.every?.(v=>typeof v=="string")||(D||(D=[])).push(`Value ${Yn(b)} in property ${N} must be a string, or an array of strings`);break;case"String":typeof b!="string"&&(D||(D=[])).push(`Value ${Yn(b)} in property ${N} must be a string`);break;case"Boolean":typeof b!="boolean"&&(D||(D=[])).push(`Value ${Yn(b)} in property ${N} must be a boolean`);break;case"Date":if(!(b instanceof Date)){if(typeof b=="string"||typeof b=="number")return new Date(b);(D||(D=[])).push(`Value ${Yn(b)} in property ${N} must be a Date`)}break;case"BigInt":if(typeof b!="bigint"){if(typeof b=="string"||typeof b=="number")return BigInt(b);(D||(D=[])).push(`Value ${Yn(b)} in property ${N} must be a bigint`)}break;case"Bytes":b instanceof Uint8Array||(D||(D=[])).push(`Value ${Yn(b)} in property ${N} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(b)){if(L.elements)for(let v=0,q=b.length;v<q;v++){let C=b[v],G=R(C,L.elements,N+"[*]");G&&(b[v]=G)}}else(D||(D=[])).push(`Value ${Yn(b)} in property ${N} must be a Buffer or Uint8Array`);break}L.nullable===!1&&b==null&&(D||(D=[])).push(`Property ${N} is required (and not does not allow null values)`)},"validateValue");for(let b=0,L=S.length;b<L;b++){let N=S[b];if(!N.relationship&&(!O||N.name in m)){let v=R(m[N.name],N,N.name);v&&(m[N.name]=v)}}if(d)for(let b in m)S.find(L=>L.name===b)||(D||(D=[])).push(`Property ${b} is not allowed`);if(D)throw new Mr.ClientError(D.join(". "))}getUpdatedTime(){return this[Vl]}wasLoadedFromSource(){return I?!!this[KA]:void 0}static async addAttributes(m){let O=S.slice(0);for(let D of m){if(!D.name)throw new Mr.ClientError("Attribute name is required");if(D.name.match(/[`/]/))throw new Mr.ClientError("Attribute names cannot include backticks or forward slashes");(0,xG.validateAttribute)(D.name),O.push(D)}return Et({table:s,database:c,schemaDefined:_,attributes:O}),Ke.indexingOperation}static async removeAttributes(m){let O=S.filter(D=>!m.includes(D.name));return Et({table:s,database:c,schemaDefined:_,attributes:O}),Ke.indexingOperation}static getRecordCount(m){let O=i.getStats().entryCount,D=1e3/2,R=performance.now(),b=Math.floor(O/2),L=m?.exactCount,N=0,v=0,q;for(let{value:C}of i.getRange({start:!0,lazy:!0}))if(C!=null&&N++,v++,!L&&v<b&&performance.now()-R>D){q=v;break}if(q){let C=N;N=0;for(let{value:re}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:q}))re!=null&&N++;let G=q*2,x=(N+C)/G,Z=Math.pow((N-C+1)/q/2,2)+x*(1-x)/G,_e=Math.max(Math.sqrt(Z)*O,1),ne=Math.round(x*O),Ue=Math.max(ne-1.96*_e,N+C),ce=Math.min(ne+1.96*_e,O),De=Math.pow(10,Math.round(Math.log10(_e)));return De>ne&&(De=De/10),N=Math.round(ne/De)*De,{recordCount:N,estimatedRange:[Math.round(Ue),Math.round(ce)]}}return{recordCount:N}}static updatedAttributes(){Xs=this.propertyResolvers={$id:(m,O,D)=>({value:D.key}),$updatedtime:(m,O,D)=>D.version,$record:(m,O,D)=>D?{value:m}:m};for(let m of this.attributes){m.resolve=null;let O=m.relationship;if(O)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),dO=!0,O.to)m.elements?.definition?(Xs[m.name]=m.resolve=(D,R,b)=>{let L=D[O.from?O.from:t],N=m.elements.definition.tableClass;return b?Ga({attribute:O.to,value:L},yn(R).getReadTxn(),!1,N,!1).asArray:N.search([{attribute:O.to,value:L}],R).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,O.from&&(m.resolve.from=O.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(O.from){let D=m.definition||m.elements?.definition;D?(Xs[m.name]=m.resolve=(R,b,L)=>{let N=R[O.from];if(N!==void 0){if(m.elements){let v,q=N.map(C=>{let G=L?D.tableClass.primaryStore.getEntry(C,{transaction:yn(b).getReadTxn()}):D.tableClass.get(C,b);return G?.then&&(v=!0),G});return O.filterMissing?v?Promise.all(q).then(C=>C.filter(vG)):q.filter(vG):v?Promise.all(q):q}return L?D.tableClass.primaryStore.getEntry(N,{transaction:yn(b).getReadTxn()}):D.tableClass.get(N,b)}},m.set=(R,b)=>{if(Array.isArray(b)){let L=b.map(N=>N[Me]||N[D.tableClass.primaryKey]);R[O.from]=L}else{let L=b[Me]||b[D.tableClass.primaryKey];R[O.from]=L}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=O.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`)}_h(this,this)}static async deleteHistory(m=0,O=!1){let D;for(let{key:R,value:b}of u.getRange({start:0,end:m}))await cc(),Bt(b).tableId===n&&(D=nh(u,R,b));if(O)for(let{key:R,value:b,localTime:L}of i.getRange({start:0,versions:!0}))await cc(),b===null&&L<m&&(D=i.remove(R));await D}static async*getHistory(m=0,O=1/0){for(let{key:D,value:R}of u.getRange({start:m||1,end:O})){await cc();let b=Bt(R);b.tableId===n&&(yield{id:b.recordId,localTime:D,version:b.version,type:b.type,value:b.getValue(i,!0,D),user:b.user})}}static async getHistoryOfRecord(m){let O=[];if(m==null)throw new Error("An id is required");let D=i.getEntry(m);if(!D)return O;let R=D.localTime;if(!R)throw new Error("The entry does not have a local audit time");let b=0;do{await cc();let L=u.get(R);if(L){let N=Bt(L);O.push({id:N.recordId,localTime:R,version:N.version,type:N.type,value:N.getValue(i,!0,R),user:N.user}),R=N.previousLocalTime}else break}while(b<1e3&&R);return O.reverse()}static cleanup(){z?.remove()}}Ke.updatedAttributes();let xq=Ke.prototype;return xq[Zie]=!0,E&&Ke.setTTLExpiration(E/1e3),Q&&Hq(),Ke;function i_(K,m,O){let D;for(let R in r){let b=r[R],L=b.isIndexing,N=O?.[R],v=m?.[R];if(N===v&&!L)continue;D=!0;let q=b.indexNulls,C=(0,$l.getIndexedValues)(N,q),G=(0,$l.getIndexedValues)(v,q);if(G?.length>0){let x=new Set(G);if(C=C?C.filter(Z=>{if(x.has(Z))x.delete(Z);else return!0}):[],G=Array.from(x),(G.length>0||C.length>0)&&CG){let Z=G.concat(C).map(_e=>({key:_e,value:K}));b.prefetch(Z,PG)}for(let Z=0,_e=G.length;Z<_e;Z++)b.remove(G[Z],K)}else C?.length>0&&CG&&b.prefetch(C.map(x=>({key:x,value:K})),PG);if(C)for(let x=0,Z=C.length;x<Z;x++)b.put(C[x],K)}return D}a(i_,"updateIndices");function fc(K){switch(typeof K){case"number":return!0;case"string":if(K.length<659)return!0;if(K.length>LG)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,xo.writeKey)(K,toe,0)>LG)throw new Error("Primary key size is too large: "+K.length);return!0}a(fc,"checkValidId");function vh(K,m,O,D,R){let b=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),O.transaction?.isDone)return R(null,K);let L=i.getEntry(K,O);return L&&m&&(L?.version>(m.lastModified||0)&&(m.lastModified=L.version),L?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=L.localTime)),R(L,K)},"whenPrefetched");return D?b():ue>0?(ue--,b()):new Promise((L,N)=>{ue===0?(ue--,i.prefetch([K],()=>{v(),q()})):(j.push(K),oe.push(q),j.length>Bq&&(ue--,v()));function v(){if(j.length>0){let C=oe;i.prefetch(j,()=>{ue===-1?v():ue++;for(let G of C)G()}),j=[],oe=[],le>2&&le--}else ue=le,le<vq&&le++}a(v,"prefetch");function q(){try{L(b())}catch(C){N(C)}}a(q,"load")})}a(vh,"loadLocalRecord");function o_(K){if(!K?.role)return;let m=K.role.permission;if(m.super_user)return roe;let O=m[c],D,R=O?.tables;if(R)return R[s];if(c==="data"&&(D=m[s])&&!D.tables)return D}a(o_,"getTablePermissions");function Bh(K,m,O,D){if(I){let R;if(O.noCache?R=!0:(m?(!m.value||m.metadataFlags&(Fl|kl)||m.expiresAt&&m.expiresAt<Date.now())&&(R=!0):R=!0,Qr(!R,"cache-hit",s)),R){let b=EO(K,m,O).then(L=>(L?.value?.[Ee]&&it.error("Can not assign a record with a record property"),O&&(L?.version>(O.lastModified||0)&&(O.lastModified=L.version),O.lastRefreshed=Date.now()),L));if(O?.onlyIfCached||m?.value&&D?.allowStaleWhileRevalidate?.(m,K)){if(b.catch(L=>it.warn(L)),O?.onlyIfCached&&!D.doesExist())throw new Mr.ServerError("Entry is not cached",504);return}else return b}}else if(m?.value&&m.expiresAt&&m.expiresAt<Date.now())return Ke.evict(m.key,m.value,m.version),m.value=null,{then(R){return R(m)}}}a(Bh,"ensureLoadedFromSource");function yn(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 O=m.next;if(!O)return m=m.next=new no,m.lmdbDb=i,m;m=O}while(!0)}else return new Td}a(yn,"txnForContext");function xh(K,m,O){if(!K)return;Ph=K;let D=K.value||K.deref?.()||(Ph=i.getEntry(K.key))?.value;if(typeof m=="object"){let b=Xs,L=D;for(let N=0,v=m.length;N<v;N++){let q=m[N],C=b?.[q];L=C&&L?C(L,O,!0)?.value:L?.[q],b=C?.definition?.tableClass?.propertyResolvers}return L}let R=Xs[m];return R?R(D,O):D[m]}a(xh,"getAttributeValue");function fO(K,m,O,D,R){let b=R?.length,L={transaction:D,lazy:b>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},N;function v(q,C){let G=q?.value;if(!G)return vo.SKIP;for(let x=0;x<b;x++)if(!N?.includes(x)&&!R[x](G,q))return vo.SKIP;return C!==void 0&&(q.key=C),q}if(a(v,"processEntry"),b>0||!K.hasEntries){let q=K.map(C=>{if(N=null,typeof C=="object"&&C?.key!==void 0)return b>0?v(C):C;if(C==null)return vo.SKIP;for(let G=0;G<b;G++){let Z=R[G].idFilter;if(Z){if(!Z(C))return vo.SKIP;N||(N=[]),N.push(G)}}return vh(C,O,L,!1,v)});return Array.isArray(K)&&(q=q.filter(C=>C!==vo.SKIP)),q.hasEntries=!0,q}return K}a(fO,"transformToEntries");async function EO(K,m,O){let D=m?.metadataFlags,R=m?.version,b,L;if(!i.attemptLock(K,R,()=>{clearTimeout(L);let C=i.getEntry(K);!C||!C.value||C.metadataFlags&(Fl|kl)?b(EO(K,i.getEntry(K),O)):b(C)}))return new Promise(C=>{b=C,L=setTimeout(()=>{i.unlock(K,R)},jie)});let N=m?.value,v={requestContext:O,replacingRecord:N,replacingVersion:R,noCacheStore:!1,source:null,resourceCache:O?.resourceCache},q=O?.responseHeaders;return new Promise((C,G)=>{let x;QA(rt(v,async Z=>{let _e=performance.now(),ne,Ue,ce;try{for(let Se of Ke.sources)if(Se.get&&(!Se.get.reliesOnPrototype||Se.prototype.get)&&(v.source=Se,ne=await Se.get(K,v),ne))break;ce=D&Fl;let re=v.lastModified||ce&&R;Ue=ce||re>R||!N,re||(re=(0,$l.getNextMonotonicTime)());let X=performance.now()-_e;if(nr(X,"cache-resolution",s,null,"success"),q&&Lf(q,"Server-Timing",`cache-resolve;dur=${X.toFixed(2)}`,!0),Z.timestamp=re,E&&!v.expiresAt&&(v.expiresAt=Date.now()+E),ne){if(typeof ne!="object")throw new Error("Only objects can be cached and stored in tables");typeof ne.toJSON=="function"&&(ne=ne.toJSON()),t&&ne[t]!==K&&(ne[t]=K)}x=!0,C({version:re,value:ne})}catch(re){re.message+=` while resolving record ${K} for ${s}`,N&&((re.code==="ECONNRESET"||re.code==="ECONNREFUSED"||re.code==="EAI_AGAIN")&&!O?.mustRevalidate||O?.staleIfError&&(re.statusCode===500||re.statusCode===502||re.statusCode===503||re.statusCode===504))?(C({version:R,value:N}),it.trace(re.message,"(returned stale record)")):G(re);let X=performance.now()-_e;nr(X,"cache-resolution",s,null,"fail"),q&&Lf(q,"Server-Timing",`cache-resolve;dur=${X.toFixed(2)}`,!0),v.transaction.abort();return}if(O?.noCacheStore||v.noCacheStore){v.transaction.abort();return}yn(v).addWrite({key:K,store:i,entry:m,nodeName:"source",commit:(re,X)=>{if(X?.version!==R)return;let Se=i_(K,N,ne);ne?(Ne.put?.(v,K,ne),T(K,ne,X,re,0,h&&Ue||null,v,v.expiresAt,"put",!!ce)):(Ne.delete?.(v,K),h||p?T(K,null,X,re,0,h&&Ue||null,v,0,"delete",!!ce):i.remove(K,R))}})}),()=>{i.unlock(K,R)},Z=>{i.unlock(K,R),x&&it.error("Error committing cache update",Z)})})}a(EO,"getFromSource");function a_(){if(xe!==n_&&(n_=xe,(0,Bo.getWorkerIndex)()===(0,Bo.getWorkerCount)()-1)){if(s_&&clearTimeout(s_),!xe)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())/xe)*xe+K.getTime(),O=a(D=>{it.trace(`Scheduled next cleanup scan at ${new Date(D)}ms`),s_=setTimeout(()=>U=U.then(async()=>{if(O(Math.max(D+xe,Date.now())),i.rootStore.status!=="open"){clearTimeout(s_);return}let R=50,b=new Array(R),L=0;it.trace(`Starting cleanup scan for ${s}`);try{let N=0;for(let{key:v,value:q,version:C,expiresAt:G}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let x;q===null&&!h&&C+Xie<Date.now()?x=i.remove(v,C):G&&G+f<Date.now()&&(x=Ke.evict(v,q,C),N++),x&&(await b[L],b[L]=x.catch(Z=>{it.error("Cleanup error",Z)}),++L>=R&&(L=0)),await cc()}it.trace(`Finished cleanup scan for ${s}, evicted ${N} entries`)}catch(N){it.trace(`Error in cleanup scan for ${s}:`,N)}}),Math.min(D-Date.now(),2147483647)).unref()},"startNextTimer");O(m)}}a(a_,"scheduleCleanup");function hO(){z=u?.addDeleteRemovalCallback(n,K=>{let m=i.getEntry(K);m?.value===null&&i.remove(K,m.version)})}a(hO,"addDeleteRemoval");function Hq(){(0,Bo.getWorkerIndex)()===0&&setInterval(async()=>{if(!Uh){Uh=!0;try{let K=Q.name,m=r[K];if(!m)throw new Error(`expiresAt attribute ${Q} must be indexed`);for(let O of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let D of m.getValues(O)){let R=i.getEntry(D);R?.value?R.value[K]<Date.now()&&Ke.evict(D,R.value,R.version):i.ifVersion(D,R?.version,()=>m.remove(O,D))}await cc()}}catch(K){it.error("Error in evicting old records",K)}finally{Uh=!1}}},Jie).unref()}a(Hq,"runRecordExpirationEviction")}function WA(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 PG(){}function noe(e){HG=e}function Eh(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;switch(r){case"Int":case"Long":return e==="null"?null:parseInt(e);case"Float":return e==="null"?null:parseFloat(e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":return isNaN(e)?e==="null"?null:(soe.test(e)||(e+="Z"),new Date(e)):new Date(+e);case void 0:case"Any":return(0,mh.autoCast)(e);default:return e}}function UG(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 QA(e,t,r){return e?.then?e.then(t,r):t(e)}function hh(e,t){e[Lr]=t,e[Ee]=t?.value??null,e[Vl]=t?.version}function vG(e){return e!=null}function Yn(e){try{return JSON.stringify(e)}catch{return e}}var Kn,vo,$l,BG,xG,Wl,Mr,Yl,Kl,it,xo,Bo,mh,zie,HG,Jie,Xie,CG,jie,Vl,Zie,Lr,ql,DG,eoe,KA,ac,Fl,kl,toe,LG,MG,roe,yTe,soe,cc,TE=Re(()=>{Kn=H(P()),vo=require("lmdb"),$l=H(Br()),BG=require("lodash"),xG=H(Cc());cn();hS();Wl=H(ee());wG();Mr=H(se()),Yl=H(Ns()),Kl=H(Pn());Ae();iE();it=H($());Ad();so();xo=require("ordered-binary"),Bo=H(Qe());ni();mh=H(J());xc();Ds();sh();tl();zie=new Uint8Array(9);zie[8]=192;Jie=6e4,Xie=864e5;Wl.initSync();CG=Wl.get(Kn.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),jie=1e4,Vl=Symbol.for("version"),Zie=Symbol.for("incremental-update"),Lr=Symbol("entry"),ql=Symbol("is-saving"),DG=1,eoe=2,KA=Symbol("loaded-from-source"),ac={isNotification:!0,ensureLoaded:!1},Fl=1,kl=8,toe=Buffer.allocUnsafeSlow(8192),LG=1978,MG=100,roe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},yTe=(0,mh.convertToMS)(Wl.get(Kn.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(ph,"makeTable");a(WA,"attributesAsObject");a(PG,"noop");a(noe,"setServerUtilities");soe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(Eh,"coerceType");a(UG,"isDescendantId");cc=a(()=>new Promise(setImmediate),"rest");a(QA,"when");a(hh,"updateResource");a(vG,"exists");a(Yn,"stringify")});var ke={};Fe(ke,{database:()=>ua,databases:()=>ct,dropDatabase:()=>gS,dropTableMeta:()=>uoe,getDatabases:()=>Tr,getDefaultCompression:()=>Nf,getTables:()=>ioe,onUpdatedTable:()=>iA,readMetaDb:()=>Ql,resetDatabases:()=>Wu,table:()=>Et,tables:()=>xr});function ioe(){return Ah||Tr(),xr||{}}function Tr(){if(Ah)return ct;Ah=!0,_c=new Map;let e=(0,St.getHdbBasePath)()&&(0,ot.join)((0,St.getHdbBasePath)(),vt.DATABASES_DIR_NAME),t=(0,St.get)(vt.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,St.get)(vt.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,nn.existsSync)(e)?e:(0,ot.join)((0,St.getHdbBasePath)(),vt.LEGACY_DATABASES_DIR_NAME)),!!e){if((0,nn.existsSync)(e))for(let r of(0,nn.readdirSync)(e,{withFileTypes:!0})){let n=(0,ot.basename)(r.name,".mdb");r.isFile()&&(0,ot.extname)(r.name).toLowerCase()===".mdb"&&!t[n]?.path&&Ql((0,ot.join)(e,r.name),null,n)}if((0,nn.existsSync)((0,lc.getBaseSchemaPath)())){for(let r of(0,nn.readdirSync)((0,lc.getBaseSchemaPath)(),{withFileTypes:!0}))if(!r.isFile()){let n=(0,ot.join)((0,lc.getBaseSchemaPath)(),r.name),s=(0,ot.join)((0,lc.getTransactionAuditStoreBasePath)(),r.name);for(let i of(0,nn.readdirSync)(n,{withFileTypes:!0}))if(i.isFile()&&(0,ot.extname)(i.name).toLowerCase()===".mdb"){let o=(0,ot.join)(s,i.name);Ql((0,ot.join)(n,i.name),(0,ot.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,ot.extname)(o.name).toLowerCase()===".mdb"&&Ql((0,ot.join)(s,o.name),(0,ot.basename)(o.name,".mdb"),r);let i=n.tables;if(i)for(let o in i){let c=i[o],u=(0,ot.join)(c.path,(0,ot.basename)(o+".mdb"));(0,nn.existsSync)(u)&&Ql(u,o,r,null,!0)}}for(let r in ct){let n=_c.get(r);if(n){let s=ct[r];r.includes("delete")&&bn.trace(`defined tables ${Array.from(n.keys())}`);for(let i in s)n.has(i)||(bn.trace(`delete table class ${i}`),delete s[i])}else if(delete ct[r],r==="data"){for(let s in xr)delete xr[s];delete xr[Oh]}}return _c=null,ct}}function Wu(){Ah=!1;for(let[,e]of Bi)e.needsDeletion=!0;Tr();for(let[e,t]of Bi)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),Bi.delete(e));return ct}function Ql(e,t,r=XA,n,s){let i=new zA.default(e,!1);try{let o=Bi.get(e);o?o.needsDeletion=!1:(o=(0,Th.open)(i),Bi.set(e,o));let c=new Ho.default(!1),u=o.dbisDb||(o.dbisDb=o.openDB(Sh.INTERNAL_DBIS_NAME,c)),_=o.auditStore;_||(n?(0,nn.existsSync)(n)&&(i.path=n,_=(0,Th.open)(i),_.isLegacy=!0):_=rh(o));let l=kG(r),d=l[Oh],E=new Map;for(let{key:f,value:h}of u.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){bn.warn(`Unable to find a primary key attribute on table ${f}, with attributes: ${JSON.stringify(p)}`);continue}}let T=l[f],A={},y=[],I,B,U=typeof S.audit=="boolean"?S.audit:(0,St.get)(vt.CONFIG_PARAMS.LOGGING_AUDITLOG),F=S.trackDeletes,M=S.expiration,Q=S.eviction,z=S.sealed;if(T)A=T.indices,y=T.attributes,T.schemaVersion++;else{I=S.tableId,I?I>=(u.get(uc)||0)&&u.putSync(uc,I+1):(S.tableId=I=u.get(uc),I||(I=1),u.putSync(uc,I+1),u.putSync(S.key,S));let j=new Ho.default(!S.is_hash_attribute,S.is_hash_attribute);if(j.compression=S.compression,j.compression){let oe=(0,St.get)(vt.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||FG;j.compression.threshold=oe}B=D_(o.openDB(S.key,j)),B.rootStore=o,B.tableId=I}for(let j of p){j.attribute=j.name;try{if(!j.is_hash_attribute&&(j.indexed||j.attribute&&!j.name)){if(!A[j.name]){let ue=new Ho.default(!j.is_hash_attribute,j.is_hash_attribute);A[j.name]=o.openDB(j.key,ue),A[j.name].indexNulls=j.indexNulls}let oe=y.find(ue=>ue.name===j.name);oe?y.splice(y.indexOf(oe),1,j):y.push(j)}}catch(oe){bn.error("Error trying to update attribute",j,y,A,oe)}}if(!T){T=VG(l,f,ph({primaryStore:B,auditStore:_,audit:U,sealed:z,expirationMS:M&&M*1e3,evictionMS:Q&&Q*1e3,trackDeletes:F,tableName:f,tableId:I,primaryKey:S.name,databasePath:s?r+"/"+f:r,databaseName:r,indices:A,attributes:p,schemaDefined:S.schemaDefined,dbisDB:u})),T.schemaVersion=1;for(let j of jA)j(T)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function kG(e){let t=ct[e];if(t||(e==="data"?t=ct[e]=xr:e==="system"?Object.defineProperty(ct,"system",{value:t=Object.create(null),configurable:!0}):t=ct[e]=Object.create(null)),_c&&!_c.has(e)){let r=new Set;t[Oh]=r,_c.set(e,r)}return t}function VG(e,t,r){return e[t]=r,r}function ua({database:e,table:t}){e||(e=XA),Tr();let r=kG(e),n=(0,ot.join)((0,St.getHdbBasePath)(),vt.DATABASES_DIR_NAME),s=(0,St.get)(vt.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,St.get)(vt.CONFIG_PARAMS.STORAGE_PATH)||((0,nn.existsSync)(n)?n:(0,ot.join)((0,St.getHdbBasePath)(),vt.LEGACY_DATABASES_DIR_NAME));let o=(0,ot.join)(n,(i?t:e)+".mdb"),c=Bi.get(o);if(!c){let u=new zA.default(o,!1);c=(0,Th.open)(u),Bi.set(o,c)}return c}async function gS(e){if(!ct[e])throw new Error("Schema does not exist");let t=ct[e],r;for(let n in t)r=t[n].primaryStore.rootStore,Bi.delete(r.path),r.status==="open"&&(await r.close(),await zl.remove(r.path));if(r||(r=ua({database:e,table:null}),r.status==="open"&&(await r.close(),await zl.remove(r.path))),e==="data"){for(let n in xr)delete xr[n];delete xr[Oh]}delete ct[e]}function Et({table:e,database:t,expiration:r,eviction:n,scanInterval:s,attributes:i,audit:o,sealed:c,trackDeletes:u,schemaDefined:_,origin:l}){t||(t=XA);let d=ua({database:t,table:e}),E=ct[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 A=new Ho.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 y,I;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=rh(d)),p=i.find(oe=>oe.isPrimaryKey)||{},h=p.name,p.is_hash_attribute=p.isPrimaryKey=!0,p.schemaDefined=_,p.compression=Nf(),u&&(p.trackDeletes=!0),o=p.audit=typeof o=="boolean"?o:(0,St.get)(vt.CONFIG_PARAMS.LOGGING_AUDITLOG),r&&(p.expiration=r),n&&(p.eviction=n),typeof c=="boolean"&&(p.sealed=c),l&&(p.origins?p.origins.includes(l)||p.origins.push(l):p.origins=[l]),bn.trace(`${e} table loading, opening primary store`);let Q=new Ho.default(!1,!0);Q.compression=p.compression;let z=e+"/",j=D_(d.openDB(z,Q));j.rootStore=d,T=d.dbisDb=d.openDB(Sh.INTERNAL_DBIS_NAME,A),j.tableId=T.get(uc),j.tableId||(j.tableId=1),T.putSync(uc,j.tableId+1),p.tableId=j.tableId,f=VG(E,e,ph({primaryStore:j,auditStore:M,audit:o,sealed:c,trackDeletes:u,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,y=!0,F(),T.put(z,p)}S=f.indices,T=T||(d.dbisDb=d.openDB(Sh.INTERNAL_DBIS_NAME,A)),f.dbisDB=T;let B=[];for(let{key:M,value:Q}of T.getRange({start:!0})){let[z,j]=M.toString().split("/");if(j===""&&(j=Q.name),j){if(z!==e)continue}else continue;let oe=i.find(le=>le.name===j),ue=!oe?.indexed&&Q.indexed&&!Q.isPrimaryKey;if((!oe||ue)&&(F(),y=!0,oe||T.remove(M),ue)){let le=f.indices[z];le&&B.push(le)}}let U=[];try{for(let M of i||[]){if(M.relationship)continue;let Q=e+"/"+(M.name||"");Object.defineProperty(M,"key",{value:Q,configurable:!0});let z=T.get(Q);if(M.isPrimaryKey){if(z=z||T.get(Q=e+"/")||{},o!==f.audit||c!==c||(+r||void 0)!==(+z.expiration||void 0)||(+n||void 0)!==(+z.eviction||void 0)){let oe=Object.assign({},z);typeof o=="boolean"&&(o&&f.enableAuditing(o),oe.audit=o),r&&(oe.expiration=+r),n&&(oe.eviction=+n),c!==void 0&&(oe.sealed=c),y=!0,F(),T.put(Q,oe)}continue}z?.attribute&&!z.name&&(z.indexed=!0);let j=!z||z.type!==M.type||z.indexed!==M.indexed||z.nullable!==M.nullable||JSON.stringify(z.properties)!==JSON.stringify(M.properties)||JSON.stringify(z.elements)!==JSON.stringify(M.elements);if(M.indexed){let oe=new Ho.default(!0,!1),ue=d.openDB(Q,oe);(j||z.indexingPID&&z.indexingPID!==process.pid||z.restartNumber<Jl.workerData?.restartNumber)&&(y=!0,F(),z=T.get(Q),(j||z.indexingPID&&z.indexingPID!==process.pid||z.restartNumber<Jl.workerData?.restartNumber)&&(y=!0,M.indexNulls===void 0&&(M.indexNulls=!0),f.primaryStore.getStats().entryCount>0&&(M.lastIndexedKey=z?.lastIndexedKey||!1,M.indexingPID=process.pid,ue.isIndexing=!0,Object.defineProperty(M,"dbi",{value:ue}),U.push(M))),T.put(Q,M)),z?.indexNulls&&M.indexNulls===void 0&&(M.indexNulls=!0),ue.indexNulls=M.indexNulls,S[M.name]=ue}else j&&(y=!0,F(),T.put(Q,M))}}finally{I&&I()}if(y&&(f.schemaVersion++,f.updatedAttributes()),bn.trace(`${e} table loading, running index`),U.length>0||B.length>0?f.indexingOperation=coe(f,U,B):y&&gh.signalSchemaChange(new Rh.SchemaEventMsg(process.pid,"schema-change",f.databaseName,f.tableName)),f.origin=l,y)for(let M of jA)M(f,l!=="cluster");return(r||n||s)&&f.setTTLExpiration({expiration:r,eviction:n,scanInterval:s}),bn.trace(`${e} table loaded`),f;function F(){I||d.transactionSync(()=>({then(M){I=M}}))}a(F,"startTxn")}async function coe(e,t,r){try{let n=e.schemaVersion;await gh.signalSchemaChange(new Rh.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o=0,c=t.length;if(await new Promise(u=>setImmediate(u)),c>0){let u=0;for(let{key:_,value:l,version:d}of e.primaryStore.getRange({start:t[0].lastIndexedKey,lazy:c<4,versions:!0,snapshot:!1}))if(l){if(u++,s=e.primaryStore.ifVersion(_,d,()=>{for(let E=0;E<c;E++){let f=t[E],h=f.name,p=(0,GG.getIndexedValues)(l[h]);if(p)for(let S=0,T=p.length;S<T;S++)f.dbi.put(p[S],_)}}),s.then(()=>u--,E=>{u--,bn.error(E)}),Jl.workerData&&Jl.workerData.restartNumber!==qG.restartNumber&&(i=!0),++o%100===0||i){for(let E of t)E.lastIndexedKey=_,e.dbisDB.put(E.key,E);if(i)return}u>ooe?await s:u>aoe&&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 gh.signalSchemaChange(new Rh.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName))}catch(n){bn.error("Error in indexing",n)}}function uoe({table:e,database:t}){let r=ua({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 iA(e){jA.push(e)}function Nf(){let e=(0,St.get)(vt.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,St.get)(vt.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,St.get)(vt.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||FG,n={startingOffset:32};return t&&(n.dictionary=zl.readFileSync(t)),r&&(n.threshold=r),e&&n}var St,Sh,Th,ot,nn,lc,Ho,zA,vt,zl,JA,GG,gh,Rh,Jl,bn,qG,XA,Oh,FG,xr,ct,uc,jA,Ah,Bi,_c,ooe,aoe,Ae=Re(()=>{St=H(ee()),Sh=H(ft()),Th=require("lmdb"),ot=require("path"),nn=require("fs"),lc=H(Xe());TE();Ho=H(Hc()),zA=H(Gc()),vt=H(P()),zl=H(require("fs-extra")),JA=require("../index"),GG=H(Br()),gh=H(Ns()),Rh=H(Pn()),Jl=require("worker_threads"),bn=H($()),qG=H(Qe());ni();xc();XA="data",Oh=Symbol("defined-tables"),FG=((0,St.get)(vt.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,St.initSync)();xr=Object.create(null),ct=Object.create(null);(0,JA._assignPackageExport)("databases",ct);(0,JA._assignPackageExport)("tables",xr);uc=Symbol.for("next-table-id"),jA=[],Bi=new Map;a(ioe,"getTables");a(Tr,"getDatabases");a(Wu,"resetDatabases");a(Ql,"readMetaDb");a(kG,"ensureDB");a(VG,"setTable");a(ua,"database");a(gS,"dropDatabase");a(Et,"table");ooe=1e3,aoe=10;a(coe,"runIndexing");a(uoe,"dropTableMeta");a(iA,"onUpdatedTable");a(Nf,"getDefaultCompression")});var J=g((UTe,nq)=>{"use strict";var xi=require("path"),QG=require("fs-extra"),Pr=$(),$G=require("fs-extra"),bh=require("os"),loe=require("net"),_oe=require("recursive-iterator"),dt=P(),doe=QO(),YG=require("papaparse"),yh=require("moment"),{inspect:foe}=require("util"),KG=require("is-number"),PTe=require("lodash"),Eoe=require("minimist"),hoe=require("https"),moe=require("http"),{hdb_errors:Nh}=se(),poe=/^((\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)))$/,zG=require("util").promisify(setTimeout),Soe=100,Toe=5,goe="",Roe=4,WG={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};nq.exports={isEmpty:sn,isEmptyOrZeroLength:ps,arrayHasEmptyValues:boe,arrayHasEmptyOrZeroLengthValues:yoe,buildFolderPath:Noe,isBoolean:JG,errorizeMessage:Aoe,stripFileExtension:woe,autoCast:Coe,autoCastJSON:XG,autoCastJSONDeep:eO,removeDir:Doe,compareVersions:Loe,isCompatibleDataVersion:Moe,escapeRawValue:Poe,unescapeValue:Uoe,stringifyProps:voe,timeoutPromise:xoe,isClusterOperation:Goe,getClusterUser:Foe,checkGlobalSchemaTable:qoe,getHomeDir:ZG,getPropsFilePath:Boe,promisifyPapaParse:koe,removeBOM:eq,createEventPromise:Voe,checkProcessRunning:$oe,checkSchemaTableExist:Yoe,checkSchemaExists:tq,checkTableExists:rq,getStartOfTomorrowInSeconds:Koe,getLimitKey:Woe,isObject:Ioe,isNotEmptyAndHasValue:Ooe,autoCasterIsNumberCheck:jG,backtickASTSchemaItems:Qoe,isPortTaken:Hoe,createForkArgs:zoe,autoCastBoolean:Joe,async_set_timeout:zG,getTableHashAttribute:Xoe,doesSchemaExist:joe,doesTableExist:Zoe,stringifyObj:eae,ms_to_time:tae,changeExtension:rae,getEnvCliRootPath:tO,noBootFile:nae,httpRequest:sae,transformReq:iae,convertToMS:oae,PACKAGE_ROOT:dt.PACKAGE_ROOT};function Aoe(e){return e instanceof Error?e:new Error(e)}a(Aoe,"errorizeMessage");function sn(e){return e==null}a(sn,"isEmpty");function Ooe(e){return!sn(e)&&(e||e===0||e===""||JG(e))}a(Ooe,"isNotEmptyAndHasValue");function ps(e){return sn(e)||e.length===0||e.size===0}a(ps,"isEmptyOrZeroLength");function boe(e){if(sn(e))return!0;for(let t=0;t<e.length;t++)if(sn(e[t]))return!0;return!1}a(boe,"arrayHasEmptyValues");function yoe(e){if(ps(e))return!0;for(let t=0;t<e.length;t++)if(ps(e[t]))return!0;return!1}a(yoe,"arrayHasEmptyOrZeroLengthValues");function Noe(...e){try{return e.join(xi.sep)}catch{console.error(e)}}a(Noe,"buildFolderPath");function JG(e){return sn(e)?!1:e===!0||e===!1}a(JG,"isBoolean");function Ioe(e){return sn(e)?!1:typeof e=="object"}a(Ioe,"isObject");function woe(e){return ps(e)?goe:e.slice(0,-Roe)}a(woe,"stripFileExtension");function Coe(e){return sn(e)||e===""||typeof e!="string"?e:WG[e]!==void 0?WG[e]:jG(e)===!0?Number(e):poe.test(e)?new Date(e):e}a(Coe,"autoCast");function XG(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(XG,"autoCastJSON");function eO(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=eO(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=eO(r);n!==r&&(e[t]=n)}return e}else return XG(e)}a(eO,"autoCastJSONDeep");function jG(e){if(e.startsWith("0.")&&KG(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&KG(e))}a(jG,"autoCasterIsNumberCheck");async function Doe(e){if(ps(e))throw new Error(`Directory path: ${e} does not exist`);try{await $G.emptyDir(e),await $G.remove(e)}catch(t){throw Pr.error(`Error removing files in ${e} -- ${t}`),t}}a(Doe,"removeDir");function Loe(e,t){if(ps(e)){Pr.info("Invalid current version sent as parameter.");return}if(ps(t)){Pr.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),u=Math.min(o.length,c.length);for(let _=0;_<u;_++)if(r=parseInt(o[_],10)-parseInt(c[_],10),r)return r;return o.length-c.length}a(Loe,"compareVersions");function Moe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(Moe,"isCompatibleDataVersion");function Poe(e){if(sn(e))return e;let t=String(e);return t==="."?dt.UNICODE_PERIOD:t===".."?dt.UNICODE_PERIOD+dt.UNICODE_PERIOD:t.replace(dt.FORWARD_SLASH_REGEX,dt.UNICODE_FORWARD_SLASH)}a(Poe,"escapeRawValue");function Uoe(e){if(sn(e))return e;let t=String(e);return t===dt.UNICODE_PERIOD?".":t===dt.UNICODE_PERIOD+dt.UNICODE_PERIOD?"..":String(e).replace(dt.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(Uoe,"unescapeValue");function voe(e,t){if(sn(e))return Pr.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+bh.EOL}!ps(n)&&n[0]===";"?r+=" "+n+s+bh.EOL:ps(n)||(r+=n+"="+s+bh.EOL)}catch{Pr.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(voe,"stringifyProps");function ZG(){let e;try{e=bh.homedir()}catch{e=process.env.HOME}return e||(e="~/"),e}a(ZG,"getHomeDir");function Boe(){let e=xi.join(ZG(),dt.HDB_HOME_DIR_NAME,dt.BOOT_PROPS_FILE_NAME);return QG.existsSync(e)||(e=xi.join(__dirname,"../","hdb_boot_properties.file")),e}a(Boe,"getPropsFilePath");function xoe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:function(){clearTimeout(r)}}}a(xoe,"timeoutPromise");async function Hoe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=loe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(Hoe,"isPortTaken");function Goe(e){try{return dt.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Pr.error(`Error checking operation against cluster ops ${t}`)}return!1}a(Goe,"isClusterOperation");function qoe(e,t){let r=(Ae(),ie(ke)).getDatabases();if(!r[e])return Nh.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return Nh.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(qoe,"checkGlobalSchemaTable");function Foe(e,t){if(sn(t)){Pr.warn("No CLUSTERING_USER defined, clustering disabled");return}if(sn(e)||ps(e)){Pr.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){Pr.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){Pr.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(Foe,"getClusterUser");function koe(){YG.parsePromise=function(e,t,r){return new Promise(function(n,s){YG.parse(e,{header:!0,transformHeader:eq,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(koe,"promisifyPapaParse");function eq(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(eq,"removeBOM");function Voe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;Pr.info(`Got cluster status event response: ${foe(s)}`);try{i.cancel()}catch{Pr.error("Error trying to cancel timeout.")}n(s)})})}a(Voe,"createEventPromise");async function $oe(e){let t=!0,r=0;do await zG(Soe*r++),(await doe.findPs(e)).length>0&&(t=!1);while(t&&r<Toe);if(t)throw new Error(`process ${e} was not started`)}a($oe,"checkProcessRunning");function Yoe(e,t){let r=tq(e);if(r)return r;let n=rq(e,t);if(n)return n}a(Yoe,"checkSchemaTableExist");function tq(e){let{getDatabases:t}=(Ae(),ie(ke));if(!t()[e])return Nh.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(tq,"checkSchemaExists");function rq(e,t){let{getDatabases:r}=(Ae(),ie(ke));if(!r()[e][t])return Nh.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(rq,"checkTableExists");function Koe(){let e=yh().utc().add(1,dt.MOMENT_DAYS_TAG).startOf(dt.MOMENT_DAYS_TAG).unix(),t=yh().utc().unix();return e-t}a(Koe,"getStartOfTomorrowInSeconds");function Woe(){return yh().utc().format("DD-MM-YYYY")}a(Woe,"getLimitKey");function Qoe(e){try{let t=new _oe(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){Pr.error("Got an error back ticking items."),Pr.error(t)}}a(Qoe,"backtickASTSchemaItems");function zoe(e){return[e]}a(zoe,"createForkArgs");function Joe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(Joe,"autoCastBoolean");function Xoe(e,t){let{getDatabases:r}=(Ae(),ie(ke)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(Xoe,"getTableHashAttribute");function joe(e){let{getDatabases:t}=(Ae(),ie(ke));return t()[e]!==void 0}a(joe,"doesSchemaExist");function Zoe(e,t){let{getDatabases:r}=(Ae(),ie(ke));return r()[e]?.[t]!==void 0}a(Zoe,"doesTableExist");function eae(e){try{return JSON.stringify(e)}catch{return e}}a(eae,"stringifyObj");function tae(e){let t=yh.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(tae,"ms_to_time");function rae(e,t){let r=xi.basename(e,xi.extname(e));return xi.join(xi.dirname(e),r+t)}a(rae,"changeExtension");function tO(){if(process.env[dt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[dt.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=Eoe(process.argv);if(e[dt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[dt.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(tO,"getEnvCliRootPath");var ZA;function nae(){if(ZA)return ZA;let e=tO();if(tO()&&QG.pathExistsSync(xi.join(e,dt.HDB_CONFIG_FILE)))return ZA=!0,!0}a(nae,"noBootFile");function sae(e,t){let r;return e.protocol==="http:"?r=moe:r=hoe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8");let c={body:"",headers:o.headers};o.on("data",u=>{c.body+=u}),o.on("end",()=>{n(c)})});i.on("error",o=>{s(o)}),i.write(JSON.stringify(t)),i.end()})}a(sae,"httpRequest");function iae(e){if(!e.schema&&!e.database){e.schema=dt.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(iae,"transformReq");function oae(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(oae,"convertToMS")});var ee=g((BTe,cq)=>{"use strict";var rO=require("fs-extra"),Go=require("path"),sq=require("os"),aae=require("properties-reader"),jl=$(),Xl=J(),de=P(),Ih=pr(),cae="Error initializing environment manager",wh="BOOT_PROPS_FILE_PATH",iq=!1,uae={[de.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},zs={};cq.exports={BOOT_PROPS_FILE_PATH:wh,getHdbBasePath:lae,setHdbBasePath:_ae,get:oq,initSync:fae,setProperty:Pe,initTestEnvironment:hae,setCloneVar:Eae};function lae(){return zs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(lae,"getHdbBasePath");function _ae(e){zs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(_ae,"setHdbBasePath");function oq(e){let t=Ih.getConfigValue(e);return t===void 0?zs[e]:t}a(oq,"get");function Pe(e,t){uae[e]&&(zs[e]=t),Ih.updateConfigObject(e,t)}a(Pe,"setProperty");function dae(){let e;try{e=Xl.getPropsFilePath(),rO.accessSync(e,rO.constants.F_OK|rO.constants.R_OK),iq=!0;let t=aae(e);return zs[de.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(de.HDB_SETTINGS_NAMES.INSTALL_USER),zs[de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),zs[wh]=e,!0}catch{return jl.trace(`Environment manager found no properties file at ${e}`),!1}}a(dae,"doesPropFileExist");function fae(e=!1){try{(iq||dae()||Xl.noBootFile())&&!aq&&(Ih.initConfig(e),zs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=Ih.getConfigValue(de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){jl.error(cae),jl.error(t),console.error(t),process.exit(1)}}a(fae,"initSync");var aq=!1;function Eae(e){aq=e}a(Eae,"setCloneVar");function hae(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,u=Go.join(__dirname,"../../","unitTests");zs[wh]=Go.join(u,"hdb_boot_properties.file"),Pe(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Go.join(u,"settings.test")),Pe(de.HDB_SETTINGS_NAMES.INSTALL_USER,sq.userInfo()?sq.userInfo().username:void 0),Pe(de.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Pe(de.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Go.join(u,"envDir","log")),Pe(de.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Pe(de.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Pe(de.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Pe(de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Go.join(u,"envDir")),Pe(de.CONFIG_PARAMS.STORAGE_PATH,Go.join(u,"envDir")),s&&(Pe(de.CONFIG_PARAMS.HTTP_SECUREPORT,oq(de.CONFIG_PARAMS.HTTP_PORT)),Pe(de.CONFIG_PARAMS.HTTP_PORT,null)),Pe(de.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Pe(de.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Pe(de.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Xl.isEmpty(i)?!1:i),Pe(de.CONFIG_PARAMS.HTTP_CORS,Xl.isEmpty(i)?!1:i),Pe(de.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Pe(de.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Pe(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Pe(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Pe(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Go.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Pe(de.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Xl.isEmpty(c)?!1:c),o&&(Pe("CORS_ACCESSLIST",o),Pe(de.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Pe(de.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Pe(de.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Pe(de.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Pe(de.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Pe(de.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Pe(de.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${wh}. Please check your boot props and settings files`;jl.fatal(r),jl.error(t)}}a(hae,"initTestEnvironment")});var fq=g((HTe,dq)=>{"use strict";var _q=require("joi"),{string:Zl,boolean:uq,array:mae}=_q.types(),lq=P(),pae=je();dq.exports=Sae;function Sae(e){let t=_q.object({operation:Zl.valid(lq.OPERATIONS_ENUM.ADD_NODE,lq.OPERATIONS_ENUM.UPDATE_NODE).required(),node_name:Zl.required(),subscriptions:mae.items({schema:Zl.required(),table:Zl.optional(),hash_attribute:Zl.optional(),subscribe:uq.required(),publish:uq.required()}).min(1).required()});return pae.validateBySchema(e,t)}a(Sae,"updateRemoteSourceValidator")});var e_=g((qTe,Eq)=>{"use strict";var nO=class{static{a(this,"UpdateRemoteResponseObject")}constructor(t,r,n=void 0){this.status=t,this.message=r,this.system_info=n}};Eq.exports=nO});var Sq=g((kTe,pq)=>{"use strict";var Tae=fq(),Js=$(),sO=Ve(),gae=P(),iO=fn(),qo=ut(),hq=yu(),Rae=md(),{Node:Aae,NodeSubscription:mq}=Ti(),oO=e_(),aO=J(),Oae=ee(),{cloneDeep:bae}=require("lodash"),{broadcast:yae}=Qe();pq.exports=Nae;async function Nae(e){try{let t=Tae(e);if(t)return Js.error(`Validation error in updateRemoteSource: ${t.message}`),new oO(sO.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,t.message);let{subscriptions:r,node_name:n,system_info:s}=e,i=[],o=bae(await iO.getNodeRecord(n)),c=!aO.isEmptyOrZeroLength(o);o=c?o[0]:o,c&&Js.trace(`Existing record found for ${n}, updating records subscriptions`);for(let _=0,l=r.length;_<l;_++){let d=r[_],E=d.schema,f=d.table;if(!aO.doesSchemaExist(E)){Js.trace(`updateRemoteSource creating schema: ${E}`);try{await hq.createSchema({operation:"create_schema",schema:E})}catch(h){Js.error(h)}}if(f&&!aO.doesTableExist(E,f)){let h=new Rae(E,f,d.hash_attribute);d.attributes&&(h.attributes=d.attributes),Js.trace(`updateRemoteSource creating table: ${f} in schema: ${E} with attributes: ${JSON.stringify(d.attributes)}`);try{await hq.createTable(h)}catch(p){Js.error(p)}}if(Js.trace(`Creating local stream for ${E}.${f}`),await qo.createLocalTableStream(E,f),c?(await qo.updateConsumerIterator(E,f,n,"stop"),await qo.updateRemoteConsumer(d,n),d.subscribe===!0&&await qo.updateConsumerIterator(E,f,n,"start")):(await qo.updateRemoteConsumer(d,n),d.subscribe===!0?await qo.updateConsumerIterator(E,f,n,"start"):await qo.updateConsumerIterator(E,f,n,"stop")),c){let h=!1;for(let p=0,S=o.subscriptions.length;p<S;p++){let T=o.subscriptions[p];if(T.schema===E&&T.table===f){T.publish=d.publish,T.subscribe=d.subscribe,h=!0;break}}h||o.subscriptions.push(new mq(E,f,d.publish,d.subscribe))}else i.push(new mq(E,f,d.publish,d.subscribe))}c||(o=new Aae(n,i,void 0),Js.trace(`No record found for ${n}, creating a new one`));let u=Object.create({});return Object.assign(u,o),u.system_info=s,await iO.upsertNodeRecord(u),yae({type:"nats_update"}),new oO(sO.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,`Node ${Oae.get(gae.CONFIG_PARAMS.CLUSTERING_NODENAME)} successfully updated remote source`,await iO.getSystemInfo())}catch(t){Js.error(t);let r=t.message?t.message:t;return new oO(sO.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(Nae,"updateRemoteSource")});var Aq=g(($Te,Rq)=>{"use strict";var gq=require("joi"),{string:Tq}=gq.types(),Iae=P(),wae=je();Rq.exports=Cae;function Cae(e){let t=gq.object({operation:Tq.valid(Iae.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:Tq.required()});return wae.validateBySchema(e,t)}a(Cae,"removeRemoteSourceValidator")});var yq=g((KTe,bq)=>{"use strict";var Dae=Aq(),Ch=$(),Dh=Ve(),cO=P(),Lae=fn(),Mae=J(),Oq=ut(),Pae=ee(),Lh=e_(),{NodeSubscription:Uae}=Ti(),vae=aa(),Bae=ci(),{broadcast:xae}=Qe(),Hae=Pae.get(cO.CONFIG_PARAMS.CLUSTERING_NODENAME);bq.exports=Gae;async function Gae(e){try{let t=Dae(e);if(t)return Ch.error(`Validation error in removeRemoteSource: ${t.message}`),new Lh(Dh.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,t.message);let r=e.node_name,n=await Lae.getNodeRecord(r);if(Mae.isEmptyOrZeroLength(n)){let i=`No record found for node '${r}'`;return Ch.error(i),new Lh(Dh.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,i)}n=n[0];for(let i=0,o=n.subscriptions.length;i<o;i++){let c=n.subscriptions[i];Ch.trace(`remove remote source removing subscription: ${c.schema}.${c.table} for node: ${r}`);let u=new Uae(c.schema,c.table,!1,!1);await Oq.updateConsumerIterator(c.schema,c.table,r,"stop"),await Oq.updateRemoteConsumer(u,r)}let s=new vae(cO.SYSTEM_SCHEMA_NAME,cO.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Bae.deleteRecord(s),xae({type:"nats_update"}),new Lh(Dh.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,`Node ${Hae} successfully removed node '${r}'.`)}catch(t){Ch.error(t);let r=t.message?t.message:t;return new Lh(Dh.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(Gae,"removeRemoteSource")});var Cq=g((QTe,wq)=>{"use strict";var Mh=$(),t_=P(),Nq=Ve(),uO=ee(),qae=J(),Iq=e_(),Fae=fn(),kae=Wd(),Vae=Fr();wq.exports=$ae;async function $ae(e){try{Mh.trace("getRemoteSourceConfig called");let t=process.uptime()*1e3,r=qae.ms_to_time(t),n=new Yae(uO.get(t_.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),uO.get(t_.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)??uO.get(t_.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT),r,await Fae.getSystemInfo());try{let s={name:e.node_name,system_info:e.system_info},i=new kae(t_.SYSTEM_SCHEMA_NAME,t_.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[s]);await Vae.update(i)}catch(s){Mh.error("Get remote config encountered an error updating system info for node:",e.node_name,s)}return Mh.trace("getRemoteSourceConfig response:",n),new Iq(Nq.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,n)}catch(t){Mh.error(t);let r=t.message?t.message:t;return new Iq(Nq.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a($ae,"getRemoteSourceConfig");function Yae(e,t,r,n){this.uptime=r,this.ports={clustering:e,operations_api:t},this.system_info=n}a(Yae,"ConfigResponseObject")});var Pq=g((JTe,Mq)=>{"use strict";var Dq=ee();Dq.initSync();var Lq=ut(),r_=$(),dc=P(),lO=Ve(),Kae=Sq(),Wae=yq(),Qae=Cq(),zae=e_(),{encode:Jae,decode:Xae}=require("msgpackr"),jae=ys(),Zae=bs(),ece=require("util"),tce=P(),{isMainThread:rce,parentPort:nce}=require("worker_threads");Qe();var sce=ece.promisify(jae.setSchemaDataToGlobal),_O=Dq.get(dc.CONFIG_PARAMS.CLUSTERING_NODENAME);Mq.exports=ice;async function ice(){try{r_.notify("Starting reply service."),await sce();let e=await Lq.getConnection(),t=`${_O}.__request__`,r=e.subscribe(t,{queue:_O});await oce(r)}catch(e){r_.error(e)}}a(ice,"initialize");async function oce(e){for await(let t of e){let r=Xae(t.data),n;switch(r.operation){case dc.OPERATIONS_ENUM.ADD_NODE:case dc.OPERATIONS_ENUM.UPDATE_NODE:n=await Kae(r);break;case dc.OPERATIONS_ENUM.REMOVE_NODE:n=await Wae(r);break;case dc.OPERATIONS_ENUM.CLUSTER_STATUS:n=await Qae(r);break;case dc.OPERATIONS_ENUM.DESCRIBE_ALL:n=await ace();break;default:let s=`node '${_O}' reply service received unrecognized request operation`;r_.error(s),n=new zae(lO.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,s)}r_.trace(n),t.respond(Jae(n))}}a(oce,"handleRequest");async function ace(){try{return{status:lO.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,message:await Zae.describeAll({bypass_auth:!0})}}catch(e){return r_.error(e),{status:lO.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,message:e.message}}}a(ace,"getRemoteDescribeAll");rce||nce.on("message",async e=>{let{type:t}=e;t===tce.ITC_EVENT_TYPES.SHUTDOWN&&Lq.closeConnection()})});var cce=Pq();(async()=>{try{await cce()}catch(e){console.error("Error launching Nats reply service."),console.error(e)}})();
|