harperdb 4.3.0-beta.2 → 4.3.0-beta.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/bin/harperdb.js +33 -30
- package/bin/lite.js +21 -18
- package/json/systemSchema.json +20 -0
- package/launchServiceScripts/launchInstallNATSServer.js +1 -1
- package/launchServiceScripts/launchNatsIngestService.js +21 -18
- package/launchServiceScripts/launchNatsReplyService.js +21 -18
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +21 -18
- package/npm-shrinkwrap.json +349 -349
- package/package.json +3 -3
- package/server/jobs/jobProcess.js +21 -18
- package/server/threads/threadServer.js +21 -18
- package/studio/build-local/asset-manifest.json +2 -2
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/static/js/{main.55fa2352.js → main.f2d1cee1.js} +2 -2
- package/utility/scripts/restartHdb.js +21 -18
- /package/studio/build-local/static/js/{main.55fa2352.js.LICENSE.txt → main.f2d1cee1.js.LICENSE.txt} +0 -0
|
@@ -1,27 +1,30 @@
|
|
|
1
|
-
"use strict";var Yx=Object.create;var Ka=Object.defineProperty;var Kx=Object.getOwnPropertyDescriptor;var Wx=Object.getOwnPropertyNames;var Qx=Object.getPrototypeOf,zx=Object.prototype.hasOwnProperty;var a=(e,t)=>Ka(e,"name",{value:t,configurable:!0});var Oe=(e,t)=>()=>(e&&(t=e(e=0)),t);var g=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),Ve=(e,t)=>{for(var r in t)Ka(e,r,{get:t[r],enumerable:!0})},SA=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Wx(t))!zx.call(e,s)&&s!==r&&Ka(e,s,{get:()=>t[s],enumerable:!(n=Kx(t,s))||n.enumerable});return e};var B=(e,t,r)=>(r=e!=null?Yx(Qx(e)):{},SA(t||!e||!e.__esModule?Ka(r,"default",{value:e,enumerable:!0}):r,e)),te=e=>SA(Ka({},"__esModule",{value:!0}),e);var RA=g((Cie,gA)=>{var Jx=require("fast-glob"),{statSync:QE,existsSync:zE,readFileSync:Xx,writeFileSync:jx}=require("fs"),{spawnSync:Zx,spawn:eF,execFileSync:Iie}=require("child_process"),{isMainThread:tF}=require("worker_threads"),{join:ks,relative:TA}=require("path"),{PACKAGE_ROOT:mn}=M(),{tmpdir:rF,platform:nF}=require("os");require("source-map-support").install();var sF=["resources","server","dataLayer","components"],Wa="ts-build",JE,iF=__filename.endsWith("tsBuild.js");if(iF){if(tF){let r;try{QE(ks(mn,Wa)),r=!0}catch{}if(r)for(let n of Jx.sync(sF.map(s=>s+"/**/*.ts"),{cwd:mn})){let s=0,i=0;try{s=QE(ks(mn,n)).mtimeMs-5e3,i=QE(ks(mn,Wa,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."),JE=!0;break}}else console.log("TypeScript modules are not compiled, compiling now"),JE=!0;if(JE){let n=ks(mn,"node_modules/.bin/tsc");nF()==="win32"&&(n+=".cmd");let s=Zx(n,{cwd:mn});if(s.stdout.length&&console.log(s.stdout.toString()),s.stderr.length&&console.log(s.stderr.toString()),r){let i=ks(rF(),"harperdb-tsc.pid"),o;if(zE(i))try{process.kill(+Xx(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=eF(n,["--watch"],{cwd:mn,detached:!0,stdio:"ignore"});jx(i,c.pid.toString()),c.unref()}}}}let e=gA.constructor,t=e._findPath;e._findPath=function(r,n,s){if(r.startsWith(".")&&!s&&n.length===1&&n[0].startsWith(mn)&&!n[0].includes("node_modules")){let i=TA(mn,n[0]),o;i.startsWith(Wa)?o=ks(mn,TA(Wa,i)):o=ks(mn,Wa,i);let c=ks(o,r),u=c+".js";if(zE(u))return u;if(c.includes(".")&&zE(c))return c}return t(r,n,s)}}});var M=g((Mie,vA)=>{"use strict";var zr=require("path"),oF=require("fs"),{relative:Die,join:Lie}=zr,{existsSync:aF}=oF;function cF(){let e=__dirname;for(;!aF(zr.join(e,"package.json"));){let t=zr.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(cF,"getHDBPackageRoot");var Vs=cF(),AA="js",Il=AA,uF="harperdb-config.yaml",lF="defaultConfig.yaml",_F="hdb",OA=`harperdb.${Il}`,bA=`customFunctionsServer.${Il}`,dF=`restartHdb.${Il}`,jE="HarperDB",wl="Custom Functions",Cl="Clustering Hub",Dl="Clustering Leaf",fF="Clustering Ingest Service",EF="Clustering Reply Service",hF="foreground.pid",mF="hdb.pid",pF="data",SF={HDB:jE,CLUSTERING_HUB:Cl,CLUSTERING_LEAF:Dl,CLUSTERING_INGEST_SERVICE:fF,CLUSTERING_REPLY_SERVICE:EF,CUSTOM_FUNCTIONS:wl,RESTART_HDB:"Restart HDB",INSTALL:"Install",RUN:"Run",STOP:"Stop",UPGRADE:"Upgrade",REGISTER:"Register",JOB:"Job",CLUSTERING_UPGRADE_4_0_0:"Upgrade-4-0-0"},TF={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},gF={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},RF={harperdb:jE,"clustering hub":Cl,"clustering leaf":Dl,"custom functions":wl,custom_functions:wl,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers"},AF={CLUSTERING_HUB_PROC_DESCRIPTOR:Cl,CLUSTERING_LEAF_PROC_DESCRIPTOR:Dl},XE={HDB:zr.join(Vs,"server/harperdb"),CUSTOM_FUNCTIONS:zr.join(Vs,"server/customFunctions"),CLUSTERING_HUB:zr.join(Vs,"server/nats"),CLUSTERING_LEAF:zr.join(Vs,"server/nats")},OF={HDB:zr.join(XE.HDB,OA),CUSTOM_FUNCTIONS:zr.join(XE.CUSTOM_FUNCTIONS,bA)},bF={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:zr.join(Vs,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:zr.join(Vs,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:zr.join(Vs,"launchServiceScripts/launchUpdateNodes4-0-0.js")},NF={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},NA="support@harperdb.io",yF="customer-success@harperdb.io",yA=1,wF=4141,wA="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",IF="https://www.harperdb.io/product",CF=`For support, please submit a request at ${wA} or contact ${NA}`,IA=`For license support, please contact ${yF}`,DF="None of the specified records were found.",LF="hash attribute not found",MF=`Your current license only supports ${yA} role. ${IA}`,UF="Your current license only supports 3 connections to a node.",PF="127.0.0.1",vF=1,BF=/^\.$/,HF=/^\.\.$/,xF="U+002E",FF=/\//g,qF="U+002F",GF=/U\+002F/g,kF=/^U\+002E$/,VF=/^U\+002EU\+002E$/,$F="d",YF=999999,KF="*",WF="--max-old-space-size=",QF="system",zF="__hdb_hash",JF=".harperdb",XF=".hdb",jF="keys",ZF="hdb_boot_properties.file",eq=".updateConfig.json",tq="SIGTSTP",rq=24,nq=6e4,sq=448,iq="blob",oq="trash",aq="database",cq="schema",uq="transactions",lq=".count",_q="id",dq="PROCESS_NAME",CA={SETTINGS_PATH_KEY:"settings_path"},DA=require("lodash"),fq={TC_AGREEMENT:"TC_AGREEMENT",CLUSTERING_USER:"CLUSTERING_USER",CLUSTERING_PASSWORD:"CLUSTERING_PASSWORD",HDB_ADMIN_USERNAME:"HDB_ADMIN_USERNAME",HDB_ADMIN_PASSWORD:"HDB_ADMIN_PASSWORD",OPERATIONSAPI_ROOT:"OPERATIONSAPI_ROOT",ROOTPATH:"ROOTPATH",OPERATIONSAPI_NETWORK_PORT:"OPERATIONSAPI_NETWORK_PORT",CLUSTERING_NODENAME:"CLUSTERING_NODENAME",CLUSTERING_ENABLED:"CLUSTERING_ENABLED",HDB_CONFIG:"HDB_CONFIG",OPERATIONSAPI_NETWORK_SECUREPORT:"OPERATIONSAPI_NETWORK_SECUREPORT",CLUSTERING_PORT:"CLUSTERING_PORT",HDB_ROOT:"HDB_ROOT",SERVER_PORT:"SERVER_PORT",NODE_NAME:"NODE_NAME",CLUSTERING:"CLUSTERING"},Eq={HDB_PATH_KEY:"HDB_INTERNAL_PATH",HDB_AUTH_HEADER:"hdb_auth_header",HDB_USER_DATA_KEY:"hdb_user",CHUNK_SIZE:1e3,MAX_CHARACTER_SIZE:250},hq={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},mq={JOB_TABLE_NAME:"hdb_job",NODE_TABLE_NAME:"hdb_nodes",ATTRIBUTE_TABLE_NAME:"hdb_attribute",LICENSE_TABLE_NAME:"hdb_license",ROLE_TABLE_NAME:"hdb_role",SCHEMA_TABLE_NAME:"hdb_schema",TABLE_TABLE_NAME:"hdb_table",USER_TABLE_NAME:"hdb_user",INFO_TABLE_NAME:"hdb_info"},pq={JOB_TABLE_HASH_ATTRIBUTE:"id",NODE_TABLE_HASH_ATTRIBUTE:"name",ATTRIBUTE_TABLE_HASH_ATTRIBUTE:"id",LICENSE_TABLE_HASH_ATTRIBUTE:"license_key",ROLE_TABLE_HASH_ATTRIBUTE:"id",SCHEMA_TABLE_HASH_ATTRIBUTE:"name",TABLE_TABLE_HASH_ATTRIBUTE:"id",USER_TABLE_HASH_ATTRIBUTE:"username",INFO_TABLE_ATTRIBUTE:"info_id"},Ar="hdb_internal:",Sq={CREATE_SCHEMA:Ar+"create_schema",CREATE_TABLE:Ar+"create_table",CREATE_ATTRIBUTE:Ar+"create_attribute",ADD_USER:Ar+"add_user",ALTER_USER:Ar+"alter_user",DROP_USER:Ar+"drop_user",HDB_NODES:Ar+"hdb_nodes",HDB_USERS:Ar+"hdb_users",HDB_WORKERS:Ar+"hdb_workers",CATCHUP:Ar+"catchup",SCHEMA_CATCHUP:Ar+"schema_catchup",WORKER_ROOM:Ar+"cluster_workers"},Tq={ATTR_ATTRIBUTE_KEY:"attribute",ATTR_CREATEDDATE_KEY:"createddate",ATTR_HASH_ATTRIBUTE_KEY:"hash_attribute",ATTR_ID_KEY:"id",ATTR_NAME_KEY:"name",ATTR_PASSWORD_KEY:"password",ATTR_RESIDENCE_KEY:"residence",ATTR_ROLE_KEY:"role",ATTR_SCHEMA_KEY:"schema",ATTR_SCHEMA_TABLE_KEY:"schema_table",ATTR_TABLE_KEY:"table",ATTR_USERNAME_KEY:"username"},gq="060493.ks",Rq=".license",Aq={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},j={INSERT:"insert",UPDATE:"update",UPSERT:"upsert",SEARCH_BY_CONDITIONS:"search_by_conditions",SEARCH_BY_HASH:"search_by_hash",SEARCH_BY_ID:"search_by_id",SEARCH_BY_VALUE:"search_by_value",SEARCH:"search",SQL:"sql",CSV_DATA_LOAD:"csv_data_load",CSV_FILE_LOAD:"csv_file_load",CSV_URL_LOAD:"csv_url_load",CREATE_SCHEMA:"create_schema",CREATE_DATABASE:"create_database",CREATE_TABLE:"create_table",CREATE_ATTRIBUTE:"create_attribute",DROP_SCHEMA:"drop_schema",DROP_DATABASE:"drop_database",DROP_TABLE:"drop_table",DESCRIBE_SCHEMA:"describe_schema",DESCRIBE_DATABASE:"describe_database",DESCRIBE_TABLE:"describe_table",DESCRIBE_ALL:"describe_all",DELETE:"delete",ADD_USER:"add_user",ALTER_USER:"alter_user",DROP_USER:"drop_user",LIST_USERS:"list_users",LIST_ROLES:"list_roles",ADD_ROLE:"add_role",ALTER_ROLE:"alter_role",DROP_ROLE:"drop_role",USER_INFO:"user_info",READ_LOG:"read_log",ADD_NODE:"add_node",UPDATE_NODE:"update_node",SET_NODE_REPLICATION:"set_node_replication",EXPORT_TO_S3:"export_to_s3",IMPORT_FROM_S3:"import_from_s3",DELETE_FILES_BEFORE:"delete_files_before",DELETE_RECORDS_BEFORE:"delete_records_before",EXPORT_LOCAL:"export_local",SEARCH_JOBS_BY_START_DATE:"search_jobs_by_start_date",GET_JOB:"get_job",DELETE_JOB:"delete_job",UPDATE_JOB:"update_job",GET_FINGERPRINT:"get_fingerprint",SET_LICENSE:"set_license",GET_REGISTRATION_INFO:"registration_info",CONFIGURE_CLUSTER:"configure_cluster",SET_CONFIGURATION:"set_configuration",CLUSTER_STATUS:"cluster_status",CLUSTER_NETWORK:"cluster_network",DROP_ATTRIBUTE:"drop_attribute",REMOVE_NODE:"remove_node",RESTART:"restart",RESTART_SERVICE:"restart_service",CATCHUP:"catchup",SYSTEM_INFORMATION:"system_information",DELETE_AUDIT_LOGS_BEFORE:"delete_audit_logs_before",READ_AUDIT_LOG:"read_audit_log",CREATE_AUTHENTICATION_TOKENS:"create_authentication_tokens",LOGIN:"login",LOGOUT:"logout",REFRESH_OPERATION_TOKEN:"refresh_operation_token",GET_CONFIGURATION:"get_configuration",CUSTOM_FUNCTIONS_STATUS:"custom_functions_status",GET_CUSTOM_FUNCTIONS:"get_custom_functions",GET_CUSTOM_FUNCTION:"get_custom_function",SET_CUSTOM_FUNCTION:"set_custom_function",GET_COMPONENTS:"get_components",GET_COMPONENT_FILE:"get_component_file",SET_COMPONENT_FILE:"set_component_file",DROP_COMPONENT:"drop_component",DROP_CUSTOM_FUNCTION:"drop_custom_function",ADD_CUSTOM_FUNCTION_PROJECT:"add_custom_function_project",ADD_COMPONENT:"add_component",DROP_CUSTOM_FUNCTION_PROJECT:"drop_custom_function_project",PACKAGE_CUSTOM_FUNCTION_PROJECT:"package_custom_function_project",DEPLOY_CUSTOM_FUNCTION_PROJECT:"deploy_custom_function_project",PACKAGE_COMPONENT:"package_component",DEPLOY_COMPONENT:"deploy_component",CLUSTER_SET_ROUTES:"cluster_set_routes",CLUSTER_DELETE_ROUTES:"cluster_delete_routes",CLUSTER_GET_ROUTES:"cluster_get_routes",READ_TRANSACTION_LOG:"read_transaction_log",DELETE_TRANSACTION_LOGS_BEFORE:"delete_transaction_logs_before",INSTALL_NODE_MODULES:"install_node_modules",AUDIT_NODE_MODULES:"audit_node_modules",PURGE_STREAM:"purge_stream",GET_BACKUP:"get_backup"},Oq={CSV:".csv",JSON:".json"},bq={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},Nq={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},Qa={};Qa[j.INSERT]=j.INSERT;Qa[j.UPDATE]=j.UPDATE;Qa[j.UPSERT]=j.UPSERT;Qa[j.DELETE]=j.DELETE;var Be=Object.create(null);Be[j.DESCRIBE_ALL]=j.DESCRIBE_ALL;Be[j.DESCRIBE_TABLE]=j.DESCRIBE_TABLE;Be[j.DESCRIBE_SCHEMA]=j.DESCRIBE_SCHEMA;Be[j.READ_LOG]=j.READ_LOG;Be[j.ADD_NODE]=j.ADD_NODE;Be[j.LIST_USERS]=j.LIST_USERS;Be[j.LIST_ROLES]=j.LIST_ROLES;Be[j.USER_INFO]=j.USER_INFO;Be[j.SQL]=j.SQL;Be[j.GET_JOB]=j.GET_JOB;Be[j.SEARCH_JOBS_BY_START_DATE]=j.SEARCH_JOBS_BY_START_DATE;Be[j.DELETE_FILES_BEFORE]=j.DELETE_FILES_BEFORE;Be[j.EXPORT_LOCAL]=j.EXPORT_LOCAL;Be[j.EXPORT_TO_S3]=j.EXPORT_TO_S3;Be[j.CLUSTER_STATUS]=j.CLUSTER_STATUS;Be[j.REMOVE_NODE]=j.REMOVE_NODE;Be[j.RESTART]=j.RESTART;Be[j.CUSTOM_FUNCTIONS_STATUS]=j.CUSTOM_FUNCTIONS_STATUS;Be[j.GET_CUSTOM_FUNCTIONS]=j.GET_CUSTOM_FUNCTIONS;Be[j.GET_CUSTOM_FUNCTION]=j.GET_CUSTOM_FUNCTION;Be[j.SET_CUSTOM_FUNCTION]=j.SET_CUSTOM_FUNCTION;Be[j.DROP_CUSTOM_FUNCTION]=j.DROP_CUSTOM_FUNCTION;Be[j.ADD_CUSTOM_FUNCTION_PROJECT]=j.ADD_CUSTOM_FUNCTION_PROJECT;Be[j.DROP_CUSTOM_FUNCTION_PROJECT]=j.DROP_CUSTOM_FUNCTION_PROJECT;Be[j.PACKAGE_CUSTOM_FUNCTION_PROJECT]=j.PACKAGE_CUSTOM_FUNCTION_PROJECT;Be[j.DEPLOY_CUSTOM_FUNCTION_PROJECT]=j.DEPLOY_CUSTOM_FUNCTION_PROJECT;var yq={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"},wq={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},LA={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"},Iq=DA.invert(LA),Cq={CUSTOMFUNCTIONS_ENABLED:"customFunctions_enabled",CUSTOMFUNCTIONS_NETWORK_PORT:"customFunctions_network_port",CUSTOMFUNCTIONS_TLS_CERTIFICATE:"customFunctions_tls_certificate",CUSTOMFUNCTIONS_NETWORK_CORS:"customFunctions_network_cors",CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST:"customFunctions_network_corsAccessList",CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT:"customFunctions_network_headersTimeout",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT:"customFunctions_network_keepAliveTimeout",CUSTOMFUNCTIONS_TLS_PRIVATEKEY:"customFunctions_tls_privateKey",CUSTOMFUNCTIONS_TLS_CERT_AUTH:"customFunctions_tls_certificateAuthority",CUSTOMFUNCTIONS_NETWORK_TIMEOUT:"customFunctions_network_timeout",CUSTOMFUNCTIONS_NODEENV:"customFunctions_nodeEnv",CUSTOMFUNCTIONS_ROOT:"customFunctions_root"},C={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",MAXHEAPMEMORY:"maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_PATH:"storage_path",STORAGE_AUDIT_PATH:"storage_audit_path",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers"},MA={settings_path:CA.SETTINGS_PATH_KEY,hdb_root_key:C.ROOTPATH,hdb_root:C.ROOTPATH,rootpath:C.ROOTPATH,server_port_key:C.OPERATIONSAPI_NETWORK_PORT,server_port:C.OPERATIONSAPI_NETWORK_PORT,cert_key:C.TLS_CERTIFICATE,certificate:C.TLS_CERTIFICATE,private_key_key:C.TLS_PRIVATEKEY,private_key:C.TLS_PRIVATEKEY,http_secure_enabled_key:C.OPERATIONSAPI_NETWORK_HTTPS,https_on:C.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:C.OPERATIONSAPI_NETWORK_CORS,cors_on:C.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:C.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:C.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:C.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:C.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:C.LOGGING_LEVEL,log_level:C.LOGGING_LEVEL,log_path_key:C.LOGGING_ROOT,log_path:C.LOGGING_ROOT,clustering_node_name_key:C.CLUSTERING_NODENAME,node_name:C.CLUSTERING_NODENAME,clustering_enabled_key:C.CLUSTERING_ENABLED,clustering:C.CLUSTERING_ENABLED,max_http_threads:C.THREADS,max_hdb_processes:C.THREADS,server_timeout_key:C.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:C.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:C.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:C.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:C.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:C.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:C.LOGGING_AUDITLOG,disable_transaction_log:C.LOGGING_AUDITLOG,operation_token_timeout_key:C.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:C.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:C.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:C.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:C.HTTP_PORT,custom_functions_port:C.HTTP_PORT,custom_functions_directory_key:C.COMPONENTSROOT,custom_functions_directory:C.COMPONENTSROOT,max_custom_function_processes:C.THREADS,log_to_file:C.LOGGING_FILE,log_to_stdstreams:C.LOGGING_STDSTREAMS,local_studio_on:C.LOCALSTUDIO_ENABLED,clustering_port:C.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:C.CLUSTERING_USER,clustering_enabled:C.CLUSTERING_ENABLED,clustering_hubserver_cluster_name:C.CLUSTERING_HUBSERVER_CLUSTER_NAME,clustering_hubserver_cluster_network_port:C.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_hubserver_cluster_network_routes:C.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,clustering_hubserver_leafnodes_network_port:C.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT,clustering_hubserver_network_port:C.CLUSTERING_HUBSERVER_NETWORK_PORT,clustering_leafserver_network_port:C.CLUSTERING_LEAFSERVER_NETWORK_PORT,clustering_leafserver_network_routes:C.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,clustering_leafserver_streams_maxage:C.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE,clustering_leafserver_streams_maxbytes:C.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES,clustering_leafserver_streams_maxmsgs:C.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS,clustering_leafserver_streams_path:C.CLUSTERING_LEAFSERVER_STREAMS_PATH,clustering_nodename:C.CLUSTERING_NODENAME,clustering_tls_certificate:C.CLUSTERING_TLS_CERTIFICATE,clustering_tls_privatekey:C.CLUSTERING_TLS_PRIVATEKEY,clustering_tls_certificateauthority:C.CLUSTERING_TLS_CERT_AUTH,clustering_tls_insecure:C.CLUSTERING_TLS_INSECURE,clustering_tls_verify:C.CLUSTERING_TLS_VERIFY,clustering_loglevel:C.CLUSTERING_LOGLEVEL,clustering_republishmessages:C.CLUSTERING_REPUBLISHMESSAGES,clustering_databaselevel:C.CLUSTERING_DATABASELEVEL,customfunctions_network_port:C.HTTP_PORT,customfunctions_tls_certificate:C.TLS_CERTIFICATE,customfunctions_network_cors:C.HTTP_CORS,customfunctions_network_corsaccesslist:C.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:C.HTTP_HEADERSTIMEOUT,customfunctions_network_https:C.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:C.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:C.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:C.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:C.HTTP_TIMEOUT,http_threads:C.THREADS,threads:C.THREADS,maxheapmemory:C.MAXHEAPMEMORY,http_session_affinity:C.HTTP_SESSIONAFFINITY,http_compressionthreshold:C.HTTP_COMPRESSIONTHRESHOLD,http_cors:C.HTTP_CORS,http_corsaccesslist:C.HTTP_CORSACCESSLIST,http_headerstimeout:C.HTTP_HEADERSTIMEOUT,http_keepalivetimeout:C.HTTP_KEEPALIVETIMEOUT,http_timeout:C.HTTP_TIMEOUT,http_port:C.HTTP_PORT,http_secureport:C.HTTP_SECUREPORT,http_mtls:C.HTTP_MTLS,http_mtls_user:C.HTTP_MTLS_USER,http_mtls_required:C.HTTP_MTLS_REQUIRED,customfunctions_processes:C.THREADS,customfunctions_root:C.COMPONENTSROOT,localstudio_enabled:C.LOCALSTUDIO_ENABLED,logging_file:C.LOGGING_FILE,logging_level:C.LOGGING_LEVEL,logging_root:C.LOGGING_ROOT,logging_rotation_enabled:C.LOGGING_ROTATION_ENABLED,logging_rotation_compress:C.LOGGING_ROTATION_COMPRESS,logging_rotation_interval:C.LOGGING_ROTATION_INTERVAL,logging_rotation_maxsize:C.LOGGING_ROTATION_MAXSIZE,logging_rotation_path:C.LOGGING_ROTATION_PATH,logging_stdstreams:C.LOGGING_STDSTREAMS,logging_auditlog:C.LOGGING_AUDITLOG,logging_auditretention:C.LOGGING_AUDITRETENTION,logging_auditauthevents_logfailed:C.LOGGING_AUDITAUTHEVENTS_LOGFAILED,logging_auditauthevents_logsuccessful:C.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL,operationsapi_authentication_operationtokentimeout:C.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operationsapi_authentication_refreshtokentimeout:C.AUTHENTICATION_REFRESHTOKENTIMEOUT,operationsapi_network_cors:C.OPERATIONSAPI_NETWORK_CORS,operationsapi_network_corsaccesslist:C.OPERATIONSAPI_NETWORK_CORSACCESSLIST,operationsapi_network_headerstimeout:C.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,operationsapi_network_https:C.OPERATIONSAPI_NETWORK_HTTPS,operationsapi_network_keepalivetimeout:C.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,operationsapi_network_port:C.OPERATIONSAPI_NETWORK_PORT,operationsapi_network_domainsocket:C.OPERATIONSAPI_NETWORK_DOMAINSOCKET,operationsapi_network_secureport:C.OPERATIONSAPI_NETWORK_SECUREPORT,operationsapi_tls_certificate:C.OPERATIONSAPI_TLS_CERTIFICATE,operationsapi_tls_privatekey:C.OPERATIONSAPI_TLS_PRIVATEKEY,operationsapi_tls_certificateauthority:C.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY,operationsapi_network_timeout:C.OPERATIONSAPI_NETWORK_TIMEOUT,operationsapi_root:C.ROOTPATH,databases:C.DATABASES,storage_path:C.STORAGE_PATH,ignorescripts:C.IGNORE_SCRIPTS,mqtt_network_port:C.MQTT_NETWORK_PORT,mqtt_websocket:C.MQTT_WEBSOCKET,mqtt_network_secureport:C.MQTT_NETWORK_SECUREPORT,mqtt_network_mtls:C.MQTT_NETWORK_MTLS,mqtt_network_mtls_certificateAuthority:C.MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY,mqtt_network_mtls_user:C.MQTT_NETWORK_MTLS_USER,mqtt_network_mtls_required:C.MQTT_NETWORK_MTLS_REQUIRED,mqtt_requireauthentication:C.MQTT_REQUIREAUTHENTICATION,analytics_aggregatePeriod:C.ANALYTICS_AGGREGATEPERIOD,authentication_authorizelocal:C.AUTHENTICATION_AUTHORIZELOCAL,authentication_cachettl:C.AUTHENTICATION_CACHETTL,authentication_enablesessions:C.AUTHENTICATION_ENABLESESSIONS,authentication_operationtokentimeout:C.AUTHENTICATION_OPERATIONTOKENTIMEOUT,authentication_refreshtokentimeout:C.AUTHENTICATION_REFRESHTOKENTIMEOUT,componentsroot:C.COMPONENTSROOT,tls_certificate:C.TLS_CERTIFICATE,tls_privatekey:C.TLS_PRIVATEKEY,tls_certificateauthority:C.TLS_CERTIFICATEAUTHORITY,tls_ciphers:C.TLS_CIPHERS};for(let e in C){let t=C[e];MA[t.toLowerCase()]=t}var Dq={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},Lq={csv_file_load:"csv_file_load",csv_data_load:j.CSV_DATA_LOAD,csv_url_load:j.CSV_URL_LOAD,delete_files_before:"delete_files_before",delete_records_before:"delete_records_before",delete_audit_logs_before:"delete_audit_logs_before",delete_transaction_logs_before:"delete_transaction_logs_before",empty_trash:"empty_trash",export_local:"export_local",export_to_s3:"export_to_s3",import_from_s3:"import_from_s3"},Mq={CLUSTERING_PAYLOAD:"clustering_payload",DELEGATE_THREAD_RESPONSE:"delegate_thread_response",CLUSTERING:"clustering",SCHEMA:"schema",CLUSTER_STATUS:"cluster_status",JOB:"job",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",USER:"user",RESTART:"restart"},Uq={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},Pq={VERSION_DEFAULT:"2.2.0"},vq={DEVELOPMENT:8192,DEFAULT:512},Bq={IDENTIFY:"identify",AUTHENTICATE:"authenticate",AUTHENTICATE_OK:"authenticated",AUTHENTICATE_FAIL:"authenticate_fail",CONNECTION:"connection",CONNECT:"connect",CATCHUP_REQUEST:"catchup_request",CATCHUP_RESPONSE:"catchup",CONFIRM_MSG:"confirm_msg",ERROR:"error",DISCONNECT:"disconnect",SCHEMA_UPDATE_REQ:"schema_update_request",SCHEMA_UPDATE_RES:"schema_update_response",RECONNECT_ATTEMPT:"reconnect_attempt",CONNECT_ERROR:"connect_error",MESSAGE:"msg",VERSION_MISMATCH:"version_mismatch",DIRECTION_CHANGE:"direction_change"},Hq={1e3:"SUCCESSFUL_SHUTDOWN",1001:"CLOSE_GOING_AWAY",1002:"CLOSE_PROTOCOL_ERROR",1003:"CLOSE_UNSUPPORTED",1005:"CLOSE_NO_STATUS",1006:"CLOSE_ABNORMAL",1007:"UNSUPPORTED_PAYLOAD",1008:"POLICY_VIOLATION",1009:"CLOSE_TOO_LARGE",1010:"MANDATORY_EXTENSION",1011:"SERVER_ERROR",1012:"SERVICE_RESTART",1013:"SERVER_BUSY",1014:"BAD_GATEWAY",1015:"HANDSHAKE_FAIL",4141:"LICENSE_LIMIT_REACHED"},xq={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST"},UA={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},Fq=Symbol("metadata"),qq="__clustering__",Gq=Object.values(UA),kq=15984864e5,PA={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},Vq=DA.invert(PA),$q={GET_CLUSTER_STATUS:"GET_CLUSTER_STATUS",CLUSTER_STATUS_RESPONSE:"CLUSTER_STATUS_RESPONSE",ERROR_RESPONSE:"ERROR",ADD_USER:"ADD_USER",ALTER_USER:"ALTER_USER",DROP_USER:"DROP_USER",HDB_OPERATION:"HDB_OPERATION",ADD_NODE:"ADD_NODE",UPDATE_NODE:"UPDATE_NODE",REMOVE_NODE:"REMOVE_NODE",HDB_USERS_MSG:"HDB_USERS_MSG",HDB_WORKERS:"HDB_WORKERS",HDB_TRANSACTION:"HDB_TRANSACTION"},Yq=111,Kq=`\r
|
|
2
|
-
`,
|
|
3
|
-
`}a(
|
|
4
|
-
`).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:NG.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(CG,"findPs")});var lt=g((qie,jA)=>{"use strict";var DG="__dbis__",LG="__txns__",MG="__environment_name__",UG="__dbi_defintion__",PG={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"},vG=["__createdtime__","__updatedtime__"],BG="\uFFFF",XA={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},HG=Object.values(XA);jA.exports={AUDIT_STORE_NAME:LG,INTERNAL_DBIS_NAME:DG,DBI_DEFINITION_NAME:UG,SEARCH_TYPES:PG,TIMESTAMP_NAMES:vG,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:MG,TRANSACTIONS_DBI_NAMES_ENUM:XA,TRANSACTIONS_DBIS:HG,OVERFLOW_MARKER:BG}});var Or=g((Gie,aO)=>{"use strict";var ZA=M(),eO=lt(),tO={CONTINUE:100,OK:200,CREATED:201,BAD_REQUEST:400,UNAUTHORIZED:401,FORBIDDEN:403,NOT_FOUND:404,METHOD_NOT_ALLOWED:405,REQUEST_TIMEOUT:408,CONFLICT:409,TOO_MANY_REQUESTS:429,INTERNAL_SERVER_ERROR:500,NOT_IMPLEMENTED:501,BAD_GATEWAY:502,SERVICE_UNAVAILABLE:503,GATEWAY_TIMEOUT:504,HTTP_VERSION_NOT_SUPPORTED:505,INSUFFICIENT_STORAGE:507,NETWORK_AUTHENTICATION_REQUIRED:511},rO=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),nO={500:rO("There was an error processing your request."),400:"Invalid request"},xG=nO[tO.INTERNAL_SERVER_ERROR],FG={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.`},qG={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},GG={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"},kG={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 ${eO.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${eO.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"},VG={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${ZA.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 ${ZA.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"},sO={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"},$G={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."},YG={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`},KG={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"},WG={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},QG={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`},iO={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.`},oO={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}`},zG={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."},JG={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},XG={...sO,...GG,...FG,...$G,...YG,...KG,...WG,...QG,...VG,...iO,...oO,...zG,...JG,...qG};aO.exports={CHECK_LOGS_WRAPPER:rO,HDB_ERROR_MSGS:XG,DEFAULT_ERROR_MSGS:nO,DEFAULT_ERROR_RESP:xG,HTTP_STATUS_CODES:tO,LMDB_ERRORS_ENUM:kG,AUTHENTICATION_ERROR_MSGS:sO,VALIDATION_ERROR_MSGS:iO,ITC_ERRORS:oO}});var ee=g((Vie,lO)=>{"use strict";var Lo=Or(),jG=Y(),ZG=M(),vl=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,cO),this.statusCode=n||Lo.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(Lo.DEFAULT_ERROR_MSGS[n]?Lo.DEFAULT_ERROR_MSGS[n]:Lo.DEFAULT_ERROR_MSGS[Lo.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&&jG[s](i)}},ah=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}},ch=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function cO(e,t,r,n=ZG.LOG_LEVELS.ERROR,s=null,i=!1){if(uO(e))return e;let o=new vl(e,t,r,n,s);return i&&delete o.stack,o}a(cO,"handleHDBError");function uO(e){return e.__proto__.constructor.name===vl.name}a(uO,"isHDBError");lO.exports={isHDBError:uO,handleHDBError:cO,ClientError:ah,ServerError:ch,hdb_errors:Lo}});var Ke=g((Yie,pO)=>{"use strict";var sc=M(),ek=J(),jt=Z(),ic=require("path"),tk=require("minimist"),_O=require("fs-extra"),dO=require("lodash");jt.initSync();var{CONFIG_PARAMS:$s,DATABASES_PARAM_CONFIG:ec,SYSTEM_SCHEMA_NAME:Bl}=sc,tc,rc,nc;function fO(){if(tc!==void 0)return tc;if(jt.getHdbBasePath()!==void 0)return tc=jt.get($s.STORAGE_PATH)||ic.join(jt.getHdbBasePath(),sc.DATABASES_DIR_NAME),tc}a(fO,"getBaseSchemaPath");function EO(){if(rc!==void 0)return rc;if(jt.getHdbBasePath()!==void 0)return rc=mO(Bl),rc}a(EO,"getSystemSchemaPath");function hO(){if(nc!==void 0)return nc;if(jt.getHdbBasePath()!==void 0)return nc=jt.get(sc.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||ic.join(jt.getHdbBasePath(),sc.TRANSACTIONS_DIR_NAME),nc}a(hO,"getTransactionAuditStoreBasePath");function rk(e,t){let r=jt.get($s.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||ic.join(hO(),e.toString())}a(rk,"getTransactionAuditStorePath");function mO(e,t){e=e.toString(),t=t&&t.toString();let r=jt.get(sc.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||ic.join(fO(),e)}a(mO,"getSchemaPath");function nk(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,tk(process.argv));let n=r[$s.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!ek.isObject(n))throw o;i=n}for(let o of i){let c=o[Bl];if(!c)continue;let u=jt.get($s.DATABASES);u=u??{};let _=c?.tables?.[t]?.[ec.PATH];if(_)return dO.set(u,[Bl,ec.TABLES,t,ec.PATH],_),jt.setProperty($s.DATABASES,u),_;let l=c?.[ec.PATH];if(l)return dO.set(u,[Bl,ec.PATH],l),jt.setProperty($s.DATABASES,u),l}}let s=r[$s.STORAGE_PATH.toUpperCase()];if(s){if(!_O.pathExistsSync(s))throw new Error(s+" does not exist");let i=ic.join(s,e);return _O.mkdirsSync(i),jt.setProperty($s.STORAGE_PATH,s),i}return EO()}a(nk,"initSystemSchemaPaths");function sk(){tc=void 0,rc=void 0,nc=void 0}a(sk,"resetPaths");pO.exports={getBaseSchemaPath:fO,getSystemSchemaPath:EO,getTransactionAuditStorePath:rk,getTransactionAuditStoreBasePath:hO,getSchemaPath:mO,initSystemSchemaPaths:nk,resetPaths:sk}});var br=g((zie,AO)=>{"use strict";var ik=Or().LMDB_ERRORS_ENUM,Wie=require("lmdb"),ok=lt(),Qie=require("buffer").Buffer,{OVERFLOW_MARKER:SO,MAX_SEARCH_KEY_LENGTH:Hl}=ok,TO=["number","string","symbol","boolean","bigint"];function ak(e){if(e=e?.primaryStore||e,!e)throw new Error(ik.ENV_REQUIRED)}a(ak,"validateEnv");function ck(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(ck,"stringifyData");function uk(e){return e instanceof Date?e.valueOf():e}a(uk,"convertKeyValueToWrite");function lk(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(TO.includes(typeof e))return e.length>Hl?[e.slice(0,Hl)+SO]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(TO.includes(typeof i))i.length>Hl?r.push(i.slice(0,Hl)+SO):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(lk,"getIndexedValues");var xl=0,gO=0;function RO(){gO=Date.now()-performance.now()}a(RO,"adjustStartTime");RO();var _k=6e4;setInterval(RO,_k).unref();function dk(){let e=performance.now()+gO;return e>xl?(xl=e,e):(xl+=488e-6,xl)}a(dk,"getNextMonotonicTime");AO.exports={validateEnv:ak,stringifyData:ck,convertKeyValueToWrite:uk,getNextMonotonicTime:dk,getIndexedValues:lk}});var OO,pn,uh,oc=Oe(()=>{OO=require("events"),pn=class extends OO.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;[Symbol.asyncIterator](){let t=new uh;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){return this.queue?.shift()}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},uh=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 bi={};Ve(bi,{server:()=>Xe});var bO,Xe,Zt=Oe(()=>{bO=require("../../index"),Xe={};(0,bO._assignPackageExport)("server",Xe)});var _h={};Ve(_h,{loadGQLSchema:()=>hk,start:()=>lh,startOnMainThread:()=>Ek});function lh({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:u,NamedTypeNode:_,StringValueNode:l}=await import("graphql"),d=o(new c(r.toString(),s)),f=new Map,E=[],h;for(let S of d.definitions)switch(S.kind){case u.OBJECT_TYPE_DEFINITION:let F=function(v){if(v.kind==="NonNullType"){let W=F(v.type);return W.nullable=!1,W}if(v.kind==="ListType")return{type:"array",elements:F(v.type)};let z={type:v.name?.value};return Object.defineProperty(z,"location",{value:v.loc.startToken}),z};a(F,"getProperty");let T=S.name.value,A=[],b={table:null,database:null,properties:A};f.set(T,b);for(let v of S.directives){if(v.name.value==="table"){for(let P of v.arguments)b[P.name.value]=P.value.value;b.schema&&(b.database=b.schema),b.table||(b.table=T),b.audit&&(b.audit=b.audit!=="false"),b.attributes=b.properties,E.push(b)}if(v.name.value==="sealed"&&(b.sealed=!0),v.name.value==="export"){b.export=!0;for(let P of v.arguments)P.name.value==="name"&&(b.export={name:P.value.value})}}let H=!1;for(let v of S.fields){let P=F(v.type);P.name=v.name.value,A.push(P);for(let z of v.directives)if(z.name.value==="primaryKey")H?console.warn("Can not define two attributes as a primary key"):(P.isPrimaryKey=!0,H=!0);else if(z.name.value==="indexed")P.indexed=!0;else if(z.name.value==="relationship"){let W={};for(let Q of z.arguments)W[Q.name.value]=Q.value.value;P.relationship=W}else if(z.name.value==="createdTime")P.assignCreatedTime=!0;else if(z.name.value==="updatedTime")P.assignUpdatedTime=!0;else if(z.name.value==="expiresAt")P.expiresAt=!0;else if(z.name.value==="allow"){let W=P.authorizedRoles=[];for(let Q of z.arguments)Q.name.value==="role"&&W.push(Q.value.value)}}b.type=T,T==="Query"&&(h=b)}function p(S){let T=f.get(S.type);T?(Object.defineProperty(S,"properties",{value:T.properties}),Object.defineProperty(S,"definition",{value:T})):S.type==="array"?p(S.elements):fk.includes(S.type)||(0,NO.getWorkerIndex)()===0&&console.error(`The type ${S.type} is unknown at line ${S.location.line}, column ${S.location.column}, in ${s}`)}a(p,"connectPropertyType");for(let S of f.values())for(let T of S.properties)p(T);for(let S of E)S.tableClass=e(S),S.export&&(S.export.name===""?i.set((0,Fl.dirname)(n),S.tableClass):i.set((0,Fl.dirname)(n)+"/"+(S.export.name||S.type),S.tableClass));if(h)for(let S of h.properties){let T=f.get(S.type);if(!T)throw new Error(`${S.type} was not found as a Query export`);i.set((0,Fl.dirname)(n)+"/"+S.name,T.tableClass)}}}var Fl,NO,fk,Ek,hk,yO=Oe(()=>{Fl=require("path");be();NO=B(je()),fk=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];a(lh,"start");Ek=lh,hk=lh({ensureTable:ot}).handleFile});async function ql(e){return mk?(ac||(ac=pk(Tk)),(await(await ac).import(e)).namespace):import(e)}async function pk(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),ac=new Compartment({console,Math,Date,fetch:Sk,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,IO.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Bt,tables:Nr,databases:Ze})}};let n=await(0,wO.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),ac}function Sk(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 Tk(){return{Resource:Bt,tables:Nr}}var wO,IO,mk,ac,dh=Oe(()=>{Sn();be();wO=require("fs/promises"),IO=require("path"),mk=!1;a(ql,"secureImport");a(pk,"getCompartment");a(Sk,"secureOnlyFetch");a(Tk,"getGlobalVars")});var Eh={};Ve(Eh,{handleFile:()=>gk});async function gk(e,t,r,n){let s=new Map,i=(0,CO.pathToFileURL)(r).toString(),o=await ql(i);u(o.default)&&n.set((0,fh.dirname)(t),o.default),c(o,(0,fh.dirname)(t));function c(_,l){for(let d in _){let f=_[d];u(f)?n.set(l+"/"+d,f):typeof f=="object"&&c(f,l+"/"+d)}}a(c,"recurseForResources");function u(_){return typeof _=="function"&&(_.get||_.put||_.post||_.delete)}return a(u,"isResource"),s}var CO,fh,DO=Oe(()=>{CO=require("url");dh();fh=require("path");a(gk,"handleFile")});var mh={};Ve(mh,{start:()=>Rk});function Rk({resources:e}){e.set("login",hh),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var hh,LO=Oe(()=>{Sn();a(Rk,"start");hh=class extends Bt{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 xO={};Ve(xO,{parse:()=>Sh,streamAsJSON:()=>cc,stringify:()=>Ni});function cc(e){return new ph({value:e})}function MO(e){return console.error(e),JSON.stringify(e.toString())}function UO(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Ni(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===BO)return HO(e);if(t.resolution)return t.resolution.then(()=>Ni(e));throw t}}function HO(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+=HO(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Ni(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Sh(e){return bk.test(e)?Ak.parse(e):JSON.parse(e)}var PO,vO,Ak,Ok,BO,ph,bk,Th=Oe(()=>{PO=require("stream"),vO=B(require("json-bigint-fixes")),Ak=(0,vO.default)({useNativeBigInt:!0}),Ok=1e4,BO={};BigInt.prototype.toJSON=function(){throw BO};a(cc,"streamAsJSON");ph=class extends PO.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),MO)}catch(s){yield MO(s)}else yield Ni(t)}else yield Ni(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);UO(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>Ok?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 UO(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(MO,"handleError");a(UO,"when");a(Ni,"stringify");a(HO,"jsStringify");bk=/-?\d{16,}/;a(Sh,"parse")});var XO=g((_oe,JO)=>{"use strict";var gh=require("recursive-iterator"),Nk=require("alasql"),Rh=require("clone"),FO=J(),{handleHDBError:qO,hdb_errors:yk}=ee(),{HDB_ERROR_MSGS:GO,HTTP_STATUS_CODES:kO}=yk,{getDatabases:wk}=(be(),te(Fe)),Ik=["DISTINCT_ARRAY"],VO=Symbol("validateTables"),Ah=Symbol("validateTable"),loe=Symbol("getAllColumns"),$O=Symbol("validateAllColumns"),Gl=Symbol("findColumn"),YO=Symbol("validateOrderBy"),uc=Symbol("validateSegment"),Oh=Symbol("validateColumn"),KO=Symbol("setColumnsForTable"),WO=Symbol("checkColumnsForAsterisk"),QO=Symbol("validateGroupBy"),zO=Symbol("hasColumns"),bh=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[VO](),this[WO](),this[$O]()}[VO](){if(this[zO]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Ah](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Ah](t.table)})}}[zO](){let t=!1,r=new gh(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Ah](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=wk();if(!r[t.databaseid])throw qO(new Error,GO.SCHEMA_NOT_FOUND(t.databaseid),kO.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw qO(new Error,GO.TABLE_NOT_FOUND(t.databaseid,t.tableid),kO.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Rh(s);i.table=Rh(t),this.attributes.push(i)})}[Gl](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)}[WO](){let t=new gh(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[KO](r.tableid)}[KO](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new Nk.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[$O](){this[uc](this.statement.columns,!1),this[uc](this.statement.joins,!1),this[uc](this.statement.where,!1),this[QO](this.statement.group,!1),this[uc](this.statement.order,!0)}[uc](t,r){if(!t)return;let n=new gh(t),s=[];for(let{node:i,path:o}of n)!FO.isEmpty(i)&&!FO.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[YO](i):s.push(this[Oh](i)));return s}[QO](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&Ik.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Rh(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Gl](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[Gl](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`}[YO](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[Oh](t)}[Oh](t){let r=this[Gl](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]}};JO.exports=bh});var ZO=g((foe,jO)=>{"use strict";var Nh=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")}};jO.exports=Nh});var tb=g((hoe,eb)=>{"use strict";var yh=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};eb.exports=yh});var ib={};Ve(ib,{HAS_EXPIRATION:()=>Ph,LAST_TIMESTAMP_PLACEHOLDER:()=>dc,LOCAL_TIMESTAMP:()=>Ck,METADATA:()=>lc,NO_TIMESTAMP:()=>Ih,PENDING_LOCAL_TIME:()=>vh,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>Uh,RecordEncoder:()=>Lh,TIMESTAMP_ASSIGN_LAST:()=>Lk,TIMESTAMP_ASSIGN_NEW:()=>nb,TIMESTAMP_ASSIGN_PREVIOUS:()=>sb,TIMESTAMP_PLACEHOLDER:()=>kl,TIMESTAMP_RECORD_PREVIOUS:()=>Ch,fromResource:()=>Kl,getUpdateRecord:()=>Bh,handleLocalTimeForGets:()=>Wl});function Uk(){return _c[0]=_c[0]^64,Dk.getFloat64(0)}function Kl(e){Mh=!0;try{return e()}finally{Mh=!1}}function Wl(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?.[lc];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?.[lc]>=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[lc];return _>=0&&(c.metadataFlags=_,c.localTime=u.localTime,c.value=u.value,u.expiresAt>0&&(c.expiresAt=u.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){if(this.timerTracked||(this.timerTracked=!0,yi.push(new WeakRef(this))),!Mh)try{throw new Error("Read transaction used outside of resource")}catch(u){this.readStack=u.stack}o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let u=0;u<yi.length;u++){let _=yi[u].deref();(!_||_.isDone||_.isCommitted)&&yi.splice(u--,1)}},i.prototype.done.isTracked=!0}return e}function Bh(e,t,r){return function(n,s,i,o,c=-1,u,_,l,d="put",f,E){if(f||u==null?Mo=i?.localTime?Ch|sb:Ih:Mo=u?i?.localTime?Ch|16384:nb|16384:Ih,l>0&&(c|=Ph),$l=c,Dh=l,i?.version===o&&u===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Mo>0},p;try{f&&(h.ifVersion=p=i?.version??null);let S=e.put(n,s,h);if(u){let T=_?.user?.username;if(E&&(Vl=e.encoder.encode(E)),f&&i?.localTime){let A=i?.localTime,b=r.get(A);if(b){let H=It(b).previousLocalTime;return r.put(A,Yl(o,t,n,H,T,d,Vl),{ifVersion:p}),S}}r.put(dc,Yl(o,t,n,i?.localTime?1:0,T,d,Vl),{append:d!=="invalidate",instructedWrite:!0,ifVersion:p})}return S}catch(S){throw S.message+=" id: "+n+" options: "+h,S}}}var rb,wh,kl,dc,Uh,Ck,lc,_c,Dk,Ih,nb,Lk,sb,Ch,Ph,vh,Mk,Vl,Mo,$l,Dh,Lh,Soe,Mh,yi,Uo=Oe(()=>{rb=require("msgpackr");wi();wh=B(Y()),kl=new Uint8Array([1,1,1,1,4,64,0,0]),dc=new Uint8Array([1,1,1,1,1,0,0,0]),Uh=new Uint8Array([1,1,1,1,3,64,0,0]),Ck=Symbol("local-timestamp"),lc=Symbol("metadata"),_c=new Uint8Array(8),Dk=new DataView(_c.buffer,0,8),Ih=0,nb=0,Lk=1,sb=3,Ch=4,Ph=16,vh=1,Mo=0,$l=-1,Dh=0,Lh=class extends rb.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(n,s){if(Mo||$l>=0){let i=0,o=Mo;o&&(i+=8,Mo=0);let c=$l,u=Dh;c>=0&&(i+=2,$l=-1,u&&(i+=8,Dh=0));let _=Mk=r.call(this,n,s|2048|i);Vl=_.subarray((_.start||0)+i,_.end);let l=_.start||0;return o&&(kl[4]=o,kl[5]=o>>8,_.set(kl,l),l+=8),c>=0&&(_[l++]=c,_[l++]=0,u&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(l,u)),_}else return r.call(this,n,s)}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,u;if(i===2){if(t.copy)t.copy(_c,0,c),c+=8;else for(let d=0;d<8;d++)_c[d]=t[c++];u=Uk(),i=t[c]}let _;i<32&&(o=i,c+=2,o&Ph&&(_=(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,[lc]:o,expiresAt:_}}return super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(Uk,"getTimestamp");Soe=Map.prototype.get;a(Kl,"fromResource");a(Wl,"handleLocalTimeForGets");yi=[];setInterval(()=>{for(let e=0;e<yi.length;e++){let t=yi[e].deref();!t||t.isDone||t.isCommitted?yi.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(wh.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):wh.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(Bh,"getUpdateRecord")});var Ql=g((goe,ob)=>{"use strict";var xh=Z(),Fh=M(),{RecordEncoder:Pk}=(Uo(),te(ib));xh.initSync();var vk=xh.get(Fh.CONFIG_PARAMS.STORAGE_COMPRESSION),Bk=xh.get(Fh.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Hk=Fh.UPDATES_PROPERTY,Hh=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.compression=vk&&r&&{startingOffset:32},this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=Bk&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:Pk},this.alwaysLazyProperty=n=>n===Hk)}};ob.exports=Hh});var Jl=g((Aoe,cb)=>{"use strict";var Po=Z(),fc=M();Po.initSync();var xk=Po.get(fc.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Po.get(fc.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Po.get(fc.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",ab=Po.get(fc.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC),Fk=Po.get(fc.CONFIG_PARAMS.STORAGE_NOREADAHEAD),zl=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=1e3,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.noSync=xk,this.noFSAccess=!0,ab!==void 0&&(this.overlappingSync=ab),this.noReadAhead=Fk}};cb.exports=zl;zl.MAX_DBS=1e4});var $e=g((boe,Sb)=>{"use strict";var Gh=require("lmdb"),Tn=require("fs-extra"),yr=require("path"),Xl=br(),_b=Y(),er=Or().LMDB_ERRORS_ENUM,jl=tb(),kh=Ql(),db=Jl(),Ys=lt(),ub=M(),{table:qk,resetDatabases:Gk}=(be(),te(Fe)),lb=Z(),gn=Ys.INTERNAL_DBIS_NAME,fb=Ys.DBI_DEFINITION_NAME,kk="data.mdb",Vk="lock.mdb",Ec=".mdb",$k="-lock",qh=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=Jr(t,r),this.key_type=this.dbi[Ys.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Ys.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new Gh.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Zl(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(Zl,"pathEnvNameValidation");async function Vh(e,t,r=!0){try{await Tn.access(e)}catch(n){throw n.code==="ENOENT"?new Error(er.INVALID_BASE_PATH):n}try{let n=yr.join(e,t+Ec);return await Tn.access(n,Tn.constants.R_OK|Tn.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Tn.access(yr.join(e,t,kk),Tn.constants.R_OK|Tn.constants.F_OK),yr.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(Vh,"validateEnvironmentPath");function e_(e,t){if(Xl.validateEnv(e),t===void 0)throw new Error(er.DBI_NAME_REQUIRED)}a(e_,"validateEnvDBIName");async function Yk(e,t,r=!1,n=!1){Zl(e,t);let s=yr.basename(e);t=t.toString();let i=lb.get(ub.CONFIG_PARAMS.DATABASES);i||lb.setProperty(ub.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await Vh(e,t,n),Eb(e,t,r)}catch(o){if(o.message===er.INVALID_ENVIRONMENT){let c=yr.join(e,t);await Tn.mkdirp(n?c:e);let u=new db(n?c:c+Ec,!1),_=Gh.open(u);_.dbis=Object.create(null);let l=new kh(!1);_.openDB(gn,l),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=$h(e,t,r);return _[Ys.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=_,_}throw o}}a(Yk,"createEnvironment");async function Kk(e,t,r,n=!0){Zl(e,t),t=t.toString();let s=yr.join(e,t);return qk({table:t,database:yr.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(Kk,"copyEnvironment");async function Eb(e,t,r=!1){Zl(e,t),t=t.toString();let n=$h(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 Vh(e,t),i=yr.join(e,t+Ec),o=s!=i,c=new db(s,o),u=Gh.open(c);u.dbis=Object.create(null);let _=mb(u);for(let l=0;l<_.length;l++)Jr(u,_[l]);return u[Ys.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=u,u}a(Eb,"openEnvironment");async function Wk(e,t,r=!1){Zl(e,t),t=t.toString();let n=yr.join(e,t+Ec),s=await Vh(e,t);if(global.lmdb_map!==void 0){let i=$h(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await hb(o),delete global.lmdb_map[i]}}await Tn.remove(s),await Tn.remove(s===n?s+$k:yr.join(yr.dirname(s),Vk))}a(Wk,"deleteEnvironment");async function hb(e){Xl.validateEnv(e);let t=e[Ys.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(hb,"closeEnvironment");function $h(e,t,r=!1){let s=`${yr.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a($h,"getCachedEnvironmentName");function Qk(e){Xl.validateEnv(e);let t=Object.create(null),r=Jr(e,gn);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==gn)try{t[n]=Object.assign(new jl,s)}catch{_b.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(Qk,"listDBIDefinitions");function mb(e){Xl.validateEnv(e);let t=[],r=Jr(e,gn);for(let{key:n}of r.getRange({start:!1}))n!==gn&&t.push(n);return t}a(mb,"listDBIs");function zk(e,t){let n=Jr(e,gn).getEntry(t),s=new jl;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{_b.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(zk,"getDBIDefinition");function pb(e,t,r,n=!r){if(e_(e,t),t=t.toString(),t===gn)throw new Error(er.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Jr(e,t)}catch(s){if(s.message===er.DBI_DOES_NOT_EXIST){let i=new kh(r,n===!0),o=e.openDB(t,i),c=new jl(r===!0,n);return o[fb]=c,Jr(e,gn).putSync(t,c),e.dbis[t]=o,o}throw s}}a(pb,"createDBI");function Jr(e,t){if(e_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==gn?r=zk(e,t):r=new jl,r===void 0)throw new Error(er.DBI_DOES_NOT_EXIST);let n;try{let s=new kh(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(er.DBI_DOES_NOT_EXIST):s}return n[fb]=r,e.dbis[t]=n,n}a(Jr,"openDBI");function Jk(e,t){e_(e,t),t=t.toString();let r=Jr(e,t),n=r.getStats();return r[Ys.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(Jk,"statDBI");async function Xk(e,t){try{let r=yr.join(e,t+Ec);return(await Tn.stat(r)).size}catch{throw new Error(er.INVALID_ENVIRONMENT)}}a(Xk,"environmentDataSize");function jk(e,t){if(e_(e,t),t=t.toString(),t===gn)throw new Error(er.CANNOT_DROP_INTERNAL_DBIS_NAME);Jr(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Jr(e,gn).removeSync(t)}a(jk,"dropDBI");function Zk(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{Jr(e,i)}catch(o){if(o.message===er.DBI_DOES_NOT_EXIST)pb(e,i,i!==t,i===t),n=!0;else throw o}}n&&Gk()}a(Zk,"initializeDBIs");Sb.exports={openDBI:Jr,openEnvironment:Eb,createEnvironment:Yk,listDBIs:mb,listDBIDefinitions:Qk,createDBI:pb,dropDBI:jk,statDBI:Jk,deleteEnvironment:Wk,initializeDBIs:Zk,TransactionCursor:qh,environmentDataSize:Xk,copyEnvironment:Kk,closeEnvironment:hb}});var gb=g((yoe,Tb)=>{"use strict";var Yh=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};Tb.exports=Yh});var Ab=g((Ioe,Rb)=>{"use strict";var Kh=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}};Rb.exports=Kh});var bb=g((Doe,Ob)=>{"use strict";var Wh=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};Ob.exports=Wh});var vo=g((voe,wb)=>{"use strict";var eV=$e(),tV=gb(),rV=Ab(),nV=bb(),Fn=br(),hc=Or().LMDB_ERRORS_ENUM,sV=lt(),_s=M(),iV=J(),oV=require("uuid"),Moe=require("lmdb"),{handleHDBError:aV,hdb_errors:cV}=ee(),{OVERFLOW_MARKER:Uoe,MAX_SEARCH_KEY_LENGTH:Poe}=sV,Nb=Z();Nb.initSync();var t_=Nb.get(_s.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),Qh=_s.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Ii=_s.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function uV(e,t,r,n,s=Fn.getNextMonotonicTime()){jh(e,t,r,n),zh(e,t,r);let i=new tV,o=[],c=[];for(let u=0;u<n.length;u++){let _=n[u];yb(_,!0,s);let l=lV(e,t,r,_),d=_[t];o.push(l),c.push(d)}return Jh(o,c,n,i,s)}a(uV,"insertRecords");function lV(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][_s.FUNC_VAL],n[o]=c)}let u=Fn.getIndexedValues(c),_=e.dbis[o];if(u){t_&&_.prefetch(u.map(l=>({key:l,value:s})),r_);for(let l=0,d=u.length;l<d;l++)_.put(u[l],s)}}t_&&e.dbis[t].prefetch([s],r_),e.dbis[t].put(s,n,n[Ii])})}a(lV,"insertRecord");function _V(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(_V,"removeSkippedRecords");function yb(e,t,r){let n=r>0;(n||!Number.isInteger(e[Ii]))&&(e[Ii]=r||(r=Fn.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[Qh]))&&(e[Qh]=r||Fn.getNextMonotonicTime()):delete e[Qh]}a(yb,"setTimestamps");function zh(e,t,r){r.indexOf(_s.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(_s.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(_s.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(_s.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),eV.initializeDBIs(e,t,r)}a(zh,"initializeTransaction");async function dV(e,t,r,n,s=Fn.getNextMonotonicTime()){jh(e,t,r,n),zh(e,t,r);let i=new rV,o=[],c=[],u=[];for(let _=0;_<n.length;_++){let l=n[_],d=l[t],f;try{f=Xh(e,t,l,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(_);continue}c.push(f),u.push(d)}return Jh(c,u,n,i,s,o)}a(dV,"updateRecords");async function fV(e,t,r,n,s=Fn.getNextMonotonicTime()){try{jh(e,t,r,n)}catch(u){throw aV(u,u.message,cV.HTTP_STATUS_CODES.BAD_REQUEST)}zh(e,t,r);let i=new nV,o=[],c=[];for(let u=0;u<n.length;u++){let _=n[u],l;iV.isEmpty(_[t])?(l=oV.v4(),_[t]=l):l=_[t];let d=Xh(e,t,_,l,i,!1,s);o.push(d),c.push(l)}return Jh(o,c,n,i,s)}a(fV,"upsertRecords");async function Jh(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||Fn.getNextMonotonicTime(),_V(r,i),n}a(Jh,"finalizeWrite");function Xh(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(yb(r,!l,o),Number.isInteger(r[Ii])&&_[Ii]>r[Ii])return!1;l&&s.original_records.push(_);let d,f=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let p=r[h],S=e.dbis[h];if(S===void 0)continue;let T=_[h];if(typeof p=="function"){let b=p([[_]]);Array.isArray(b)&&(p=b[0][_s.FUNC_VAL],r[h]=p)}if(p===T)continue;let A=Fn.getIndexedValues(T);if(A){t_&&S.prefetch(A.map(b=>({key:b,value:n})),r_);for(let b=0,H=A.length;b<H;b++)S.remove(A[b],n)}if(A=Fn.getIndexedValues(p),A){t_&&S.prefetch(A.map(b=>({key:b,value:n})),r_);for(let b=0,H=A.length;b<H;b++)S.put(A[b],n)}}let E=Object.assign({},_,r);c.put(n,E,E[Ii])},"do_put");return u?d=c.ifVersion(n,u.version,f):d=c.ifNoExists(n,f),d.then(E=>E?!0:Xh(e,t,r,n,s,i,o))}a(Xh,"updateUpsertRecord");function EV(e,t,r){if(Fn.validateEnv(e),t===void 0)throw new Error(hc.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(hc.WRITE_ATTRIBUTES_REQUIRED):new Error(hc.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(EV,"validateBasic");function jh(e,t,r,n){if(EV(e,t,r),!Array.isArray(n))throw n===void 0?new Error(hc.RECORDS_REQUIRED):new Error(hc.RECORDS_MUST_BE_ARRAY)}a(jh,"validateWrite");function r_(){}a(r_,"noop");wb.exports={insertRecords:uV,updateRecords:dV,upsertRecords:fV}});var Ci=g((Hoe,hV)=>{hV.exports={hdb_table:{hash_attribute:"id",name:"hdb_table",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"name"},{attribute:"hash_attribute"},{attribute:"schema"},{attribute:"residence"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_attribute:{hash_attribute:"id",name:"hdb_attribute",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"schema"},{attribute:"table"},{attribute:"attribute"},{attribute:"schema_table"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_schema:{hash_attribute:"name",name:"hdb_schema",schema:"system",residence:["*"],attributes:[{attribute:"name"},{attribute:"createddate"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metric"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]}}});var Gn=g((xoe,Db)=>{"use strict";var Cb=J(),Ib=M(),Bo=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,qn=require("joi"),Ks={schema_format:{pattern:Bo,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},mV=qn.alternatives(qn.string().min(1).max(Ks.schema_length.maximum).pattern(Bo).messages({"string.pattern.base":"{:#label} "+Ks.schema_format.message}),qn.number(),qn.array()).required(),pV=qn.alternatives(qn.string().min(1).max(Ks.schema_length.maximum).pattern(Bo).messages({"string.pattern.base":"{:#label} "+Ks.schema_format.message}),qn.number()),SV=qn.alternatives(qn.string().min(1).max(Ks.schema_length.maximum).pattern(Bo).messages({"string.pattern.base":"{:#label} "+Ks.schema_format.message}),qn.number()).required();function TV(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Ks.schema_length.maximum?`'${e}' maximum of 250 characters`:Bo.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(TV,"checkValidTable");function gV(e,t){return Cb.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(gV,"validateSchemaExists");function RV(e,t){let r=t.state.ancestors[0].schema;return Cb.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(RV,"validateTableExists");function AV(e,t){return e.toLowerCase()===Ib.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${Ib.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(AV,"validateSchemaName");Db.exports={common_validators:Ks,schema_regex:Bo,hdb_schema_table:mV,validateSchemaExists:gV,validateTableExists:RV,validateSchemaName:AV,checkValidTable:TV,hdb_database:pV,hdb_table:SV}});var et=g((qoe,Lb)=>{"use strict";var tr=require("validate.js");tr.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||tr.validators.type.checks[t](e)?null:` must be a '${t}' value`};tr.validators.type.checks={Object:function(e){return tr.isObject(e)&&!tr.isArray(e)},Array:tr.isArray,Integer:tr.isInteger,Number:tr.isNumber,String:tr.isString,Date:tr.isDate,Boolean:function(e){return typeof e=="boolean"}};tr.validators.hasValidFileExt=function(e,t){return tr.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};Lb.exports={validateObject:OV,validateObjectAsync:bV,validateBySchema:NV};function OV(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=tr(e,t,{format:"flat"});return r?new Error(r):null}a(OV,"validateObject");async function bV(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await tr.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(bV,"validateObjectAsync");function NV(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(NV,"validateBySchema")});var n_=g((koe,Mb)=>{var{common_validators:kn}=Gn(),pc=et(),mc="is required",_t={database:{presence:!1,format:kn.schema_format,length:kn.schema_length},schema:{presence:!1,format:kn.schema_format,length:kn.schema_length},table:{presence:!0,format:kn.schema_format,length:kn.schema_length},attribute:{presence:!0,format:kn.schema_format,length:kn.schema_length},hash_attribute:{presence:!0,format:kn.schema_format,length:kn.schema_length}};function Sc(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(Sc,"makeAttributesStrings");function yV(e){return e=Sc(e),_t.table.presence=!1,_t.attribute.presence=!1,_t.hash_attribute.presence=!1,pc.validateObject(e,_t)}a(yV,"schema_object");function wV(e){return e=Sc(e),_t.table.presence={message:mc},_t.attribute.presence=!1,_t.hash_attribute.presence=!1,pc.validateObject(e,_t)}a(wV,"table_object");function IV(e){return e=Sc(e),_t.table.presence={message:mc},_t.attribute.presence=!1,pc.validateObject(e,_t)}a(IV,"create_table_object");function CV(e){return e=Sc(e),_t.table.presence={message:mc},_t.attribute.presence={message:mc},_t.hash_attribute.presence=!1,pc.validateObject(e,_t)}a(CV,"attribute_object");function DV(e){return e=Sc(e),_t.table.presence={message:mc},_t.attribute.presence=!1,_t.hash_attribute.presence=!1,pc.validateObject(e,_t)}a(DV,"describe_table");function LV(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(LV,"validateTableResidence");Mb.exports={schema_object:yV,create_table_object:IV,table_object:wV,attribute_object:CV,describe_table:DV,validateTableResidence:LV}});var Pb=g(($oe,Ub)=>{"use strict";var MV=require("uuid"),Zh=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||MV.v4(),this.schema_table=`${this.schema}.${this.table}`}};Ub.exports=Zh});var s_=g((Koe,vb)=>{"use strict";var UV=Pb(),em=class extends UV{static{a(this,"LMDBCreateAttributeObject")}constructor(t,r,n,s,i=!0,o=!1){super(t,r,n,s),this.dup_sort=i,this.is_hash_attribute=o}};vb.exports=em});var Hb=g((Qoe,Bb)=>{"use strict";Bb.exports=vV;var PV="inserted";function vV(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===PV?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(vV,"returnObject")});var i_=g((Joe,kb)=>{"use strict";var BV=M(),tm=$e(),HV=vo(),{getSystemSchemaPath:xV,getSchemaPath:FV}=Ke(),qV=Ci(),GV=n_(),kV=s_(),VV=Hb(),{handleHDBError:xb,hdb_errors:qb}=ee(),Fb=J(),{HTTP_STATUS_CODES:$V}=qb,rm=qV.hdb_attribute,Gb=[];for(let e=0;e<rm.attributes.length;e++)Gb.push(rm.attributes[e].attribute);var YV="inserted";kb.exports=KV;async function KV(e){let t=GV.attribute_object(e);if(t)throw xb(new Error,t.message,qb.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&Fb.checkGlobalSchemaTable(e.schema,e.table);if(r)throw xb(new Error,r,$V.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=Fb.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 kV(e.schema,e.table,e.attribute,e.id);try{let i=await tm.openEnvironment(FV(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}`);tm.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await tm.openEnvironment(xV(),BV.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:u}=await HV.insertRecords(o,rm.hash_attribute,Gb,[s]);return VV(YV,c,{records:[s]},u)}catch(i){throw i}}a(KV,"lmdbCreateAttribute")});var sm=g((joe,$b)=>{var{hdb_table:WV,hdb_database:Vb}=Gn(),QV=et(),nm=require("joi"),zV={undefined:"undefined",null:"null"},JV=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||zV[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"),XV=nm.object({database:Vb,schema:Vb,table:WV,records:nm.array().items(nm.object().custom(JV)).required()});$b.exports=function(e){return QV.validateBySchema(e,XV)}});var Tc=g((tae,Kb)=>{"use strict";var ds=J(),Yb=Y(),eae=sm(),{getDatabases:jV}=(be(),te(Fe)),{ClientError:Di}=ee();Kb.exports=ZV;function ZV(e){if(ds.isEmpty(e))throw new Di("invalid update parameters defined.");if(ds.isEmptyOrZeroLength(e.schema))throw new Di("invalid schema specified.");if(ds.isEmptyOrZeroLength(e.table))throw new Di("invalid table specified.");if(!Array.isArray(e.records))throw new Di("records must be an array");let t=jV()[e.schema]?.[e.table];if(ds.isEmpty(t))throw new Di(`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&&ds.isEmptyOrZeroLength(o[r]))throw Yb.error("a valid hash attribute must be provided with update record:",o),new Di("a valid hash attribute must be provided with update record, check log for more info");if(!ds.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw Yb.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Di(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!ds.isEmpty(o[r])&&o[r]!==""&&n.has(ds.autoCast(o[r]))&&(o.skip=!0),n.add(ds.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(ZV,"insertUpdateValidate")});var gc=g((nae,Wb)=>{"use strict";var e$=M().OPERATIONS_ENUM,im=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=e$.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};Wb.exports=im});var bc=g((oae,Qb)=>{"use strict";var iae=gc(),o_=M(),am=J(),om=Y(),t$=require("uuid"),{handleHDBError:Rc,hdb_errors:r$}=ee(),{HDB_ERROR_MSGS:Ac,HTTP_STATUS_CODES:Oc}=r$;Qb.exports=n$;function n$(e,t,r){for(let s=0;s<t.length;s++)s$(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];i$(i,r,e.operation)}}a(n$,"processRows");function s$(e){if(Buffer.byteLength(String(e))>o_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Rc(new Error,Ac.ATTR_NAME_LENGTH_ERR(e),Oc.BAD_REQUEST,void 0,void 0,!0);if(am.isEmptyOrZeroLength(e)||am.isEmpty(e.trim()))throw Rc(new Error,Ac.ATTR_NAME_NULLISH_ERR,Oc.BAD_REQUEST,void 0,void 0,!0)}a(s$,"validateAttribute");function i$(e,t,r){if(!e.hasOwnProperty(t)||am.isEmptyOrZeroLength(e[t])){if(r===o_.OPERATIONS_ENUM.INSERT||r===o_.OPERATIONS_ENUM.UPSERT){e[t]=t$.v4();return}throw om.error("Update transaction aborted due to record with no hash value:",e),Rc(new Error,Ac.RECORD_MISSING_HASH_ERR,Oc.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>o_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw om.error(e),Rc(new Error,Ac.HASH_VAL_LENGTH_ERR,Oc.BAD_REQUEST,void 0,void 0,!0);if(isNaN(e[t])&&e[t].includes("/"))throw om.error(e),Rc(new Error,Ac.INVALID_FORWARD_SLASH_IN_HASH_ERR,Oc.BAD_REQUEST,void 0,void 0,!0)}a(i$,"validateHash")});var Jb=g((cae,zb)=>{"use strict";var cm=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};zb.exports=cm});var Zb=g((lae,jb)=>{"use strict";var um=$e(),o$=Y(),Xb=Or().LMDB_ERRORS_ENUM;jb.exports=a$;async function a$(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 um.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==Xb.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await um.closeEnvironment(global.lmdb_map[n]),await um.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==Xb.ENV_REQUIRED)throw i}break;case"drop_attribute":r=global.lmdb_map[`${e.schema}.${e.table}`],r!==void 0&&typeof r.dbis=="object"&&r.dbis[`${e.attribute}`]!==void 0&&delete r.dbis[`${e.attribute}`];break;default:break}}}catch(t){o$.error(t)}}a(a$,"cleanLMDBMap")});var Es=g((dae,nN)=>{"use strict";var Nc=require("crypto"),c$=Z(),{CONFIG_PARAMS:u$}=M(),tN="aes-256-cbc",l$=32,_$=16,lm=64,rN=32,d$=lm+rN,eN=new Map;nN.exports={encrypt:f$,decrypt:E$,createNatsTableStreamName:h$};function f$(e){let t=Nc.randomBytes(l$),r=Nc.randomBytes(_$),n=Nc.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(f$,"encrypt");function E$(e){let t=e.substr(0,lm),r=e.substr(lm,rN),n=e.substr(d$,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=Nc.createDecipheriv(tN,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(E$,"decrypt");function h$(e,t){let r=c$.get(u$.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=eN.get(r);return n||(n=Nc.createHash("md5").update(r).digest("hex"),eN.set(r,n)),n}a(h$,"createNatsTableStreamName")});var Li=g((hae,iN)=>{"use strict";var Eae=Xr(),a_=Y(),sN=n_(),m$=Es(),c_=J(),{handleHDBError:u_,hdb_errors:p$}=ee(),{HDB_ERROR_MSGS:l_,HTTP_STATUS_CODES:_m}=p$,S$=Z();S$.initSync();var{getDatabases:dm}=(be(),te(Fe));iN.exports={describeAll:T$,describeTable:__,describeSchema:g$};async function T$(e){try{let t=c_.isEmptyOrZeroLength(e),r,n;t||(r=e.hdb_user.role.permission,n=r.super_user||r.cluster_user);let s=dm(),i={},o={},c=[],u=e?.exact_count;for(let l in s){i[l]=!0,!t&&!n&&(o[l]=e.hdb_user.role.permission[l].describe);let d=s[l];for(let f in d)try{let E;if(t||n)E=await __({schema:l,table:f,exact_count:u});else if(r&&r[l].describe&&r[l].tables[f].describe){let h=r[l].tables[f].attribute_permissions;E=await __({schema:l,table:f,exact_count:u},h)}E&&c.push(E)}catch(E){a_.error(E)}}let _={};for(let l in c)t||n?(_[c[l].schema]==null&&(_[c[l].schema]={}),_[c[l].schema][c[l].name]=c[l],i[c[l].schema]&&delete i[c[l].schema]):o[c[l].schema]&&(_[c[l].schema]==null&&(_[c[l].schema]={}),_[c[l].schema][c[l].name]=c[l],i[c[l].schema]&&delete i[c[l].schema]);for(let l in i)t||n?_[l]={}:o[l]&&(_[l]={});return _}catch(t){return a_.error("Got an error in describeAll"),a_.error(t),u_(new Error,l_.DESCRIBE_ALL_ERR)}}a(T$,"describeAll");async function __(e,t){c_.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=dm()[r];if(!c)throw u_(new Error,l_.SCHEMA_NOT_FOUND(e.schema),_m.NOT_FOUND);let u=c[n];if(!u)throw u_(new Error,l_.TABLE_NOT_FOUND(e.schema,e.table),_m.NOT_FOUND);function _(f){l.push(Object.assign({},{attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(E=>({type:E.type,name:E.name})):void 0}))}a(_,"pushAtt");let l=[];if(s){let f={};s.forEach(E=>{E.describe&&(f[E.attribute_name]=!0)}),u.attributes.forEach(E=>{f[E.name]&&_(E)})}else u.attributes?.forEach(f=>_(f));let d={schema:r,name:u.tableName,hash_attribute:u.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:u.audit,schema_defined:u.schemaDefined,attributes:l};d.clustering_stream_name=m$.createNatsTableStreamName(d.schema,d.name);try{let f=u.getRecordCount({exactCount:e.exact_count==="true"});d.record_count=f.recordCount,d.estimated_record_range=f.estimatedRange;let E=u.auditStore;if(E)for(let h of E.getKeys({reverse:!0,limit:1}))d.last_updated_record=h[0];if(!d.last_updated_record&&u.indices.__updatedtime__)for(let h of u.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))d.last_updated_record=h}catch(f){a_.warn(`unable to stat table dbi due to ${f}`)}return d}a(__,"descTable");async function g$(e){c_.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=dm()[n];if(!i)throw u_(new Error,l_.SCHEMA_NOT_FOUND(e.schema),_m.NOT_FOUND);let o={};for(let c in i){let u;if(r&&r.tables[c]&&(u=r.tables[c]),c_.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(g$,"describeSchema")});var Ws=g((Tae,lN)=>{var R$=Ci(),{callbackify:aN,promisify:A$}=require("util"),{getDatabases:cN}=(be(),te(Fe));lN.exports={setSchemaDataToGlobal:oN,getTableSchema:O$,getSystemSchema:b$,setSchemaDataToGlobalAsync:A$(oN)};var uN=Li(),pae=aN(uN.describeAll),Sae=aN(uN.describeTable);function oN(e){global.hdb_schema=cN(),e&&e()}a(oN,"setSchemaDataToGlobal");function O$(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(O$,"getTableSchema");function b$(){return R$}a(b$,"getSystemSchema")});var jr=g((Rae,EN)=>{"use strict";var f_=sm(),Ht=J(),N$=require("util"),E_=Rn(),y$=Ws(),_N=Y(),{handleHDBError:Mi,hdb_errors:w$}=ee(),{HTTP_STATUS_CODES:Ui}=w$,I$=N$.promisify(y$.getTableSchema),C$="updated",dN="inserted",fN="upserted";EN.exports={insert:L$,update:M$,upsert:U$,validation:D$,flush:P$};async function D$(e){if(Ht.isEmpty(e))throw new Error("invalid update parameters defined.");if(Ht.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Ht.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await I$(e.schema,e.table),r=f_(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&&Ht.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(!Ht.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`);!Ht.isEmpty(c[n])&&c[n]!==""&&s.has(Ht.autoCast(c[n]))&&(c.skip=!0),s.add(Ht.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(D$,"validation");async function L$(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=f_(e);if(t)throw Mi(new Error,t.message,Ui.BAD_REQUEST);Ht.transformReq(e);let r=Ht.checkSchemaTableExist(e.schema,e.table);if(r)throw Mi(new Error,r,Ui.BAD_REQUEST);let n=await E_.createRecords(e);return d_(dN,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(L$,"insertData");async function M$(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=f_(e);if(t)throw Mi(new Error,t.message,Ui.BAD_REQUEST);Ht.transformReq(e);let r=Ht.checkSchemaTableExist(e.schema,e.table);if(r)throw Mi(new Error,r,Ui.BAD_REQUEST);let n=await E_.updateRecords(e);return Ht.isEmpty(n.existing_rows)?d_(C$,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):d_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(M$,"updateData");async function U$(e){if(e.operation!=="upsert")throw Mi(new Error,"invalid operation, must be upsert",Ui.INTERNAL_SERVER_ERROR);let t=f_(e);if(t)throw Mi(new Error,t.message,Ui.BAD_REQUEST);Ht.transformReq(e);let r=Ht.checkSchemaTableExist(e.schema,e.table);if(r)throw Mi(new Error,r,Ui.BAD_REQUEST);let n=await E_.upsertRecords(e);return d_(fN,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(U$,"upsertData");function d_(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(d_,"returnObject");function P$(e){return Ht.transformReq(e),E_.flush(e.schema,e.table)}a(P$,"flush")});var Em=g((Oae,pN)=>{var v$=et(),fm=require("joi"),{hdb_table:B$,hdb_database:hN}=Gn(),mN={schema:hN,database:hN,table:B$},H$={date:fm.date().iso().required()},x$={timestamp:fm.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};pN.exports=function(e,t){let r=t==="timestamp"?{...mN,...x$}:{...mN,...H$},n=fm.object(r);return v$.validateBySchema(e,n)}});var gN=g((bae,TN)=>{var F$=et(),hm=require("joi"),{hdb_table:q$,hdb_database:SN}=Gn(),G$=hm.object({schema:SN,database:SN,table:q$,hash_values:hm.array().required(),ids:hm.array()});TN.exports=function(e){return F$.validateBySchema(e,G$)}});var AN=g((Nae,RN)=>{"use strict";var mm=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}},pm=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}},Sm=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};RN.exports={InsertObject:mm,NoSQLSeachObject:pm,DeleteResponseObject:Sm}});var Bi=g((wae,wN)=>{"use strict";var bN=Em(),k$=gN(),Pi=J(),ON=require("moment"),NN=Y(),{promisify:V$,callbackify:$$}=require("util"),vi=M(),Y$=Ws(),Tm=V$(Y$.getTableSchema),gm=Rn(),{DeleteResponseObject:K$}=AN(),{handleHDBError:Qs,hdb_errors:W$}=ee(),{HDB_ERROR_MSGS:h_,HTTP_STATUS_CODES:zs}=W$,Q$="records successfully deleted",z$=$$(yN);wN.exports={delete:z$,deleteRecord:yN,deleteFilesBefore:J$,deleteAuditLogsBefore:X$};async function J$(e){let t=bN(e,"date");if(t)throw Qs(t,t.message,zs.BAD_REQUEST,void 0,void 0,!0);if(Pi.transformReq(e),!ON(e.date,ON.ISO_8601).isValid())throw Qs(new Error,h_.INVALID_DATE,zs.BAD_REQUEST,vi.LOG_LEVELS.ERROR,h_.INVALID_DATE,!0);let n=Pi.checkSchemaTableExist(e.schema,e.table);if(n)throw Qs(new Error,n,zs.NOT_FOUND,vi.LOG_LEVELS.ERROR,n,!0);let s=await gm.deleteRecordsBefore(e);if(await Tm(e.schema,e.table),NN.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(J$,"deleteFilesBefore");async function X$(e){let t=bN(e,"timestamp");if(t)throw Qs(t,t.message,zs.BAD_REQUEST,void 0,void 0,!0);if(Pi.transformReq(e),isNaN(e.timestamp))throw Qs(new Error,h_.INVALID_VALUE("Timestamp"),zs.BAD_REQUEST,vi.LOG_LEVELS.ERROR,h_.INVALID_VALUE("Timestamp"),!0);let r=Pi.checkSchemaTableExist(e.schema,e.table);if(r)throw Qs(new Error,r,zs.NOT_FOUND,vi.LOG_LEVELS.ERROR,r,!0);let n=await gm.deleteAuditLogsBefore(e);return await Tm(e.schema,e.table),NN.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(X$,"deleteAuditLogsBefore");async function yN(e){e.ids&&(e.hash_values=e.ids);let t=k$(e);if(t)throw Qs(t,t.message,zs.BAD_REQUEST,void 0,void 0,!0);Pi.transformReq(e);let r=Pi.checkSchemaTableExist(e.schema,e.table);if(r)throw Qs(new Error,r,zs.NOT_FOUND,vi.LOG_LEVELS.ERROR,r,!0);try{await Tm(e.schema,e.table);let n=await gm.deleteRecords(e);return Pi.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${Q$}`),n}catch(n){if(n.message===vi.SEARCH_NOT_FOUND_MESSAGE){let s=new K$;return s.message=vi.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(yN,"deleteRecord")});var m_=g((Cae,DN)=>{var j$=require("crypto"),IN=9;function Z$(e){let t=t1(IN),r=CN(e+t);return t+r}a(Z$,"createHash");function e1(e,t){let r=e?.substr(0,IN),n=r+CN(t+r);return e===n}a(e1,"validateHash");function t1(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(t1,"generateSalt");function CN(e){return j$.createHash("md5").update(e).digest("hex")}a(CN,"md5");DN.exports={hash:Z$,validate:e1}});var MN=g((Lae,LN)=>{var Rm=et(),$t={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 r1(e){return $t.password.presence=!0,$t.username.presence=!0,$t.role.presence=!0,$t.active.presence=!0,Rm.validateObject(e,$t)}a(r1,"addUserValidation");function n1(e){return $t.password.presence=!1,$t.username.presence=!0,$t.role.presence=!1,$t.active.presence=!1,Rm.validateObject(e,$t)}a(n1,"alterUserValidation");function s1(e){return $t.password.presence=!1,$t.username.presence=!0,$t.role.presence=!1,$t.active.presence=!1,Rm.validateObject(e,$t)}a(s1,"dropUserValidation");LN.exports={addUserValidation:r1,alterUserValidation:n1,dropUserValidation:s1}});var tt=g((Pae,PN)=>{"use strict";var{platform:Uae}=require("os"),i1="nats-server.zip",Am="nats-server",o1=process.platform==="win32"?`${Am}.exe`:Am,Om="HDB",a1=/^[^\s.,*>]+$/,UN="__request__",c1=a(e=>`${e}.${UN}`,"REQUEST_SUBJECT"),u1={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},l1={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},_1={HUB:"hub.pid",LEAF:"leaf.pid"},d1={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},f1={stream_name:"__HARPERDB_WORK_QUEUE__",durable_name:"HDB_WORK_QUEUE",deliver_group:Om,deliver_subject:"__HDB__.WORKQUEUE"},E1={stream_name:"__HARPERDB_SCHEMA_QUEUE__",durable_name:"HDB_SCHEMA_QUEUE",deliver_group:Om,deliver_subject:"HDB.SCHEMAQUEUE"},h1={stream_name:"__HARPERDB_USER_QUEUE__",durable_name:"HDB_USER_QUEUE",deliver_group:Om,deliver_subject:"HDB.USERQUEUE"},m1={SUCCESS:"success",ERROR:"error"},p1={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},S1={TXN:"txn",MSGID:"msgid"},Ho={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},T1={[Ho.ERR]:1,[Ho.WRN]:2,[Ho.INF]:3,[Ho.DBG]:4,[Ho.TRC]:5},g1={debug:"-D",trace:"-DVV"};PN.exports={NATS_SERVER_ZIP:i1,NATS_SERVER_NAME:Am,NATS_BINARY_NAME:o1,PID_FILES:_1,NATS_CONFIG_FILES:l1,SERVER_SUFFIX:d1,WORK_QUEUE_CONSUMER_NAMES:f1,SCHEMA_QUEUE_CONSUMER_NAMES:E1,USER_QUEUE_CONSUMER_NAMES:h1,NATS_TERM_CONSTRAINTS_RX:a1,REQUEST_SUFFIX:UN,UPDATE_REMOTE_RESPONSE_STATUSES:m1,CLUSTER_STATUS_STATUSES:p1,REQUEST_SUBJECT:c1,SUBJECT_PREFIXES:S1,MSG_HEADERS:u1,LOG_LEVELS:Ho,LOG_LEVEL_FLAGS:g1,LOG_LEVEL_HIERARCHY:T1}});var BN=g((Bae,vN)=>{"use strict";var R1={key:"-----BEGIN RSA PRIVATE KEY-----\rMIIEowIBAAKCAQEArBFJQRfFiJku/KwhV1Ssp7cX61vvuKmd4Rp6A9jB2QLgx8nj\r/+Xhp2hPRkISnOA8BuAxr4dMD9syGJwX4kNy9mbZ5Q0fWZCiEGBpVcU1J+k+N5K4\rSuZ2SqgxeN2IN2RLzt3GyQY4imcdHgNv7aHoXUrEwBx0MeYEw3IIDXtrYKCR2D8I\rvWBfwMUgWa24G8lpWILWA5hd9srRz9NxlAiHSjhbgT7B0xruEpHRCHSyKjvaIJVt\rWBR+amejYsAKVrD/hgrqjsA1123Y6++YqvU6vwg64xhS2kz5r3dkNKhvwbWgpZdI\rIaRvsiB77f4kLGo0vi8RFgJ1ZRjGg3RRK2w1LQIDAQABAoIBAQCEOmh78EOpnGZC\rYBjjHrvrysVD5gvLcfVUtl8Ls7gMB60re1eOIF+PoZZCHKZnDd6zPfiQtj1adg0C\rYnnsM/8VoaZS4gm0b3RLd3ubIQifWhuo40RissY2yxfxlPSH9LhZCY8ojnJG0cTL\resK579E8WCfopjUY33XLqEbN7Ylv39J+DSqInjqV3efJZUa+HqUJ98VxxzodcKMD\rP3bwUU4gHoSSp4pAsOFH5sQhaIWH1IcNjrAwpee2cJQuh4G157RRIuuUpagtaEG/\rXJIiAyBguJyu3JQFnIBQF01N5+omJgXYJ1L0m54543/iIRThmF3zDCDgCyUzmOk+\rH6As9fv1AoGBANOpOtOZLSAScjGsgJamT3ceJ2wCa86g2j8Oxu8lJUmUp5s3tA0v\rBFW5O3S4KR1EXwkLMBUMrfFM8YvzHWxsXBI6XV8azGLvyqPHxr65OhmpGYkGZMXu\rn9okgjkqlewnY2I073gvyK7ppX51UL5y9fF1vlsk+UlW+Rgx/vMHbdcjAoGBANAc\rxRUsxs4QJpbS4zD3JOkHjr24a97TrS3kCybAHUMpR2NrEHPZw9zex0/aphOJUHfL\rIMkOZdpfDqMfxWy4FAEmqBEMkO2SB+h0Wp4P+qp81ax4vGFiB0cD3wtixr11U1tt\rlZ/ZTdv4VDpDFNK1KaplhTDeyuCjeYfS3/GJia9vAoGAcOsAgjBevZR5rXx84WH6\rVO8WUu37u7FenXNxt9VWTinrPMh72uixZFY8nOk+rely1e1NCn3IMko9Ns9NbDFm\r8SaH95vhXArXTYbfxZIlp9jp0YtCqcHDL+p4Oq04bFMbFyJseu7rHj1x18QYfnHw\rOY/6LL/N6k1m+Hx7qgXVmIcCgYB/w0nTCBw84XlvWqSTqQaF8VfWbWP79mP5KmkW\rLxdH5g2noVEGbohqDnK6OXd/wusdwByukiJBf94Skyy25AOT+VFwthA7aU1ljhkb\rtJ+lDuJ28eBkwLPLCzthWBC+u0qjdJFJAzVjd/7tjcU43nNn4s90AzL12iaAFhvZ\rwyA+DQKBgGc/4cdyGJ3YkcA8150gQBawgJZ7q8V1JND87ggWA8wnK3cHn7rMZQl2\r3emDp9HEFXFex5dbGDDqZFAoesZCDxjknIn9oNfW4PvaWS8q7b6ZKLZG1p03Pu7/\rtYaD0kPbo0kysfFT/co+NgHbdykvIyboomfGdNLTUjYuy6lpwpvs\r-----END RSA PRIVATE KEY-----\r".replace(/\r/g,`\r
|
|
1
|
+
"use strict";var Qx=Object.create;var za=Object.defineProperty;var zx=Object.getOwnPropertyDescriptor;var Jx=Object.getOwnPropertyNames;var Xx=Object.getPrototypeOf,jx=Object.prototype.hasOwnProperty;var a=(e,t)=>za(e,"name",{value:t,configurable:!0});var Oe=(e,t)=>()=>(e&&(t=e(e=0)),t);var T=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),ke=(e,t)=>{for(var r in t)za(e,r,{get:t[r],enumerable:!0})},RA=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Jx(t))!jx.call(e,s)&&s!==r&&za(e,s,{get:()=>t[s],enumerable:!(n=zx(t,s))||n.enumerable});return e};var x=(e,t,r)=>(r=e!=null?Qx(Xx(e)):{},RA(t||!e||!e.__esModule?za(r,"default",{value:e,enumerable:!0}):r,e)),te=e=>RA(za({},"__esModule",{value:!0}),e);var bA=T((Cie,OA)=>{var Zx=require("fast-glob"),{statSync:WE,existsSync:QE,readFileSync:eF,writeFileSync:tF}=require("fs"),{spawnSync:rF,spawn:nF,execFileSync:Iie}=require("child_process"),{isMainThread:sF}=require("worker_threads"),{join:$s,relative:AA}=require("path"),{PACKAGE_ROOT:Sn}=U(),{tmpdir:iF,platform:oF}=require("os");require("source-map-support").install();var aF=["resources","server","dataLayer","components"],Ja="ts-build",zE,cF=__filename.endsWith("tsBuild.js");if(cF){if(sF){let r;try{WE($s(Sn,Ja)),r=!0}catch{}if(r)for(let n of Zx.sync(aF.map(s=>s+"/**/*.ts"),{cwd:Sn})){let s=0,i=0;try{s=WE($s(Sn,n)).mtimeMs-5e3,i=WE($s(Sn,Ja,n.replace(/.ts$/,".js"))).mtimeMs}catch{}if(s>i){console.warn(`TypeScript ${n} is not compiled`+(i?` (TS source file was modified at ${new Date(s)} and compiled file at ${new Date(i)})`:"")+", consider enabling auto-compilation of TypeScript in your IDE), compiling now."),zE=!0;break}}else console.log("TypeScript modules are not compiled, compiling now"),zE=!0;if(zE){let n=$s(Sn,"node_modules/.bin/tsc");oF()==="win32"&&(n+=".cmd");let s=rF(n,{cwd:Sn});if(s.stdout.length&&console.log(s.stdout.toString()),s.stderr.length&&console.log(s.stderr.toString()),r){let i=$s(iF(),"harperdb-tsc.pid"),o;if(QE(i))try{process.kill(+eF(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=nF(n,["--watch"],{cwd:Sn,detached:!0,stdio:"ignore"});tF(i,c.pid.toString()),c.unref()}}}}let e=OA.constructor,t=e._findPath;e._findPath=function(r,n,s){if(r.startsWith(".")&&!s&&n.length===1&&n[0].startsWith(Sn)&&!n[0].includes("node_modules")){let i=AA(Sn,n[0]),o;i.startsWith(Ja)?o=$s(Sn,AA(Ja,i)):o=$s(Sn,Ja,i);let c=$s(o,r),u=c+".js";if(QE(u))return u;if(c.includes(".")&&QE(c))return c}return t(r,n,s)}}});var U=T((Mie,xA)=>{"use strict";var Jr=require("path"),uF=require("fs"),{relative:Die,join:Lie}=Jr,{existsSync:lF}=uF;function _F(){let e=__dirname;for(;!lF(Jr.join(e,"package.json"));){let t=Jr.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(_F,"getHDBPackageRoot");var Ys=_F(),NA="js",Cl=NA,dF="harperdb-config.yaml",fF="defaultConfig.yaml",EF="hdb",yA=`harperdb.${Cl}`,wA=`customFunctionsServer.${Cl}`,hF=`restartHdb.${Cl}`,XE="HarperDB",Il="Custom Functions",Dl="Clustering Hub",Ll="Clustering Leaf",mF="Clustering Ingest Service",pF="Clustering Reply Service",SF="foreground.pid",TF="hdb.pid",gF="data",RF={HDB:XE,CLUSTERING_HUB:Dl,CLUSTERING_LEAF:Ll,CLUSTERING_INGEST_SERVICE:mF,CLUSTERING_REPLY_SERVICE:pF,CUSTOM_FUNCTIONS:Il,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"},AF={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},OF={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},bF={harperdb:XE,"clustering hub":Dl,"clustering leaf":Ll,"custom functions":Il,custom_functions:Il,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers"},NF={CLUSTERING_HUB_PROC_DESCRIPTOR:Dl,CLUSTERING_LEAF_PROC_DESCRIPTOR:Ll},JE={HDB:Jr.join(Ys,"server/harperdb"),CUSTOM_FUNCTIONS:Jr.join(Ys,"server/customFunctions"),CLUSTERING_HUB:Jr.join(Ys,"server/nats"),CLUSTERING_LEAF:Jr.join(Ys,"server/nats")},yF={HDB:Jr.join(JE.HDB,yA),CUSTOM_FUNCTIONS:Jr.join(JE.CUSTOM_FUNCTIONS,wA)},wF={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:Jr.join(Ys,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:Jr.join(Ys,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:Jr.join(Ys,"launchServiceScripts/launchUpdateNodes4-0-0.js")},IF={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},IA="support@harperdb.io",CF="customer-success@harperdb.io",CA=1,DF=4141,DA="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",LF="https://www.harperdb.io/product",MF=`For support, please submit a request at ${DA} or contact ${IA}`,LA=`For license support, please contact ${CF}`,UF="None of the specified records were found.",PF="hash attribute not found",vF=`Your current license only supports ${CA} role. ${LA}`,BF="Your current license only supports 3 connections to a node.",HF="127.0.0.1",xF=1,FF=/^\.$/,qF=/^\.\.$/,GF="U+002E",kF=/\//g,VF="U+002F",$F=/U\+002F/g,YF=/^U\+002E$/,KF=/^U\+002EU\+002E$/,WF="d",QF=999999,zF="*",JF="--max-old-space-size=",XF="system",jF="__hdb_hash",ZF=".harperdb",eq=".hdb",tq="keys",rq="hdb_boot_properties.file",nq=".updateConfig.json",sq="SIGTSTP",iq=24,oq=6e4,aq=448,cq="blob",uq="trash",lq="database",_q="schema",dq="transactions",fq=".count",Eq="id",hq="PROCESS_NAME",MA={SETTINGS_PATH_KEY:"settings_path"},UA=require("lodash"),mq={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"},pq={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},Sq={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},Tq={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"},gq={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"},Or="hdb_internal:",Rq={CREATE_SCHEMA:Or+"create_schema",CREATE_TABLE:Or+"create_table",CREATE_ATTRIBUTE:Or+"create_attribute",ADD_USER:Or+"add_user",ALTER_USER:Or+"alter_user",DROP_USER:Or+"drop_user",HDB_NODES:Or+"hdb_nodes",HDB_USERS:Or+"hdb_users",HDB_WORKERS:Or+"hdb_workers",CATCHUP:Or+"catchup",SCHEMA_CATCHUP:Or+"schema_catchup",WORKER_ROOM:Or+"cluster_workers"},Aq={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"},Oq="060493.ks",bq=".license",Nq={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},X={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"},yq={CSV:".csv",JSON:".json"},wq={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},Iq={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},Xa={};Xa[X.INSERT]=X.INSERT;Xa[X.UPDATE]=X.UPDATE;Xa[X.UPSERT]=X.UPSERT;Xa[X.DELETE]=X.DELETE;var Be=Object.create(null);Be[X.DESCRIBE_ALL]=X.DESCRIBE_ALL;Be[X.DESCRIBE_TABLE]=X.DESCRIBE_TABLE;Be[X.DESCRIBE_SCHEMA]=X.DESCRIBE_SCHEMA;Be[X.READ_LOG]=X.READ_LOG;Be[X.ADD_NODE]=X.ADD_NODE;Be[X.LIST_USERS]=X.LIST_USERS;Be[X.LIST_ROLES]=X.LIST_ROLES;Be[X.USER_INFO]=X.USER_INFO;Be[X.SQL]=X.SQL;Be[X.GET_JOB]=X.GET_JOB;Be[X.SEARCH_JOBS_BY_START_DATE]=X.SEARCH_JOBS_BY_START_DATE;Be[X.DELETE_FILES_BEFORE]=X.DELETE_FILES_BEFORE;Be[X.EXPORT_LOCAL]=X.EXPORT_LOCAL;Be[X.EXPORT_TO_S3]=X.EXPORT_TO_S3;Be[X.CLUSTER_STATUS]=X.CLUSTER_STATUS;Be[X.REMOVE_NODE]=X.REMOVE_NODE;Be[X.RESTART]=X.RESTART;Be[X.CUSTOM_FUNCTIONS_STATUS]=X.CUSTOM_FUNCTIONS_STATUS;Be[X.GET_CUSTOM_FUNCTIONS]=X.GET_CUSTOM_FUNCTIONS;Be[X.GET_CUSTOM_FUNCTION]=X.GET_CUSTOM_FUNCTION;Be[X.SET_CUSTOM_FUNCTION]=X.SET_CUSTOM_FUNCTION;Be[X.DROP_CUSTOM_FUNCTION]=X.DROP_CUSTOM_FUNCTION;Be[X.ADD_CUSTOM_FUNCTION_PROJECT]=X.ADD_CUSTOM_FUNCTION_PROJECT;Be[X.DROP_CUSTOM_FUNCTION_PROJECT]=X.DROP_CUSTOM_FUNCTION_PROJECT;Be[X.PACKAGE_CUSTOM_FUNCTION_PROJECT]=X.PACKAGE_CUSTOM_FUNCTION_PROJECT;Be[X.DEPLOY_CUSTOM_FUNCTION_PROJECT]=X.DEPLOY_CUSTOM_FUNCTION_PROJECT;var Cq={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"},Dq={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},PA={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"},Lq=UA.invert(PA),Mq={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"},C={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",MAXHEAPMEMORY:"maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_PATH:"storage_path",STORAGE_AUDIT_PATH:"storage_audit_path",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers"},vA={settings_path:MA.SETTINGS_PATH_KEY,hdb_root_key:C.ROOTPATH,hdb_root:C.ROOTPATH,rootpath:C.ROOTPATH,server_port_key:C.OPERATIONSAPI_NETWORK_PORT,server_port:C.OPERATIONSAPI_NETWORK_PORT,cert_key:C.TLS_CERTIFICATE,certificate:C.TLS_CERTIFICATE,private_key_key:C.TLS_PRIVATEKEY,private_key:C.TLS_PRIVATEKEY,http_secure_enabled_key:C.OPERATIONSAPI_NETWORK_HTTPS,https_on:C.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:C.OPERATIONSAPI_NETWORK_CORS,cors_on:C.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:C.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:C.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:C.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:C.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:C.LOGGING_LEVEL,log_level:C.LOGGING_LEVEL,log_path_key:C.LOGGING_ROOT,log_path:C.LOGGING_ROOT,clustering_node_name_key:C.CLUSTERING_NODENAME,node_name:C.CLUSTERING_NODENAME,clustering_enabled_key:C.CLUSTERING_ENABLED,clustering:C.CLUSTERING_ENABLED,max_http_threads:C.THREADS,max_hdb_processes:C.THREADS,server_timeout_key:C.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:C.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:C.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:C.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:C.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:C.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:C.LOGGING_AUDITLOG,disable_transaction_log:C.LOGGING_AUDITLOG,operation_token_timeout_key:C.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:C.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:C.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:C.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:C.HTTP_PORT,custom_functions_port:C.HTTP_PORT,custom_functions_directory_key:C.COMPONENTSROOT,custom_functions_directory:C.COMPONENTSROOT,max_custom_function_processes:C.THREADS,log_to_file:C.LOGGING_FILE,log_to_stdstreams:C.LOGGING_STDSTREAMS,local_studio_on:C.LOCALSTUDIO_ENABLED,clustering_port:C.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:C.CLUSTERING_USER,clustering_enabled:C.CLUSTERING_ENABLED,clustering_hubserver_cluster_name:C.CLUSTERING_HUBSERVER_CLUSTER_NAME,clustering_hubserver_cluster_network_port:C.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_hubserver_cluster_network_routes:C.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,clustering_hubserver_leafnodes_network_port:C.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT,clustering_hubserver_network_port:C.CLUSTERING_HUBSERVER_NETWORK_PORT,clustering_leafserver_network_port:C.CLUSTERING_LEAFSERVER_NETWORK_PORT,clustering_leafserver_network_routes:C.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,clustering_leafserver_streams_maxage:C.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE,clustering_leafserver_streams_maxbytes:C.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES,clustering_leafserver_streams_maxmsgs:C.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS,clustering_leafserver_streams_path:C.CLUSTERING_LEAFSERVER_STREAMS_PATH,clustering_nodename:C.CLUSTERING_NODENAME,clustering_tls_certificate:C.CLUSTERING_TLS_CERTIFICATE,clustering_tls_privatekey:C.CLUSTERING_TLS_PRIVATEKEY,clustering_tls_certificateauthority:C.CLUSTERING_TLS_CERT_AUTH,clustering_tls_insecure:C.CLUSTERING_TLS_INSECURE,clustering_tls_verify:C.CLUSTERING_TLS_VERIFY,clustering_loglevel:C.CLUSTERING_LOGLEVEL,clustering_republishmessages:C.CLUSTERING_REPUBLISHMESSAGES,clustering_databaselevel:C.CLUSTERING_DATABASELEVEL,customfunctions_network_port:C.HTTP_PORT,customfunctions_tls_certificate:C.TLS_CERTIFICATE,customfunctions_network_cors:C.HTTP_CORS,customfunctions_network_corsaccesslist:C.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:C.HTTP_HEADERSTIMEOUT,customfunctions_network_https:C.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:C.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:C.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:C.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:C.HTTP_TIMEOUT,http_threads:C.THREADS,threads:C.THREADS,maxheapmemory:C.MAXHEAPMEMORY,http_session_affinity:C.HTTP_SESSIONAFFINITY,http_compressionthreshold:C.HTTP_COMPRESSIONTHRESHOLD,http_cors:C.HTTP_CORS,http_corsaccesslist:C.HTTP_CORSACCESSLIST,http_headerstimeout:C.HTTP_HEADERSTIMEOUT,http_keepalivetimeout:C.HTTP_KEEPALIVETIMEOUT,http_timeout:C.HTTP_TIMEOUT,http_port:C.HTTP_PORT,http_secureport:C.HTTP_SECUREPORT,http_mtls:C.HTTP_MTLS,http_mtls_user:C.HTTP_MTLS_USER,http_mtls_required:C.HTTP_MTLS_REQUIRED,customfunctions_processes:C.THREADS,customfunctions_root:C.COMPONENTSROOT,localstudio_enabled:C.LOCALSTUDIO_ENABLED,logging_file:C.LOGGING_FILE,logging_level:C.LOGGING_LEVEL,logging_root:C.LOGGING_ROOT,logging_rotation_enabled:C.LOGGING_ROTATION_ENABLED,logging_rotation_compress:C.LOGGING_ROTATION_COMPRESS,logging_rotation_interval:C.LOGGING_ROTATION_INTERVAL,logging_rotation_maxsize:C.LOGGING_ROTATION_MAXSIZE,logging_rotation_path:C.LOGGING_ROTATION_PATH,logging_stdstreams:C.LOGGING_STDSTREAMS,logging_auditlog:C.LOGGING_AUDITLOG,logging_auditretention:C.LOGGING_AUDITRETENTION,logging_auditauthevents_logfailed:C.LOGGING_AUDITAUTHEVENTS_LOGFAILED,logging_auditauthevents_logsuccessful:C.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL,operationsapi_authentication_operationtokentimeout:C.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operationsapi_authentication_refreshtokentimeout:C.AUTHENTICATION_REFRESHTOKENTIMEOUT,operationsapi_network_cors:C.OPERATIONSAPI_NETWORK_CORS,operationsapi_network_corsaccesslist:C.OPERATIONSAPI_NETWORK_CORSACCESSLIST,operationsapi_network_headerstimeout:C.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,operationsapi_network_https:C.OPERATIONSAPI_NETWORK_HTTPS,operationsapi_network_keepalivetimeout:C.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,operationsapi_network_port:C.OPERATIONSAPI_NETWORK_PORT,operationsapi_network_domainsocket:C.OPERATIONSAPI_NETWORK_DOMAINSOCKET,operationsapi_network_secureport:C.OPERATIONSAPI_NETWORK_SECUREPORT,operationsapi_tls_certificate:C.OPERATIONSAPI_TLS_CERTIFICATE,operationsapi_tls_privatekey:C.OPERATIONSAPI_TLS_PRIVATEKEY,operationsapi_tls_certificateauthority:C.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY,operationsapi_network_timeout:C.OPERATIONSAPI_NETWORK_TIMEOUT,operationsapi_root:C.ROOTPATH,databases:C.DATABASES,storage_path:C.STORAGE_PATH,ignorescripts:C.IGNORE_SCRIPTS,mqtt_network_port:C.MQTT_NETWORK_PORT,mqtt_websocket:C.MQTT_WEBSOCKET,mqtt_network_secureport:C.MQTT_NETWORK_SECUREPORT,mqtt_network_mtls:C.MQTT_NETWORK_MTLS,mqtt_network_mtls_certificateAuthority:C.MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY,mqtt_network_mtls_user:C.MQTT_NETWORK_MTLS_USER,mqtt_network_mtls_required:C.MQTT_NETWORK_MTLS_REQUIRED,mqtt_requireauthentication:C.MQTT_REQUIREAUTHENTICATION,analytics_aggregatePeriod:C.ANALYTICS_AGGREGATEPERIOD,authentication_authorizelocal:C.AUTHENTICATION_AUTHORIZELOCAL,authentication_cachettl:C.AUTHENTICATION_CACHETTL,authentication_enablesessions:C.AUTHENTICATION_ENABLESESSIONS,authentication_operationtokentimeout:C.AUTHENTICATION_OPERATIONTOKENTIMEOUT,authentication_refreshtokentimeout:C.AUTHENTICATION_REFRESHTOKENTIMEOUT,componentsroot:C.COMPONENTSROOT,tls_certificate:C.TLS_CERTIFICATE,tls_privatekey:C.TLS_PRIVATEKEY,tls_certificateauthority:C.TLS_CERTIFICATEAUTHORITY,tls_ciphers:C.TLS_CIPHERS};for(let e in C){let t=C[e];vA[t.toLowerCase()]=t}var Uq={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},Pq={csv_file_load:"csv_file_load",csv_data_load:X.CSV_DATA_LOAD,csv_url_load:X.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"},vq={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"},Bq={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},Hq={VERSION_DEFAULT:"2.2.0"},xq={DEVELOPMENT:8192,DEFAULT:512},Fq={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"},qq={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"},Gq={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST"},BA={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},kq=Symbol("metadata"),Vq="__clustering__",$q=Object.values(BA),Yq=15984864e5,HA={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},Kq=UA.invert(HA),Wq={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"},Qq=111,zq=`\r
|
|
2
|
+
`,Jq={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},Xq=["*","%"],jq="unauthorized_access",Zq="func_val",eG={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},tG={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},rG={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"},nG={HDB_CORE:"hdb_core",CUSTOM_FUNCTIONS:"custom_functions"},sG={HTTP:"http"},iG={STOPPED:"stopped",ONLINE:"online"},oG="3.x.x",aG={SUCCESS:"success",FAILURE:"failure"},cG={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"};xA.exports={LOCAL_HARPERDB_OPERATIONS:Be,HDB_SUPPORT_ADDRESS:IA,HDB_SUPPORT_URL:DA,HDB_PRICING_URL:LF,SUPPORT_HELP_MSG:MF,LICENSE_HELP_MSG:LA,HDB_PROC_NAME:yA,HDB_PROC_DESCRIPTOR:XE,CLUSTERING_LEAF_PROC_DESCRIPTOR:Ll,CLUSTERING_HUB_PROC_DESCRIPTOR:Dl,SYSTEM_SCHEMA_NAME:XF,HASH_FOLDER_NAME:jF,HDB_HOME_DIR_NAME:ZF,UPDATE_FILE_NAME:nq,LICENSE_KEY_DIR_NAME:tq,BOOT_PROPS_FILE_NAME:rq,JOB_TYPE_ENUM:Pq,JOB_STATUS_ENUM:Nq,SYSTEM_TABLE_NAMES:Tq,SYSTEM_TABLE_HASH_ATTRIBUTES:gq,OPERATIONS_ENUM:X,VALID_S3_FILE_TYPES:yq,S3_BUCKET_AUTH_KEYS:wq,VALID_SQL_OPS_ENUM:Iq,GEO_CONVERSION_ENUM:Dq,HDB_SETTINGS_NAMES:PA,HDB_SETTINGS_NAMES_REVERSE_LOOKUP:Lq,SERVICE_ACTIONS_ENUM:Cq,CLUSTER_MESSAGE_TYPE_ENUM:vq,CLUSTER_CONNECTION_DIRECTION_ENUM:Bq,CLUSTER_EVENTS_DEFS_ENUM:Fq,PERIOD_REGEX:FF,DOUBLE_PERIOD_REGEX:qF,UNICODE_PERIOD:GF,FORWARD_SLASH_REGEX:kF,UNICODE_FORWARD_SLASH:VF,ESCAPED_FORWARD_SLASH_REGEX:$F,ESCAPED_PERIOD_REGEX:YF,ESCAPED_DOUBLE_PERIOD_REGEX:KF,REG_KEY_FILE_NAME:Oq,RESTART_TIMEOUT_MS:oq,HDB_FILE_PERMISSIONS:aq,DATABASES_DIR_NAME:lq,LEGACY_DATABASES_DIR_NAME:_q,TRANSACTIONS_DIR_NAME:dq,LIMIT_COUNT_NAME:fq,ID_ATTRIBUTE_STRING:Eq,INSERT_MODULE_ENUM:pq,UPGRADE_JSON_FIELD_NAMES_ENUM:Sq,RESTART_CODE:sq,RESTART_CODE_NUM:iq,CLUSTER_OPERATIONS:Xa,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:Aq,HDB_INTERNAL_SC_CHANNEL_PREFIX:Or,INTERNAL_SC_CHANNELS:Rq,CLUSTERING_MESSAGE_TYPES:Wq,HDB_FILE_SUFFIX:eq,BLOB_FOLDER_NAME:cq,HDB_TRASH_DIR:uq,ORIGINATOR_SET_VALUE:Qq,LICENSE_VALUES:Hq,RAM_ALLOCATION_ENUM:xq,TIME_STAMP_NAMES_ENUM:BA,TIME_STAMP_NAMES:$q,PERMS_UPDATE_RELEASE_TIMESTAMP:Yq,SEARCH_NOT_FOUND_MESSAGE:UF,SEARCH_ATTRIBUTE_NOT_FOUND:PF,LICENSE_ROLE_DENIED_RESPONSE:vF,LICENSE_MAX_CONNS_REACHED:BF,BASIC_LICENSE_MAX_NON_CU_ROLES:CA,BASIC_LICENSE_CLUSTER_CONNECTION_LIMIT_WS_ERROR_CODE:DF,VALUE_SEARCH_COMPARATORS:HA,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:Kq,LICENSE_FILE_NAME:bq,WEBSOCKET_CLOSE_CODE_DESCRIPTION_LOOKUP:qq,NEW_LINE:zq,BASIC_LICENSE_MAX_CLUSTER_USER_ROLES:xF,MOMENT_DAYS_TAG:WF,API_TURNOVER_SEC:QF,LOOPBACK:HF,CODE_EXTENSION:Cl,WILDCARD_SEARCH_VALUE:zF,NODE_ERROR_CODES:Gq,JAVASCRIPT_EXTENSION:NA,PERMS_CRUD_ENUM:Jq,UNAUTHORIZED_PERMISSION_NAME:jq,SEARCH_WILDCARDS:Xq,FUNC_VAL:Zq,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:eG,JWT_ENUM:tG,CLUSTERING_FLAG:Vq,ITC_EVENT_TYPES:rG,CUSTOM_FUNCTION_PROC_NAME:wA,CUSTOM_FUNCTION_PROC_DESCRIPTOR:Il,SERVICES:nG,THREAD_TYPES:sG,MEM_SETTING_KEY:JF,HDB_RESTART_SCRIPT:hF,PROCESS_DESCRIPTORS:RF,SERVICE_SERVERS:yF,SERVICE_SERVERS_CWD:JE,PROCESS_DESCRIPTORS_VALIDATE:bF,LAUNCH_SERVICE_SCRIPTS:wF,LOG_LEVELS:OF,PROCESS_NAME_ENV_PROP:hq,LOG_NAMES:AF,PM2_PROCESS_STATUSES:iG,CONFIG_PARAM_MAP:vA,CONFIG_PARAMS:C,HDB_CONFIG_FILE:dF,HDB_DEFAULT_CONFIG_FILE:fF,ROLE_TYPES_ENUM:IF,BOOT_PROP_PARAMS:MA,INSTALL_PROMPTS:mq,HDB_ROOT_DIR_NAME:EF,CLUSTERING_PROCESSES:NF,FOREGROUND_PID_FILE:SF,PACKAGE_ROOT:Ys,PRE_4_0_0_VERSION:oG,DATABASES_PARAM_CONFIG:Uq,METADATA_PROPERTY:kq,AUTH_AUDIT_STATUS:aG,AUTH_AUDIT_TYPES:cG,HDB_PID_FILE:TF,DEFAULT_DATABASE_NAME:gF,LEGACY_CONFIG_PARAMS:Mq};bA()});var jE=T((Pie,GA)=>{"use strict";var FA=require("minimist");GA.exports=uG;function uG(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=qA(process.env),n=qA(FA(process.argv))):(r=process.env,n=FA(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(uG,"assignCMDENVVariables");function qA(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(qA,"objKeysToLowerCase")});var W=T((Bie,ih)=>{"use strict";var Ni=require("fs-extra"),{workerData:lG,threadId:_G}=require("worker_threads"),_s=require("path"),$A=require("yaml"),YA=require("properties-reader"),Tt=U(),kA=jE(),dG=require("os"),{PACKAGE_ROOT:eh}=U(),{_assignPackageExport:fG}=require("../../index"),Za={};for(let e in console)Za[e]||(Za[e]=console[e]);var Jt={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},KA={STDOUT:"stdOut",STDERR:"stdErr"},EG=_s.join(eh,"logs"),hG=_s.join(eh,"config/yaml/",Tt.HDB_DEFAULT_CONFIG_FILE),mG=1e4,ls,qn,zt,Ml,Ul,ec,Mo,ja;ja===void 0&&WA();ih.exports={notify:JA,fatal:XA,error:tc,warn:sh,info:Pl,debug:nh,trace:rh,setLogLevel:OG,log_level:zt,loggerWithTag:pG,suppressLogging:SG,initLogSettings:WA,setupConsoleLogging:QA,logCustomLevel:RG,closeLogFile:th,getLogFilePath:()=>ec,OUTPUTS:KA,AuthAuditLog:yG};fG("logger",ih.exports);function WA(e=!1){try{if(ja===void 0||e){th();let t=AG(),r=kA(["ROOTPATH"]);try{ja=YA(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!Ni.pathExistsSync(_s.join(r.ROOTPATH,Tt.HDB_CONFIG_FILE)))throw n}({level:zt,config_log_path:Ul,to_file:ls,to_stream:qn}=bG(r.ROOTPATH?_s.join(r.ROOTPATH,Tt.HDB_CONFIG_FILE):ja.get("settings_path"))),Ml=Tt.LOG_NAMES.HDB,ec=_s.join(Ul,Ml)}}catch(t){if(ja=void 0,t.code===Tt.NODE_ERROR_CODES.ENOENT){let r=kA(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){zt=u;continue}if(c===Tt.CONFIG_PARAMS.LOGGING_STDSTREAMS){qn=u;continue}c===Tt.CONFIG_PARAMS.LOGGING_FILE&&(ls=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=NG();ls=ls===void 0?s:ls,ls=VA(ls),qn=qn===void 0?i:qn,qn=VA(qn),zt=zt===void 0?n:zt,Ul=EG,Ml=Tt.LOG_NAMES.INSTALL,ec=_s.join(Ul,Ml);return}throw tc("Error initializing log settings"),tc(t),t}process.env.DEV_MODE&&(qn=!0),QA()}a(WA,"initLogSettings");var ZE=!0;function QA(){Lo("error",tc),Lo("warn",sh),Lo("log",Pl),Lo("info",Pl),Lo("debug",nh),Lo("trace",rh)}a(QA,"setupConsoleLogging");function Lo(e,t){console[e]=function(...r){if(ZE&&t(...r),!/PM2 log:|App \[/.test(r[0]))return Za[e](...r)}}a(Lo,"logConsole");function pG(e){let t={tagName:e.replace(/ /g,"-")};return{notify:r(JA),fatal:r(XA),error:r(tc),warn:r(sh),info:r(Pl),debug:r(nh),trace:r(rh)};function r(n){return function(...s){return n(t,...s)}}}a(pG,"loggerWithTag");function SG(e){try{ZE=!1,e()}finally{ZE=!0}}a(SG,"suppressLogging");var TG=lG?.name?.replace(/ /g,"-")||"main";function ds(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||TG+"/"+_G);c<s;c++){let _=t[c];_ instanceof Error&&_.stack?n+=_.stack:typeof _=="object"?n+=JSON.stringify(_):n+=_,c<i&&(n+=" ")}return`${r} [${o.join("] [")}]: ${n}
|
|
3
|
+
`}a(ds,"createLogRecord");function rc(e){ls&&zA(e),qn&&process.stdout.write(e)}a(rc,"logStdOut");function vl(e){ls&&zA(e),qn&&process.stderr.write(e)}a(vl,"logStdErr");function zA(e){gG(),Mo?Ni.appendFileSync(Mo,e):Za.log(e)}a(zA,"logToFile");function th(){try{Ni.closeSync(Mo)}catch{}Mo=null}a(th,"closeLogFile");function gG(){if(!Mo){try{if(!ec)debugger;Mo=Ni.openSync(ec,"a")}catch(e){Za.error(e)}setTimeout(()=>{th()},mG).unref()}}a(gG,"openLogFile");function Pl(...e){Jt[zt]<=Jt.info&&rc(ds("info",e))}a(Pl,"info");function rh(...e){Jt[zt]<=Jt.trace&&rc(ds("trace",e))}a(rh,"trace");function tc(...e){Jt[zt]<=Jt.error&&vl(ds("error",e))}a(tc,"error");function nh(...e){Jt[zt]<=Jt.debug&&rc(ds("debug",e))}a(nh,"debug");function JA(...e){Jt[zt]<=Jt.notify&&rc(ds("notify",e))}a(JA,"notify");function XA(...e){Jt[zt]<=Jt.fatal&&vl(ds("fatal",e))}a(XA,"fatal");function sh(...e){Jt[zt]<=Jt.warn&&vl(ds("warn",e))}a(sh,"warn");function RG(e,t,...r){t===KA.STDERR?vl(ds(e,r)):rc(ds(e,r))}a(RG,"logCustomLevel");function AG(){let e;try{e=dG.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=_s.join(e,Tt.HDB_HOME_DIR_NAME,Tt.BOOT_PROPS_FILE_NAME);return Ni.existsSync(t)||(t=_s.join(eh,"utility/hdb_boot_properties.file")),t}a(AG,"getPropsFilePath");function OG(e){zt=e}a(OG,"setLogLevel");function VA(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(VA,"autoCastBoolean");function bG(e){try{if(e.includes("config/settings.js")){let o=YA(e);return{level:o.get(Tt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:_s.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=$A.parseDocument(Ni.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(bG,"getLogConfig");function NG(){try{let e=$A.parseDocument(Ni.readFileSync(hG,"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(NG,"getDefaultConfig");function yG(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(yG,"AuthAuditLog")});var ZA=T((xie,jA)=>{"use strict";var wG=require("util"),IG=require("path"),CG=require("child_process"),DG=wG.promisify(CG.execFile),LG=1e3*1e3*10;jA.exports={findPs:MG};async function MG(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await DG("ps",["wwxo",`pid,${r}`],{maxBuffer:LG});for(let s of n.trim().split(`
|
|
4
|
+
`).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:IG.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(MG,"findPs")});var lt=T((qie,tO)=>{"use strict";var UG="__dbis__",PG="__txns__",vG="__environment_name__",BG="__dbi_defintion__",HG={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"},xG=["__createdtime__","__updatedtime__"],FG="\uFFFF",eO={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},qG=Object.values(eO);tO.exports={AUDIT_STORE_NAME:PG,INTERNAL_DBIS_NAME:UG,DBI_DEFINITION_NAME:BG,SEARCH_TYPES:HG,TIMESTAMP_NAMES:xG,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:vG,TRANSACTIONS_DBI_NAMES_ENUM:eO,TRANSACTIONS_DBIS:qG,OVERFLOW_MARKER:FG}});var br=T((Gie,lO)=>{"use strict";var rO=U(),nO=lt(),sO={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},iO=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),oO={500:iO("There was an error processing your request."),400:"Invalid request"},GG=oO[sO.INTERNAL_SERVER_ERROR],kG={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.`},VG={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},$G={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"},YG={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 ${nO.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${nO.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"},KG={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${rO.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 ${rO.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},aO={GENERIC_AUTH_FAIL:"Login failed",USER_INACTIVE:"Cannot complete request: User is inactive",INVALID_TOKEN:"invalid token",NO_ENCRYPTION_KEYS:"unable to generate JWT as there are no encryption keys. please contact your administrator",INVALID_CREDENTIALS:"invalid credentials",PASSWORD_REQUIRED:"password is required",USERNAME_REQUIRED:"username is required",REFRESH_TOKEN_REQUIRED:"refresh_token is required",INVALID_AUTH_OBJECT:"invalid auth_object",INVALID_BODY:"invalid body",TOKEN_EXPIRED:"token expired",REFRESH_TOKEN_SAVE_FAILED:"unable to store refresh_token"},WG={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."},QG={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`},zG={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"},JG={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},XG={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`},cO={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.`},uO={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}`},jG={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."},ZG={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},ek={...aO,...$G,...kG,...WG,...QG,...zG,...JG,...XG,...KG,...cO,...uO,...jG,...ZG,...VG};lO.exports={CHECK_LOGS_WRAPPER:iO,HDB_ERROR_MSGS:ek,DEFAULT_ERROR_MSGS:oO,DEFAULT_ERROR_RESP:GG,HTTP_STATUS_CODES:sO,LMDB_ERRORS_ENUM:YG,AUTHENTICATION_ERROR_MSGS:aO,VALIDATION_ERROR_MSGS:cO,ITC_ERRORS:uO}});var ee=T((Vie,fO)=>{"use strict";var Uo=br(),tk=W(),rk=U(),Bl=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,_O),this.statusCode=n||Uo.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(Uo.DEFAULT_ERROR_MSGS[n]?Uo.DEFAULT_ERROR_MSGS[n]:Uo.DEFAULT_ERROR_MSGS[Uo.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&&tk[s](i)}},oh=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}},ah=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function _O(e,t,r,n=rk.LOG_LEVELS.ERROR,s=null,i=!1){if(dO(e))return e;let o=new Bl(e,t,r,n,s);return i&&delete o.stack,o}a(_O,"handleHDBError");function dO(e){return e.__proto__.constructor.name===Bl.name}a(dO,"isHDBError");fO.exports={isHDBError:dO,handleHDBError:_O,ClientError:oh,ServerError:ah,hdb_errors:Uo}});var Ye=T((Yie,gO)=>{"use strict";var ac=U(),nk=J(),Xt=Z(),cc=require("path"),sk=require("minimist"),EO=require("fs-extra"),hO=require("lodash");Xt.initSync();var{CONFIG_PARAMS:Ks,DATABASES_PARAM_CONFIG:nc,SYSTEM_SCHEMA_NAME:Hl}=ac,sc,ic,oc;function mO(){if(sc!==void 0)return sc;if(Xt.getHdbBasePath()!==void 0)return sc=Xt.get(Ks.STORAGE_PATH)||cc.join(Xt.getHdbBasePath(),ac.DATABASES_DIR_NAME),sc}a(mO,"getBaseSchemaPath");function pO(){if(ic!==void 0)return ic;if(Xt.getHdbBasePath()!==void 0)return ic=TO(Hl),ic}a(pO,"getSystemSchemaPath");function SO(){if(oc!==void 0)return oc;if(Xt.getHdbBasePath()!==void 0)return oc=Xt.get(ac.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||cc.join(Xt.getHdbBasePath(),ac.TRANSACTIONS_DIR_NAME),oc}a(SO,"getTransactionAuditStoreBasePath");function ik(e,t){let r=Xt.get(Ks.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||cc.join(SO(),e.toString())}a(ik,"getTransactionAuditStorePath");function TO(e,t){e=e.toString(),t=t&&t.toString();let r=Xt.get(ac.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||cc.join(mO(),e)}a(TO,"getSchemaPath");function ok(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,sk(process.argv));let n=r[Ks.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!nk.isObject(n))throw o;i=n}for(let o of i){let c=o[Hl];if(!c)continue;let u=Xt.get(Ks.DATABASES);u=u??{};let _=c?.tables?.[t]?.[nc.PATH];if(_)return hO.set(u,[Hl,nc.TABLES,t,nc.PATH],_),Xt.setProperty(Ks.DATABASES,u),_;let l=c?.[nc.PATH];if(l)return hO.set(u,[Hl,nc.PATH],l),Xt.setProperty(Ks.DATABASES,u),l}}let s=r[Ks.STORAGE_PATH.toUpperCase()];if(s){if(!EO.pathExistsSync(s))throw new Error(s+" does not exist");let i=cc.join(s,e);return EO.mkdirsSync(i),Xt.setProperty(Ks.STORAGE_PATH,s),i}return pO()}a(ok,"initSystemSchemaPaths");function ak(){sc=void 0,ic=void 0,oc=void 0}a(ak,"resetPaths");gO.exports={getBaseSchemaPath:mO,getSystemSchemaPath:pO,getTransactionAuditStorePath:ik,getTransactionAuditStoreBasePath:SO,getSchemaPath:TO,initSystemSchemaPaths:ok,resetPaths:ak}});var Nr=T((zie,NO)=>{"use strict";var ck=br().LMDB_ERRORS_ENUM,Wie=require("lmdb"),uk=lt(),Qie=require("buffer").Buffer,{OVERFLOW_MARKER:RO,MAX_SEARCH_KEY_LENGTH:xl}=uk,AO=["number","string","symbol","boolean","bigint"];function lk(e){if(e=e?.primaryStore||e,!e)throw new Error(ck.ENV_REQUIRED)}a(lk,"validateEnv");function _k(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(_k,"stringifyData");function dk(e){return e instanceof Date?e.valueOf():e}a(dk,"convertKeyValueToWrite");function fk(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(AO.includes(typeof e))return e.length>xl?[e.slice(0,xl)+RO]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(AO.includes(typeof i))i.length>xl?r.push(i.slice(0,xl)+RO):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(fk,"getIndexedValues");var Fl=0,OO=0;function bO(){OO=Date.now()-performance.now()}a(bO,"adjustStartTime");bO();var Ek=6e4;setInterval(bO,Ek).unref();function hk(){let e=performance.now()+OO;return e>Fl?(Fl=e,e):(Fl+=488e-6,Fl)}a(hk,"getNextMonotonicTime");NO.exports={validateEnv:lk,stringifyData:_k,convertKeyValueToWrite:dk,getNextMonotonicTime:hk,getIndexedValues:fk}});var yO,Tn,ch,uc=Oe(()=>{yO=require("events"),Tn=class extends yO.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;[Symbol.asyncIterator](){let t=new ch;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){return this.queue?.shift()}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},ch=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 yi={};ke(yi,{server:()=>Xe});var wO,Xe,jt=Oe(()=>{wO=require("../../index"),Xe={};(0,wO._assignPackageExport)("server",Xe)});var _h={};ke(_h,{loadGQLSchema:()=>Sk,start:()=>lh,startOnMainThread:()=>pk});function lh({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:u,NamedTypeNode:_,StringValueNode:l}=await import("graphql"),d=o(new c(r.toString(),s)),f=new Map,E=[],h;for(let S of d.definitions)switch(S.kind){case u.OBJECT_TYPE_DEFINITION:let H=function(v){if(v.kind==="NonNullType"){let K=H(v.type);return K.nullable=!1,K}if(v.kind==="ListType")return{type:"array",elements:H(v.type)};let $={type:v.name?.value};return Object.defineProperty($,"location",{value:v.loc.startToken}),$};a(H,"getProperty");let O=S.name.value,g=[],R={table:null,database:null,properties:g};f.set(O,R);for(let v of S.directives){if(v.name.value==="table"){for(let M of v.arguments)R[M.name.value]=M.value.value;R.schema&&(R.database=R.schema),R.table||(R.table=O),R.audit&&(R.audit=R.audit!=="false"),R.attributes=R.properties,E.push(R)}if(v.name.value==="sealed"&&(R.sealed=!0),v.name.value==="export"){R.export=!0;for(let M of v.arguments)M.name.value==="name"&&(R.export={name:M.value.value})}}let B=!1;for(let v of S.fields){let M=H(v.type);M.name=v.name.value,g.push(M);for(let $ of v.directives)if($.name.value==="primaryKey")B?console.warn("Can not define two attributes as a primary key"):(M.isPrimaryKey=!0,B=!0);else if($.name.value==="indexed")M.indexed=!0;else if($.name.value==="relationship"){let K={};for(let z of $.arguments)K[z.name.value]=z.value.value;M.relationship=K}else if($.name.value==="createdTime")M.assignCreatedTime=!0;else if($.name.value==="updatedTime")M.assignUpdatedTime=!0;else if($.name.value==="expiresAt")M.expiresAt=!0;else if($.name.value==="allow"){let K=M.authorizedRoles=[];for(let z of $.arguments)z.name.value==="role"&&K.push(z.value.value)}}R.type=O,O==="Query"&&(h=R)}function p(S){let O=f.get(S.type);O?(Object.defineProperty(S,"properties",{value:O.properties}),Object.defineProperty(S,"definition",{value:O})):S.type==="array"?p(S.elements):mk.includes(S.type)||(0,IO.getWorkerIndex)()===0&&console.error(`The type ${S.type} is unknown at line ${S.location.line}, column ${S.location.column}, in ${s}`)}a(p,"connectPropertyType");for(let S of f.values())for(let O of S.properties)p(O);for(let S of E)S.tableClass=e(S),S.export&&(S.export.name===""?i.set((0,uh.dirname)(n),S.tableClass):i.set((0,uh.dirname)(n)+"/"+(S.export.name||S.type),S.tableClass))}}var uh,IO,mk,pk,Sk,CO=Oe(()=>{uh=require("path");be();IO=x(je()),mk=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];a(lh,"start");pk=lh,Sk=lh({ensureTable:ot}).handleFile});async function ql(e){return Tk?(lc||(lc=gk(Ak)),(await(await lc).import(e)).namespace):import(e)}async function gk(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:Rk,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,LO.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:vt,tables:yr,databases:Ze})}};let n=await(0,DO.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),lc}function Rk(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 Ak(){return{Resource:vt,tables:yr}}var DO,LO,Tk,lc,dh=Oe(()=>{gn();be();DO=require("fs/promises"),LO=require("path"),Tk=!1;a(ql,"secureImport");a(gk,"getCompartment");a(Rk,"secureOnlyFetch");a(Ak,"getGlobalVars")});var Eh={};ke(Eh,{handleFile:()=>Ok});async function Ok(e,t,r,n){let s=new Map,i=(0,MO.pathToFileURL)(r).toString(),o=await ql(i);u(o.default)&&n.set((0,fh.dirname)(t),o.default),c(o,(0,fh.dirname)(t));function c(_,l){for(let d in _){let f=_[d];u(f)?n.set(l+"/"+d,f):typeof f=="object"&&c(f,l+"/"+d)}}a(c,"recurseForResources");function u(_){return typeof _=="function"&&(_.get||_.put||_.post||_.delete)}return a(u,"isResource"),s}var MO,fh,UO=Oe(()=>{MO=require("url");dh();fh=require("path");a(Ok,"handleFile")});var mh={};ke(mh,{start:()=>bk});function bk({resources:e}){e.set("login",hh),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var hh,PO=Oe(()=>{gn();a(bk,"start");hh=class extends vt{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 GO={};ke(GO,{parse:()=>Sh,streamAsJSON:()=>_c,stringify:()=>wi});function _c(e){return new ph({value:e})}function vO(e){return console.error(e),JSON.stringify(e.toString())}function BO(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function wi(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===FO)return qO(e);if(t.resolution)return t.resolution.then(()=>wi(e));throw t}}function qO(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+=qO(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+wi(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Sh(e){return wk.test(e)?Nk.parse(e):JSON.parse(e)}var HO,xO,Nk,yk,FO,ph,wk,Th=Oe(()=>{HO=require("stream"),xO=x(require("json-bigint-fixes")),Nk=(0,xO.default)({useNativeBigInt:!0}),yk=1e4,FO={};BigInt.prototype.toJSON=function(){throw FO};a(_c,"streamAsJSON");ph=class extends HO.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),vO)}catch(s){yield vO(s)}else yield wi(t)}else yield wi(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);BO(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>yk?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 BO(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(vO,"handleError");a(BO,"when");a(wi,"stringify");a(qO,"jsStringify");wk=/-?\d{16,}/;a(Sh,"parse")});var eb=T((_oe,ZO)=>{"use strict";var gh=require("recursive-iterator"),Ik=require("alasql"),Rh=require("clone"),kO=J(),{handleHDBError:VO,hdb_errors:Ck}=ee(),{HDB_ERROR_MSGS:$O,HTTP_STATUS_CODES:YO}=Ck,{getDatabases:Dk}=(be(),te(Fe)),Lk=["DISTINCT_ARRAY"],KO=Symbol("validateTables"),Ah=Symbol("validateTable"),loe=Symbol("getAllColumns"),WO=Symbol("validateAllColumns"),Gl=Symbol("findColumn"),QO=Symbol("validateOrderBy"),dc=Symbol("validateSegment"),Oh=Symbol("validateColumn"),zO=Symbol("setColumnsForTable"),JO=Symbol("checkColumnsForAsterisk"),XO=Symbol("validateGroupBy"),jO=Symbol("hasColumns"),bh=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[KO](),this[JO](),this[WO]()}[KO](){if(this[jO]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Ah](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Ah](t.table)})}}[jO](){let t=!1,r=new gh(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Ah](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=Dk();if(!r[t.databaseid])throw VO(new Error,$O.SCHEMA_NOT_FOUND(t.databaseid),YO.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw VO(new Error,$O.TABLE_NOT_FOUND(t.databaseid,t.tableid),YO.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Rh(s);i.table=Rh(t),this.attributes.push(i)})}[Gl](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)}[JO](){let t=new gh(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[zO](r.tableid)}[zO](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new Ik.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[WO](){this[dc](this.statement.columns,!1),this[dc](this.statement.joins,!1),this[dc](this.statement.where,!1),this[XO](this.statement.group,!1),this[dc](this.statement.order,!0)}[dc](t,r){if(!t)return;let n=new gh(t),s=[];for(let{node:i,path:o}of n)!kO.isEmpty(i)&&!kO.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[QO](i):s.push(this[Oh](i)));return s}[XO](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&Lk.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Rh(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Gl](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[Gl](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`}[QO](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[Oh](t)}[Oh](t){let r=this[Gl](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]}};ZO.exports=bh});var rb=T((foe,tb)=>{"use strict";var Nh=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")}};tb.exports=Nh});var sb=T((hoe,nb)=>{"use strict";var yh=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};nb.exports=yh});var cb={};ke(cb,{HAS_EXPIRATION:()=>Ph,LAST_TIMESTAMP_PLACEHOLDER:()=>hc,LOCAL_TIMESTAMP:()=>Mk,METADATA:()=>fc,NO_TIMESTAMP:()=>Ih,PENDING_LOCAL_TIME:()=>vh,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>Uh,RecordEncoder:()=>Lh,TIMESTAMP_ASSIGN_LAST:()=>Pk,TIMESTAMP_ASSIGN_NEW:()=>ob,TIMESTAMP_ASSIGN_PREVIOUS:()=>ab,TIMESTAMP_PLACEHOLDER:()=>kl,TIMESTAMP_RECORD_PREVIOUS:()=>Ch,fromResource:()=>Kl,getUpdateRecord:()=>Bh,handleLocalTimeForGets:()=>Wl});function Bk(){return Ec[0]=Ec[0]^64,Uk.getFloat64(0)}function Kl(e){Mh=!0;try{return e()}finally{Mh=!1}}function Wl(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?.[fc];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?.[fc]>=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[fc];return _>=0&&(c.metadataFlags=_,c.localTime=u.localTime,c.value=u.value,u.expiresAt>0&&(c.expiresAt=u.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){if(this.timerTracked||(this.timerTracked=!0,Ii.push(new WeakRef(this))),!Mh)try{throw new Error("Read transaction used outside of resource")}catch(u){this.readStack=u.stack}o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let u=0;u<Ii.length;u++){let _=Ii[u].deref();(!_||_.isDone||_.isCommitted)&&Ii.splice(u--,1)}},i.prototype.done.isTracked=!0}return e}function Bh(e,t,r){return function(n,s,i,o,c=-1,u,_,l,d="put",f,E){if(f||u==null?Po=i?.localTime?Ch|ab:Ih:Po=u?i?.localTime?Ch|16384:ob|16384:Ih,l>0&&(c|=Ph),$l=c,Dh=l,i?.version===o&&u===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Po>0},p;try{f&&(h.ifVersion=p=i?.version??null);let S=e.put(n,s,h);if(u){let O=_?.user?.username;if(E&&(Vl=e.encoder.encode(E)),f&&i?.localTime){let g=i?.localTime,R=r.get(g);if(R){let B=Ct(R).previousLocalTime;return r.put(g,Yl(o,t,n,B,O,d,Vl),{ifVersion:p}),S}}r.put(hc,Yl(o,t,n,i?.localTime?1:0,O,d,Vl),{append:d!=="invalidate",instructedWrite:!0,ifVersion:p})}return S}catch(S){throw S.message+=" id: "+n+" options: "+h,S}}}var ib,wh,kl,hc,Uh,Mk,fc,Ec,Uk,Ih,ob,Pk,ab,Ch,Ph,vh,vk,Vl,Po,$l,Dh,Lh,Soe,Mh,Ii,vo=Oe(()=>{ib=require("msgpackr");Ci();wh=x(W()),kl=new Uint8Array([1,1,1,1,4,64,0,0]),hc=new Uint8Array([1,1,1,1,1,0,0,0]),Uh=new Uint8Array([1,1,1,1,3,64,0,0]),Mk=Symbol("local-timestamp"),fc=Symbol("metadata"),Ec=new Uint8Array(8),Uk=new DataView(Ec.buffer,0,8),Ih=0,ob=0,Pk=1,ab=3,Ch=4,Ph=16,vh=1,Po=0,$l=-1,Dh=0,Lh=class extends ib.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(n,s){if(Po||$l>=0){let i=0,o=Po;o&&(i+=8,Po=0);let c=$l,u=Dh;c>=0&&(i+=2,$l=-1,u&&(i+=8,Dh=0));let _=vk=r.call(this,n,s|2048|i);Vl=_.subarray((_.start||0)+i,_.end);let l=_.start||0;return o&&(kl[4]=o,kl[5]=o>>8,_.set(kl,l),l+=8),c>=0&&(_[l++]=c,_[l++]=0,u&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(l,u)),_}else return r.call(this,n,s)}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,u;if(i===2){if(t.copy)t.copy(Ec,0,c),c+=8;else for(let d=0;d<8;d++)Ec[d]=t[c++];u=Bk(),i=t[c]}let _;i<32&&(o=i,c+=2,o&Ph&&(_=(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,[fc]:o,expiresAt:_}}return super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(Bk,"getTimestamp");Soe=Map.prototype.get;a(Kl,"fromResource");a(Wl,"handleLocalTimeForGets");Ii=[];setInterval(()=>{for(let e=0;e<Ii.length;e++){let t=Ii[e].deref();!t||t.isDone||t.isCommitted?Ii.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(wh.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):wh.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(Bh,"getUpdateRecord")});var Ql=T((goe,ub)=>{"use strict";var xh=Z(),Fh=U(),{RecordEncoder:Hk}=(vo(),te(cb));xh.initSync();var xk=xh.get(Fh.CONFIG_PARAMS.STORAGE_COMPRESSION),Fk=xh.get(Fh.CONFIG_PARAMS.STORAGE_CACHING)!==!1,qk=Fh.UPDATES_PROPERTY,Hh=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.compression=xk&&r&&{startingOffset:32},this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=Fk&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:Hk},this.alwaysLazyProperty=n=>n===qk)}};ub.exports=Hh});var Jl=T((Aoe,_b)=>{"use strict";var Bo=Z(),mc=U();Bo.initSync();var Gk=Bo.get(mc.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Bo.get(mc.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Bo.get(mc.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",lb=Bo.get(mc.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC),kk=Bo.get(mc.CONFIG_PARAMS.STORAGE_NOREADAHEAD),zl=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=1e3,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.noSync=Gk,this.noFSAccess=!0,lb!==void 0&&(this.overlappingSync=lb),this.noReadAhead=kk}};_b.exports=zl;zl.MAX_DBS=1e4});var Ve=T((boe,Rb)=>{"use strict";var Gh=require("lmdb"),Rn=require("fs-extra"),wr=require("path"),Xl=Nr(),Eb=W(),Zt=br().LMDB_ERRORS_ENUM,jl=sb(),kh=Ql(),hb=Jl(),Ws=lt(),db=U(),{table:Vk,resetDatabases:$k}=(be(),te(Fe)),fb=Z(),An=Ws.INTERNAL_DBIS_NAME,mb=Ws.DBI_DEFINITION_NAME,Yk="data.mdb",Kk="lock.mdb",pc=".mdb",Wk="-lock",qh=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=Xr(t,r),this.key_type=this.dbi[Ws.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Ws.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new Gh.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Zl(e,t){if(e===void 0)throw new Error(Zt.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Zt.ENV_NAME_REQUIRED)}a(Zl,"pathEnvNameValidation");async function Vh(e,t,r=!0){try{await Rn.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Zt.INVALID_BASE_PATH):n}try{let n=wr.join(e,t+pc);return await Rn.access(n,Rn.constants.R_OK|Rn.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Rn.access(wr.join(e,t,Yk),Rn.constants.R_OK|Rn.constants.F_OK),wr.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Zt.INVALID_ENVIRONMENT)}else throw new Error(Zt.INVALID_ENVIRONMENT);throw n}}a(Vh,"validateEnvironmentPath");function e_(e,t){if(Xl.validateEnv(e),t===void 0)throw new Error(Zt.DBI_NAME_REQUIRED)}a(e_,"validateEnvDBIName");async function Qk(e,t,r=!1,n=!1){Zl(e,t);let s=wr.basename(e);t=t.toString();let i=fb.get(db.CONFIG_PARAMS.DATABASES);i||fb.setProperty(db.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await Vh(e,t,n),pb(e,t,r)}catch(o){if(o.message===Zt.INVALID_ENVIRONMENT){let c=wr.join(e,t);await Rn.mkdirp(n?c:e);let u=new hb(n?c:c+pc,!1),_=Gh.open(u);_.dbis=Object.create(null);let l=new kh(!1);_.openDB(An,l),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=$h(e,t,r);return _[Ws.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=_,_}throw o}}a(Qk,"createEnvironment");async function zk(e,t,r,n=!0){Zl(e,t),t=t.toString();let s=wr.join(e,t);return Vk({table:t,database:wr.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(zk,"copyEnvironment");async function pb(e,t,r=!1){Zl(e,t),t=t.toString();let n=$h(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 Vh(e,t),i=wr.join(e,t+pc),o=s!=i,c=new hb(s,o),u=Gh.open(c);u.dbis=Object.create(null);let _=Tb(u);for(let l=0;l<_.length;l++)Xr(u,_[l]);return u[Ws.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=u,u}a(pb,"openEnvironment");async function Jk(e,t,r=!1){Zl(e,t),t=t.toString();let n=wr.join(e,t+pc),s=await Vh(e,t);if(global.lmdb_map!==void 0){let i=$h(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await Sb(o),delete global.lmdb_map[i]}}await Rn.remove(s),await Rn.remove(s===n?s+Wk:wr.join(wr.dirname(s),Kk))}a(Jk,"deleteEnvironment");async function Sb(e){Xl.validateEnv(e);let t=e[Ws.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(Sb,"closeEnvironment");function $h(e,t,r=!1){let s=`${wr.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a($h,"getCachedEnvironmentName");function Xk(e){Xl.validateEnv(e);let t=Object.create(null),r=Xr(e,An);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==An)try{t[n]=Object.assign(new jl,s)}catch{Eb.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(Xk,"listDBIDefinitions");function Tb(e){Xl.validateEnv(e);let t=[],r=Xr(e,An);for(let{key:n}of r.getRange({start:!1}))n!==An&&t.push(n);return t}a(Tb,"listDBIs");function jk(e,t){let n=Xr(e,An).getEntry(t),s=new jl;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{Eb.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(jk,"getDBIDefinition");function gb(e,t,r,n=!r){if(e_(e,t),t=t.toString(),t===An)throw new Error(Zt.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Xr(e,t)}catch(s){if(s.message===Zt.DBI_DOES_NOT_EXIST){let i=new kh(r,n===!0),o=e.openDB(t,i),c=new jl(r===!0,n);return o[mb]=c,Xr(e,An).putSync(t,c),e.dbis[t]=o,o}throw s}}a(gb,"createDBI");function Xr(e,t){if(e_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==An?r=jk(e,t):r=new jl,r===void 0)throw new Error(Zt.DBI_DOES_NOT_EXIST);let n;try{let s=new kh(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(Zt.DBI_DOES_NOT_EXIST):s}return n[mb]=r,e.dbis[t]=n,n}a(Xr,"openDBI");function Zk(e,t){e_(e,t),t=t.toString();let r=Xr(e,t),n=r.getStats();return r[Ws.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(Zk,"statDBI");async function eV(e,t){try{let r=wr.join(e,t+pc);return(await Rn.stat(r)).size}catch{throw new Error(Zt.INVALID_ENVIRONMENT)}}a(eV,"environmentDataSize");function tV(e,t){if(e_(e,t),t=t.toString(),t===An)throw new Error(Zt.CANNOT_DROP_INTERNAL_DBIS_NAME);Xr(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Xr(e,An).removeSync(t)}a(tV,"dropDBI");function rV(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{Xr(e,i)}catch(o){if(o.message===Zt.DBI_DOES_NOT_EXIST)gb(e,i,i!==t,i===t),n=!0;else throw o}}n&&$k()}a(rV,"initializeDBIs");Rb.exports={openDBI:Xr,openEnvironment:pb,createEnvironment:Qk,listDBIs:Tb,listDBIDefinitions:Xk,createDBI:gb,dropDBI:tV,statDBI:Zk,deleteEnvironment:Jk,initializeDBIs:rV,TransactionCursor:qh,environmentDataSize:eV,copyEnvironment:zk,closeEnvironment:Sb}});var Ob=T((yoe,Ab)=>{"use strict";var Yh=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};Ab.exports=Yh});var Nb=T((Ioe,bb)=>{"use strict";var Kh=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}};bb.exports=Kh});var wb=T((Doe,yb)=>{"use strict";var Wh=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};yb.exports=Wh});var Ho=T((voe,Db)=>{"use strict";var nV=Ve(),sV=Ob(),iV=Nb(),oV=wb(),Gn=Nr(),Sc=br().LMDB_ERRORS_ENUM,aV=lt(),Es=U(),cV=J(),uV=require("uuid"),Moe=require("lmdb"),{handleHDBError:lV,hdb_errors:_V}=ee(),{OVERFLOW_MARKER:Uoe,MAX_SEARCH_KEY_LENGTH:Poe}=aV,Ib=Z();Ib.initSync();var t_=Ib.get(Es.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),Qh=Es.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Di=Es.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function dV(e,t,r,n,s=Gn.getNextMonotonicTime()){jh(e,t,r,n),zh(e,t,r);let i=new sV,o=[],c=[];for(let u=0;u<n.length;u++){let _=n[u];Cb(_,!0,s);let l=fV(e,t,r,_),d=_[t];o.push(l),c.push(d)}return Jh(o,c,n,i,s)}a(dV,"insertRecords");function fV(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][Es.FUNC_VAL],n[o]=c)}let u=Gn.getIndexedValues(c),_=e.dbis[o];if(u){t_&&_.prefetch(u.map(l=>({key:l,value:s})),r_);for(let l=0,d=u.length;l<d;l++)_.put(u[l],s)}}t_&&e.dbis[t].prefetch([s],r_),e.dbis[t].put(s,n,n[Di])})}a(fV,"insertRecord");function EV(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(EV,"removeSkippedRecords");function Cb(e,t,r){let n=r>0;(n||!Number.isInteger(e[Di]))&&(e[Di]=r||(r=Gn.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[Qh]))&&(e[Qh]=r||Gn.getNextMonotonicTime()):delete e[Qh]}a(Cb,"setTimestamps");function zh(e,t,r){r.indexOf(Es.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Es.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Es.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Es.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),nV.initializeDBIs(e,t,r)}a(zh,"initializeTransaction");async function hV(e,t,r,n,s=Gn.getNextMonotonicTime()){jh(e,t,r,n),zh(e,t,r);let i=new iV,o=[],c=[],u=[];for(let _=0;_<n.length;_++){let l=n[_],d=l[t],f;try{f=Xh(e,t,l,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(_);continue}c.push(f),u.push(d)}return Jh(c,u,n,i,s,o)}a(hV,"updateRecords");async function mV(e,t,r,n,s=Gn.getNextMonotonicTime()){try{jh(e,t,r,n)}catch(u){throw lV(u,u.message,_V.HTTP_STATUS_CODES.BAD_REQUEST)}zh(e,t,r);let i=new oV,o=[],c=[];for(let u=0;u<n.length;u++){let _=n[u],l;cV.isEmpty(_[t])?(l=uV.v4(),_[t]=l):l=_[t];let d=Xh(e,t,_,l,i,!1,s);o.push(d),c.push(l)}return Jh(o,c,n,i,s)}a(mV,"upsertRecords");async function Jh(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||Gn.getNextMonotonicTime(),EV(r,i),n}a(Jh,"finalizeWrite");function Xh(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(Cb(r,!l,o),Number.isInteger(r[Di])&&_[Di]>r[Di])return!1;l&&s.original_records.push(_);let d,f=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let p=r[h],S=e.dbis[h];if(S===void 0)continue;let O=_[h];if(typeof p=="function"){let R=p([[_]]);Array.isArray(R)&&(p=R[0][Es.FUNC_VAL],r[h]=p)}if(p===O)continue;let g=Gn.getIndexedValues(O);if(g){t_&&S.prefetch(g.map(R=>({key:R,value:n})),r_);for(let R=0,B=g.length;R<B;R++)S.remove(g[R],n)}if(g=Gn.getIndexedValues(p),g){t_&&S.prefetch(g.map(R=>({key:R,value:n})),r_);for(let R=0,B=g.length;R<B;R++)S.put(g[R],n)}}let E=Object.assign({},_,r);c.put(n,E,E[Di])},"do_put");return u?d=c.ifVersion(n,u.version,f):d=c.ifNoExists(n,f),d.then(E=>E?!0:Xh(e,t,r,n,s,i,o))}a(Xh,"updateUpsertRecord");function pV(e,t,r){if(Gn.validateEnv(e),t===void 0)throw new Error(Sc.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Sc.WRITE_ATTRIBUTES_REQUIRED):new Error(Sc.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(pV,"validateBasic");function jh(e,t,r,n){if(pV(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Sc.RECORDS_REQUIRED):new Error(Sc.RECORDS_MUST_BE_ARRAY)}a(jh,"validateWrite");function r_(){}a(r_,"noop");Db.exports={insertRecords:dV,updateRecords:hV,upsertRecords:mV}});var Li=T((Hoe,SV)=>{SV.exports={hdb_table:{hash_attribute:"id",name:"hdb_table",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"name"},{attribute:"hash_attribute"},{attribute:"schema"},{attribute:"residence"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_attribute:{hash_attribute:"id",name:"hdb_attribute",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"schema"},{attribute:"table"},{attribute:"attribute"},{attribute:"schema_table"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_schema:{hash_attribute:"name",name:"hdb_schema",schema:"system",residence:["*"],attributes:[{attribute:"name"},{attribute:"createddate"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metric"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var Vn=T((xoe,Ub)=>{"use strict";var Mb=J(),Lb=U(),xo=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,kn=require("joi"),Qs={schema_format:{pattern:xo,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},TV=kn.alternatives(kn.string().min(1).max(Qs.schema_length.maximum).pattern(xo).messages({"string.pattern.base":"{:#label} "+Qs.schema_format.message}),kn.number(),kn.array()).required(),gV=kn.alternatives(kn.string().min(1).max(Qs.schema_length.maximum).pattern(xo).messages({"string.pattern.base":"{:#label} "+Qs.schema_format.message}),kn.number()),RV=kn.alternatives(kn.string().min(1).max(Qs.schema_length.maximum).pattern(xo).messages({"string.pattern.base":"{:#label} "+Qs.schema_format.message}),kn.number()).required();function AV(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Qs.schema_length.maximum?`'${e}' maximum of 250 characters`:xo.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(AV,"checkValidTable");function OV(e,t){return Mb.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(OV,"validateSchemaExists");function bV(e,t){let r=t.state.ancestors[0].schema;return Mb.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(bV,"validateTableExists");function NV(e,t){return e.toLowerCase()===Lb.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${Lb.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(NV,"validateSchemaName");Ub.exports={common_validators:Qs,schema_regex:xo,hdb_schema_table:TV,validateSchemaExists:OV,validateTableExists:bV,validateSchemaName:NV,checkValidTable:AV,hdb_database:gV,hdb_table:RV}});var et=T((qoe,Pb)=>{"use strict";var er=require("validate.js");er.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||er.validators.type.checks[t](e)?null:` must be a '${t}' value`};er.validators.type.checks={Object:function(e){return er.isObject(e)&&!er.isArray(e)},Array:er.isArray,Integer:er.isInteger,Number:er.isNumber,String:er.isString,Date:er.isDate,Boolean:function(e){return typeof e=="boolean"}};er.validators.hasValidFileExt=function(e,t){return er.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};Pb.exports={validateObject:yV,validateObjectAsync:wV,validateBySchema:IV};function yV(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=er(e,t,{format:"flat"});return r?new Error(r):null}a(yV,"validateObject");async function wV(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await er.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(wV,"validateObjectAsync");function IV(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(IV,"validateBySchema")});var n_=T((koe,vb)=>{var{common_validators:$n}=Vn(),gc=et(),Tc="is required",_t={database:{presence:!1,format:$n.schema_format,length:$n.schema_length},schema:{presence:!1,format:$n.schema_format,length:$n.schema_length},table:{presence:!0,format:$n.schema_format,length:$n.schema_length},attribute:{presence:!0,format:$n.schema_format,length:$n.schema_length},hash_attribute:{presence:!0,format:$n.schema_format,length:$n.schema_length}};function Rc(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(Rc,"makeAttributesStrings");function CV(e){return e=Rc(e),_t.table.presence=!1,_t.attribute.presence=!1,_t.hash_attribute.presence=!1,gc.validateObject(e,_t)}a(CV,"schema_object");function DV(e){return e=Rc(e),_t.table.presence={message:Tc},_t.attribute.presence=!1,_t.hash_attribute.presence=!1,gc.validateObject(e,_t)}a(DV,"table_object");function LV(e){return e=Rc(e),_t.table.presence={message:Tc},_t.attribute.presence=!1,gc.validateObject(e,_t)}a(LV,"create_table_object");function MV(e){return e=Rc(e),_t.table.presence={message:Tc},_t.attribute.presence={message:Tc},_t.hash_attribute.presence=!1,gc.validateObject(e,_t)}a(MV,"attribute_object");function UV(e){return e=Rc(e),_t.table.presence={message:Tc},_t.attribute.presence=!1,_t.hash_attribute.presence=!1,gc.validateObject(e,_t)}a(UV,"describe_table");function PV(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(PV,"validateTableResidence");vb.exports={schema_object:CV,create_table_object:LV,table_object:DV,attribute_object:MV,describe_table:UV,validateTableResidence:PV}});var Hb=T(($oe,Bb)=>{"use strict";var vV=require("uuid"),Zh=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||vV.v4(),this.schema_table=`${this.schema}.${this.table}`}};Bb.exports=Zh});var s_=T((Koe,xb)=>{"use strict";var BV=Hb(),em=class extends BV{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}};xb.exports=em});var qb=T((Qoe,Fb)=>{"use strict";Fb.exports=xV;var HV="inserted";function xV(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===HV?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(xV,"returnObject")});var i_=T((Joe,Yb)=>{"use strict";var FV=U(),tm=Ve(),qV=Ho(),{getSystemSchemaPath:GV,getSchemaPath:kV}=Ye(),VV=Li(),$V=n_(),YV=s_(),KV=qb(),{handleHDBError:Gb,hdb_errors:Vb}=ee(),kb=J(),{HTTP_STATUS_CODES:WV}=Vb,rm=VV.hdb_attribute,$b=[];for(let e=0;e<rm.attributes.length;e++)$b.push(rm.attributes[e].attribute);var QV="inserted";Yb.exports=zV;async function zV(e){let t=$V.attribute_object(e);if(t)throw Gb(new Error,t.message,Vb.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&kb.checkGlobalSchemaTable(e.schema,e.table);if(r)throw Gb(new Error,r,WV.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=kb.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 YV(e.schema,e.table,e.attribute,e.id);try{let i=await tm.openEnvironment(kV(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}`);tm.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await tm.openEnvironment(GV(),FV.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:u}=await qV.insertRecords(o,rm.hash_attribute,$b,[s]);return KV(QV,c,{records:[s]},u)}catch(i){throw i}}a(zV,"lmdbCreateAttribute")});var sm=T((joe,Wb)=>{var{hdb_table:JV,hdb_database:Kb}=Vn(),XV=et(),nm=require("joi"),jV={undefined:"undefined",null:"null"},ZV=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||jV[o]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${o}'`:s+=`. Invalid attribute name: '${o}'`)}return s?t.message(s):e},"custom_records_val"),e$=nm.object({database:Kb,schema:Kb,table:JV,records:nm.array().items(nm.object().custom(ZV)).required()});Wb.exports=function(e){return XV.validateBySchema(e,e$)}});var Ac=T((tae,zb)=>{"use strict";var hs=J(),Qb=W(),eae=sm(),{getDatabases:t$}=(be(),te(Fe)),{ClientError:Mi}=ee();zb.exports=r$;function r$(e){if(hs.isEmpty(e))throw new Mi("invalid update parameters defined.");if(hs.isEmptyOrZeroLength(e.schema))throw new Mi("invalid schema specified.");if(hs.isEmptyOrZeroLength(e.table))throw new Mi("invalid table specified.");if(!Array.isArray(e.records))throw new Mi("records must be an array");let t=t$()[e.schema]?.[e.table];if(hs.isEmpty(t))throw new Mi(`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&&hs.isEmptyOrZeroLength(o[r]))throw Qb.error("a valid hash attribute must be provided with update record:",o),new Mi("a valid hash attribute must be provided with update record, check log for more info");if(!hs.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw Qb.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Mi(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!hs.isEmpty(o[r])&&o[r]!==""&&n.has(hs.autoCast(o[r]))&&(o.skip=!0),n.add(hs.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(r$,"insertUpdateValidate")});var Oc=T((nae,Jb)=>{"use strict";var n$=U().OPERATIONS_ENUM,im=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=n$.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};Jb.exports=im});var wc=T((oae,Xb)=>{"use strict";var iae=Oc(),o_=U(),am=J(),om=W(),s$=require("uuid"),{handleHDBError:bc,hdb_errors:i$}=ee(),{HDB_ERROR_MSGS:Nc,HTTP_STATUS_CODES:yc}=i$;Xb.exports=o$;function o$(e,t,r){for(let s=0;s<t.length;s++)a$(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];c$(i,r,e.operation)}}a(o$,"processRows");function a$(e){if(Buffer.byteLength(String(e))>o_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw bc(new Error,Nc.ATTR_NAME_LENGTH_ERR(e),yc.BAD_REQUEST,void 0,void 0,!0);if(am.isEmptyOrZeroLength(e)||am.isEmpty(e.trim()))throw bc(new Error,Nc.ATTR_NAME_NULLISH_ERR,yc.BAD_REQUEST,void 0,void 0,!0)}a(a$,"validateAttribute");function c$(e,t,r){if(!e.hasOwnProperty(t)||am.isEmptyOrZeroLength(e[t])){if(r===o_.OPERATIONS_ENUM.INSERT||r===o_.OPERATIONS_ENUM.UPSERT){e[t]=s$.v4();return}throw om.error("Update transaction aborted due to record with no hash value:",e),bc(new Error,Nc.RECORD_MISSING_HASH_ERR,yc.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>o_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw om.error(e),bc(new Error,Nc.HASH_VAL_LENGTH_ERR,yc.BAD_REQUEST,void 0,void 0,!0);if(isNaN(e[t])&&e[t].includes("/"))throw om.error(e),bc(new Error,Nc.INVALID_FORWARD_SLASH_IN_HASH_ERR,yc.BAD_REQUEST,void 0,void 0,!0)}a(c$,"validateHash")});var Zb=T((cae,jb)=>{"use strict";var cm=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};jb.exports=cm});var rN=T((lae,tN)=>{"use strict";var um=Ve(),u$=W(),eN=br().LMDB_ERRORS_ENUM;tN.exports=l$;async function l$(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 um.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==eN.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await um.closeEnvironment(global.lmdb_map[n]),await um.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==eN.ENV_REQUIRED)throw i}break;case"drop_attribute":r=global.lmdb_map[`${e.schema}.${e.table}`],r!==void 0&&typeof r.dbis=="object"&&r.dbis[`${e.attribute}`]!==void 0&&delete r.dbis[`${e.attribute}`];break;default:break}}}catch(t){u$.error(t)}}a(l$,"cleanLMDBMap")});var ms=T((dae,oN)=>{"use strict";var Ic=require("crypto"),_$=Z(),{CONFIG_PARAMS:d$}=U(),sN="aes-256-cbc",f$=32,E$=16,lm=64,iN=32,h$=lm+iN,nN=new Map;oN.exports={encrypt:m$,decrypt:p$,createNatsTableStreamName:S$};function m$(e){let t=Ic.randomBytes(f$),r=Ic.randomBytes(E$),n=Ic.createCipheriv(sN,Buffer.from(t),r),s=n.update(e);s=Buffer.concat([s,n.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=s.toString("hex");return i+o+c}a(m$,"encrypt");function p$(e){let t=e.substr(0,lm),r=e.substr(lm,iN),n=e.substr(h$,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=Ic.createDecipheriv(sN,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(p$,"decrypt");function S$(e,t){let r=_$.get(d$.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=nN.get(r);return n||(n=Ic.createHash("md5").update(r).digest("hex"),nN.set(r,n)),n}a(S$,"createNatsTableStreamName")});var Ui=T((hae,cN)=>{"use strict";var Eae=jr(),a_=W(),aN=n_(),T$=ms(),c_=J(),{handleHDBError:u_,hdb_errors:g$}=ee(),{HDB_ERROR_MSGS:l_,HTTP_STATUS_CODES:_m}=g$,R$=Z();R$.initSync();var{getDatabases:dm}=(be(),te(Fe));cN.exports={describeAll:A$,describeTable:__,describeSchema:O$};async function A$(e){try{let t=c_.isEmptyOrZeroLength(e),r,n;t||(r=e.hdb_user.role.permission,n=r.super_user||r.cluster_user);let s=dm(),i={},o={},c=[],u=e?.exact_count;for(let l in s){i[l]=!0,!t&&!n&&(o[l]=e.hdb_user.role.permission[l].describe);let d=s[l];for(let f in d)try{let E;if(t||n)E=await __({schema:l,table:f,exact_count:u});else if(r&&r[l].describe&&r[l].tables[f].describe){let h=r[l].tables[f].attribute_permissions;E=await __({schema:l,table:f,exact_count:u},h)}E&&c.push(E)}catch(E){a_.error(E)}}let _={};for(let l in c)t||n?(_[c[l].schema]==null&&(_[c[l].schema]={}),_[c[l].schema][c[l].name]=c[l],i[c[l].schema]&&delete i[c[l].schema]):o[c[l].schema]&&(_[c[l].schema]==null&&(_[c[l].schema]={}),_[c[l].schema][c[l].name]=c[l],i[c[l].schema]&&delete i[c[l].schema]);for(let l in i)t||n?_[l]={}:o[l]&&(_[l]={});return _}catch(t){return a_.error("Got an error in describeAll"),a_.error(t),u_(new Error,l_.DESCRIBE_ALL_ERR)}}a(A$,"describeAll");async function __(e,t){c_.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user.role.permission.super_user&&(s=e.hdb_user.role.permission[r].tables[n].attribute_permissions);let i=aN.describe_table(e);if(i)throw i;let c=dm()[r];if(!c)throw u_(new Error,l_.SCHEMA_NOT_FOUND(e.schema),_m.NOT_FOUND);let u=c[n];if(!u)throw u_(new Error,l_.TABLE_NOT_FOUND(e.schema,e.table),_m.NOT_FOUND);function _(f){l.push(Object.assign({},{attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(E=>({type:E.type,name:E.name})):void 0}))}a(_,"pushAtt");let l=[];if(s){let f={};s.forEach(E=>{E.describe&&(f[E.attribute_name]=!0)}),u.attributes.forEach(E=>{f[E.name]&&_(E)})}else u.attributes?.forEach(f=>_(f));let d={schema:r,name:u.tableName,hash_attribute:u.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:u.audit,schema_defined:u.schemaDefined,attributes:l};d.clustering_stream_name=T$.createNatsTableStreamName(d.schema,d.name);try{let f=u.getRecordCount({exactCount:e.exact_count==="true"});d.record_count=f.recordCount,d.estimated_record_range=f.estimatedRange;let E=u.auditStore;if(E)for(let h of E.getKeys({reverse:!0,limit:1}))d.last_updated_record=h[0];if(!d.last_updated_record&&u.indices.__updatedtime__)for(let h of u.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))d.last_updated_record=h}catch(f){a_.warn(`unable to stat table dbi due to ${f}`)}return d}a(__,"descTable");async function O$(e){c_.transformReq(e);let t=aN.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user.role.permission.super_user&&(r=e.hdb_user.role.permission[e.schema]);let n=e.schema.toString(),i=dm()[n];if(!i)throw u_(new Error,l_.SCHEMA_NOT_FOUND(e.schema),_m.NOT_FOUND);let o={};for(let c in i){let u;if(r&&r.tables[c]&&(u=r.tables[c]),c_.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(O$,"describeSchema")});var zs=T((Tae,fN)=>{var b$=Li(),{callbackify:lN,promisify:N$}=require("util"),{getDatabases:_N}=(be(),te(Fe));fN.exports={setSchemaDataToGlobal:uN,getTableSchema:y$,getSystemSchema:w$,setSchemaDataToGlobalAsync:N$(uN)};var dN=Ui(),pae=lN(dN.describeAll),Sae=lN(dN.describeTable);function uN(e){global.hdb_schema=_N(),e&&e()}a(uN,"setSchemaDataToGlobal");function y$(e,t,r){let n=_N()[e];if(!n)return r(`schema ${e} does not exist`);let s=n[t];return s?r(null,{schema:e,name:t,hash_attribute:s.primaryKey}):r(`table ${e}.${t} does not exist`)}a(y$,"getTableSchema");function w$(){return b$}a(w$,"getSystemSchema")});var Zr=T((Rae,pN)=>{"use strict";var f_=sm(),Bt=J(),I$=require("util"),E_=On(),C$=zs(),EN=W(),{handleHDBError:Pi,hdb_errors:D$}=ee(),{HTTP_STATUS_CODES:vi}=D$,L$=I$.promisify(C$.getTableSchema),M$="updated",hN="inserted",mN="upserted";pN.exports={insert:P$,update:v$,upsert:B$,validation:U$,flush:H$};async function U$(e){if(Bt.isEmpty(e))throw new Error("invalid update parameters defined.");if(Bt.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Bt.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await L$(e.schema,e.table),r=f_(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&&Bt.isEmptyOrZeroLength(c[n]))throw EN.error("a valid hash attribute must be provided with update record:",c),new Error("a valid hash attribute must be provided with update record");if(!Bt.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw EN.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Bt.isEmpty(c[n])&&c[n]!==""&&s.has(Bt.autoCast(c[n]))&&(c.skip=!0),s.add(Bt.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(U$,"validation");async function P$(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=f_(e);if(t)throw Pi(new Error,t.message,vi.BAD_REQUEST);Bt.transformReq(e);let r=Bt.checkSchemaTableExist(e.schema,e.table);if(r)throw Pi(new Error,r,vi.BAD_REQUEST);let n=await E_.createRecords(e);return d_(hN,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(P$,"insertData");async function v$(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=f_(e);if(t)throw Pi(new Error,t.message,vi.BAD_REQUEST);Bt.transformReq(e);let r=Bt.checkSchemaTableExist(e.schema,e.table);if(r)throw Pi(new Error,r,vi.BAD_REQUEST);let n=await E_.updateRecords(e);return Bt.isEmpty(n.existing_rows)?d_(M$,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):d_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(v$,"updateData");async function B$(e){if(e.operation!=="upsert")throw Pi(new Error,"invalid operation, must be upsert",vi.INTERNAL_SERVER_ERROR);let t=f_(e);if(t)throw Pi(new Error,t.message,vi.BAD_REQUEST);Bt.transformReq(e);let r=Bt.checkSchemaTableExist(e.schema,e.table);if(r)throw Pi(new Error,r,vi.BAD_REQUEST);let n=await E_.upsertRecords(e);return d_(mN,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(B$,"upsertData");function d_(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===hN?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===mN?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(d_,"returnObject");function H$(e){return Bt.transformReq(e),E_.flush(e.schema,e.table)}a(H$,"flush")});var Em=T((Oae,gN)=>{var x$=et(),fm=require("joi"),{hdb_table:F$,hdb_database:SN}=Vn(),TN={schema:SN,database:SN,table:F$},q$={date:fm.date().iso().required()},G$={timestamp:fm.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};gN.exports=function(e,t){let r=t==="timestamp"?{...TN,...G$}:{...TN,...q$},n=fm.object(r);return x$.validateBySchema(e,n)}});var ON=T((bae,AN)=>{var k$=et(),hm=require("joi"),{hdb_table:V$,hdb_database:RN}=Vn(),$$=hm.object({schema:RN,database:RN,table:V$,hash_values:hm.array().required(),ids:hm.array()});AN.exports=function(e){return k$.validateBySchema(e,$$)}});var NN=T((Nae,bN)=>{"use strict";var mm=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}},pm=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}},Sm=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};bN.exports={InsertObject:mm,NoSQLSeachObject:pm,DeleteResponseObject:Sm}});var xi=T((wae,DN)=>{"use strict";var wN=Em(),Y$=ON(),Bi=J(),yN=require("moment"),IN=W(),{promisify:K$,callbackify:W$}=require("util"),Hi=U(),Q$=zs(),Tm=K$(Q$.getTableSchema),gm=On(),{DeleteResponseObject:z$}=NN(),{handleHDBError:Js,hdb_errors:J$}=ee(),{HDB_ERROR_MSGS:h_,HTTP_STATUS_CODES:Xs}=J$,X$="records successfully deleted",j$=W$(CN);DN.exports={delete:j$,deleteRecord:CN,deleteFilesBefore:Z$,deleteAuditLogsBefore:e1};async function Z$(e){let t=wN(e,"date");if(t)throw Js(t,t.message,Xs.BAD_REQUEST,void 0,void 0,!0);if(Bi.transformReq(e),!yN(e.date,yN.ISO_8601).isValid())throw Js(new Error,h_.INVALID_DATE,Xs.BAD_REQUEST,Hi.LOG_LEVELS.ERROR,h_.INVALID_DATE,!0);let n=Bi.checkSchemaTableExist(e.schema,e.table);if(n)throw Js(new Error,n,Xs.NOT_FOUND,Hi.LOG_LEVELS.ERROR,n,!0);let s=await gm.deleteRecordsBefore(e);if(await Tm(e.schema,e.table),IN.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(Z$,"deleteFilesBefore");async function e1(e){let t=wN(e,"timestamp");if(t)throw Js(t,t.message,Xs.BAD_REQUEST,void 0,void 0,!0);if(Bi.transformReq(e),isNaN(e.timestamp))throw Js(new Error,h_.INVALID_VALUE("Timestamp"),Xs.BAD_REQUEST,Hi.LOG_LEVELS.ERROR,h_.INVALID_VALUE("Timestamp"),!0);let r=Bi.checkSchemaTableExist(e.schema,e.table);if(r)throw Js(new Error,r,Xs.NOT_FOUND,Hi.LOG_LEVELS.ERROR,r,!0);let n=await gm.deleteAuditLogsBefore(e);return await Tm(e.schema,e.table),IN.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(e1,"deleteAuditLogsBefore");async function CN(e){e.ids&&(e.hash_values=e.ids);let t=Y$(e);if(t)throw Js(t,t.message,Xs.BAD_REQUEST,void 0,void 0,!0);Bi.transformReq(e);let r=Bi.checkSchemaTableExist(e.schema,e.table);if(r)throw Js(new Error,r,Xs.NOT_FOUND,Hi.LOG_LEVELS.ERROR,r,!0);try{await Tm(e.schema,e.table);let n=await gm.deleteRecords(e);return Bi.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${X$}`),n}catch(n){if(n.message===Hi.SEARCH_NOT_FOUND_MESSAGE){let s=new z$;return s.message=Hi.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(CN,"deleteRecord")});var m_=T((Cae,UN)=>{var t1=require("crypto"),LN=9;function r1(e){let t=s1(LN),r=MN(e+t);return t+r}a(r1,"createHash");function n1(e,t){let r=e?.substr(0,LN),n=r+MN(t+r);return e===n}a(n1,"validateHash");function s1(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,n="";for(let s=0;s<e;s++){let i=Math.floor(Math.random()*r);n+=t[i]}return n}a(s1,"generateSalt");function MN(e){return t1.createHash("md5").update(e).digest("hex")}a(MN,"md5");UN.exports={hash:r1,validate:n1}});var vN=T((Lae,PN)=>{var Rm=et(),Vt={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 i1(e){return Vt.password.presence=!0,Vt.username.presence=!0,Vt.role.presence=!0,Vt.active.presence=!0,Rm.validateObject(e,Vt)}a(i1,"addUserValidation");function o1(e){return Vt.password.presence=!1,Vt.username.presence=!0,Vt.role.presence=!1,Vt.active.presence=!1,Rm.validateObject(e,Vt)}a(o1,"alterUserValidation");function a1(e){return Vt.password.presence=!1,Vt.username.presence=!0,Vt.role.presence=!1,Vt.active.presence=!1,Rm.validateObject(e,Vt)}a(a1,"dropUserValidation");PN.exports={addUserValidation:i1,alterUserValidation:o1,dropUserValidation:a1}});var tt=T((Pae,HN)=>{"use strict";var{platform:Uae}=require("os"),c1="nats-server.zip",Am="nats-server",u1=process.platform==="win32"?`${Am}.exe`:Am,Om="HDB",l1=/^[^\s.,*>]+$/,BN="__request__",_1=a(e=>`${e}.${BN}`,"REQUEST_SUBJECT"),d1={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},f1={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},E1={HUB:"hub.pid",LEAF:"leaf.pid"},h1={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},m1={stream_name:"__HARPERDB_WORK_QUEUE__",durable_name:"HDB_WORK_QUEUE",deliver_group:Om,deliver_subject:"__HDB__.WORKQUEUE"},p1={stream_name:"__HARPERDB_SCHEMA_QUEUE__",durable_name:"HDB_SCHEMA_QUEUE",deliver_group:Om,deliver_subject:"HDB.SCHEMAQUEUE"},S1={stream_name:"__HARPERDB_USER_QUEUE__",durable_name:"HDB_USER_QUEUE",deliver_group:Om,deliver_subject:"HDB.USERQUEUE"},T1={SUCCESS:"success",ERROR:"error"},g1={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},R1={TXN:"txn",MSGID:"msgid"},Fo={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},A1={[Fo.ERR]:1,[Fo.WRN]:2,[Fo.INF]:3,[Fo.DBG]:4,[Fo.TRC]:5},O1={debug:"-D",trace:"-DVV"};HN.exports={NATS_SERVER_ZIP:c1,NATS_SERVER_NAME:Am,NATS_BINARY_NAME:u1,PID_FILES:E1,NATS_CONFIG_FILES:f1,SERVER_SUFFIX:h1,WORK_QUEUE_CONSUMER_NAMES:m1,SCHEMA_QUEUE_CONSUMER_NAMES:p1,USER_QUEUE_CONSUMER_NAMES:S1,NATS_TERM_CONSTRAINTS_RX:l1,REQUEST_SUFFIX:BN,UPDATE_REMOTE_RESPONSE_STATUSES:T1,CLUSTER_STATUS_STATUSES:g1,REQUEST_SUBJECT:_1,SUBJECT_PREFIXES:R1,MSG_HEADERS:d1,LOG_LEVELS:Fo,LOG_LEVEL_FLAGS:O1,LOG_LEVEL_HIERARCHY:A1}});var FN=T((Bae,xN)=>{"use strict";var b1={key:"-----BEGIN RSA PRIVATE KEY-----\rMIIEowIBAAKCAQEArBFJQRfFiJku/KwhV1Ssp7cX61vvuKmd4Rp6A9jB2QLgx8nj\r/+Xhp2hPRkISnOA8BuAxr4dMD9syGJwX4kNy9mbZ5Q0fWZCiEGBpVcU1J+k+N5K4\rSuZ2SqgxeN2IN2RLzt3GyQY4imcdHgNv7aHoXUrEwBx0MeYEw3IIDXtrYKCR2D8I\rvWBfwMUgWa24G8lpWILWA5hd9srRz9NxlAiHSjhbgT7B0xruEpHRCHSyKjvaIJVt\rWBR+amejYsAKVrD/hgrqjsA1123Y6++YqvU6vwg64xhS2kz5r3dkNKhvwbWgpZdI\rIaRvsiB77f4kLGo0vi8RFgJ1ZRjGg3RRK2w1LQIDAQABAoIBAQCEOmh78EOpnGZC\rYBjjHrvrysVD5gvLcfVUtl8Ls7gMB60re1eOIF+PoZZCHKZnDd6zPfiQtj1adg0C\rYnnsM/8VoaZS4gm0b3RLd3ubIQifWhuo40RissY2yxfxlPSH9LhZCY8ojnJG0cTL\resK579E8WCfopjUY33XLqEbN7Ylv39J+DSqInjqV3efJZUa+HqUJ98VxxzodcKMD\rP3bwUU4gHoSSp4pAsOFH5sQhaIWH1IcNjrAwpee2cJQuh4G157RRIuuUpagtaEG/\rXJIiAyBguJyu3JQFnIBQF01N5+omJgXYJ1L0m54543/iIRThmF3zDCDgCyUzmOk+\rH6As9fv1AoGBANOpOtOZLSAScjGsgJamT3ceJ2wCa86g2j8Oxu8lJUmUp5s3tA0v\rBFW5O3S4KR1EXwkLMBUMrfFM8YvzHWxsXBI6XV8azGLvyqPHxr65OhmpGYkGZMXu\rn9okgjkqlewnY2I073gvyK7ppX51UL5y9fF1vlsk+UlW+Rgx/vMHbdcjAoGBANAc\rxRUsxs4QJpbS4zD3JOkHjr24a97TrS3kCybAHUMpR2NrEHPZw9zex0/aphOJUHfL\rIMkOZdpfDqMfxWy4FAEmqBEMkO2SB+h0Wp4P+qp81ax4vGFiB0cD3wtixr11U1tt\rlZ/ZTdv4VDpDFNK1KaplhTDeyuCjeYfS3/GJia9vAoGAcOsAgjBevZR5rXx84WH6\rVO8WUu37u7FenXNxt9VWTinrPMh72uixZFY8nOk+rely1e1NCn3IMko9Ns9NbDFm\r8SaH95vhXArXTYbfxZIlp9jp0YtCqcHDL+p4Oq04bFMbFyJseu7rHj1x18QYfnHw\rOY/6LL/N6k1m+Hx7qgXVmIcCgYB/w0nTCBw84XlvWqSTqQaF8VfWbWP79mP5KmkW\rLxdH5g2noVEGbohqDnK6OXd/wusdwByukiJBf94Skyy25AOT+VFwthA7aU1ljhkb\rtJ+lDuJ28eBkwLPLCzthWBC+u0qjdJFJAzVjd/7tjcU43nNn4s90AzL12iaAFhvZ\rwyA+DQKBgGc/4cdyGJ3YkcA8150gQBawgJZ7q8V1JND87ggWA8wnK3cHn7rMZQl2\r3emDp9HEFXFex5dbGDDqZFAoesZCDxjknIn9oNfW4PvaWS8q7b6ZKLZG1p03Pu7/\rtYaD0kPbo0kysfFT/co+NgHbdykvIyboomfGdNLTUjYuy6lpwpvs\r-----END RSA PRIVATE KEY-----\r".replace(/\r/g,`\r
|
|
5
5
|
`),cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
|
|
6
|
-
`)},A1="certificate.pem",O1="privateKey.pem",b1="ca.pem";vN.exports={CERTIFICATE_VALUES:R1,CERTIFICATE_PEM_NAME:A1,PRIVATEKEY_PEM_NAME:O1,CA_PEM_NAME:b1}});var Nm=g((xae,GN)=>{"use strict";var qN=require("fs-extra"),ce=require("joi"),N1=require("os"),{boolean:De,string:wr,number:Ct,array:bm}=ce.types(),{totalmem:HN}=require("os"),Hi=require("path"),y1=Y(),p_=J(),Hae=BN(),xN=M(),w1=et(),FN="log",I1="components",C1="Invalid logging.rotation.maxSize unit. Available units are G, M or K",D1="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",L1="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",M1="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",U1="rootPath config parameter is undefined",P1="clustering.enabled config parameter is undefined",xi=Ct.min(0).required(),S_=bm.items({host:wr.required(),port:xi}).empty(null),Vn;GN.exports={configValidator:v1,routesValidator:G1,route_constraints:S_};function v1(e){if(Vn=e.rootPath,p_.isEmpty(Vn))throw U1;let t=De.required(),r=Ct.min(0).max(1e3).empty(null).default(q1),n=wr.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(yc),s=wr.optional().empty(null),i=wr.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),o=ce.string().empty(null).default(yc),c=ce.custom(H1).empty(null).default(yc),u=e.clustering?.enabled;if(p_.isEmpty(u))throw P1;let _;return u===!0?_=ce.object({enabled:t,hubServer:ce.object({cluster:ce.object({name:ce.required().empty(null),network:ce.object({port:xi,routes:S_}).required()}).required(),leafNodes:ce.object({network:ce.object({port:xi}).required()}).required(),network:ce.object({port:xi}).required()}).required(),leafServer:ce.object({network:ce.object({port:xi,routes:S_}).required(),streams:ce.object({maxAge:Ct.min(120).allow(null).optional(),maxBytes:Ct.min(1).allow(null).optional(),maxMsgs:Ct.min(1).allow(null).optional(),path:o}).required()}).required(),logLevel:ce.valid("error","warn","info","debug","trace"),nodeName:i,republishMessages:De.optional(),databaseLevel:De.optional(),tls:ce.object({certificate:s,certificateAuthority:s,privateKey:s,insecure:De.required(),verify:De.optional()}),user:wr.optional().empty(null)}).required():_=ce.object({enabled:t,tls:ce.object({certificate:s,certificateAuthority:s,privateKey:s,insecure:De.required()})}).required(),ce.object({authentication:ce.object({authorizeLocal:De,cacheTTL:Ct.required(),enableSessions:De}),analytics:ce.object({aggregatePeriod:Ct}),componentsRoot:n.optional(),clustering:_,localStudio:ce.object({enabled:t}).required(),logging:ce.object({auditAuthEvents:ce.object({logFailed:De,logSuccessful:De}),file:De.required(),level:ce.valid("notify","fatal","error","warn","info","debug","trace"),rotation:ce.object({enabled:De.optional(),compress:De.optional(),interval:wr.custom(F1).optional().empty(null),maxSize:wr.custom(x1).optional().empty(null),path:wr.optional().empty(null).default(yc)}).required(),root:n,stdStreams:De.required(),auditLog:De.required()}).required(),operationsApi:ce.object({network:ce.object({cors:De.optional(),corsAccessList:bm.optional(),headersTimeout:Ct.min(1).optional(),keepAliveTimeout:Ct.min(1).optional(),port:Ct.optional().empty(null),domainSocket:ce.optional().empty("hdb/operations-server").default(yc),securePort:Ct.optional().empty(null),timeout:Ct.min(1).optional()}).optional(),tls:ce.object({certificate:s,certificateAuthority:s,privateKey:s})}).required(),rootPath:wr.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:ce.object({network:ce.object({port:xi,securePort:xi,mtls:ce.alternatives([De.optional(),ce.object({user:wr.optional(),certificateAuthority:s,required:De.optional()})])}).required(),webSocket:De.optional(),requireAuthentication:De.optional()}),http:ce.object({compressionThreshold:Ct.optional(),cors:De.optional(),corsAccessList:bm.optional(),headersTimeout:Ct.min(1).optional(),port:Ct.min(0).optional().empty(null),securePort:Ct.min(0).optional().empty(null),mtls:ce.alternatives([De.optional(),ce.object({user:wr.optional(),certificateAuthority:s,required:De.optional()})])}).required(),threads:r.optional(),maxHeapMemory:Ct.min(0).optional(),storage:ce.object({writeAsync:De.required(),overlappingSync:De.optional(),caching:De.optional(),compression:De.optional(),noReadAhead:De.optional(),path:c,prefetchWrites:De.optional()}).required(),ignoreScripts:De.optional(),tls:ce.object({certificate:s.optional(),certificateAuthority:s.optional(),privateKey:s.optional(),ciphers:wr.optional()})}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(v1,"configValidator");function B1(e){return qN.existsSync(e)?null:`Specified path ${e} does not exist.`}a(B1,"doesPathExist");function H1(e,t){ce.assert(e,wr.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=B1(e);if(r)return t.message(r)}a(H1,"validatePath");function x1(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(C1);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(L1):e}a(x1,"validateRotationMaxSize");function F1(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(D1);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(M1):e}a(F1,"validateRotationInterval");function q1(e,t){let r=t.state.path.join("."),n=N1.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),y1.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(q1,"setDefaultThreads");function yc(e,t){let r=t.state.path.join(".");if(!p_.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(p_.isEmpty(Vn))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Hi.join(Vn,I1);case"logging.root":return Hi.join(Vn,FN);case"clustering.leafServer.streams.path":return Hi.join(Vn,"clustering","leaf");case"storage.path":let n=Hi.join(Vn,xN.LEGACY_DATABASES_DIR_NAME);return qN.existsSync(n)?n:Hi.join(Vn,xN.DATABASES_DIR_NAME);case"logging.rotation.path":return Hi.join(Vn,FN);case"operationsApi.network.domainSocket":return r==null?null:Hi.join(Vn,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(yc,"setDefaultRoot");function G1(e){let t=ce.object({routes:S_});return w1.validateBySchema({routes:e},t)}a(G1,"routesValidator")});var Dr=g((Gae,JN)=>{"use strict";var Cr=M(),Dt=J(),Tt=Y(),{configValidator:k1,routesValidator:kN}=Nm(),rr=require("fs-extra"),V1=require("yaml"),An=require("path"),$1=require("is-number"),$N=require("properties-reader"),Y1=require("lodash"),{handleHDBError:K1}=ee(),{HTTP_STATUS_CODES:W1,HDB_ERROR_MSGS:T_}=Or(),qae=require("minimist"),{server:Q1}=(Zt(),te(bi)),{DATABASES_PARAM_CONFIG:wc,CONFIG_PARAMS:Ir,CONFIG_PARAM_MAP:On}=Cr,z1="Unable to get config value because config is uninitialized",J1="Config successfully initialized",X1="Error backing up config file",j1="Empty parameter sent to getConfigValue",YN=An.join(Cr.PACKAGE_ROOT,"config","yaml",Cr.HDB_DEFAULT_CONFIG_FILE),Z1="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",VN={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"},g_,gt,R_;JN.exports={createConfigFile:eY,getDefaultConfig:tY,getConfigValue:WN,initConfig:wm,flattenConfig:xo,updateConfigValue:QN,updateConfigObject:nY,getConfiguration:oY,setConfiguration:aY,readConfigFile:Cm,getClusteringRoutes:cY,initOldConfig:zN,getConfigFromFile:uY,getConfigFilePath:Fi,addConfig:lY,deleteConfigFromFile:_Y,getConfigObj:dY};function eY(e){let t=Js(YN);g_=xo(t.toJSON());let r;for(let o in e){let c=On[o.toLowerCase()];if(c===Ir.DATABASES){r=e[o];continue}if(!c&&o.endsWith("_package")&&(c=o),c!==void 0){let u=c.split("_"),_=ym(c,e[o]);c==="rootPath"&&_?.endsWith("/")&&(_=_.slice(0,-1));try{t.setIn([...u],_)}catch(l){Tt.error(l)}}}r&&KN(t,r),Im(t);let n=t.toJSON();gt=xo(n);let s=t.getIn(["rootPath"]),i=An.join(s,Cr.HDB_CONFIG_FILE);rr.createFileSync(i),rr.writeFileSync(i,String(t)),Tt.trace(`Config file written to ${i}`)}a(eY,"createConfigFile");function KN(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Dt.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(wc.TABLES))for(let i in n[s][wc.TABLES])for(let o in n[s][wc.TABLES][i]){let c=n[s][wc.TABLES][i][o],u=[Ir.DATABASES,s,wc.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=[Ir.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){Tt.error("Error parsing schemas CLI/env config arguments",n)}}a(KN,"setSchemasConfig");function tY(e){if(g_===void 0){let r=Js(YN);g_=xo(r.toJSON())}let t=On[e.toLowerCase()];if(t!==void 0)return g_[t.toLowerCase()]}a(tY,"getDefaultConfig");function WN(e){if(e==null){Tt.error(j1);return}if(gt===void 0){Tt.trace(z1);return}let t=On[e.toLowerCase()];if(t!==void 0)return gt[t.toLowerCase()]}a(WN,"getConfigValue");function Fi(e=Dt.getPropsFilePath()){let t=Dt.getEnvCliRootPath();return t?An.join(t,Cr.HDB_CONFIG_FILE):$N(e).get(Cr.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY)}a(Fi,"getConfigFilePath");function wm(e=!1){if(gt===void 0||e){let t;if(!Dt.noBootFile()){t=Dt.getPropsFilePath();try{rr.accessSync(t,rr.constants.F_OK|rr.constants.R_OK)}catch(i){throw Tt.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Fi(t),n;if(r.includes("config/settings.js"))try{zN(r);return}catch(i){if(i.code!==Cr.NODE_ERROR_CODES.ENOENT)throw i}try{n=Js(r)}catch(i){if(i.code===Cr.NODE_ERROR_CODES.ENOENT){Tt.trace(`HarperDB config file not found at ${r}.
|
|
7
|
-
This can occur during early stages of install where the config file has not yet been created`);return}else throw Tt.error(i),new Error(`Error reading HarperDB config file at ${r}`)}rY(n,r),Im(n);let s=n.toJSON();if(Q1.config=s,gt=xo(s),gt.logging_rotation_rotate)for(let i in VN)gt[i]&&Tt.error(`Config ${VN[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);Tt.trace(J1)}}a(wm,"initConfig");function rY(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],An.join(r,"database")),n=!0),e.hasIn(["clustering","leafServer","streams","path"])||(e.setIn(["clustering","leafServer","streams","path"],An.join(r,"clustering","leaf")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],An.join(r,"log")),n=!0),e.hasIn(["clustering","tls","verify"])||(e.setIn(["clustering","tls","verify"],!0),n=!0),n&&(Tt.trace("Updating config file with missing config params"),rr.writeFileSync(t,String(e)))}a(rY,"checkForUpdatedConfig");function Im(e){let t=e.toJSON();t.componentsRoot=t.componentsRoot??t?.customFunctions?.root,t.threads=t.threads??t?.http?.threads;let r=k1(t);if(r.error)throw T_.CONFIG_VALIDATION(r.error.message);e.setIn(["threads"],r.value.threads),e.setIn(["componentsRoot"],r.value.componentsRoot),e.setIn(["logging","root"],r.value.logging.root),e.setIn(["storage","path"],r.value.storage.path),e.setIn(["logging","rotation","path"],r.value.logging.rotation.path),e.setIn(["clustering","leafServer","streams","path"],r.value.clustering.leafServer.streams?.path),e.setIn(["operationsApi","network","domainSocket"],r.value?.operationsApi?.network?.domainSocket)}a(Im,"validateConfig");function nY(e,t){gt===void 0&&(gt={});let r=On[e.toLowerCase()];if(r===void 0){Tt.trace(`Unable to update config object because config param '${e}' does not exist`);return}gt[r.toLowerCase()]=t}a(nY,"updateConfigObject");function QN(e,t,r=void 0,n=!1,s=!1,i=!1){gt===void 0&&wm();let o=WN(On.hdb_root),c=An.join(o,Cr.HDB_CONFIG_FILE),u=Js(c),_;if(r===void 0&&e.toLowerCase()===Ir.DATABASES)_=t;else if(r===void 0){let f;if(i)f=e;else if(f=On[e.toLowerCase()],f===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let E=f.split("_"),h=ym(f,t);u.setIn([...E],h)}else for(let f in r){let E=On[f.toLowerCase()];if(E===Ir.HTTP_SECUREPORT&&r[f]===gt[Ir.HTTP_PORT]?.toString()&&u.setIn(["http","port"],null),E===Ir.OPERATIONSAPI_NETWORK_SECUREPORT&&r[f]===gt[Ir.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&u.setIn(["operationsApi","network","port"],null),E===Ir.DATABASES){_=r[f];continue}if(!E&&f.endsWith("_package")&&(E=f),E!==void 0){let h=E.split("_"),p=Cr.LEGACY_CONFIG_PARAMS[f.toUpperCase()];p&&p.startsWith("customFunctions")&&u.hasIn(p.split("_"))&&(E=p,h=p.split("_"));let S=ym(E,r[f]);E==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof u.getIn(h.slice(0,-1))=="boolean"&&u.deleteIn(h.slice(0,-1)),u.setIn([...h],S)}catch(T){Tt.error(T)}}}_&&KN(u,_),Im(u);let l=u.getIn(["rootPath"]),d=An.join(l,Cr.HDB_CONFIG_FILE);n===!0&&sY(c,l),rr.writeFileSync(d,String(u)),s&&(gt=xo(u.toJSON())),Tt.trace(`Config parameter: ${e} updated with value: ${t}`)}a(QN,"updateConfigValue");function sY(e,t){try{let r=An.join(t,"backup",`${Cr.HDB_CONFIG_FILE}.bak`);rr.copySync(e,r),Tt.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){Tt.error(X1),Tt.error(r)}}a(sY,"backupConfigFile");var iY=["databases"];function xo(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)),R_=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])&&!iY.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;!Ir[u.toUpperCase()]&&On[u]&&(s[On[u].toLowerCase()]=o[c]),s[u]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(xo,"flattenConfig");function ym(e,t){if(e===Ir.CLUSTERING_NODENAME||e===Ir.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($1(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Dt.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 Dt.autoCast(t)}a(ym,"castConfigValue");function oY(){let e=Dt.getPropsFilePath(),t=Fi(e);return Js(t).toJSON()}a(oY,"getConfiguration");async function aY(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return QN(void 0,void 0,s,!0),Z1}catch(i){throw typeof i=="string"||i instanceof String?K1(i,i,W1.BAD_REQUEST,void 0,void 0,!0):i}}a(aY,"setConfiguration");function Cm(){let e=Dt.getPropsFilePath();try{rr.accessSync(e,rr.constants.F_OK|rr.constants.R_OK)}catch(n){if(!Dt.noBootFile())throw Tt.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Fi(e);return Js(t).toJSON()}a(Cm,"readConfigFile");function Js(e){return V1.parseDocument(rr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Js,"parseYamlDoc");function cY(){let e=Cm(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Dt.isEmptyOrZeroLength(t)?[]:t;let r=kN(t);if(r)throw T_.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Dt.isEmptyOrZeroLength(n)?[]:n;let s=kN(n);if(s)throw T_.CONFIG_VALIDATION(s.message);if(!Dt.isEmptyOrZeroLength(n)&&!Dt.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Dt.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw T_.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(cY,"getClusteringRoutes");function zN(e){let t=$N(e);gt={};for(let r in On){let n=t.get(r.toUpperCase());if(Dt.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=On[r].toLowerCase();s===Ir.LOGGING_ROOT?gt[s]=An.dirname(n):gt[s]=n}return gt}a(zN,"initOldConfig");function uY(e){let t=Cm();return Y1.get(t,e.replaceAll("_","."))}a(uY,"getConfigFromFile");async function lY(e,t){let r=Js(Fi());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await rr.writeFile(Fi(),String(r))}a(lY,"addConfig");function _Y(e){let t=Fi(Dt.getPropsFilePath()),r=Js(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=An.join(n,Cr.HDB_CONFIG_FILE);rr.writeFileSync(s,String(r))}a(_Y,"deleteConfigFromFile");function dY(){return R_||(wm(),R_)}a(dY,"getConfigObj")});var jN=g((Vae,XN)=>{"use strict";var A_=M(),O_=class{static{a(this,"BaseLicense")}constructor(t=0,r=A_.RAM_ALLOCATION_ENUM.DEFAULT,n=A_.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},Dm=class extends O_{static{a(this,"ExtendedLicense")}constructor(t=0,r=A_.RAM_ALLOCATION_ENUM.DEFAULT,n=A_.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};XN.exports={BaseLicense:O_,ExtendedLicense:Dm}});var qi=g((Yae,sy)=>{"use strict";var qo=require("fs-extra"),ey=m_(),ty=require("crypto"),fY=require("moment"),EY=require("uuid").v4,Yt=Y(),Mm=require("path"),hY=J(),Xs=M(),{totalmem:ZN}=require("os"),mY=jN().ExtendedLicense,Fo="invalid license key format",pY="061183",SY="mofi25",TY="aes-256-cbc",gY=16,RY=32,ry=Z();ry.initSync();var Lm;sy.exports={validateLicense:ny,generateFingerPrint:OY,licenseSearch:vm,getLicense:yY,checkMemoryLimit:wY};function Um(){return Mm.join(ry.getHdbBasePath(),Xs.LICENSE_KEY_DIR_NAME,Xs.LICENSE_FILE_NAME)}a(Um,"getLicenseDirPath");function AY(){let e=Um();return Mm.join(e,Xs.LICENSE_FILE_NAME)}a(AY,"getLicenseFilePath");function Pm(){let e=Um();return Mm.join(e,Xs.REG_KEY_FILE_NAME)}a(Pm,"getFingerPrintFilePath");async function OY(){let e=Pm();try{return await qo.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await bY();throw Yt.error(`Error writing fingerprint file to ${e}`),Yt.error(t),new Error("There was an error generating the fingerprint")}}a(OY,"generateFingerPrint");async function bY(){let e=EY(),t=ey.hash(e),r=Pm();try{await qo.mkdirp(Um()),await qo.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Yt.error(`Error writing fingerprint file to ${r}`),Yt.error(n),new Error("There was an error generating the fingerprint")}return t}a(bY,"writeFingerprint");function ny(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:Xs.RAM_ALLOCATION_ENUM.DEFAULT,version:Xs.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Yt.error("empty license key passed to validate."),r;let n=Pm(),s=!1;try{s=qo.statSync(n)}catch(i){Yt.error(i)}if(s){let i;try{i=qo.readFileSync(n,"utf8")}catch{Yt.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(SY),c=o[1];c=Buffer.concat([Buffer.from(c)],gY);let u=Buffer.concat([Buffer.from(i)],RY),_=ty.createDecipheriv(TY,u,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let l=null;try{l=_.update(o[0],"hex","utf8"),l.trim(),l+=_.final("utf8")}catch{let E=NY(o[0],i);if(E)l=E;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Fo),Yt.error(Fo),new Error(Fo)}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(Fo),Yt.error(Fo),new Error(Fo)}else r.exp_date=l;r.exp_date<fY().valueOf()&&(r.valid_date=!1),ey.validate(o[1],`${pY}${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||Yt.error("Invalid licence"),r}a(ny,"validateLicense");function NY(e,t){try{let r=ty.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Yt.warn("Check old license failed")}}a(NY,"checkOldLicense");function vm(){let e=new mY,t=[];try{t=qo.readFileSync(AY(),"utf-8").split(Xs.NEW_LINE)}catch(r){r.code==="ENOENT"?Yt.info("no license file found"):Yt.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(hY.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=ny(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){Yt.error("There was an error parsing the license string."),Yt.error(s),e.ram_allocation=Xs.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return Lm=e,e}a(vm,"licenseSearch");async function yY(){return Lm||await vm(),Lm}a(yY,"getLicense");function wY(){let e=vm().ram_allocation,t=process.constrainedMemory?.()||ZN();if(t=Math.round(Math.min(t,ZN())/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(wY,"checkMemoryLimit")});var Zr=g((Jae,gy)=>{"use strict";var cy="username is required",uy="nothing to update, must supply active, role or password to update",ly="password cannot be an empty string",_y="If role is specified, it cannot be empty.",dy="active must be true or false";gy.exports={addUser:BY,alterUser:HY,dropUser:FY,getSuperUser:VY,userInfo:qY,listUsers:N_,listUsersExternal:GY,setUsersToGlobal:ko,findAndValidateUser:Sy,getClusterUser:$Y,USERNAME_REQUIRED:cy,ALTERUSER_NOTHING_TO_UPDATE:uy,EMPTY_PASSWORD:ly,EMPTY_ROLE:_y,ACTIVE_BOOLEAN:dy};var fy=jr(),IY=Bi(),xm=m_(),Ey=MN(),hy=Xr(),Fm=hs(),Lr=J(),my=require("validate.js"),Ae=Y(),{promisify:CY}=require("util"),qm=Es(),iy=M(),oy=tt(),DY=Dr(),Wae=Z(),Qae=qi(),LY=Ci(),{table:zae}=(be(),te(Fe)),{handleHDBError:$n,hdb_errors:MY}=ee(),{HTTP_STATUS_CODES:Yn,AUTHENTICATION_ERROR_MSGS:Bm,HDB_ERROR_MSGS:Go}=MY,{UserEventMsg:Gm}=bn(),Hm=require("lodash"),{server:km}=(Zt(),te(bi)),UY=Y();km.getUser=(e,t)=>Sy(e,t,t!=null);var py={username:!0,active:!0,role:!0,password:!0},ay=new Map,b_=hy.searchByValue,PY=hy.searchByHash,vY=CY(IY.delete);async function BY(e){let t=my.cleanAttributes(e,py),r=Ey.addUserValidation(t);if(r)throw $n(new Error,r.message,Yn.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 b_(n),s=s&&Array.from(s)}catch(u){throw Ae.error("There was an error searching for a role in add user"),Ae.error(u),u}if(!s||s.length<1)throw $n(new Error,Go.ROLE_NAME_NOT_FOUND(t.role),Yn.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw $n(new Error,Go.DUP_ROLES_FOUND(t.role),Yn.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=qm.encrypt(t.password)),t.password=xm.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await fy.insert(i)}catch(u){throw Ae.error("There was an error searching for a user."),Ae.error(u),u}Ae.debug(o);try{await ko()}catch(u){throw Ae.error("Got an error setting users to global"),Ae.error(u),u}if(o.skipped_hashes.length===1)throw $n(new Error,Go.USER_ALREADY_EXISTS(t.username),Yn.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],Fm.signalUserChange(new Gm(process.pid)),`${c.username} successfully added`}a(BY,"addUser");async function HY(e){let t=my.cleanAttributes(e,py);if(Lr.isEmptyOrZeroLength(t.username))throw new Error(cy);if(Lr.isEmptyOrZeroLength(t.password)&&Lr.isEmptyOrZeroLength(t.role)&&Lr.isEmptyOrZeroLength(t.active))throw new Error(uy);if(!Lr.isEmpty(t.password)&&Lr.isEmptyOrZeroLength(t.password.trim()))throw new Error(ly);if(!Lr.isEmpty(t.active)&&!Lr.isBoolean(t.active))throw new Error(dy);let r=xY(t.username);if(!Lr.isEmpty(t.password)&&!Lr.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=qm.encrypt(t.password)),t.password=xm.hash(t.password)),t.role==="")throw new Error(_y);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 b_(i)||[])}catch(c){throw Ae.error("Got an error searching for a role."),Ae.error(c),c}if(!o||o.length===0){let c=Go.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Ae.error(c),$n(new Error,c,Yn.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Go.ALTER_USER_DUP_ROLES(t.role);throw Ae.error(c),$n(new Error,c,Yn.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 fy.update(n)}catch(i){throw Ae.error("Error during update."),Ae.error(i),i}try{await ko()}catch(i){throw Ae.error("Got an error setting users to global"),Ae.error(i),i}return Fm.signalUserChange(new Gm(process.pid)),s}a(HY,"alterUser");function xY(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(xY,"isClusterUser");async function FY(e){try{let t=Ey.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Lr.isEmpty(global.hdb_users.get(e.username)))throw $n(new Error,Go.USER_NOT_EXIST(e.username),Yn.NOT_FOUND,void 0,void 0,!0);let n;try{n=await vY(r)}catch(s){throw Ae.error("Got an error deleting a user."),Ae.error(s),s}Ae.debug(n);try{await ko()}catch(s){throw Ae.error("Got an error setting users to global."),Ae.error(s),s}return Fm.signalUserChange(new Gm(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(FY,"dropUser");async function qY(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=Hm.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await PY(r)}catch(s){throw Ae.error("Got an error searching for a role."),Ae.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Ae.error(r),r}return t}a(qY,"userInfo");async function GY(){let e;try{e=await N_()}catch(t){throw Ae.error("Got an error listing users."),Ae.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(GY,"listUsersExternal");async function N_(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await b_(e)}catch(o){throw Ae.error("Got an error searching for roles."),Ae.error(o),o}let r={};for(let o of t)r[o.id]=Hm.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 b_(n)}catch(o){throw Ae.error("Got an error searching for users."),Ae.error(o),o}let i=new Map;for(let o of s)o=Hm.cloneDeep(o),o.role=r[o.role],kY(o.role),i.set(o.username,o);return i}catch(e){throw Ae.error("got an error listing users"),Ae.error(e),Lr.errorizeMessage(e)}return null}a(N_,"listUsers");function kY(e){try{if(!e){Ae.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(LY)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Ae.error("Got an error trying to set system permissions."),Ae.error(t)}}a(kY,"appendSystemTablesToRole");async function ko(){try{let e=await N_();global.hdb_users=e}catch(e){throw Ae.error(e),e}}a(ko,"setUsersToGlobal");async function Sy(e,t,r=!0){global.hdb_users||await ko();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw $n(new Error,Bm.GENERIC_AUTH_FAIL,Yn.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw $n(new Error,Bm.USER_INACTIVE,Yn.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(ay.get(t)===n.password)return s;if(xm.validate(n.password,t))ay.set(t,n.password);else throw $n(new Error,Bm.GENERIC_AUTH_FAIL,Yn.UNAUTHORIZED,void 0,void 0,!0)}return s}a(Sy,"findAndValidateUser");async function VY(){global.hdb_users||await ko();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(VY,"getSuperUser");async function $Y(){let e=await N_(),t=DY.getConfigFromFile(iy.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Lr.isEmpty(r)&&r?.role?.role===iy.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=qm.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+oy.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+oy.SERVER_SUFFIX.ADMIN,r}a($Y,"getClusterUser");var Ty=[];km.invalidateUser=function(e){for(let t of Ty)try{t(e)}catch(r){UY.error("Error invalidating user",r)}};km.onInvalidatedUser=function(e){Ty.push(e)}});var Cc=g((ece,by)=>{"use strict";var Gi=Y(),Mr=M(),YY=Zb(),jae=Ws(),Zae=Li(),KY=Zr(),{validateEvent:Ry}=bn(),Ic=Rn(),WY=require("process"),{resetDatabases:QY}=(be(),te(Fe)),zY={[Mr.ITC_EVENT_TYPES.SCHEMA]:JY,[Mr.ITC_EVENT_TYPES.USER]:Oy};async function JY(e){let t=Ry(e);if(t){Gi.error(t);return}Gi.trace("ITC schemaHandler received schema event:",e),await YY(e.message),await XY(e.message)}a(JY,"schemaHandler");async function XY(e){try{Ic.resetReadTxn(Mr.SYSTEM_SCHEMA_NAME,Mr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Ic.resetReadTxn(Mr.SYSTEM_SCHEMA_NAME,Mr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Ic.resetReadTxn(Mr.SYSTEM_SCHEMA_NAME,Mr.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=QY();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Gi.error(t)}}a(XY,"syncSchemaMetadata");var Ay=[];async function Oy(e){try{try{Ic.resetReadTxn(Mr.SYSTEM_SCHEMA_NAME,Mr.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Ic.resetReadTxn(Mr.SYSTEM_SCHEMA_NAME,Mr.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Gi.warn(r)}let t=Ry(e);if(t){Gi.error(t);return}Gi.trace(`ITC userHandler ${Mr.HDB_ITC_CLIENT_PREFIX}${WY.pid} received user event:`,e),await KY.setUsersToGlobal();for(let r of Ay)r()}catch(t){Gi.error(t)}}a(Oy,"userHandler");Oy.addListener=function(e){Ay.push(e)};by.exports=zY});var bn=g((oce,yy)=>{"use strict";var rce=Y(),Vm=J(),jY=M(),{ITC_ERRORS:Dc}=Or(),{parentPort:nce,threadId:ZY,isMainThread:eK,workerData:sce}=require("worker_threads"),{onMessageFromWorkers:tK,broadcast:ice,broadcastWithAcknowledgement:rK}=je();yy.exports={sendItcEvent:nK,validateEvent:Ny,SchemaEventMsg:sK,UserEventMsg:iK};var y_;tK(async(e,t)=>{y_=y_||Cc(),Ny(e),y_[e.type]&&await y_[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function nK(e){return!eK&&e.message&&(e.message.originator=ZY),rK(e)}a(nK,"sendItcEvent");function Ny(e){if(typeof e!="object")return Dc.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||Vm.isEmpty(e.type))return Dc.MISSING_TYPE;if(!e.hasOwnProperty("message")||Vm.isEmpty(e.message))return Dc.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||Vm.isEmpty(e.message.originator))return Dc.MISSING_ORIGIN;if(jY.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Dc.INVALID_EVENT(e.type)}a(Ny,"validateEvent");function sK(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}a(sK,"SchemaEventMsg");function iK(e){this.originator=e}a(iK,"UserEventMsg")});var hs=g((uce,Dy)=>{"use strict";var wy=M(),cce=J(),w_=Y(),Iy=Jb(),Vo,{sendItcEvent:Cy}=bn();function oK(e){try{w_.trace("signalSchemaChange called with message:",e),Vo=Vo||Cc();let t=new Iy(wy.ITC_EVENT_TYPES.SCHEMA,e);return Vo.schema(t),Cy(t)}catch(t){w_.error(t)}}a(oK,"signalSchemaChange");function aK(e){try{w_.trace("signalUserChange called with message:",e),Vo=Vo||Cc();let t=new Iy(wy.ITC_EVENT_TYPES.USER,e);return Vo.user(t),Cy(t)}catch(t){w_.error(t)}}a(aK,"signalUserChange");Dy.exports={signalSchemaChange:oK,signalUserChange:aK}});var I_=g((_ce,My)=>{"use strict";var Ly=J(),cK=M(),uK=Y(),lK=i_(),_K=s_(),dK=hs(),{SchemaEventMsg:fK}=bn(),EK="already exists in";My.exports=hK;async function hK(e,t,r){if(Ly.isEmptyOrZeroLength(r))return r;let n=[];Ly.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 mK(e,t.schema,t.name,i)})),s}a(hK,"lmdbCheckForNewAttributes");async function mK(e,t,r,n){let s=new _K(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await pK(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(EK))uK.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(mK,"createNewAttribute");async function pK(e){let t;return t=await lK(e),dK.signalSchemaChange(new fK(process.pid,cK.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(pK,"createAttribute")});var $o=g((fce,Uy)=>{"use strict";var $m=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}};Uy.exports=$m});var vy=g((hce,Py)=>{"use strict";var SK=$o(),TK=M().OPERATIONS_ENUM,Ym=class extends SK{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(TK.INSERT,r,n,s,i),this.records=t}};Py.exports=Ym});var Hy=g((pce,By)=>{"use strict";var gK=$o(),RK=M().OPERATIONS_ENUM,Km=class extends gK{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(RK.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};By.exports=Km});var Fy=g((Tce,xy)=>{"use strict";var AK=$o(),OK=M().OPERATIONS_ENUM,Wm=class extends AK{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(OK.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};xy.exports=Wm});var Gy=g((Rce,qy)=>{"use strict";var bK=$o(),NK=M().OPERATIONS_ENUM,Qm=class extends bK{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(NK.DELETE,n,s,t,i),this.original_records=r}};qy.exports=Qm});var Lc=g((bce,Yy)=>{"use strict";var Oce=require("path"),ky=$e(),yK=vy(),wK=Hy(),IK=Fy(),CK=Gy(),Yo=lt(),Vy=J(),{CONFIG_PARAMS:DK}=M(),$y=Z();$y.initSync();var C_=M().OPERATIONS_ENUM,{getTransactionAuditStorePath:LK}=Ke();Yy.exports=MK;async function MK(e,t){if($y.get(DK.LOGGING_AUDITLOG)===!1)return;let r=LK(e.schema,e.table),n=await ky.openEnvironment(r,e.table,!0),s=UK(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){ky.initializeDBIs(n,Yo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Yo.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Yo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Yo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),Vy.isEmpty(s.user_name)||n.dbis[Yo.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Yo.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(MK,"writeTransaction");function UK(e,t){let r=Vy.isEmpty(e.hdb_user)?void 0:e.hdb_user.username;if(e.operation===C_.INSERT)return new yK(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===C_.UPDATE)return new wK(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===C_.UPSERT)return new IK(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===C_.DELETE)return new CK(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(UK,"createTransactionObject")});var zm=g((wce,Ky)=>{"use strict";var PK=Tc(),yce=gc(),Mc=M(),vK=bc(),BK=vo().insertRecords,HK=$e(),xK=Y(),FK=I_(),{getSchemaPath:qK}=Ke(),GK=Lc();Ky.exports=kK;async function kK(e){try{let{schema_table:t,attributes:r}=PK(e);vK(e,r,t.hash_attribute),e.schema!==Mc.SYSTEM_SCHEMA_NAME&&(r.includes(Mc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Mc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Mc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Mc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await FK(e.hdb_auth_header,t,r),s=qK(e.schema,e.table),i=await HK.openEnvironment(s,e.table),o=await BK(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await GK(e,o)}catch(c){xK.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(kK,"lmdbCreateRecords")});var zy=g((Cce,Qy)=>{"use strict";var Wy=M(),VK=zm(),$K=gc(),YK=require("fs-extra"),{getSchemaPath:KK}=Ke();Qy.exports=WK;async function WK(e){let t=[{name:e.schema,createddate:Date.now()}],r=new $K(Wy.SYSTEM_SCHEMA_NAME,Wy.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await VK(r),await YK.mkdirp(KK(e.schema))}a(WK,"lmdbCreateSchema")});var Xy=g((Lce,Jy)=>{"use strict";var Jm=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}};Jy.exports=Jm});var tw=g((Bce,ew)=>{"use strict";var jy=$e(),Xm=br(),jm=Or().LMDB_ERRORS_ENUM,QK=lt(),Zy=Y(),Uce=J(),zK=require("lmdb"),JK=Xy(),XK=M(),{OVERFLOW_MARKER:Pce,MAX_SEARCH_KEY_LENGTH:vce}=QK,jK=XK.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function ZK(e,t,r,n){if(Xm.validateEnv(e),t===void 0)throw new Error(jm.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(jm.IDS_REQUIRED):new Error(jm.IDS_MUST_BE_ITERABLE);try{let s=jy.listDBIs(e);jy.initializeDBIs(e,t,s);let i=new JK,o,c=[],u=[];for(let f=0,E=r.length;f<E;f++)try{o=r[f];let h=e.dbis[t].get(o);if(!h||n&&h[jK]>n){i.skipped.push(o);continue}let p=e.dbis[t].ifVersion(o,zK.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 H=Xm.getIndexedValues(b);if(H)for(let F=0,v=H.length;F<v;F++)A.remove(H[F],o)}catch{Zy.warn(`cannot delete from attribute: ${T}, ${b}:${o}`)}}});c.push(p),u.push(o),i.original_records.push(h)}catch(h){Zy.warn(h),i.skipped.push(o)}let _=[],l=await Promise.all(c);for(let f=0,E=l.length;f<E;f++)l[f]===!0?i.deleted.push(u[f]):(i.skipped.push(u[f]),_.push(f));let d=0;for(let f=0;f<_.length;f++){let E=_[f];i.original_records.splice(E-d,1),d++}return i.txn_time=Xm.getNextMonotonicTime(),i}catch(s){throw s}}a(ZK,"deleteRecords");ew.exports={deleteRecords:ZK}});var Uc=g((xce,nw)=>{"use strict";var Ko=J(),eW=tw(),tW=$e(),{getSchemaPath:rW}=Ke(),nW=Lc(),sW=Y();nw.exports=iW;async function iW(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Ko.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Ko.isEmptyOrZeroLength(e.hash_values)&&!Ko.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let u=e.records[c][n];Ko.isEmpty(u)||e.hash_values.push(u)}}if(Ko.isEmptyOrZeroLength(e.hash_values))return rw([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Ko.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=rW(e.schema,e.table),i=await tW.openEnvironment(s,e.table),o=await eW.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await nW(e,o)}catch(c){sW.error(`unable to write transaction due to ${c.message}`)}return rw(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(iW,"lmdbDeleteRecords");function rw(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(rw,"createDeleteResponse")});var ep=g((Gce,sw)=>{"use strict";var oW=M(),qce=br();function Zm(e,t){let r=Object.create(null);if(t.length===1&&oW.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(Zm,"parseRow");function aW(e,t,r,n){let s=Zm(r,e);n.push(s)}a(aW,"searchAll");function cW(e,t,r,n){let s=Zm(r,e);n[t]=s}a(cW,"searchAllToMap");function uW(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(uW,"iterateDBI");function ki(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(ki,"pushResults");function lW(e,t,r,n,s,i){t.toString().endsWith(e)&&ki(t,r,n,s,i)}a(lW,"endsWith");function _W(e,t,r,n,s,i){t.toString().includes(e)&&ki(t,r,n,s,i)}a(_W,"contains");function dW(e,t,r,n,s,i){t>e&&ki(t,r,n,s,i)}a(dW,"greaterThanCompare");function fW(e,t,r,n,s,i){t>=e&&ki(t,r,n,s,i)}a(fW,"greaterThanEqualCompare");function EW(e,t,r,n,s,i){t<e&&ki(t,r,n,s,i)}a(EW,"lessThanCompare");function hW(e,t,r,n,s,i){t<=e&&ki(t,r,n,s,i)}a(hW,"lessThanEqualCompare");sw.exports={parseRow:Zm,searchAll:aW,searchAllToMap:cW,iterateDBI:uW,endsWith:lW,contains:_W,greaterThanCompare:dW,greaterThanEqualCompare:fW,lessThanCompare:EW,lessThanEqualCompare:hW,pushResults:ki}});var Wo=g((Kce,_w)=>{"use strict";var js=$e(),Vce=Y(),Ur=br(),D_=lt(),at=Or().LMDB_ERRORS_ENUM,$ce=J(),mW=M(),L_=ep(),{parseRow:pW}=L_,Yce=require("lmdb"),{OVERFLOW_MARKER:iw,MAX_SEARCH_KEY_LENGTH:SW}=D_;function ow(e,t,r,n=!1,s=void 0,i=void 0){return Vi(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(ow,"iterateFullIndex");function Pc(e,t,r,n,s,i=!1,o=void 0,c=void 0,u=!1,_=!1){return Vi(e,t,r,(l,d,f,E)=>{let A={transaction:l,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!u:!_,exclusiveStart:i===!0?_:u};return E===r?(A.values=!1,d.getRange(A).map(b=>({value:b}))):d.getRange(A)})}a(Pc,"iterateRangeBetween");function Vi(e,t,r,n){let s=e.database||e,i=js.openDBI(s,r);i[D_.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&js.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(Vi,"setupTransaction");function aw(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(iw)){if(!s)if(r)s=js.openDBI(e,r);else{let u=js.listDBIs(e);for(let _=0,l=u.length;_<l&&(s=js.openDBI(e,u[_]),!s[D_.DBI_DEFINITION_NAME].is_hash_attribute);_++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(aw,"getOverflowCheck");function TW(e,t,r,n=!1,s=void 0,i=void 0){if(Ur.validateEnv(e),t===void 0)throw new Error(at.HASH_ATTRIBUTE_REQUIRED);return Vi(e,t,t,(o,c,u)=>(M_(r),r=vc(u,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(_=>pW(_.value,r))))}a(TW,"searchAll");function gW(e,t,r,n=!1,s=void 0,i=void 0){if(Ur.validateEnv(e),t===void 0)throw new Error(at.HASH_ATTRIBUTE_REQUIRED);M_(r),r=vc(e.database||e,r);let o=new Map;for(let{key:c,value:u}of ow(e,t,t,n,s,i))o.set(c,L_.parseRow(u,r));return o}a(gW,"searchAllToMap");function RW(e,t,r=!1,n=void 0,s=void 0){if(Ur.validateEnv(e),t===void 0)throw new Error(at.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=ow(e,void 0,t,r,n,s),c=o.transaction,u=aw(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(RW,"iterateDBI");function AW(e,t){if(Ur.validateEnv(e),t===void 0)throw new Error(at.HASH_ATTRIBUTE_REQUIRED);return js.statDBI(e,t).entryCount}a(AW,"countAll");function OW(e,t,r,n,s=!1,i=void 0,o=void 0){return Zs(e,r,n),Vi(e,t,r,(c,u,_,l)=>(n=Ur.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(OW,"equals");function bW(e,t,r){return Zs(e,t,r),js.openDBI(e,t).getValuesCount(r)}a(bW,"count");function NW(e,t,r,n,s=!1,i=void 0,o=void 0){return Zs(e,r,n),Vi(e,null,r,(c,u)=>{n=Ur.convertKeyValueToWrite(n);let _=!0;typeof n=="number"&&(_=!1);let l;if(s===!0){let d;for(let f of u.getKeys({transaction:c,start:n}))if(!f.startsWith(n)){d=f;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),l=u.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(f=>{let{key:E}=f;if(E!==d){if(E.toString().startsWith(n))return f;if(_===!0)return l.DONE}}),l.filter(f=>f)}else return l=u.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(_===!0)return l.DONE}),_?l:l.filter(d=>d)})}a(NW,"startsWith");function yW(e,t,r,n,s=!1,i=void 0,o=void 0){return cw(e,t,r,n,s,i,o,!0)}a(yW,"endsWith");function cw(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Zs(e,r,n),Vi(e,null,r,(u,_,l,d)=>{let f=aw(l,u,d,r);return o=Number.isInteger(o)?o:0,_.getKeys({transaction:u,end:s?!1:void 0,reverse:s}).flatMap(E=>{let h=E.toString();return h.endsWith(iw)?_.getValues(E,{transaction:u}).map(p=>{let S=f(E,p);if(c?S.endsWith(n):S.includes(n))return{key:S,value:p}}).filter(p=>p):(c?h.endsWith(n):h.includes(n))?_[D_.DBI_DEFINITION_NAME].is_hash_attribute?{key:E,value:E}:_.getValues(E,{transaction:u}).map(p=>({key:E,value:p})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(cw,"contains");function wW(e,t,r,n,s=!1,i=void 0,o=void 0){Zs(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),Pc(e,t,r,n,u,s,i,o,!0,!1)}a(wW,"greaterThan");function IW(e,t,r,n,s=!1,i=void 0,o=void 0){Zs(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),Pc(e,t,r,n,u,s,i,o,!1,!1)}a(IW,"greaterThanEqual");function CW(e,t,r,n,s=!1,i=void 0,o=void 0){Zs(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),Pc(e,t,r,u,n,s,i,o,!1,!0)}a(CW,"lessThan");function DW(e,t,r,n,s=!1,i=void 0,o=void 0){Zs(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),Pc(e,t,r,u,n,s,i,o,!1,!1)}a(DW,"lessThanEqual");function LW(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Ur.validateEnv(e),r===void 0)throw new Error(at.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(at.START_VALUE_REQUIRED);if(s===void 0)throw new Error(at.END_VALUE_REQUIRED);if(n=Ur.convertKeyValueToWrite(n),s=Ur.convertKeyValueToWrite(s),n>s)throw new Error(at.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Pc(e,t,r,n,s,i,o,c)}a(LW,"between");function MW(e,t,r,n){Ur.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(at.HASH_ATTRIBUTE_REQUIRED);if(M_(r),r=vc(s,r),n===void 0)throw new Error(at.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=L_.parseRow(c,r)),o}a(MW,"searchByHash");function UW(e,t,r){Ur.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(at.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(at.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(UW,"checkHashExists");function PW(e,t,r,n,s=[]){return lw(e,t,r,n,s),uw(e,t,r,n,s).map(i=>i[1])}a(PW,"batchSearchByHash");function vW(e,t,r,n,s=[]){lw(e,t,r,n,s);let i=new Map;for(let[o,c]of uw(e,t,r,n,s))i.set(o,c);return i}a(vW,"batchSearchByHashToMap");function uw(e,t,r,n,s=[]){return Vi(e,t,t,(i,o,c)=>{r=vc(c,r);let u=r.length<3;return n.map(_=>{let l=c.dbis[t].get(_,{transaction:i,lazy:u});if(l)return[_,L_.parseRow(l,r)];s.push(_)}).filter(_=>_)})}a(uw,"batchHashSearch");function lw(e,t,r,n,s){if(Ur.validateEnv(e),t===void 0)throw new Error(at.HASH_ATTRIBUTE_REQUIRED);if(M_(r),n==null)throw new Error(at.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(at.IDS_MUST_BE_ITERABLE)}a(lw,"initializeBatchSearchByHash");function M_(e){if(!Array.isArray(e))throw e===void 0?new Error(at.FETCH_ATTRIBUTES_REQUIRED):new Error(at.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(M_,"validateFetchAttributes");function Zs(e,t,r){if(Ur.validateEnv(e),t===void 0)throw new Error(at.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(at.SEARCH_VALUE_REQUIRED);if(r?.length>SW)throw new Error(at.SEARCH_VALUE_TOO_LARGE)}a(Zs,"validateComparisonFunctions");function vc(e,t){return t.length===1&&mW.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=js.listDBIs(e)),t}a(vc,"setGetWholeRowAttributes");_w.exports={searchAll:TW,searchAllToMap:gW,count:bW,countAll:AW,equals:OW,startsWith:NW,endsWith:yW,contains:cw,searchByHash:MW,setGetWholeRowAttributes:vc,batchSearchByHash:PW,batchSearchByHashToMap:vW,checkHashExists:UW,iterateDBI:RW,greaterThan:wW,greaterThanEqual:IW,lessThan:CW,lessThanEqual:DW,between:LW}});var Qo=g((Qce,mw)=>{var dw=require("lodash"),fw=et(),Ee=require("joi"),BW=J(),{hdb_schema_table:Bc,checkValidTable:Ew,hdb_table:hw,hdb_database:U_}=Gn(),{handleHDBError:HW,hdb_errors:xW}=ee(),{getDatabases:FW}=(be(),te(Fe)),{HTTP_STATUS_CODES:qW}=xW,GW=Ee.object({database:U_,schema:U_,table:hw,search_attribute:Bc,search_value:Ee.any().required(),get_attributes:Ee.array().min(1).items(Ee.alternatives(Bc,Ee.object())).optional(),desc:Ee.bool(),limit:Ee.number().integer().min(1),offset:Ee.number().integer().min(0)}),kW=Ee.object({database:U_,schema:U_,table:hw,operator:Ee.string().valid("and","or").default("and").lowercase(),offset:Ee.number().integer().min(0),limit:Ee.number().integer().min(1),get_attributes:Ee.array().min(1).items(Ee.alternatives(Bc,Ee.object())).optional(),sort:Ee.object({attribute:Ee.alternatives(Bc,Ee.array().min(1)),descending:Ee.bool().optional()}).optional(),conditions:Ee.array().min(1).items(Ee.alternatives(Ee.object({operator:Ee.string().valid("and","or").default("and").lowercase(),conditions:Ee.array()}),Ee.object({search_attribute:Ee.alternatives(Bc,Ee.array().min(1)),search_type:Ee.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:Ee.when("search_type",{switch:[{is:"equals",then:Ee.any()},{is:"between",then:Ee.array().items(Ee.alternatives([Ee.string(),Ee.number()])).length(2)}],otherwise:Ee.alternatives(Ee.string(),Ee.number())}).required()}))).required()});mw.exports=function(e,t){let r=null;switch(t){case"value":r=fw.validateBySchema(e,GW);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(Ew("database",e.schema)),i(Ew("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=fw.validateBySchema(e,kW);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=BW.checkGlobalSchemaTable(e.schema,e.table);if(s)return HW(new Error,s,qW.NOT_FOUND);let o=FW()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let u=a(l=>{for(let d=0,f=l.conditions.length;d<f;d++){let E=l.conditions[d];E.conditions?u(E):c.push(E.search_attribute)}},"addConditions");t==="conditions"&&u(e);let _=dw.filter(c,l=>l!=="*"&&l.attribute!=="*"&&!Array.isArray(l)&&!dw.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 tp=g((Jce,pw)=>{"use strict";var VW=$e(),$W=Qo(),{getSchemaPath:YW}=Ke();pw.exports=KW;function KW(e){let t=$W(e,"hashes");if(t)throw t;let r=YW(e.schema,e.table);return VW.openEnvironment(r,e.table)}a(KW,"initialize")});var rp=g((jce,Sw)=>{"use strict";var WW=Wo(),QW=tp();Sw.exports=zW;async function zW(e){let t=await QW(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return WW.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(zW,"lmdbGetDataByHash")});var zo=g((eue,Tw)=>{"use strict";var np=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};Tw.exports=np});var Rw=g((nue,gw)=>{"use strict";var rue=zo(),JW=Wo(),XW=tp();gw.exports=jW;async function jW(e){let t=await XW(e),r=global.hdb_schema[e.schema][e.table];return JW.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(jW,"lmdbSearchByHash")});var Kn=g((iue,Aw)=>{"use strict";var sp=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}};Aw.exports=sp});var P_=g((aue,Iw)=>{"use strict";var Kt=Wo(),ZW=$e(),eQ=J(),he=lt(),$i=M(),tQ=Ci(),Ow=Or().LMDB_ERRORS_ENUM,{getSchemaPath:rQ}=Ke(),ms=$i.SEARCH_WILDCARDS;async function nQ(e,t,r){let n;e.schema===$i.SYSTEM_SCHEMA_NAME?n=tQ[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(nQ,"prepSearch");async function Nw(e,t,r,n){let s=rQ(e.schema,e.table),i=await ZW.openEnvironment(s,e.table),o=yw(i,e,t,r),c=o.transaction||i;if([he.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,he.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,he.SEARCH_TYPES.SEARCH_ALL,he.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(sQ(e,r)===!1){let l=e.search_attribute;if(l===r)return n?bw(o,()=>!0):o.map(f=>({[r]:f.key}));let d=a(f=>({[r]:f.value,[l]:f.key}),"toObject");return n?bw(o,d):o.map(d)}let _=e.search_attribute===r?o.map(l=>l.key):o.map(l=>l.value);return n===!0?Kt.batchSearchByHashToMap(c,r,e.get_attributes,_):Kt.batchSearchByHash(c,r,e.get_attributes,_)}a(Nw,"executeSearch");function yw(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 he.SEARCH_TYPES.EQUALS:s=Kt.equals(e,i,t.search_attribute,t.search_value,o,c,u);break;case he.SEARCH_TYPES.CONTAINS:s=Kt.contains(e,i,t.search_attribute,t.search_value,o,c,u);break;case he.SEARCH_TYPES.ENDS_WITH:case he.SEARCH_TYPES._ENDS_WITH:s=Kt.endsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case he.SEARCH_TYPES.STARTS_WITH:case he.SEARCH_TYPES._STARTS_WITH:s=Kt.startsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case he.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Kt.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case he.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Kt.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case he.SEARCH_TYPES.SEARCH_ALL:return Kt.searchAll(e,n,t.get_attributes,o,c,u);case he.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Kt.searchAllToMap(e,n,t.get_attributes,o,c,u);case he.SEARCH_TYPES.BETWEEN:s=Kt.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,u);break;case he.SEARCH_TYPES.GREATER_THAN:case he.SEARCH_TYPES._GREATER_THAN:s=Kt.greaterThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case he.SEARCH_TYPES.GREATER_THAN_EQUAL:case he.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Kt.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;case he.SEARCH_TYPES.LESS_THAN:case he.SEARCH_TYPES._LESS_THAN:s=Kt.lessThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case he.SEARCH_TYPES.LESS_THAN_EQUAL:case he.SEARCH_TYPES._LESS_THAN_EQUAL:s=Kt.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;default:return Object.create(null)}return s}a(yw,"searchByType");function bw(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(bw,"createMapFromIterable");function sQ(e,t){if(e.get_attributes.length===1&&e.get_attributes[0]==="*")return!0;let r=[e.search_attribute];e.get_attributes.indexOf(t)>=0&&r.push(t);let n=!1;for(let s=0;s<e.get_attributes.length;s++)if(r.indexOf(e.get_attributes[s])<0){n=!0;break}return n}a(sQ,"checkToFetchMore");function ww(e,t,r,n){if(eQ.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),ms.indexOf(s)>-1)return r===!0?he.SEARCH_TYPES.SEARCH_ALL_TO_MAP:he.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(ms[0])<0&&s.indexOf(ms[1])<0)return c===!0?r===!0?he.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:he.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:he.SEARCH_TYPES.EQUALS;if(ms.indexOf(i)>=0&&ms.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),he.SEARCH_TYPES.CONTAINS;if(ms.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),he.SEARCH_TYPES.ENDS_WITH;if(ms.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),he.SEARCH_TYPES.STARTS_WITH;if(s.includes(ms[0])||s.includes(ms[1]))return he.SEARCH_TYPES.EQUALS;throw new Error(Ow.UNKNOWN_SEARCH_TYPE)}else switch(n){case $i.VALUE_SEARCH_COMPARATORS.BETWEEN:return he.SEARCH_TYPES.BETWEEN;case $i.VALUE_SEARCH_COMPARATORS.GREATER:return he.SEARCH_TYPES.GREATER_THAN;case $i.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return he.SEARCH_TYPES.GREATER_THAN_EQUAL;case $i.VALUE_SEARCH_COMPARATORS.LESS:return he.SEARCH_TYPES.LESS_THAN;case $i.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return he.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(Ow.UNKNOWN_SEARCH_TYPE)}}a(ww,"createSearchTypeFromSearchObject");Iw.exports={executeSearch:Nw,createSearchTypeFromSearchObject:ww,prepSearch:nQ,searchByType:yw}});var Dw=g((lue,Cw)=>{"use strict";var uue=Kn(),iQ=Qo(),oQ=J(),aQ=M(),cQ=P_();Cw.exports=uQ;function uQ(e,t){if(!oQ.isEmpty(t)&&aQ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=iQ(e,"value");if(n)throw n;return cQ.prepSearch(e,t,!0)}a(uQ,"lmdbGetDataByValue")});var Hc=g((fue,Lw)=>{"use strict";var due=Kn(),lQ=Qo(),_Q=J(),dQ=M(),fQ=P_();Lw.exports=EQ;async function EQ(e,t){if(!_Q.isEmpty(t)&&dQ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=lQ(e,"value");if(n)throw n;return fQ.prepSearch(e,t,!1)}a(EQ,"lmdbSearchByValue")});var Uw=g((mue,Mw)=>{"use strict";var hue=lt(),ip=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}},op=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},ap=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};Mw.exports={SearchByConditionsObject:ip,SearchCondition:op,SortAttribute:ap}});var xw=g((gue,Hw)=>{"use strict";var Sue=Uw().SearchByConditionsObject,hQ=Kn(),mQ=Qo(),cp=Wo(),v_=lt(),{Resource:Tue}=(Sn(),te(up)),Bw=P_(),pQ=ep(),SQ=require("lodash"),{getSchemaPath:TQ}=Ke(),Pw=$e(),{handleHDBError:gQ,hdb_errors:RQ}=ee(),{HTTP_STATUS_CODES:AQ}=RQ,OQ=1e8;Hw.exports=bQ;async function bQ(e){let t=mQ(e,"conditions");if(t)throw gQ(t,t.message,AQ.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=TQ(e.schema,e.table),n=await Pw.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let _ of e.conditions)Pw.openDBI(n,_.search_attribute);let i=SQ.sortBy(e.conditions,_=>{if(_.estimated_count===void 0){let l=_.search_type;l===v_.SEARCH_TYPES.EQUALS?_.estimated_count=cp.count(n,_.search_attribute,_.search_value):l===v_.SEARCH_TYPES.CONTAINS||l===v_.SEARCH_TYPES.ENDS_WITH?_.estimated_count=1/0:_.estimated_count=OQ}return _.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await vw(o,e,i[0],s.hash_attribute),u;if(!e.operator||e.operator.toLowerCase()==="and"){let _=n.dbis[s.hash_attribute],l=i.slice(1).map(Bw.filterByType),d=l.length,f=cp.setGetWholeRowAttributes(n,e.get_attributes);u=c.map(E=>_.get(E,{transaction:o,lazy:!0})),d>0&&(u=u.filter(E=>{for(let h=0;h<d;h++)if(!l[h](E))return!1;return!0})),(e.offset||e.limit!==void 0)&&(u=u.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),u=u.map(E=>pQ.parseRow(E,f))}else{for(let d=1;d<i.length;d++){let f=i[d],E=await vw(o,e,f,s.hash_attribute);c=c.concat(E)}let _=new Set,l=e.offset||0;c=c.filter(d=>_.has(d)?!1:(_.add(d),!0)).slice(l,e.limit&&e.limit+l),u=cp.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return u.onDone=()=>{o.done()},u}a(bQ,"lmdbSearchByConditions");async function vw(e,t,r,n){let s=new hQ(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===v_.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,Bw.searchByType(e,s,i,n).map(o=>o.value)}a(vw,"executeConditionSearch")});var xc=g((Aue,Fw)=>{"use strict";var NQ=M().OPERATIONS_ENUM,lp=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=NQ.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Fw.exports=lp});var _p=g((bue,Ww)=>{"use strict";var Vw=Kn(),$w=xc(),Yw=Hc(),Kw=Uc(),nr=M(),qw=J(),Gw=$e(),{getTransactionAuditStorePath:yQ,getSchemaPath:wQ}=Ke(),kw=Y();Ww.exports=IQ;async function IQ(e){try{if(qw.isEmpty(global.hdb_schema[e.schema])||qw.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await CQ(e),await DQ(e);let t=wQ(e.schema,e.table);try{await Gw.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")kw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=yQ(e.schema,e.table);await Gw.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")kw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(IQ,"lmdbDropTable");async function CQ(e){let t=new Vw(nr.SYSTEM_SCHEMA_NAME,nr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,nr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[nr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Yw(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 $w(nr.SYSTEM_SCHEMA_NAME,nr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await Kw(s)}a(CQ,"deleteAttributesFromSystem");async function DQ(e){let t=new Vw(nr.SYSTEM_SCHEMA_NAME,nr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,nr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[nr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,nr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,nr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Yw(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 $w(nr.SYSTEM_SCHEMA_NAME,nr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await Kw(s)}catch(i){throw i}}a(DQ,"dropTableFromSystem")});var zw=g((yue,Qw)=>{"use strict";var LQ=require("fs-extra"),MQ=Kn(),UQ=zo(),PQ=xc(),vQ=_p(),BQ=Uc(),HQ=rp(),xQ=Hc(),ps=M(),{getSchemaPath:FQ}=Ke(),{handleHDBError:qQ,hdb_errors:GQ}=ee(),{HDB_ERROR_MSGS:kQ,HTTP_STATUS_CODES:VQ}=GQ;Qw.exports=$Q;async function $Q(e){let t;try{t=await YQ(e.schema);let r=new MQ(ps.SYSTEM_SCHEMA_NAME,ps.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,ps.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[ps.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await xQ(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await vQ(c)}catch(u){if(u.message!=="invalid environment")throw u}}let s=new PQ(ps.SYSTEM_SCHEMA_NAME,ps.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await BQ(s);let i=FQ(t);await LQ.remove(i)}catch(r){throw r}}a($Q,"lmdbDropSchema");async function YQ(e){let t=new UQ(ps.SYSTEM_SCHEMA_NAME,ps.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[ps.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await HQ(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw qQ(new Error,kQ.SCHEMA_NOT_FOUND(e),VQ.NOT_FOUND,void 0,void 0,!0);return n}a(YQ,"validateDropSchema")});var fp=g((Iue,Jw)=>{"use strict";var dp=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Jw.exports=dp});var jw=g((Lue,Xw)=>{"use strict";var KQ=require("fs-extra"),B_=$e(),{getTransactionAuditStorePath:WQ}=Ke(),Ep=lt(),Due=fp();Xw.exports=QQ;async function QQ(e){let t;try{let r=WQ(e.schema,e.table);await KQ.mkdirp(r),t=await B_.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{B_.createDBI(t,Ep.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),B_.createDBI(t,Ep.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),B_.createDBI(t,Ep.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(QQ,"createTransactionsAuditEnvironment")});var rI=g((Uue,tI)=>{"use strict";var hp=M(),Zw=$e(),zQ=vo(),{getSystemSchemaPath:JQ,getSchemaPath:XQ}=Ke(),jQ=Ci(),ZQ=i_(),mp=s_(),ez=Y(),tz=jw(),Sp=jQ.hdb_table,eI=[];for(let e=0;e<Sp.attributes.length;e++)eI.push(Sp.attributes[e].attribute);tI.exports=rz;async function rz(e,t){let r=XQ(t.schema,t.table),n=new mp(t.schema,t.table,hp.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new mp(t.schema,t.table,hp.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new mp(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Zw.createEnvironment(r,t.table),e!==void 0){let o=await Zw.openEnvironment(JQ(),hp.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await zQ.insertRecords(o,Sp.hash_attribute,eI,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await pp(n),await pp(s),await pp(i)}await tz(t)}catch(o){throw o}}a(rz,"lmdbCreateTable");async function pp(e){try{await ZQ(e)}catch(t){ez.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(pp,"createAttribute")});var sI=g((vue,nI)=>{"use strict";var nz=Tc(),sz=bc(),iz=I_(),Fc=M(),oz=vo().updateRecords,az=$e(),{getSchemaPath:cz}=Ke(),uz=Lc(),lz=Y();nI.exports=_z;async function _z(e){try{let{schema_table:t,attributes:r}=nz(e);sz(e,r,t.hash_attribute),e.schema!==Fc.SYSTEM_SCHEMA_NAME&&(r.includes(Fc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Fc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Fc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Fc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await iz(e.hdb_auth_header,t,r),s=cz(e.schema,e.table),i=await az.openEnvironment(s,e.table),o=await oz(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await uz(e,o)}catch(c){lz.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(_z,"lmdbUpdateRecords")});var oI=g((Hue,iI)=>{"use strict";var dz=M().OPERATIONS_ENUM,Tp=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=dz.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};iI.exports=Tp});var cI=g((que,aI)=>{"use strict";var Fue=oI(),fz=Tc(),Ez=bc(),hz=I_(),qc=M(),mz=vo().upsertRecords,pz=$e(),{getSchemaPath:Sz}=Ke(),Tz=Lc(),gz=Y(),{handleHDBError:Rz,hdb_errors:Az}=ee();aI.exports=Oz;async function Oz(e){let t;try{t=fz(e)}catch(u){throw Rz(u,u.message,Az.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;Ez(e,n,r.hash_attribute),e.schema!==qc.SYSTEM_SCHEMA_NAME&&(n.includes(qc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(qc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(qc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(qc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await hz(e.hdb_auth_header,r,n),i=Sz(e.schema,e.table),o=await pz.openEnvironment(i,e.table),c=await mz(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await Tz(e,c)}catch(u){gz.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(Oz,"lmdbUpsertRecords")});var lI=g((kue,uI)=>{"use strict";var gp=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};uI.exports=gp});var dI=g(($ue,_I)=>{"use strict";var Rp=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}};_I.exports=Rp});var hI=g((Wue,EI)=>{"use strict";var Ap=$e(),{getTransactionAuditStorePath:bz}=Ke(),Kue=lI(),Gc=lt(),Nz=J(),fI=dI(),yz=require("util").promisify,wz=yz(setTimeout),Iz=1e4,Cz=100;EI.exports=Dz;async function Dz(e){let t=bz(e.schema,e.table),r=await Ap.openEnvironment(t,e.table,!0),n=Ap.listDBIs(r);Ap.initializeDBIs(r,Gc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new fI;do s=await Lz(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 wz(Cz);while(s.transactions_deleted>0);return i}a(Dz,"deleteAuditLogsBefore");async function Lz(e,t){let r=new fI;try{let n=e.dbis[Gc.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[Gc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Nz.isEmpty(c)||(s=e.dbis[Gc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let u=0;u<o.hash_values.length;u++)s=e.dbis[Gc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[u],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>Iz)break}return await s,r}catch(n){throw n}}a(Lz,"deleteTransactions")});var pI=g((zue,mI)=>{"use strict";var Op=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};mI.exports=Op});var TI=g((jue,SI)=>{"use strict";var Mz=Kn(),Uz=xc(),Xue=pI(),Wn=M(),Pz=J(),bp=$e(),vz=Ci(),Bz=Hc(),Hz=Uc(),{getSchemaPath:xz}=Ke();SI.exports=Fz;async function Fz(e,t=!0){let r;e.schema===Wn.SYSTEM_SCHEMA_NAME?r=vz[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await Gz(e),s=xz(e.schema,e.table),i=await bp.openEnvironment(s,e.table);return t===!0&&await qz(e,i,r.hash_attribute),bp.dropDBI(i,e.attribute),n}a(Fz,"lmdbDropAttribute");async function qz(e,t,r){let n=bp.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(qz,"removeAttributeFromAllObjects");async function Gz(e){let t=new Mz(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Wn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Wn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Wn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await Bz(t)).filter(o=>o[Wn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(Pz.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Wn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new Uz(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Hz(i)}a(Gz,"dropAttributeFromSystem")});var NI=g((tle,bI)=>{"use strict";var Np=$e(),Jo=lt(),ele=br(),yp=M(),gI=J(),{getTransactionAuditStorePath:kz}=Ke(),Vz=Wo(),H_=$o(),$z=Y();bI.exports=Yz;async function Yz(e){let t=kz(e.schema,e.table),r=await Np.openEnvironment(t,e.table,!0),n=Np.listDBIs(r);Np.initializeDBIs(r,Jo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case yp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return RI(r,e.search_values);case yp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,Wz(r,e.search_values,s);case yp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return Kz(r,e.search_values);default:return RI(r)}}a(Yz,"readAuditLog");function RI(e,t=[0,Date.now()]){gI.isEmpty(t[0])&&(t[0]=0),gI.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Jo.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 H_,s))}a(RI,"searchTransactionsByTimestamp");function Kz(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[Jo.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,OI(e,i))}return Object.fromEntries(r)}a(Kz,"searchTransactionsByUsername");function Wz(e,t,r){let n=new Map;for(let c=0,u=t.length;c<u;c++){let _=t[c],l=Vz.equals(e,Jo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Jo.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,_);for(let{value:d}of l){let f=Number(d);n.has(f)?n.get(f).push(_.toString()):n.set(f,[_.toString()])}}let s=Array.from(n.keys()),i=OI(e,s),o=new Map;for(let c=0;c<i.length;c++){let u=i[c],_=u.timestamp,l=n.get(_);AI(u,"records",r,l,o),AI(u,"original_records",r,l,o)}return Object.fromEntries(o)}a(Wz,"searchTransactionsByHashValues");function AI(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 H_(e.operation,e.user_name,i,void 0);d[t]=[c],_.push(d)}}else{let _=new H_(e.operation,e.user_name,i,void 0);_[t]=[c],s.set(u,[_])}}}a(AI,"loopRecords");function OI(e,t){let r=[];try{let n=e.dbis[Jo.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 H_,i);r.push(o)}}catch(i){$z.warn(i)}return r}catch(n){throw n}}a(OI,"batchSearchTransactions")});var wI=g((ile,yI)=>{"use strict";var{getSchemaPath:nle}=Ke(),sle=$e(),{database:Qz}=(be(),te(Fe));yI.exports={writeTransaction:zz};async function zz(e,t,r){return Qz({database:e,table:t}).transaction(r)}a(zz,"writeTransaction")});var LI=g((ale,DI)=>{"use strict";var{getSchemaPath:II}=Ke(),CI=$e();DI.exports={flush:Jz,resetReadTxn:Xz};async function Jz(e,t){return(await CI.openEnvironment(II(e,t),t.toString())).flushed}a(Jz,"flush");async function Xz(e,t){try{(await CI.openEnvironment(II(e,t),t.toString())).resetReadTxn()}catch{}}a(Xz,"resetReadTxn")});var vI=g((ule,PI)=>{"use strict";var{Readable:jz}=require("stream"),{getDatabases:Zz}=(be(),te(Fe)),{readSync:eJ,openSync:tJ,createReadStream:MI}=require("fs"),{open:rJ}=require("lmdb"),UI=Ql(),nJ=Jl(),{AUDIT_STORE_OPTIONS:sJ}=(wi(),te(BI)),{INTERNAL_DBIS_NAME:iJ,AUDIT_STORE_NAME:oJ}=lt();PI.exports=cJ;var wp=32768,aJ=100;async function cJ(e){let t=e.database||e.schema||"data",r=Zz()[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=rJ({noSync:!0,maxDbs:nJ.MAX_DBS}),f,E=d.openDB(iJ,new UI(!1)),h=l.useReadTransaction(),p=0,S=a(async function(A,b){b.encoding="binary",b.encoder=void 0;let H=d.openDB(A,b),F=l.openDB(A,b);for(let{key:v,version:P,value:z}of F.getRange({transaction:h,versions:F.useVersions}))f=H.put(v,z,P),p++%aJ===0&&(await new Promise(W=>setTimeout(W,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:A,value:b}of l.getRange({transaction:h,start:!1}))if(s.some(H=>A.startsWith?.(H+"/"))){E.put(A,b);let[,H]=A.split("/"),F=!H,v=new UI(!F,F);await S(A,v)}e.include_audit&&await S(oJ,Object.assign({},sJ)),await f;let T=MI(d.path);return T.headers=u(),T.on("close",()=>{h.done(),d.close()}),T}let o=r[Object.keys(r)[0]].primaryStore,c=tJ(o.path);return o.transaction(()=>{let _=Buffer.alloc(wp);eJ(c,_,0,wp),o.resetReadTxn();let l=o.useReadTransaction();l.renew();let d=MI(null,{fd:c,start:wp}),f=new jz.from(async function*(){yield _;for await(let E of d)l.openTimer&&(l.openTimer=0),yield E;l.done()}());return f.headers=u(),f});function u(){let _=new Map;return _.set("content-type","application/octet-stream"),_.set("content-disposition",`attachment; filename="${t}"`),_.set("date",n),_}}a(cJ,"getBackup")});var FI=g((_le,xI)=>{"use strict";var uJ=Y(),{handleHDBError:lJ}=ee(),_J=ZO(),dJ=i_(),fJ=zm(),EJ=zy(),hJ=Uc(),mJ=rp(),pJ=Rw(),SJ=Dw(),TJ=Hc(),gJ=xw(),RJ=zw(),AJ=rI(),OJ=sI(),bJ=cI(),NJ=hI(),yJ=_p(),wJ=TI(),IJ=NI(),CJ=wI(),HI=LI(),DJ=vI(),Ip=class extends _J{static{a(this,"LMDBBridge")}async searchByConditions(t){return gJ(t)}async getDataByHash(t){return await mJ(t)}async searchByHash(t){return await pJ(t)}async getDataByValue(t,r){return await SJ(t,r)}async searchByValue(t){return await TJ(t)}async createSchema(t){return await EJ(t)}async dropSchema(t){return await RJ(t)}async createTable(t,r){return await AJ(t,r)}async dropTable(t){return await yJ(t)}async createAttribute(t){return await dJ(t)}async createRecords(t){return await fJ(t)}async updateRecords(t){return await OJ(t)}async upsertRecords(t){try{return await bJ(t)}catch(r){throw lJ(r,null,null,uJ.ERR,r)}}async deleteRecords(t){return await hJ(t)}async dropAttribute(t){return await wJ(t)}async deleteAuditLogsBefore(t){return await NJ(t)}async readAuditLog(t){return await IJ(t)}writeTransaction(t,r,n){return CJ.writeTransaction(t,r,n)}flush(t,r){return HI.flush(t,r)}resetReadTxn(t,r){return HI.resetReadTxn(t,r)}getBackup(t){return DJ(t)}};xI.exports=Ip});function PJ(){UJ=setInterval(function(){for(let e of Cp)if(e.stale){let t=e[Ne]?.url;qI.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},MJ).unref()}var Dp,qI,LJ,Cp,Yi,x_,MJ,UJ,Lp=Oe(()=>{Dp=B(br()),qI=B(Y());Sn();Uo();LJ=100,Cp=new Set,Yi=class{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;open=!0;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)throw new Error("Can not start a read on a transaction that is no longer open");return this.readTxnsUsed=1,Kl(()=>{this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxn.openTimer&&(this.readTxn.openTimer=0)}),Cp.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),Kl(()=>{this.readTxn.use()}),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(Cp.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}addWrite(t){if(!this.open&&!this.autoCommitMode)throw new Error("Can not use a transaction that is no longer open");this.writes.push(t),this.autoCommitMode&&this.commit()}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp=t.timestamp||(0,Dp.getNextMonotonicTime)());let n=t.retries||0;if(this.validated<this.writes.length)try{let l=this.validated;this.validated=this.writes.length;for(let f=l;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let d;for(let f=l;f<this.validated;f++){let E=this.writes[f];E&&(E.before||E.beforeIntermediate)&&(d=!0)}if(d)return(async()=>{try{for(let f=0;f<2;f++){let E;for(let h=l;h<this.validated;h++){let p=this.writes[h];if(!p)continue;let S=p[f===0?"before":"beforeIntermediate"];if(S){let T=S();E?E.push?E.push(T):E=[E,T]:E=T}}E&&await(E.push?Promise.all(E):E)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(l){throw this.abort(),l}n||this.doneReadTxn(),t?.prepared?.(),this.open=!1;let s,i=[],o=0;this.writes=this.writes.filter(l=>l);let c=a(l=>{l.commit(r,l.entry,n)},"doWrite"),u=a(()=>{let l=this.writes[o++];if(l)if(l.key){n>0&&(l.entry=l.store.getEntry(l.key));let d=l.store.ifVersion(l.key,l.entry?.version??null,u);s=s||d}else u();else for(let d of this.writes)c(d)},"nextCondition");if(this.writes.length<LJ>>n?u():s=this.writes[0].store.transaction(()=>{for(let l of this.writes)l.entry=l.store.getEntry(l.key),c(l);return!0}),s)return s.then(l=>l?(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))):(t?t.retries=n+1:t={retries:1},this.commit(t)));let _={txnTime:r};if(this.next){let l=this.next?.commit(t);if(l?.then)return l?.then(d=>({txnTime:r,next:d}));_.next=l}return _}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=!1,this.writes=[]}},x_=class extends Yi{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,Dp.getNextMonotonicTime)())}getReadTxn(){}},MJ=3e4;a(PJ,"startMonitoringTxns");PJ()});function We(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open&&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 Yi;e.timestamp&&(n.timestamp=e.timestamp),n[Ne]=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(r?.resetTransaction?{prepared(){n.autoCommitMode=!0}}:{});return u.then?u.then(()=>c):c}function o(c){throw n.abort({}),c}}var GI,Ki=Oe(()=>{GI=require("../../index");Sn();Lp();a(We,"transaction");(0,GI._assignPackageExport)("transaction",We);We.commit=function(e){let t=(e[Ne]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};We.abort=function(e){let t=(e[Ne]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var JI={};Ve(JI,{ResourceBridge:()=>Pp});function vp({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 VI(e,t){let r=Qn(e),n=vp(e,r);if(!r)throw new Nn.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user},o;We(i,()=>new Promise(_=>o=_));let c=e.ids||e.hash_values,u=0;return{[Symbol.asyncIterator](){return{async next(){if(u<c.length){let _=c[u++],l=await r.get({id:_,lazy:s,select:n},i);return l=l&&q_(l),t?{value:{key:_,value:l}}:{value:l}}else return o(),{done:!0}},return(_){return o(),{value:_,done:!0}},throw(_){return o(),{done:!0}}}}}}function Qn(e){let t=e.database||e.schema||BJ,r=yn()[t];if(!r)throw(0,Nn.handleHDBError)(new Error,vJ.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function $I(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*YI(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 KI,F_,Nn,WI,QI,wn,Mp,Up,zI,vJ,BJ,HJ,xJ,kI,Pp,XI=Oe(()=>{"use strict";KI=B(FI()),F_=B(Qo()),Nn=B(ee());be();WI=B(Tc()),QI=B(bc()),wn=B(M()),Mp=B(hs()),Up=B(bn()),zI=B(J());Ki();G_();({HDB_ERROR_MSGS:vJ}=Nn.hdb_errors),BJ="data",HJ=1e4,xJ=10,Pp=class extends KI.default{static{a(this,"ResourceBridge")}constructor(t){super(t),kI=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,F_.default)(t,"conditions");if(r)throw(0,Nn.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Qn(t);if(!n)throw new Nn.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:vp(t,n),sort:t.sort,allowFullScan:!0})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new Nn.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}]}ot({database:r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await Qn(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Qn(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){Qn(t).dropTable()}createSchema(t){return kc({database:t.schema,table:null}),Mp.signalSchemaChange(new Up.SchemaEventMsg(process.pid,wn.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Bp(t.schema),Mp.signalSchemaChange(new Up.SchemaEventMsg(process.pid,wn.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,kI.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,WI.default)(t);(0,QI.default)(t,n,r.primaryKey);let s,i=yn()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt};return We(o,async c=>{if(!i.schemaDefined){s=[];for(let l of n)i.attributes.find(f=>f.name==l)||s.push(l);s.length>0&&await i.addAttributes(s.map(l=>({name:l,indexed:!0})))}let u=[],_=[];for(let l of t.records){let d=await i.get(l[i.primaryKey],o);if(t.requires_existing&&!d||t.requires_no_existing&&d){_.push(l[i.primaryKey]);continue}d&&(d=q_(d));for(let f in l)if(Object.prototype.hasOwnProperty.call(l,f)){let E=l[f];if(typeof E=="function")try{let h=E([[d]]);Array.isArray(h)&&(E=h[0].func_val,l[f]=E)}catch(h){throw h.message+="Trying to set key "+f+" on object"+JSON.stringify(l),h}}if(d)for(let f in d)Object.prototype.hasOwnProperty.call(l,f)||(l[f]=d[f]);await i.put(l,o),u.push(l[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:u,new_attributes:s,skipped_hashes:_}})}async deleteRecords(t){let r=yn()[t.schema][t.table],n={user:t.hdb_user};return We(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 $I(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=yn()[t.schema][t.table];if(!r.createdTimeProperty)throw new Nn.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:wn.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,zI.async_set_timeout)(xJ),u=[],s=!0},"chunkDelete");for await(let l of n)u.push(l[r.primaryKey]),c++,c%HJ===0&&await _();return u.length>0&&await _(),s?$I(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,F_.default)(t,"hashes");if(r)throw r;return VI(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of VI(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&wn.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,F_.default)(t,"value");if(n)throw n;let s=Qn(t);if(!s)throw new Nn.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===wn.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:vp(t,s)})}async getDataByValue(t,r){let n=new Map,s=Qn(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){Qn({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Qn(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=Qn(t),n={};switch(t.search_type){case wn.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 wn.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of YI(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return YI(r,t.search_values?.[0],t.search_values?.[1])}}};a(vp,"getSelect");a(VI,"getRecords");a(Qn,"getTable");a($I,"createDeleteResponse");a(YI,"groupRecordsInHistory")});var Rn=g((yle,jI)=>{"use strict";var{ResourceBridge:FJ}=(XI(),te(JI)),qJ=Z();qJ.initSync();var k_;function GJ(){return k_||(k_=new FJ,k_)}a(GJ,"getBridge");jI.exports=GJ()});var rC=g((Ile,tC)=>{"use strict";var ZI=require("lodash"),Vc=require("mathjs"),kJ=require("jsonata"),eC=J();tC.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?ZI.uniqWith(e,ZI.isEqual):e,searchJSON:VJ,mad:$c.bind(null,Vc.mad),mean:$c.bind(null,Vc.mean),mode:$c.bind(null,Vc.mode),prod:$c.bind(null,Vc.prod),median:$c.bind(null,Vc.median)};function $c(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($c,"aggregateFunction");function VJ(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(eC.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),eC.isEmpty(this.__ala__.res[r])){let n=kJ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(VJ,"searchJSON")});var sC=g((Dle,nC)=>{"use strict";var dt=require("moment"),Hp="YYYY-MM-DDTHH:mm:ss.SSSZZ";dt.suppressDeprecationWarnings=!0;nC.exports={current_date:()=>dt().utc().format("YYYY-MM-DD"),current_time:()=>dt().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return dt(e).utc().format("YYYY");case"month":return dt(e).utc().format("MM");case"day":return dt(e).utc().format("DD");case"hour":return dt(e).utc().format("HH");case"minute":return dt(e).utc().format("mm");case"second":return dt(e).utc().format("ss");case"millisecond":return dt(e).utc().format("SSS");default:break}},date:e=>dt(e).utc().format(Hp),date_format:(e,t)=>dt(e).utc().format(t),date_add:(e,t,r)=>dt(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>dt(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=dt(e).utc(),s=dt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>dt().utc().valueOf(),get_server_time:()=>dt().format(Hp),offset_utc:(e,t)=>dt(e).utc().utcOffset(t).format(Hp)}});var cC=g((Lle,aC)=>{"use strict";var $J=require("@turf/area"),YJ=require("@turf/length"),KJ=require("@turf/circle"),WJ=require("@turf/difference"),QJ=require("@turf/distance"),zJ=require("@turf/boolean-contains"),JJ=require("@turf/boolean-equal"),XJ=require("@turf/boolean-disjoint"),jJ=require("@turf/helpers"),iC=M(),Te=J(),Ss=Y();aC.exports={geoArea:ZJ,geoLength:e2,geoCircle:t2,geoDifference:r2,geoDistance:oC,geoNear:n2,geoContains:s2,geoEqual:i2,geoCrosses:o2,geoConvert:a2};function ZJ(e){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return $J.default(e)}catch(t){return Ss.trace(t,e),NaN}}a(ZJ,"geoArea");function e2(e,t){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return YJ.default(e,{units:t||"kilometers"})}catch(r){return Ss.trace(r,e),NaN}}a(e2,"geoLength");function t2(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return KJ.default(e,t,{units:r||"kilometers"})}catch(n){return Ss.trace(n,e,t),NaN}}a(t2,"geoCircle");function r2(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 WJ(e,t)}catch(r){return Ss.trace(r,e,t),NaN}}a(r2,"geoDifference");function oC(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 QJ.default(e,t,{units:r||"kilometers"})}catch(n){return Ss.trace(n,e,t),NaN}}a(oC,"geoDistance");function n2(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 oC(e,t,n)<=r}catch(s){return Ss.trace(s,e,t),!1}}a(n2,"geoNear");function s2(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 zJ.default(e,t)}catch(r){return Ss.trace(r,e,t),!1}}a(s2,"geoContains");function i2(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 JJ.default(e,t)}catch(r){return Ss.trace(r,e,t),!1}}a(i2,"geoEqual");function o2(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!XJ.default(e,t)}catch(r){return Ss.trace(r,e,t),!1}}a(o2,"geoCrosses");function a2(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(iC.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(iC.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Te.autoCastJSON(e)),jJ[t](e,r)}a(a2,"geoConvert")});var V_=g((Ule,uC)=>{var Wi=rC(),Pr=sC(),zn=cC();uC.exports=e=>{e.aggr.mad=e.aggr.MAD=Wi.mad,e.aggr.mean=e.aggr.MEAN=Wi.mean,e.aggr.mode=e.aggr.MODE=Wi.mode,e.aggr.prod=e.aggr.PROD=Wi.prod,e.aggr.median=e.aggr.MEDIAN=Wi.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Wi.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Wi.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Pr.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Pr.current_time,e.fn.extract=e.fn.EXTRACT=Pr.extract,e.fn.date=e.fn.DATE=Pr.date,e.fn.date_format=e.fn.DATE_FORMAT=Pr.date_format,e.fn.date_add=e.fn.DATE_ADD=Pr.date_add,e.fn.date_sub=e.fn.DATE_SUB=Pr.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Pr.date_diff,e.fn.now=e.fn.NOW=Pr.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Pr.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Pr.get_server_time,e.fn.getdate=e.fn.GETDATE=Pr.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Pr.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=zn.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=zn.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=zn.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=zn.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=zn.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=zn.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=zn.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=zn.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=zn.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=zn.geoNear}});var fC=g((Ple,dC)=>{"use strict";var Yc=require("lodash"),sr=require("alasql");sr.options.cache=!1;var c2=V_(),lC=require("clone"),$_=require("recursive-iterator"),fe=Y(),Ce=J(),Xo=Rn(),u2=M(),{hdb_errors:l2}=ee(),{getDatabases:_C}=(be(),te(Fe)),_2="IS NULL",In="There was a problem performing this search. Please check the logs and try again.";c2(sr);var xp=class{static{a(this,"SQLSearch")}constructor(t,r){if(Ce.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(),Ce.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Ce.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(In)}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(In)}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(In)}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(In)}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(In)}}_getColumns(){let t=new $_(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(lC(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=Yc.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=_C()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Ce.isEmpty(this.statement.where)){fe.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new $_(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Ce.isEmpty(r)&&r.right)if(Ce.isNotEmptyAndHasValue(r.right.value)){let n=Ce.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new sr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Ce.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new sr.yy.LogicValue({value:i}):n instanceof sr.yy.StringValue&&Ce.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new sr.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 $_(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!Ce.isEmpty(u2.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Ce.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Ce.isEmptyOrZeroLength(r.left.columnid)||Ce.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(Ce.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!Ce.isEmpty(r.right.value)||!Ce.isEmpty(r.left.value)?n.add(Ce.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let u=Array.isArray(r.right)?r.right:r.left;for(let _=0;_<u.length;_++)if(u[_].value)n.add(u[_].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(Ce.isEmptyOrZeroLength(this.all_table_attributes)&&Ce.isEmptyOrZeroLength(this.statement.from)&&Ce.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&Yc.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(Ce.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Ce.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(Ce.isEmptyOrZeroLength(this.all_table_attributes)&&!Ce.isEmptyOrZeroLength(this.columns.columns))return t;if(Ce.isEmptyOrZeroLength(this.all_table_attributes)&&Ce.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await sr.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(lC(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(Ce.isEmptyOrZeroLength(Object.keys(this.columns)))return[];this._addFetchColumns(this.columns.joins);let t=null;try{t=this.statement.where?this.statement.where.toString():""}catch{throw new Error("Could not generate proper where clause")}this.columns.where&&this._addFetchColumns(this.columns.where);let r=this._isSimpleSelect();if(r?this._addFetchColumns(this.columns.columns):(!this.columns.where&&this.fetch_attributes.length===0)|t.indexOf(_2)>-1&&this.tables.forEach(s=>{let i={columnid:_C()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=Yc.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},u=!1,_=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(u=!0),!Ce.isEmpty(this.exact_search_values[_])&&!this.exact_search_values[_].ignore&&!Ce.isEmptyOrZeroLength(this.exact_search_values[_].values))if(u)try{c.hash_values=Array.from(this.exact_search_values[_].values);let l=await Xo.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(In)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[_].values).map(async l=>{let d=Object.assign({},c);d.search_value=l;let f=await Xo.getDataByValue(d);for(let[E,h]of f)this.data[i].__merged_data[E]?this._updateMergedAttribute(i,E,s.attribute,h[s.attribute]):(this.data[i].__merged_data[E]=[...n[i]],this._updateMergedAttribute(i,E,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,E))}))}catch(l){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(l),new Error(In)}else if(!Ce.isEmpty(this.comparator_search_values[_])&&!this.comparator_search_values[_].ignore&&!Ce.isEmptyOrZeroLength(this.comparator_search_values[_].comparators))try{let l=this.comparator_search_values[_].comparators;for(let d=0,f=l.length;d<f;d++){let E=l[d];c.search_attribute=E.attribute,c.search_value=E.search_value;let h=await Xo.getDataByValue(c,E.operation);if(u)for(let[p]of h)this.data[i].__merged_data[p]||(this.data[i].__merged_data[p]=[...n[i]],this._setMergedHashAttribute(i,p));else for(let[p,S]of h)this.data[i].__merged_data[p]?this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]):(this.data[i].__merged_data[p]=[...n[i]],this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]),this._setMergedHashAttribute(i,p))}}catch(l){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),fe.error(l),new Error(In)}else try{c.search_attribute=s.attribute,c.search_value="*";let l=await Xo.getDataByValue(c);if(u)for(let[d]of l)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,f]of l)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,f[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,f[s.attribute]),this._setMergedHashAttribute(i,d))}catch(l){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),fe.error(l),new Error(In)}}}_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 sr.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 sr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new sr.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 sr.yy.FuncValue:new sr.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(E=>{E.joinmode&&E.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(E.table);let h=E.joinmode+" JOIN ? AS "+(E.as?E.as:E.table.tableid);E.on&&(h+=" ON "+E.on.toString()),i.push(h),t.push(Object.values(this.data[`${E.table.databaseid_orig}_${E.table.as?E.table.as_orig:E.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(E=>{let h=this.data[`${E.databaseid_orig}_${E.as?E.as_orig:E.tableid_orig}`].__hash_name,p=E.as?E.as_orig:E.tableid_orig;o.push({key:`'${p}.${h}'`,schema:E.databaseid_orig,table:E.as?E.as_orig:E.tableid_orig,keys:new Set}),r.push(`${E.as?E.as:E.tableid}.\`${h}\` AS "${p}.${h}"`),c[E.as?E.as_orig:E.tableid_orig]=this.data[`${E.databaseid_orig}_${E.as?E.as_orig:E.tableid_orig}`].__merged_attributes});let u=this.statement.where?"WHERE "+this.statement.where:"";u=u.replace(/NOT\(NULL\)/g,"NOT NULL");let _="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(_="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(E=>{E.is_func?r.push(E.initial_select_column.toString()):E.initial_select_column.tableid?r.push(`${E.initial_select_column.tableid}.${E.initial_select_column.columnid} AS ${E.expression.columnid}`):r.push(`${E.initial_select_column.columnid} AS ${E.expression.columnid}`)}));let l="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(l=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let f=[];try{let E=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${u} ${_} ${l} ${d}`,h=this._convertColumnsToIndexes(E,s);f=await sr.promise(h,t),t=null}catch(E){throw fe.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),fe.error(E),new Error("There was a problem processing the data.")}if(f&&f.length>0){for(let E=0,h=f.length;E<h;E++){let p=f[E];o.forEach(S=>{p[S.key]!==null&&p[S.key]!==void 0&&S.keys.add(p[S.key])})}o.forEach(E=>{let h=Object.keys(this.data[`${E.schema}_${E.table}`].__merged_data),p=Yc.difference(h,[...E.keys].map(S=>S.toString()));for(let S=0,T=p.length;S<T;S++){let A=p[S];delete this.data[`${E.schema}_${E.table}`].__merged_data[A]}})}return{existing_attributes:c,joined_length:f?f.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new $_(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=Yc.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(In)}}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 Xo.getDataByHash(c),_=s.columns.length;for(let l=0,d=o.length;l<d;l++){let f=o[l],E=u.get(f);for(let h=0;h<_;h++){let p=s.columns[h],S=E[p]===void 0?null:E[p];this.data[n].__merged_data[f].push(S)}}}}catch(r){throw 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 sr.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(l2.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 Xo.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(In)}}return Object.values(Object.values(this.data)[0].__merged_data)}};dC.exports=xp});var Xr=g((Ble,EC)=>{"use strict";var d2=XO();EC.exports={searchByConditions:E2,searchByHash:h2,searchByValue:m2,search:p2};var Fp=Rn(),{transformReq:qp}=J(),f2=fC();async function E2(e){return qp(e),Fp.searchByConditions(e)}a(E2,"searchByConditions");async function h2(e){qp(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of Fp.searchByHash(e))r&&t.push(r);return t}a(h2,"searchByHash");async function m2(e){qp(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of Fp.searchByValue(e))t.push(r);return t}a(m2,"searchByValue");function p2(e,t){try{let r=new d2(e);r.validate(),new f2(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(p2,"search")});var Y_=g((xle,hC)=>{"use strict";var S2=Rn();hC.exports={writeTransaction:T2};function T2(e,t,r){return S2.writeTransaction(e,t,r)}a(T2,"writeTransaction")});var TC=g((Gle,SC)=>{"use strict";var g2=Xr(),R2=Ws(),mC=Y(),A2=jr(),qle=Y_(),O2=require("clone"),kp=require("alasql"),b2=V_(),pC=require("util"),N2=pC.promisify(R2.getTableSchema),y2=pC.promisify(g2.search),w2=M(),Gp=J();b2(kp);SC.exports={update:C2};var I2="There was a problem performing this update. Please check the logs and try again.";async function C2({statement:e,hdb_user:t}){let r=await N2(e.table.databaseid,e.table.tableid),n=D2(e.columns);Gp.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=O2(s),c=Gp.isEmpty(i)?"":` WHERE ${i.toString()}`,u=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,_=kp.parse(u).statements[0],l=await y2(_),d=L2(n,l);return M2(o,d,t)}a(C2,"update");function D2(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=kp.compile(`SELECT ${r.expression.toString()} AS [${w2.FUNC_VAL}] FROM ?`)}),t}catch(t){throw mC.error(t),new Error(I2)}}a(D2,"createUpdateRecord");function L2(e,t){return Gp.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(L2,"buildUpdateRecords");async function M2(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await A2.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){mC.error(`Error delete new_attributes from update response: ${i}`)}return s}a(M2,"updateRecords")});var RC=g((Yle,gC)=>{var U2=require("alasql"),P2=Xr(),v2=Y(),B2=Rn(),$p=require("util"),Vp=J(),H2=M(),x2=Ws(),Vle=Y_(),$le=jr(),F2="record",q2="successfully deleted",G2=$p.callbackify(Y2),k2=$p.promisify(P2.search),V2=$p.promisify(x2.getTableSchema);gC.exports={convertDelete:G2};function $2(e){return`${e.deleted_hashes.length} ${F2}${e.deleted_hashes.length===1?"":"s"} ${q2}`}a($2,"generateReturnMessage");async function Y2({statement:e,hdb_user:t}){let r=await V2(e.table.databaseid,e.table.tableid);Vp.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=Vp.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=U2.parse(o).statements[0],u={operation:H2.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{u.records=await k2(c);let _=await B2.deleteRecords(u);return Vp.isEmptyOrZeroLength(_.message)&&(_.message=$2(_)),delete _.txn_time,_}catch(_){throw v2.error(_),_.hdb_code?_.message:_}}a(Y2,"convertDelete")});var yC=g((Wle,NC)=>{"use strict";var K2=Li(),{hdb_errors:AC}=ee(),{getDatabases:OC}=(be(),te(Fe));NC.exports={checkSchemaExists:bC,checkSchemaTableExists:W2,schema_describe:K2};async function bC(e){if(!OC()[e])return AC.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(bC,"checkSchemaExists");async function W2(e,t){let r=await bC(e);if(r)return r;if(!OC()[e][t])return AC.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(W2,"checkSchemaTableExists")});var Kc=g((zle,Q2)=>{Q2.exports={name:"harperdb",version:"4.3.0-beta.2",description:"HarperDB is a distributed SQL & NoSQL data platform focused on speed, flexibility, and ease of use.",keywords:["database","sql","nosql","api","distributed","cloud","enterprise","Fastify","NATS"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.1","nats-server":"2.10.1"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive",build:"eslint -c ./.eslintbuild bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",pretty:"eslint --fix bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test"},dependencies:{"@aws-sdk/abort-controller":"3.374.0","@aws-sdk/client-s3":"3.477.0","@aws-sdk/lib-storage":"3.477.0","@endo/static-module-record":"^1.0.0","@fastify/autoload":"5.7.1","@fastify/compress":"~6.5.0","@fastify/cors":"~8.5.0","@fastify/static":"~6.11.2","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.5.4",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.1",fastify:"~4.25.1","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.8.1","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.11.0","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.6",jsonwebtoken:"9.0.2",lmdb:"2.9.3-beta.5-debug",lodash:"4.17.21",mathjs:"11.11.2",minimist:"1.2.8",mkcert:"1.5.1",moment:"2.29.4","mqtt-packet":"~8.2.1",msgpackr:"1.10.1",nats:"2.17.0",needle:"3.2.0","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.1",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.3.0",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^0.18.0","serve-static":"1.15.0",ses:"1.0.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.21.20","tar-fs":"2.1.1",ulidx:"0.5.0",uuid:"9.0.1","validate.js":"0.13.1",ws:"8.15.1",yaml:"2.3.4"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"latest","@typescript-eslint/eslint-plugin":"^5.55.0","@typescript-eslint/parser":"^5.55.0",axios:"1.6.2",chai:"4.3.7","chai-integer":"0.1.0",esbuild:"^0.19.1",eslint:"8.22.0","eslint-config-prettier":"8.3.0","eslint-plugin-prettier":"3.4.1","eslint-plugin-radar":"0.2.1",eventsource:"^2.0.2","hook-std":"3.0.0","intercept-stdout":"0.1.2",mocha:"^10.2.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.7",newman:"5.3.2","newman-reporter-html":"1.0.5","newman-reporter-htmlextra":"^1.22.11","newman-reporter-teamcity":"^0.1.12","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"2.8.4",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.3.3","why-is-node-still-running":"^1.0.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},"newman-reporter-html":{newman:"5.3.2"},alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","utf-8-validate":"^5.0.10"}}});var Jc={};Ve(Jc,{addAnalyticsListener:()=>zc,recordAction:()=>vr,recordActionBinary:()=>en,setAnalyticsEnabled:()=>z2});function z2(e){BC=e}function vr(e,t,r,n,s){if(!BC)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=Q_.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},Q_.set(i,o)}K_||J2()}function en(e,t,r,n,s){vr(!!e,t,r,n,s)}function zc(e){FC.push(e)}function J2(){K_=performance.now(),setTimeout(async()=>{let e=performance.now()-K_;K_=0;let t=[],r={time:Date.now(),period:e,threadId:Qi.threadId,metrics:t};for(let[s,i]of Q_){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 qC){let f=Math.floor(c*d),E=o[f-1];if(f>u){let h=f-u;if(E===l){let p=_[_.length-1];typeof p=="number"?_[_.length-1]={value:p,count:1+h}:p.count+=h}else _.push(h>1?{value:E,count:h}:E),l=E;u=f}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:_,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await GC()}let n=process.memoryUsage();t.push({metric:"memory",threadId:Qi.threadId,byThread:!0,...n});for(let s of FC)s(t);Q_=new Map,Qi.parentPort?Qi.parentPort.postMessage({type:xC,report:r}):$C({report:r})},HC).unref()}async function X2(e,t=6e4){let r=Wp(),n=kC(),s;for(let h of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(h.value?.time){s=h.value.time;break}if(Date.now()-t<s)return;let i,o=new Map,c=new Map,u=[],_;for(let{key:h,value:p}of r.primaryStore.getRange({start:s||!1,exclusiveStart:!0,end:1/0})){if(!p)continue;if(i){if(h>i+t)break}else i=h;_=h;let{metrics:S,threadId:T}=p;for(let A of S||[]){let{path:b,method:H,type:F,metric:v,count:P,total:z,distribution:W,threads:Q,...se}=A;P||(P=1);let pe=v+(b?"-"+b:"");H!==void 0&&(pe+="-"+H),F!==void 0&&(pe+="-"+F);let oe=o.get(pe);if(oe){if(oe.threads){let le=oe.threads[T];if(le)oe=le;else{oe.threads[T]=Object.assign({},se);continue}}oe.count||(oe.count=1);let xe=oe.count;for(let le in se){let wt=se[le];typeof wt=="number"&&(oe[le]=(oe[le]*xe+wt*P)/(xe+P))}oe.count+=P,z>=0&&(oe.total+=z,oe.ratio=oe.total/oe.count)}else oe=Object.assign({period:t},A),delete oe.distribution,o.set(pe,oe),oe.byThread&&(oe.threads=[],oe.threads[T]=Object.assign({},se),u.push(oe));if(W){W=W.map(le=>typeof le=="number"?{value:le,count:1}:le);let xe=c.get(pe);xe?xe.push(...W):c.set(pe,W)}}await GC()}for(let h of u){let{path:p,method:S,type:T,metric:A,count:b,total:H,distribution:F,threads:v,...P}=h;v=v.filter(z=>z);for(let z in P){if(typeof h[z]!="number")continue;let W=0;for(let Q of v){let se=Q[z];typeof se=="number"&&(W+=se)}h[z]=W}h.count=v.length,delete h.threads,delete h.byThread}for(let[h,p]of c){let S=o.get(h);p.sort((le,wt)=>le.value>wt.value?1:-1);let T=S.count-1,A=[],b=0,H=0,F;for(let le of qC){let wt=T*le;for(;b<wt;)F=p[H++],b+=F.count,H===1&&b--;let Ol=p[H>1?H-2:0];F||(F=p[0]),A.push(F.value-(F.value-Ol.value)*(b-wt)/F.count)}let[v,P,z,W,Q,se,pe,oe,xe]=A;Object.assign(S,{p1:v,p10:P,p25:z,median:W,p75:Q,p90:se,p95:pe,p99:oe,p999:xe})}let l;for(let[h,p]of o)p.id=(0,W_.getNextMonotonicTime)(),p.time=_,n.primaryStore.put(p.id,p,{append:!0}).then(S=>{S||n.primaryStore.put(p.id,p)}),l=!0;let d=Date.now(),{idle:f,active:E}=performance.eventLoopUtilization();if(l||E*10>f){let h=(0,W_.getNextMonotonicTime)(),p={id:h,metric:"main-thread-utilization",idle:f-wC,active:E-IC,time:d,...process.memoryUsage()};n.primaryStore.put(h,p,{append:!0}).then(S=>{S||n.primaryStore.put(h,p)})}wC=f,IC=E}async function CC(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function Wp(){return DC||(DC=ot({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function kC(){return LC||(LC=ot({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function e4(){VC=!0;let e=(0,Qc.get)(Kp.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await X2(HC,e),await CC(Wp(),j2),await CC(kC(),Z2)},Math.min(e/2,2147483647)).unref()}function $C(e,t){let r=e.report;r.threadId=t?.threadId||Qi.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(MC+=n.mean*n.count);r.totalBytesProcessed=MC,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(UC.get(t))}),UC.set(t,t.performance.eventLoopUtilization())),r.id=(0,W_.getNextMonotonicTime)(),Wp().primaryStore.put(r.id,r),VC||e4(),t4&&(YC=n4(r))}async function n4(e){if(await YC,!ei){let r=(0,Wc.dirname)((0,vC.getLogFilePath)());try{ei=await(0,Yp.open)((0,Wc.join)(r,"analytics.log"),"r+")}catch{ei=await(0,Yp.open)((0,Wc.join)(r,"analytics.log"),"w+")}}let t=(await ei.stat()).size;if(t>r4){let r=Buffer.alloc(t);await ei.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await ei.write(r,{position:0}),await ei.truncate(r.length),t=r.length}await ei.write(JSON.stringify(e)+`
|
|
8
|
-
`,t)}var
|
|
6
|
+
`)},N1="certificate.pem",y1="privateKey.pem",w1="ca.pem";xN.exports={CERTIFICATE_VALUES:b1,CERTIFICATE_PEM_NAME:N1,PRIVATEKEY_PEM_NAME:y1,CA_PEM_NAME:w1}});var Nm=T((xae,$N)=>{"use strict";var VN=require("fs-extra"),ue=require("joi"),I1=require("os"),{boolean:De,string:Ir,number:Dt,array:bm}=ue.types(),{totalmem:qN}=require("os"),Fi=require("path"),C1=W(),p_=J(),Hae=FN(),GN=U(),D1=et(),kN="log",L1="components",M1="Invalid logging.rotation.maxSize unit. Available units are G, M or K",U1="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",P1="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",v1="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",B1="rootPath config parameter is undefined",H1="clustering.enabled config parameter is undefined",qi=Dt.min(0).required(),S_=bm.items({host:Ir.required(),port:qi}).empty(null),Yn;$N.exports={configValidator:x1,routesValidator:$1,route_constraints:S_};function x1(e){if(Yn=e.rootPath,p_.isEmpty(Yn))throw B1;let t=De.required(),r=Dt.min(0).max(1e3).empty(null).default(V1),n=Ir.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(Cc),s=Ir.optional().empty(null),i=Ir.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),o=ue.string().empty(null).default(Cc),c=ue.custom(q1).empty(null).default(Cc),u=e.clustering?.enabled;if(p_.isEmpty(u))throw H1;let _;return u===!0?_=ue.object({enabled:t,hubServer:ue.object({cluster:ue.object({name:ue.required().empty(null),network:ue.object({port:qi,routes:S_}).required()}).required(),leafNodes:ue.object({network:ue.object({port:qi}).required()}).required(),network:ue.object({port:qi}).required()}).required(),leafServer:ue.object({network:ue.object({port:qi,routes:S_}).required(),streams:ue.object({maxAge:Dt.min(120).allow(null).optional(),maxBytes:Dt.min(1).allow(null).optional(),maxMsgs:Dt.min(1).allow(null).optional(),path:o}).required()}).required(),logLevel:ue.valid("error","warn","info","debug","trace"),nodeName:i,republishMessages:De.optional(),databaseLevel:De.optional(),tls:ue.object({certificate:s,certificateAuthority:s,privateKey:s,insecure:De.required(),verify:De.optional()}),user:Ir.optional().empty(null)}).required():_=ue.object({enabled:t,tls:ue.object({certificate:s,certificateAuthority:s,privateKey:s,insecure:De.required()})}).required(),ue.object({authentication:ue.object({authorizeLocal:De,cacheTTL:Dt.required(),enableSessions:De}),analytics:ue.object({aggregatePeriod:Dt}),componentsRoot:n.optional(),clustering:_,localStudio:ue.object({enabled:t}).required(),logging:ue.object({auditAuthEvents:ue.object({logFailed:De,logSuccessful:De}),file:De.required(),level:ue.valid("notify","fatal","error","warn","info","debug","trace"),rotation:ue.object({enabled:De.optional(),compress:De.optional(),interval:Ir.custom(k1).optional().empty(null),maxSize:Ir.custom(G1).optional().empty(null),path:Ir.optional().empty(null).default(Cc)}).required(),root:n,stdStreams:De.required(),auditLog:De.required()}).required(),operationsApi:ue.object({network:ue.object({cors:De.optional(),corsAccessList:bm.optional(),headersTimeout:Dt.min(1).optional(),keepAliveTimeout:Dt.min(1).optional(),port:Dt.optional().empty(null),domainSocket:ue.optional().empty("hdb/operations-server").default(Cc),securePort:Dt.optional().empty(null),timeout:Dt.min(1).optional()}).optional(),tls:ue.object({certificate:s,certificateAuthority:s,privateKey:s})}).required(),rootPath:Ir.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:ue.object({network:ue.object({port:qi,securePort:qi,mtls:ue.alternatives([De.optional(),ue.object({user:Ir.optional(),certificateAuthority:s,required:De.optional()})])}).required(),webSocket:De.optional(),requireAuthentication:De.optional()}),http:ue.object({compressionThreshold:Dt.optional(),cors:De.optional(),corsAccessList:bm.optional(),headersTimeout:Dt.min(1).optional(),port:Dt.min(0).optional().empty(null),securePort:Dt.min(0).optional().empty(null),mtls:ue.alternatives([De.optional(),ue.object({user:Ir.optional(),certificateAuthority:s,required:De.optional()})])}).required(),threads:r.optional(),maxHeapMemory:Dt.min(0).optional(),storage:ue.object({writeAsync:De.required(),overlappingSync:De.optional(),caching:De.optional(),compression:De.optional(),noReadAhead:De.optional(),path:c,prefetchWrites:De.optional()}).required(),ignoreScripts:De.optional(),tls:ue.object({certificate:s.optional(),certificateAuthority:s.optional(),privateKey:s.optional(),ciphers:Ir.optional()})}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(x1,"configValidator");function F1(e){return VN.existsSync(e)?null:`Specified path ${e} does not exist.`}a(F1,"doesPathExist");function q1(e,t){ue.assert(e,Ir.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=F1(e);if(r)return t.message(r)}a(q1,"validatePath");function G1(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(M1);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(P1):e}a(G1,"validateRotationMaxSize");function k1(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(U1);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(v1):e}a(k1,"validateRotationInterval");function V1(e,t){let r=t.state.path.join("."),n=I1.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||qN();return i=Math.round(Math.min(i,qN())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),C1.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(V1,"setDefaultThreads");function Cc(e,t){let r=t.state.path.join(".");if(!p_.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(p_.isEmpty(Yn))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Fi.join(Yn,L1);case"logging.root":return Fi.join(Yn,kN);case"clustering.leafServer.streams.path":return Fi.join(Yn,"clustering","leaf");case"storage.path":let n=Fi.join(Yn,GN.LEGACY_DATABASES_DIR_NAME);return VN.existsSync(n)?n:Fi.join(Yn,GN.DATABASES_DIR_NAME);case"logging.rotation.path":return Fi.join(Yn,kN);case"operationsApi.network.domainSocket":return r==null?null:Fi.join(Yn,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Cc,"setDefaultRoot");function $1(e){let t=ue.object({routes:S_});return D1.validateBySchema({routes:e},t)}a($1,"routesValidator")});var Lr=T((Gae,ZN)=>{"use strict";var Dr=U(),Lt=J(),gt=W(),{configValidator:Y1,routesValidator:YN}=Nm(),tr=require("fs-extra"),K1=require("yaml"),bn=require("path"),W1=require("is-number"),WN=require("properties-reader"),Q1=require("lodash"),{handleHDBError:z1}=ee(),{HTTP_STATUS_CODES:J1,HDB_ERROR_MSGS:T_}=br(),qae=require("minimist"),{server:X1}=(jt(),te(yi)),{DATABASES_PARAM_CONFIG:Dc,CONFIG_PARAMS:Cr,CONFIG_PARAM_MAP:Nn}=Dr,j1="Unable to get config value because config is uninitialized",Z1="Config successfully initialized",eY="Error backing up config file",tY="Empty parameter sent to getConfigValue",QN=bn.join(Dr.PACKAGE_ROOT,"config","yaml",Dr.HDB_DEFAULT_CONFIG_FILE),rY="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",KN={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"},g_,Rt,R_;ZN.exports={createConfigFile:nY,getDefaultConfig:sY,getConfigValue:JN,initConfig:wm,flattenConfig:qo,updateConfigValue:XN,updateConfigObject:oY,getConfiguration:uY,setConfiguration:lY,readConfigFile:Cm,getClusteringRoutes:_Y,initOldConfig:jN,getConfigFromFile:dY,getConfigFilePath:Gi,addConfig:fY,deleteConfigFromFile:EY,getConfigObj:hY};function nY(e){let t=js(QN);g_=qo(t.toJSON());let r;for(let o in e){let c=Nn[o.toLowerCase()];if(c===Cr.DATABASES){r=e[o];continue}if(!c&&o.endsWith("_package")&&(c=o),c!==void 0){let u=c.split("_"),_=ym(c,e[o]);c==="rootPath"&&_?.endsWith("/")&&(_=_.slice(0,-1));try{t.setIn([...u],_)}catch(l){gt.error(l)}}}r&&zN(t,r),Im(t);let n=t.toJSON();Rt=qo(n);let s=t.getIn(["rootPath"]),i=bn.join(s,Dr.HDB_CONFIG_FILE);tr.createFileSync(i),tr.writeFileSync(i,String(t)),gt.trace(`Config file written to ${i}`)}a(nY,"createConfigFile");function zN(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Lt.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(Dc.TABLES))for(let i in n[s][Dc.TABLES])for(let o in n[s][Dc.TABLES][i]){let c=n[s][Dc.TABLES][i][o],u=[Cr.DATABASES,s,Dc.TABLES,i,o];e.hasIn(u)?e.setIn(u,c):e.addIn(u,c)}else for(let i in n[s]){let o=n[s][i],c=[Cr.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){gt.error("Error parsing schemas CLI/env config arguments",n)}}a(zN,"setSchemasConfig");function sY(e){if(g_===void 0){let r=js(QN);g_=qo(r.toJSON())}let t=Nn[e.toLowerCase()];if(t!==void 0)return g_[t.toLowerCase()]}a(sY,"getDefaultConfig");function JN(e){if(e==null){gt.error(tY);return}if(Rt===void 0){gt.trace(j1);return}let t=Nn[e.toLowerCase()];if(t!==void 0)return Rt[t.toLowerCase()]}a(JN,"getConfigValue");function Gi(e=Lt.getPropsFilePath()){let t=Lt.getEnvCliRootPath();return t?bn.join(t,Dr.HDB_CONFIG_FILE):WN(e).get(Dr.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY)}a(Gi,"getConfigFilePath");function wm(e=!1){if(Rt===void 0||e){let t;if(!Lt.noBootFile()){t=Lt.getPropsFilePath();try{tr.accessSync(t,tr.constants.F_OK|tr.constants.R_OK)}catch(i){throw gt.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Gi(t),n;if(r.includes("config/settings.js"))try{jN(r);return}catch(i){if(i.code!==Dr.NODE_ERROR_CODES.ENOENT)throw i}try{n=js(r)}catch(i){if(i.code===Dr.NODE_ERROR_CODES.ENOENT){gt.trace(`HarperDB config file not found at ${r}.
|
|
7
|
+
This can occur during early stages of install where the config file has not yet been created`);return}else throw gt.error(i),new Error(`Error reading HarperDB config file at ${r}`)}iY(n,r),Im(n);let s=n.toJSON();if(X1.config=s,Rt=qo(s),Rt.logging_rotation_rotate)for(let i in KN)Rt[i]&>.error(`Config ${KN[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);gt.trace(Z1)}}a(wm,"initConfig");function iY(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],bn.join(r,"database")),n=!0),e.hasIn(["clustering","leafServer","streams","path"])||(e.setIn(["clustering","leafServer","streams","path"],bn.join(r,"clustering","leaf")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],bn.join(r,"log")),n=!0),e.hasIn(["clustering","tls","verify"])||(e.setIn(["clustering","tls","verify"],!0),n=!0),n&&(gt.trace("Updating config file with missing config params"),tr.writeFileSync(t,String(e)))}a(iY,"checkForUpdatedConfig");function Im(e){let t=e.toJSON();t.componentsRoot=t.componentsRoot??t?.customFunctions?.root,t.threads=t.threads??t?.http?.threads;let r=Y1(t);if(r.error)throw T_.CONFIG_VALIDATION(r.error.message);e.setIn(["threads"],r.value.threads),e.setIn(["componentsRoot"],r.value.componentsRoot),e.setIn(["logging","root"],r.value.logging.root),e.setIn(["storage","path"],r.value.storage.path),e.setIn(["logging","rotation","path"],r.value.logging.rotation.path),e.setIn(["clustering","leafServer","streams","path"],r.value.clustering.leafServer.streams?.path),e.setIn(["operationsApi","network","domainSocket"],r.value?.operationsApi?.network?.domainSocket)}a(Im,"validateConfig");function oY(e,t){Rt===void 0&&(Rt={});let r=Nn[e.toLowerCase()];if(r===void 0){gt.trace(`Unable to update config object because config param '${e}' does not exist`);return}Rt[r.toLowerCase()]=t}a(oY,"updateConfigObject");function XN(e,t,r=void 0,n=!1,s=!1,i=!1){Rt===void 0&&wm();let o=JN(Nn.hdb_root),c=bn.join(o,Dr.HDB_CONFIG_FILE),u=js(c),_;if(r===void 0&&e.toLowerCase()===Cr.DATABASES)_=t;else if(r===void 0){let f;if(i)f=e;else if(f=Nn[e.toLowerCase()],f===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let E=f.split("_"),h=ym(f,t);u.setIn([...E],h)}else for(let f in r){let E=Nn[f.toLowerCase()];if(E===Cr.HTTP_SECUREPORT&&r[f]===Rt[Cr.HTTP_PORT]?.toString()&&u.setIn(["http","port"],null),E===Cr.OPERATIONSAPI_NETWORK_SECUREPORT&&r[f]===Rt[Cr.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&u.setIn(["operationsApi","network","port"],null),E===Cr.DATABASES){_=r[f];continue}if(!E&&f.endsWith("_package")&&(E=f),E!==void 0){let h=E.split("_"),p=Dr.LEGACY_CONFIG_PARAMS[f.toUpperCase()];p&&p.startsWith("customFunctions")&&u.hasIn(p.split("_"))&&(E=p,h=p.split("_"));let S=ym(E,r[f]);E==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof u.getIn(h.slice(0,-1))=="boolean"&&u.deleteIn(h.slice(0,-1)),u.setIn([...h],S)}catch(O){gt.error(O)}}}_&&zN(u,_),Im(u);let l=u.getIn(["rootPath"]),d=bn.join(l,Dr.HDB_CONFIG_FILE);n===!0&&aY(c,l),tr.writeFileSync(d,String(u)),s&&(Rt=qo(u.toJSON())),gt.trace(`Config parameter: ${e} updated with value: ${t}`)}a(XN,"updateConfigValue");function aY(e,t){try{let r=bn.join(t,"backup",`${Dr.HDB_CONFIG_FILE}.bak`);tr.copySync(e,r),gt.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){gt.error(eY),gt.error(r)}}a(aY,"backupConfigFile");var cY=["databases"];function qo(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)),R_=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])&&!cY.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let u=i+"_"+c;!Cr[u.toUpperCase()]&&Nn[u]&&(s[Nn[u].toLowerCase()]=o[c]),s[u]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(qo,"flattenConfig");function ym(e,t){if(e===Cr.CLUSTERING_NODENAME||e===Cr.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(W1(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Lt.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return Lt.autoCast(t)}a(ym,"castConfigValue");function uY(){let e=Lt.getPropsFilePath(),t=Gi(e);return js(t).toJSON()}a(uY,"getConfiguration");async function lY(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return XN(void 0,void 0,s,!0),rY}catch(i){throw typeof i=="string"||i instanceof String?z1(i,i,J1.BAD_REQUEST,void 0,void 0,!0):i}}a(lY,"setConfiguration");function Cm(){let e=Lt.getPropsFilePath();try{tr.accessSync(e,tr.constants.F_OK|tr.constants.R_OK)}catch(n){if(!Lt.noBootFile())throw gt.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Gi(e);return js(t).toJSON()}a(Cm,"readConfigFile");function js(e){return K1.parseDocument(tr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(js,"parseYamlDoc");function _Y(){let e=Cm(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Lt.isEmptyOrZeroLength(t)?[]:t;let r=YN(t);if(r)throw T_.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Lt.isEmptyOrZeroLength(n)?[]:n;let s=YN(n);if(s)throw T_.CONFIG_VALIDATION(s.message);if(!Lt.isEmptyOrZeroLength(n)&&!Lt.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Lt.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw T_.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(_Y,"getClusteringRoutes");function jN(e){let t=WN(e);Rt={};for(let r in Nn){let n=t.get(r.toUpperCase());if(Lt.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=Nn[r].toLowerCase();s===Cr.LOGGING_ROOT?Rt[s]=bn.dirname(n):Rt[s]=n}return Rt}a(jN,"initOldConfig");function dY(e){let t=Cm();return Q1.get(t,e.replaceAll("_","."))}a(dY,"getConfigFromFile");async function fY(e,t){let r=js(Gi());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await tr.writeFile(Gi(),String(r))}a(fY,"addConfig");function EY(e){let t=Gi(Lt.getPropsFilePath()),r=js(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=bn.join(n,Dr.HDB_CONFIG_FILE);tr.writeFileSync(s,String(r))}a(EY,"deleteConfigFromFile");function hY(){return R_||(wm(),R_)}a(hY,"getConfigObj")});var ty=T((Vae,ey)=>{"use strict";var A_=U(),O_=class{static{a(this,"BaseLicense")}constructor(t=0,r=A_.RAM_ALLOCATION_ENUM.DEFAULT,n=A_.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},Dm=class extends O_{static{a(this,"ExtendedLicense")}constructor(t=0,r=A_.RAM_ALLOCATION_ENUM.DEFAULT,n=A_.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};ey.exports={BaseLicense:O_,ExtendedLicense:Dm}});var ki=T((Yae,ay)=>{"use strict";var ko=require("fs-extra"),ny=m_(),sy=require("crypto"),mY=require("moment"),pY=require("uuid").v4,$t=W(),Mm=require("path"),SY=J(),Zs=U(),{totalmem:ry}=require("os"),TY=ty().ExtendedLicense,Go="invalid license key format",gY="061183",RY="mofi25",AY="aes-256-cbc",OY=16,bY=32,iy=Z();iy.initSync();var Lm;ay.exports={validateLicense:oy,generateFingerPrint:yY,licenseSearch:vm,getLicense:CY,checkMemoryLimit:DY};function Um(){return Mm.join(iy.getHdbBasePath(),Zs.LICENSE_KEY_DIR_NAME,Zs.LICENSE_FILE_NAME)}a(Um,"getLicenseDirPath");function NY(){let e=Um();return Mm.join(e,Zs.LICENSE_FILE_NAME)}a(NY,"getLicenseFilePath");function Pm(){let e=Um();return Mm.join(e,Zs.REG_KEY_FILE_NAME)}a(Pm,"getFingerPrintFilePath");async function yY(){let e=Pm();try{return await ko.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await wY();throw $t.error(`Error writing fingerprint file to ${e}`),$t.error(t),new Error("There was an error generating the fingerprint")}}a(yY,"generateFingerPrint");async function wY(){let e=pY(),t=ny.hash(e),r=Pm();try{await ko.mkdirp(Um()),await ko.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw $t.error(`Error writing fingerprint file to ${r}`),$t.error(n),new Error("There was an error generating the fingerprint")}return t}a(wY,"writeFingerprint");function oy(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:Zs.RAM_ALLOCATION_ENUM.DEFAULT,version:Zs.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return $t.error("empty license key passed to validate."),r;let n=Pm(),s=!1;try{s=ko.statSync(n)}catch(i){$t.error(i)}if(s){let i;try{i=ko.readFileSync(n,"utf8")}catch{$t.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(RY),c=o[1];c=Buffer.concat([Buffer.from(c)],OY);let u=Buffer.concat([Buffer.from(i)],bY),_=sy.createDecipheriv(AY,u,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let l=null;try{l=_.update(o[0],"hex","utf8"),l.trim(),l+=_.final("utf8")}catch{let E=IY(o[0],i);if(E)l=E;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Go),$t.error(Go),new Error(Go)}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(Go),$t.error(Go),new Error(Go)}else r.exp_date=l;r.exp_date<mY().valueOf()&&(r.valid_date=!1),ny.validate(o[1],`${gY}${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||$t.error("Invalid licence"),r}a(oy,"validateLicense");function IY(e,t){try{let r=sy.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{$t.warn("Check old license failed")}}a(IY,"checkOldLicense");function vm(){let e=new TY,t=[];try{t=ko.readFileSync(NY(),"utf-8").split(Zs.NEW_LINE)}catch(r){r.code==="ENOENT"?$t.info("no license file found"):$t.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(SY.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=oy(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){$t.error("There was an error parsing the license string."),$t.error(s),e.ram_allocation=Zs.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return Lm=e,e}a(vm,"licenseSearch");async function CY(){return Lm||await vm(),Lm}a(CY,"getLicense");function DY(){let e=vm().ram_allocation,t=process.constrainedMemory?.()||ry();if(t=Math.round(Math.min(t,ry())/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(DY,"checkMemoryLimit")});var en=T((Jae,Oy)=>{"use strict";var _y="username is required",dy="nothing to update, must supply active, role or password to update",fy="password cannot be an empty string",Ey="If role is specified, it cannot be empty.",hy="active must be true or false";Oy.exports={addUser:FY,alterUser:qY,dropUser:kY,getSuperUser:KY,userInfo:VY,listUsers:N_,listUsersExternal:$Y,setUsersToGlobal:$o,findAndValidateUser:Ry,getClusterUser:WY,USERNAME_REQUIRED:_y,ALTERUSER_NOTHING_TO_UPDATE:dy,EMPTY_PASSWORD:fy,EMPTY_ROLE:Ey,ACTIVE_BOOLEAN:hy};var my=Zr(),LY=xi(),xm=m_(),py=vN(),Sy=jr(),Fm=ps(),Mr=J(),Ty=require("validate.js"),Ae=W(),{promisify:MY}=require("util"),qm=ms(),cy=U(),uy=tt(),UY=Lr(),Wae=Z(),Qae=ki(),PY=Li(),{table:zae}=(be(),te(Fe)),{handleHDBError:Kn,hdb_errors:vY}=ee(),{HTTP_STATUS_CODES:Wn,AUTHENTICATION_ERROR_MSGS:Bm,HDB_ERROR_MSGS:Vo}=vY,{UserEventMsg:Gm}=yn(),Hm=require("lodash"),{server:km}=(jt(),te(yi)),BY=W();km.getUser=(e,t)=>Ry(e,t,t!=null);var gy={username:!0,active:!0,role:!0,password:!0},ly=new Map,b_=Sy.searchByValue,HY=Sy.searchByHash,xY=MY(LY.delete);async function FY(e){let t=Ty.cleanAttributes(e,gy),r=py.addUserValidation(t);if(r)throw Kn(new Error,r.message,Wn.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 b_(n),s=s&&Array.from(s)}catch(u){throw Ae.error("There was an error searching for a role in add user"),Ae.error(u),u}if(!s||s.length<1)throw Kn(new Error,Vo.ROLE_NAME_NOT_FOUND(t.role),Wn.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Kn(new Error,Vo.DUP_ROLES_FOUND(t.role),Wn.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=qm.encrypt(t.password)),t.password=xm.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await my.insert(i)}catch(u){throw Ae.error("There was an error searching for a user."),Ae.error(u),u}Ae.debug(o);try{await $o()}catch(u){throw Ae.error("Got an error setting users to global"),Ae.error(u),u}if(o.skipped_hashes.length===1)throw Kn(new Error,Vo.USER_ALREADY_EXISTS(t.username),Wn.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],Fm.signalUserChange(new Gm(process.pid)),`${c.username} successfully added`}a(FY,"addUser");async function qY(e){let t=Ty.cleanAttributes(e,gy);if(Mr.isEmptyOrZeroLength(t.username))throw new Error(_y);if(Mr.isEmptyOrZeroLength(t.password)&&Mr.isEmptyOrZeroLength(t.role)&&Mr.isEmptyOrZeroLength(t.active))throw new Error(dy);if(!Mr.isEmpty(t.password)&&Mr.isEmptyOrZeroLength(t.password.trim()))throw new Error(fy);if(!Mr.isEmpty(t.active)&&!Mr.isBoolean(t.active))throw new Error(hy);let r=GY(t.username);if(!Mr.isEmpty(t.password)&&!Mr.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=qm.encrypt(t.password)),t.password=xm.hash(t.password)),t.role==="")throw new Error(Ey);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 b_(i)||[])}catch(c){throw Ae.error("Got an error searching for a role."),Ae.error(c),c}if(!o||o.length===0){let c=Vo.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Ae.error(c),Kn(new Error,c,Wn.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Vo.ALTER_USER_DUP_ROLES(t.role);throw Ae.error(c),Kn(new Error,c,Wn.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 my.update(n)}catch(i){throw Ae.error("Error during update."),Ae.error(i),i}try{await $o()}catch(i){throw Ae.error("Got an error setting users to global"),Ae.error(i),i}return Fm.signalUserChange(new Gm(process.pid)),s}a(qY,"alterUser");function GY(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(GY,"isClusterUser");async function kY(e){try{let t=py.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Mr.isEmpty(global.hdb_users.get(e.username)))throw Kn(new Error,Vo.USER_NOT_EXIST(e.username),Wn.NOT_FOUND,void 0,void 0,!0);let n;try{n=await xY(r)}catch(s){throw Ae.error("Got an error deleting a user."),Ae.error(s),s}Ae.debug(n);try{await $o()}catch(s){throw Ae.error("Got an error setting users to global."),Ae.error(s),s}return Fm.signalUserChange(new Gm(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(kY,"dropUser");async function VY(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=Hm.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await HY(r)}catch(s){throw Ae.error("Got an error searching for a role."),Ae.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Ae.error(r),r}return t}a(VY,"userInfo");async function $Y(){let e;try{e=await N_()}catch(t){throw Ae.error("Got an error listing users."),Ae.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($Y,"listUsersExternal");async function N_(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await b_(e)}catch(o){throw Ae.error("Got an error searching for roles."),Ae.error(o),o}let r={};for(let o of t)r[o.id]=Hm.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 b_(n)}catch(o){throw Ae.error("Got an error searching for users."),Ae.error(o),o}let i=new Map;for(let o of s)o=Hm.cloneDeep(o),o.role=r[o.role],YY(o.role),i.set(o.username,o);return i}catch(e){throw Ae.error("got an error listing users"),Ae.error(e),Mr.errorizeMessage(e)}return null}a(N_,"listUsers");function YY(e){try{if(!e){Ae.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(PY)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Ae.error("Got an error trying to set system permissions."),Ae.error(t)}}a(YY,"appendSystemTablesToRole");async function $o(){try{let e=await N_();global.hdb_users=e}catch(e){throw Ae.error(e),e}}a($o,"setUsersToGlobal");async function Ry(e,t,r=!0){global.hdb_users||await $o();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Kn(new Error,Bm.GENERIC_AUTH_FAIL,Wn.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Kn(new Error,Bm.USER_INACTIVE,Wn.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(ly.get(t)===n.password)return s;if(xm.validate(n.password,t))ly.set(t,n.password);else throw Kn(new Error,Bm.GENERIC_AUTH_FAIL,Wn.UNAUTHORIZED,void 0,void 0,!0)}return s}a(Ry,"findAndValidateUser");async function KY(){global.hdb_users||await $o();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(KY,"getSuperUser");async function WY(){let e=await N_(),t=UY.getConfigFromFile(cy.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Mr.isEmpty(r)&&r?.role?.role===cy.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=qm.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+uy.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+uy.SERVER_SUFFIX.ADMIN,r}a(WY,"getClusterUser");var Ay=[];km.invalidateUser=function(e){for(let t of Ay)try{t(e)}catch(r){BY.error("Error invalidating user",r)}};km.onInvalidatedUser=function(e){Ay.push(e)}});var Mc=T((ece,wy)=>{"use strict";var Vi=W(),Ur=U(),QY=rN(),jae=zs(),Zae=Ui(),zY=en(),{validateEvent:by}=yn(),Lc=On(),JY=require("process"),{resetDatabases:XY}=(be(),te(Fe)),jY={[Ur.ITC_EVENT_TYPES.SCHEMA]:ZY,[Ur.ITC_EVENT_TYPES.USER]:yy};async function ZY(e){let t=by(e);if(t){Vi.error(t);return}Vi.trace("ITC schemaHandler received schema event:",e),await QY(e.message),await eK(e.message)}a(ZY,"schemaHandler");async function eK(e){try{Lc.resetReadTxn(Ur.SYSTEM_SCHEMA_NAME,Ur.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Lc.resetReadTxn(Ur.SYSTEM_SCHEMA_NAME,Ur.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Lc.resetReadTxn(Ur.SYSTEM_SCHEMA_NAME,Ur.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=XY();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Vi.error(t)}}a(eK,"syncSchemaMetadata");var Ny=[];async function yy(e){try{try{Lc.resetReadTxn(Ur.SYSTEM_SCHEMA_NAME,Ur.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Lc.resetReadTxn(Ur.SYSTEM_SCHEMA_NAME,Ur.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Vi.warn(r)}let t=by(e);if(t){Vi.error(t);return}Vi.trace(`ITC userHandler ${Ur.HDB_ITC_CLIENT_PREFIX}${JY.pid} received user event:`,e),await zY.setUsersToGlobal();for(let r of Ny)r()}catch(t){Vi.error(t)}}a(yy,"userHandler");yy.addListener=function(e){Ny.push(e)};wy.exports=jY});var yn=T((oce,Cy)=>{"use strict";var rce=W(),Vm=J(),tK=U(),{ITC_ERRORS:Uc}=br(),{parentPort:nce,threadId:rK,isMainThread:nK,workerData:sce}=require("worker_threads"),{onMessageFromWorkers:sK,broadcast:ice,broadcastWithAcknowledgement:iK}=je();Cy.exports={sendItcEvent:oK,validateEvent:Iy,SchemaEventMsg:aK,UserEventMsg:cK};var y_;sK(async(e,t)=>{y_=y_||Mc(),Iy(e),y_[e.type]&&await y_[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function oK(e){return!nK&&e.message&&(e.message.originator=rK),iK(e)}a(oK,"sendItcEvent");function Iy(e){if(typeof e!="object")return Uc.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||Vm.isEmpty(e.type))return Uc.MISSING_TYPE;if(!e.hasOwnProperty("message")||Vm.isEmpty(e.message))return Uc.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||Vm.isEmpty(e.message.originator))return Uc.MISSING_ORIGIN;if(tK.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Uc.INVALID_EVENT(e.type)}a(Iy,"validateEvent");function aK(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(aK,"SchemaEventMsg");function cK(e){this.originator=e}a(cK,"UserEventMsg")});var ps=T((uce,Uy)=>{"use strict";var Dy=U(),cce=J(),w_=W(),Ly=Zb(),Yo,{sendItcEvent:My}=yn();function uK(e){try{w_.trace("signalSchemaChange called with message:",e),Yo=Yo||Mc();let t=new Ly(Dy.ITC_EVENT_TYPES.SCHEMA,e);return Yo.schema(t),My(t)}catch(t){w_.error(t)}}a(uK,"signalSchemaChange");function lK(e){try{w_.trace("signalUserChange called with message:",e),Yo=Yo||Mc();let t=new Ly(Dy.ITC_EVENT_TYPES.USER,e);return Yo.user(t),My(t)}catch(t){w_.error(t)}}a(lK,"signalUserChange");Uy.exports={signalSchemaChange:uK,signalUserChange:lK}});var I_=T((_ce,vy)=>{"use strict";var Py=J(),_K=U(),dK=W(),fK=i_(),EK=s_(),hK=ps(),{SchemaEventMsg:mK}=yn(),pK="already exists in";vy.exports=SK;async function SK(e,t,r){if(Py.isEmptyOrZeroLength(r))return r;let n=[];Py.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 TK(e,t.schema,t.name,i)})),s}a(SK,"lmdbCheckForNewAttributes");async function TK(e,t,r,n){let s=new EK(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await gK(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(pK))dK.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(TK,"createNewAttribute");async function gK(e){let t;return t=await fK(e),hK.signalSchemaChange(new mK(process.pid,_K.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(gK,"createAttribute")});var Ko=T((fce,By)=>{"use strict";var $m=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}};By.exports=$m});var xy=T((hce,Hy)=>{"use strict";var RK=Ko(),AK=U().OPERATIONS_ENUM,Ym=class extends RK{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(AK.INSERT,r,n,s,i),this.records=t}};Hy.exports=Ym});var qy=T((pce,Fy)=>{"use strict";var OK=Ko(),bK=U().OPERATIONS_ENUM,Km=class extends OK{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(bK.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};Fy.exports=Km});var ky=T((Tce,Gy)=>{"use strict";var NK=Ko(),yK=U().OPERATIONS_ENUM,Wm=class extends NK{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(yK.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};Gy.exports=Wm});var $y=T((Rce,Vy)=>{"use strict";var wK=Ko(),IK=U().OPERATIONS_ENUM,Qm=class extends wK{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(IK.DELETE,n,s,t,i),this.original_records=r}};Vy.exports=Qm});var Pc=T((bce,Qy)=>{"use strict";var Oce=require("path"),Yy=Ve(),CK=xy(),DK=qy(),LK=ky(),MK=$y(),Wo=lt(),Ky=J(),{CONFIG_PARAMS:UK}=U(),Wy=Z();Wy.initSync();var C_=U().OPERATIONS_ENUM,{getTransactionAuditStorePath:PK}=Ye();Qy.exports=vK;async function vK(e,t){if(Wy.get(UK.LOGGING_AUDITLOG)===!1)return;let r=PK(e.schema,e.table),n=await Yy.openEnvironment(r,e.table,!0),s=BK(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){Yy.initializeDBIs(n,Wo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Wo.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Wo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Wo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),Ky.isEmpty(s.user_name)||n.dbis[Wo.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Wo.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(vK,"writeTransaction");function BK(e,t){let r=Ky.isEmpty(e.hdb_user)?void 0:e.hdb_user.username;if(e.operation===C_.INSERT)return new CK(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===C_.UPDATE)return new DK(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===C_.UPSERT)return new LK(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===C_.DELETE)return new MK(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(BK,"createTransactionObject")});var zm=T((wce,zy)=>{"use strict";var HK=Ac(),yce=Oc(),vc=U(),xK=wc(),FK=Ho().insertRecords,qK=Ve(),GK=W(),kK=I_(),{getSchemaPath:VK}=Ye(),$K=Pc();zy.exports=YK;async function YK(e){try{let{schema_table:t,attributes:r}=HK(e);xK(e,r,t.hash_attribute),e.schema!==vc.SYSTEM_SCHEMA_NAME&&(r.includes(vc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(vc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(vc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(vc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await kK(e.hdb_auth_header,t,r),s=VK(e.schema,e.table),i=await qK.openEnvironment(s,e.table),o=await FK(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await $K(e,o)}catch(c){GK.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(YK,"lmdbCreateRecords")});var jy=T((Cce,Xy)=>{"use strict";var Jy=U(),KK=zm(),WK=Oc(),QK=require("fs-extra"),{getSchemaPath:zK}=Ye();Xy.exports=JK;async function JK(e){let t=[{name:e.schema,createddate:Date.now()}],r=new WK(Jy.SYSTEM_SCHEMA_NAME,Jy.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await KK(r),await QK.mkdirp(zK(e.schema))}a(JK,"lmdbCreateSchema")});var ew=T((Lce,Zy)=>{"use strict";var Jm=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}};Zy.exports=Jm});var sw=T((Bce,nw)=>{"use strict";var tw=Ve(),Xm=Nr(),jm=br().LMDB_ERRORS_ENUM,XK=lt(),rw=W(),Uce=J(),jK=require("lmdb"),ZK=ew(),eW=U(),{OVERFLOW_MARKER:Pce,MAX_SEARCH_KEY_LENGTH:vce}=XK,tW=eW.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function rW(e,t,r,n){if(Xm.validateEnv(e),t===void 0)throw new Error(jm.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(jm.IDS_REQUIRED):new Error(jm.IDS_MUST_BE_ITERABLE);try{let s=tw.listDBIs(e);tw.initializeDBIs(e,t,s);let i=new ZK,o,c=[],u=[];for(let f=0,E=r.length;f<E;f++)try{o=r[f];let h=e.dbis[t].get(o);if(!h||n&&h[tW]>n){i.skipped.push(o);continue}let p=e.dbis[t].ifVersion(o,jK.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let S=0;S<s.length;S++){let O=s[S];if(!h.hasOwnProperty(O)||O===t)continue;let g=e.dbis[O],R=h[O];if(R!=null)try{let B=Xm.getIndexedValues(R);if(B)for(let H=0,v=B.length;H<v;H++)g.remove(B[H],o)}catch{rw.warn(`cannot delete from attribute: ${O}, ${R}:${o}`)}}});c.push(p),u.push(o),i.original_records.push(h)}catch(h){rw.warn(h),i.skipped.push(o)}let _=[],l=await Promise.all(c);for(let f=0,E=l.length;f<E;f++)l[f]===!0?i.deleted.push(u[f]):(i.skipped.push(u[f]),_.push(f));let d=0;for(let f=0;f<_.length;f++){let E=_[f];i.original_records.splice(E-d,1),d++}return i.txn_time=Xm.getNextMonotonicTime(),i}catch(s){throw s}}a(rW,"deleteRecords");nw.exports={deleteRecords:rW}});var Bc=T((xce,ow)=>{"use strict";var Qo=J(),nW=sw(),sW=Ve(),{getSchemaPath:iW}=Ye(),oW=Pc(),aW=W();ow.exports=cW;async function cW(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Qo.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Qo.isEmptyOrZeroLength(e.hash_values)&&!Qo.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let u=e.records[c][n];Qo.isEmpty(u)||e.hash_values.push(u)}}if(Qo.isEmptyOrZeroLength(e.hash_values))return iw([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Qo.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=iW(e.schema,e.table),i=await sW.openEnvironment(s,e.table),o=await nW.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await oW(e,o)}catch(c){aW.error(`unable to write transaction due to ${c.message}`)}return iw(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(cW,"lmdbDeleteRecords");function iw(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(iw,"createDeleteResponse")});var ep=T((Gce,aw)=>{"use strict";var uW=U(),qce=Nr();function Zm(e,t){let r=Object.create(null);if(t.length===1&&uW.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(Zm,"parseRow");function lW(e,t,r,n){let s=Zm(r,e);n.push(s)}a(lW,"searchAll");function _W(e,t,r,n){let s=Zm(r,e);n[t]=s}a(_W,"searchAllToMap");function dW(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(dW,"iterateDBI");function $i(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($i,"pushResults");function fW(e,t,r,n,s,i){t.toString().endsWith(e)&&$i(t,r,n,s,i)}a(fW,"endsWith");function EW(e,t,r,n,s,i){t.toString().includes(e)&&$i(t,r,n,s,i)}a(EW,"contains");function hW(e,t,r,n,s,i){t>e&&$i(t,r,n,s,i)}a(hW,"greaterThanCompare");function mW(e,t,r,n,s,i){t>=e&&$i(t,r,n,s,i)}a(mW,"greaterThanEqualCompare");function pW(e,t,r,n,s,i){t<e&&$i(t,r,n,s,i)}a(pW,"lessThanCompare");function SW(e,t,r,n,s,i){t<=e&&$i(t,r,n,s,i)}a(SW,"lessThanEqualCompare");aw.exports={parseRow:Zm,searchAll:lW,searchAllToMap:_W,iterateDBI:dW,endsWith:fW,contains:EW,greaterThanCompare:hW,greaterThanEqualCompare:mW,lessThanCompare:pW,lessThanEqualCompare:SW,pushResults:$i}});var zo=T((Kce,Ew)=>{"use strict";var ei=Ve(),Vce=W(),Pr=Nr(),D_=lt(),at=br().LMDB_ERRORS_ENUM,$ce=J(),TW=U(),L_=ep(),{parseRow:gW}=L_,Yce=require("lmdb"),{OVERFLOW_MARKER:cw,MAX_SEARCH_KEY_LENGTH:RW}=D_;function uw(e,t,r,n=!1,s=void 0,i=void 0){return Yi(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(uw,"iterateFullIndex");function Hc(e,t,r,n,s,i=!1,o=void 0,c=void 0,u=!1,_=!1){return Yi(e,t,r,(l,d,f,E)=>{let g={transaction:l,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!u:!_,exclusiveStart:i===!0?_:u};return E===r?(g.values=!1,d.getRange(g).map(R=>({value:R}))):d.getRange(g)})}a(Hc,"iterateRangeBetween");function Yi(e,t,r,n){let s=e.database||e,i=ei.openDBI(s,r);i[D_.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&ei.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(Yi,"setupTransaction");function lw(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(cw)){if(!s)if(r)s=ei.openDBI(e,r);else{let u=ei.listDBIs(e);for(let _=0,l=u.length;_<l&&(s=ei.openDBI(e,u[_]),!s[D_.DBI_DEFINITION_NAME].is_hash_attribute);_++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(lw,"getOverflowCheck");function AW(e,t,r,n=!1,s=void 0,i=void 0){if(Pr.validateEnv(e),t===void 0)throw new Error(at.HASH_ATTRIBUTE_REQUIRED);return Yi(e,t,t,(o,c,u)=>(M_(r),r=xc(u,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(_=>gW(_.value,r))))}a(AW,"searchAll");function OW(e,t,r,n=!1,s=void 0,i=void 0){if(Pr.validateEnv(e),t===void 0)throw new Error(at.HASH_ATTRIBUTE_REQUIRED);M_(r),r=xc(e.database||e,r);let o=new Map;for(let{key:c,value:u}of uw(e,t,t,n,s,i))o.set(c,L_.parseRow(u,r));return o}a(OW,"searchAllToMap");function bW(e,t,r=!1,n=void 0,s=void 0){if(Pr.validateEnv(e),t===void 0)throw new Error(at.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=uw(e,void 0,t,r,n,s),c=o.transaction,u=lw(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(bW,"iterateDBI");function NW(e,t){if(Pr.validateEnv(e),t===void 0)throw new Error(at.HASH_ATTRIBUTE_REQUIRED);return ei.statDBI(e,t).entryCount}a(NW,"countAll");function yW(e,t,r,n,s=!1,i=void 0,o=void 0){return ti(e,r,n),Yi(e,t,r,(c,u,_,l)=>(n=Pr.convertKeyValueToWrite(n),l===r?u.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:u.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(yW,"equals");function wW(e,t,r){return ti(e,t,r),ei.openDBI(e,t).getValuesCount(r)}a(wW,"count");function IW(e,t,r,n,s=!1,i=void 0,o=void 0){return ti(e,r,n),Yi(e,null,r,(c,u)=>{n=Pr.convertKeyValueToWrite(n);let _=!0;typeof n=="number"&&(_=!1);let l;if(s===!0){let d;for(let f of u.getKeys({transaction:c,start:n}))if(!f.startsWith(n)){d=f;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),l=u.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(f=>{let{key:E}=f;if(E!==d){if(E.toString().startsWith(n))return f;if(_===!0)return l.DONE}}),l.filter(f=>f)}else return l=u.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(_===!0)return l.DONE}),_?l:l.filter(d=>d)})}a(IW,"startsWith");function CW(e,t,r,n,s=!1,i=void 0,o=void 0){return _w(e,t,r,n,s,i,o,!0)}a(CW,"endsWith");function _w(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return ti(e,r,n),Yi(e,null,r,(u,_,l,d)=>{let f=lw(l,u,d,r);return o=Number.isInteger(o)?o:0,_.getKeys({transaction:u,end:s?!1:void 0,reverse:s}).flatMap(E=>{let h=E.toString();return h.endsWith(cw)?_.getValues(E,{transaction:u}).map(p=>{let S=f(E,p);if(c?S.endsWith(n):S.includes(n))return{key:S,value:p}}).filter(p=>p):(c?h.endsWith(n):h.includes(n))?_[D_.DBI_DEFINITION_NAME].is_hash_attribute?{key:E,value:E}:_.getValues(E,{transaction:u}).map(p=>({key:E,value:p})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(_w,"contains");function DW(e,t,r,n,s=!1,i=void 0,o=void 0){ti(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),Hc(e,t,r,n,u,s,i,o,!0,!1)}a(DW,"greaterThan");function LW(e,t,r,n,s=!1,i=void 0,o=void 0){ti(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),Hc(e,t,r,n,u,s,i,o,!1,!1)}a(LW,"greaterThanEqual");function MW(e,t,r,n,s=!1,i=void 0,o=void 0){ti(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),Hc(e,t,r,u,n,s,i,o,!1,!0)}a(MW,"lessThan");function UW(e,t,r,n,s=!1,i=void 0,o=void 0){ti(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),Hc(e,t,r,u,n,s,i,o,!1,!1)}a(UW,"lessThanEqual");function PW(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Pr.validateEnv(e),r===void 0)throw new Error(at.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(at.START_VALUE_REQUIRED);if(s===void 0)throw new Error(at.END_VALUE_REQUIRED);if(n=Pr.convertKeyValueToWrite(n),s=Pr.convertKeyValueToWrite(s),n>s)throw new Error(at.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Hc(e,t,r,n,s,i,o,c)}a(PW,"between");function vW(e,t,r,n){Pr.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(at.HASH_ATTRIBUTE_REQUIRED);if(M_(r),r=xc(s,r),n===void 0)throw new Error(at.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=L_.parseRow(c,r)),o}a(vW,"searchByHash");function BW(e,t,r){Pr.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(at.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(at.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(BW,"checkHashExists");function HW(e,t,r,n,s=[]){return fw(e,t,r,n,s),dw(e,t,r,n,s).map(i=>i[1])}a(HW,"batchSearchByHash");function xW(e,t,r,n,s=[]){fw(e,t,r,n,s);let i=new Map;for(let[o,c]of dw(e,t,r,n,s))i.set(o,c);return i}a(xW,"batchSearchByHashToMap");function dw(e,t,r,n,s=[]){return Yi(e,t,t,(i,o,c)=>{r=xc(c,r);let u=r.length<3;return n.map(_=>{let l=c.dbis[t].get(_,{transaction:i,lazy:u});if(l)return[_,L_.parseRow(l,r)];s.push(_)}).filter(_=>_)})}a(dw,"batchHashSearch");function fw(e,t,r,n,s){if(Pr.validateEnv(e),t===void 0)throw new Error(at.HASH_ATTRIBUTE_REQUIRED);if(M_(r),n==null)throw new Error(at.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(at.IDS_MUST_BE_ITERABLE)}a(fw,"initializeBatchSearchByHash");function M_(e){if(!Array.isArray(e))throw e===void 0?new Error(at.FETCH_ATTRIBUTES_REQUIRED):new Error(at.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(M_,"validateFetchAttributes");function ti(e,t,r){if(Pr.validateEnv(e),t===void 0)throw new Error(at.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(at.SEARCH_VALUE_REQUIRED);if(r?.length>RW)throw new Error(at.SEARCH_VALUE_TOO_LARGE)}a(ti,"validateComparisonFunctions");function xc(e,t){return t.length===1&&TW.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=ei.listDBIs(e)),t}a(xc,"setGetWholeRowAttributes");Ew.exports={searchAll:AW,searchAllToMap:OW,count:wW,countAll:NW,equals:yW,startsWith:IW,endsWith:CW,contains:_w,searchByHash:vW,setGetWholeRowAttributes:xc,batchSearchByHash:HW,batchSearchByHashToMap:xW,checkHashExists:BW,iterateDBI:bW,greaterThan:DW,greaterThanEqual:LW,lessThan:MW,lessThanEqual:UW,between:PW}});var Jo=T((Qce,Tw)=>{var hw=require("lodash"),mw=et(),me=require("joi"),FW=J(),{hdb_schema_table:Fc,checkValidTable:pw,hdb_table:Sw,hdb_database:U_}=Vn(),{handleHDBError:qW,hdb_errors:GW}=ee(),{getDatabases:kW}=(be(),te(Fe)),{HTTP_STATUS_CODES:VW}=GW,$W=me.object({database:U_,schema:U_,table:Sw,search_attribute:Fc,search_value:me.any().required(),get_attributes:me.array().min(1).items(me.alternatives(Fc,me.object())).optional(),desc:me.bool(),limit:me.number().integer().min(1),offset:me.number().integer().min(0)}),YW=me.object({database:U_,schema:U_,table:Sw,operator:me.string().valid("and","or").default("and").lowercase(),offset:me.number().integer().min(0),limit:me.number().integer().min(1),get_attributes:me.array().min(1).items(me.alternatives(Fc,me.object())).optional(),sort:me.object({attribute:me.alternatives(Fc,me.array().min(1)),descending:me.bool().optional()}).optional(),conditions:me.array().min(1).items(me.alternatives(me.object({operator:me.string().valid("and","or").default("and").lowercase(),conditions:me.array()}),me.object({search_attribute:me.alternatives(Fc,me.array().min(1)),search_type:me.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:me.when("search_type",{switch:[{is:"equals",then:me.any()},{is:"between",then:me.array().items(me.alternatives([me.string(),me.number()])).length(2)}],otherwise:me.alternatives(me.string(),me.number())}).required()}))).required()});Tw.exports=function(e,t){let r=null;switch(t){case"value":r=mw.validateBySchema(e,$W);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(pw("database",e.schema)),i(pw("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=mw.validateBySchema(e,YW);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=FW.checkGlobalSchemaTable(e.schema,e.table);if(s)return qW(new Error,s,VW.NOT_FOUND);let o=kW()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let u=a(l=>{for(let d=0,f=l.conditions.length;d<f;d++){let E=l.conditions[d];E.conditions?u(E):c.push(E.search_attribute)}},"addConditions");t==="conditions"&&u(e);let _=hw.filter(c,l=>l!=="*"&&l.attribute!=="*"&&!Array.isArray(l)&&!hw.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 tp=T((Jce,gw)=>{"use strict";var KW=Ve(),WW=Jo(),{getSchemaPath:QW}=Ye();gw.exports=zW;function zW(e){let t=WW(e,"hashes");if(t)throw t;let r=QW(e.schema,e.table);return KW.openEnvironment(r,e.table)}a(zW,"initialize")});var rp=T((jce,Rw)=>{"use strict";var JW=zo(),XW=tp();Rw.exports=jW;async function jW(e){let t=await XW(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return JW.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(jW,"lmdbGetDataByHash")});var Xo=T((eue,Aw)=>{"use strict";var np=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};Aw.exports=np});var bw=T((nue,Ow)=>{"use strict";var rue=Xo(),ZW=zo(),eQ=tp();Ow.exports=tQ;async function tQ(e){let t=await eQ(e),r=global.hdb_schema[e.schema][e.table];return ZW.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(tQ,"lmdbSearchByHash")});var Qn=T((iue,Nw)=>{"use strict";var sp=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}};Nw.exports=sp});var P_=T((aue,Lw)=>{"use strict";var Yt=zo(),rQ=Ve(),nQ=J(),pe=lt(),Ki=U(),sQ=Li(),yw=br().LMDB_ERRORS_ENUM,{getSchemaPath:iQ}=Ye(),Ss=Ki.SEARCH_WILDCARDS;async function oQ(e,t,r){let n;e.schema===Ki.SYSTEM_SCHEMA_NAME?n=sQ[e.table]:n=global.hdb_schema[e.schema][e.table];let s=Dw(e,n.hash_attribute,r,t);return Iw(e,s,n.hash_attribute,r)}a(oQ,"prepSearch");async function Iw(e,t,r,n){let s=iQ(e.schema,e.table),i=await rQ.openEnvironment(s,e.table),o=Cw(i,e,t,r),c=o.transaction||i;if([pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,pe.SEARCH_TYPES.SEARCH_ALL,pe.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(aQ(e,r)===!1){let l=e.search_attribute;if(l===r)return n?ww(o,()=>!0):o.map(f=>({[r]:f.key}));let d=a(f=>({[r]:f.value,[l]:f.key}),"toObject");return n?ww(o,d):o.map(d)}let _=e.search_attribute===r?o.map(l=>l.key):o.map(l=>l.value);return n===!0?Yt.batchSearchByHashToMap(c,r,e.get_attributes,_):Yt.batchSearchByHash(c,r,e.get_attributes,_)}a(Iw,"executeSearch");function Cw(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 pe.SEARCH_TYPES.EQUALS:s=Yt.equals(e,i,t.search_attribute,t.search_value,o,c,u);break;case pe.SEARCH_TYPES.CONTAINS:s=Yt.contains(e,i,t.search_attribute,t.search_value,o,c,u);break;case pe.SEARCH_TYPES.ENDS_WITH:case pe.SEARCH_TYPES._ENDS_WITH:s=Yt.endsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case pe.SEARCH_TYPES.STARTS_WITH:case pe.SEARCH_TYPES._STARTS_WITH:s=Yt.startsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Yt.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Yt.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case pe.SEARCH_TYPES.SEARCH_ALL:return Yt.searchAll(e,n,t.get_attributes,o,c,u);case pe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Yt.searchAllToMap(e,n,t.get_attributes,o,c,u);case pe.SEARCH_TYPES.BETWEEN:s=Yt.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,u);break;case pe.SEARCH_TYPES.GREATER_THAN:case pe.SEARCH_TYPES._GREATER_THAN:s=Yt.greaterThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case pe.SEARCH_TYPES.GREATER_THAN_EQUAL:case pe.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Yt.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;case pe.SEARCH_TYPES.LESS_THAN:case pe.SEARCH_TYPES._LESS_THAN:s=Yt.lessThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case pe.SEARCH_TYPES.LESS_THAN_EQUAL:case pe.SEARCH_TYPES._LESS_THAN_EQUAL:s=Yt.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;default:return Object.create(null)}return s}a(Cw,"searchByType");function ww(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(ww,"createMapFromIterable");function aQ(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(aQ,"checkToFetchMore");function Dw(e,t,r,n){if(nQ.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),Ss.indexOf(s)>-1)return r===!0?pe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:pe.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Ss[0])<0&&s.indexOf(Ss[1])<0)return c===!0?r===!0?pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:pe.SEARCH_TYPES.EQUALS;if(Ss.indexOf(i)>=0&&Ss.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),pe.SEARCH_TYPES.CONTAINS;if(Ss.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),pe.SEARCH_TYPES.ENDS_WITH;if(Ss.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),pe.SEARCH_TYPES.STARTS_WITH;if(s.includes(Ss[0])||s.includes(Ss[1]))return pe.SEARCH_TYPES.EQUALS;throw new Error(yw.UNKNOWN_SEARCH_TYPE)}else switch(n){case Ki.VALUE_SEARCH_COMPARATORS.BETWEEN:return pe.SEARCH_TYPES.BETWEEN;case Ki.VALUE_SEARCH_COMPARATORS.GREATER:return pe.SEARCH_TYPES.GREATER_THAN;case Ki.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return pe.SEARCH_TYPES.GREATER_THAN_EQUAL;case Ki.VALUE_SEARCH_COMPARATORS.LESS:return pe.SEARCH_TYPES.LESS_THAN;case Ki.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return pe.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(yw.UNKNOWN_SEARCH_TYPE)}}a(Dw,"createSearchTypeFromSearchObject");Lw.exports={executeSearch:Iw,createSearchTypeFromSearchObject:Dw,prepSearch:oQ,searchByType:Cw}});var Uw=T((lue,Mw)=>{"use strict";var uue=Qn(),cQ=Jo(),uQ=J(),lQ=U(),_Q=P_();Mw.exports=dQ;function dQ(e,t){if(!uQ.isEmpty(t)&&lQ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=cQ(e,"value");if(n)throw n;return _Q.prepSearch(e,t,!0)}a(dQ,"lmdbGetDataByValue")});var qc=T((fue,Pw)=>{"use strict";var due=Qn(),fQ=Jo(),EQ=J(),hQ=U(),mQ=P_();Pw.exports=pQ;async function pQ(e,t){if(!EQ.isEmpty(t)&&hQ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=fQ(e,"value");if(n)throw n;return mQ.prepSearch(e,t,!1)}a(pQ,"lmdbSearchByValue")});var Bw=T((mue,vw)=>{"use strict";var hue=lt(),ip=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}},op=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},ap=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};vw.exports={SearchByConditionsObject:ip,SearchCondition:op,SortAttribute:ap}});var Gw=T((gue,qw)=>{"use strict";var Sue=Bw().SearchByConditionsObject,SQ=Qn(),TQ=Jo(),cp=zo(),v_=lt(),{Resource:Tue}=(gn(),te(up)),Fw=P_(),gQ=ep(),RQ=require("lodash"),{getSchemaPath:AQ}=Ye(),Hw=Ve(),{handleHDBError:OQ,hdb_errors:bQ}=ee(),{HTTP_STATUS_CODES:NQ}=bQ,yQ=1e8;qw.exports=wQ;async function wQ(e){let t=TQ(e,"conditions");if(t)throw OQ(t,t.message,NQ.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=AQ(e.schema,e.table),n=await Hw.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let _ of e.conditions)Hw.openDBI(n,_.search_attribute);let i=RQ.sortBy(e.conditions,_=>{if(_.estimated_count===void 0){let l=_.search_type;l===v_.SEARCH_TYPES.EQUALS?_.estimated_count=cp.count(n,_.search_attribute,_.search_value):l===v_.SEARCH_TYPES.CONTAINS||l===v_.SEARCH_TYPES.ENDS_WITH?_.estimated_count=1/0:_.estimated_count=yQ}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(Fw.filterByType),d=l.length,f=cp.setGetWholeRowAttributes(n,e.get_attributes);u=c.map(E=>_.get(E,{transaction:o,lazy:!0})),d>0&&(u=u.filter(E=>{for(let h=0;h<d;h++)if(!l[h](E))return!1;return!0})),(e.offset||e.limit!==void 0)&&(u=u.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),u=u.map(E=>gQ.parseRow(E,f))}else{for(let d=1;d<i.length;d++){let f=i[d],E=await xw(o,e,f,s.hash_attribute);c=c.concat(E)}let _=new Set,l=e.offset||0;c=c.filter(d=>_.has(d)?!1:(_.add(d),!0)).slice(l,e.limit&&e.limit+l),u=cp.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return u.onDone=()=>{o.done()},u}a(wQ,"lmdbSearchByConditions");async function xw(e,t,r,n){let s=new SQ(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===v_.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,Fw.searchByType(e,s,i,n).map(o=>o.value)}a(xw,"executeConditionSearch")});var Gc=T((Aue,kw)=>{"use strict";var IQ=U().OPERATIONS_ENUM,lp=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=IQ.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};kw.exports=lp});var _p=T((bue,Jw)=>{"use strict";var Kw=Qn(),Ww=Gc(),Qw=qc(),zw=Bc(),rr=U(),Vw=J(),$w=Ve(),{getTransactionAuditStorePath:CQ,getSchemaPath:DQ}=Ye(),Yw=W();Jw.exports=LQ;async function LQ(e){try{if(Vw.isEmpty(global.hdb_schema[e.schema])||Vw.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await MQ(e),await UQ(e);let t=DQ(e.schema,e.table);try{await $w.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Yw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=CQ(e.schema,e.table);await $w.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Yw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(LQ,"lmdbDropTable");async function MQ(e){let t=new Kw(rr.SYSTEM_SCHEMA_NAME,rr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,rr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[rr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Qw(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 Ww(rr.SYSTEM_SCHEMA_NAME,rr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await zw(s)}a(MQ,"deleteAttributesFromSystem");async function UQ(e){let t=new Kw(rr.SYSTEM_SCHEMA_NAME,rr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,rr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[rr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,rr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,rr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Qw(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 Ww(rr.SYSTEM_SCHEMA_NAME,rr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await zw(s)}catch(i){throw i}}a(UQ,"dropTableFromSystem")});var jw=T((yue,Xw)=>{"use strict";var PQ=require("fs-extra"),vQ=Qn(),BQ=Xo(),HQ=Gc(),xQ=_p(),FQ=Bc(),qQ=rp(),GQ=qc(),Ts=U(),{getSchemaPath:kQ}=Ye(),{handleHDBError:VQ,hdb_errors:$Q}=ee(),{HDB_ERROR_MSGS:YQ,HTTP_STATUS_CODES:KQ}=$Q;Xw.exports=WQ;async function WQ(e){let t;try{t=await QQ(e.schema);let r=new vQ(Ts.SYSTEM_SCHEMA_NAME,Ts.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Ts.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Ts.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await GQ(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await xQ(c)}catch(u){if(u.message!=="invalid environment")throw u}}let s=new HQ(Ts.SYSTEM_SCHEMA_NAME,Ts.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await FQ(s);let i=kQ(t);await PQ.remove(i)}catch(r){throw r}}a(WQ,"lmdbDropSchema");async function QQ(e){let t=new BQ(Ts.SYSTEM_SCHEMA_NAME,Ts.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Ts.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await qQ(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw VQ(new Error,YQ.SCHEMA_NOT_FOUND(e),KQ.NOT_FOUND,void 0,void 0,!0);return n}a(QQ,"validateDropSchema")});var fp=T((Iue,Zw)=>{"use strict";var dp=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Zw.exports=dp});var tI=T((Lue,eI)=>{"use strict";var zQ=require("fs-extra"),B_=Ve(),{getTransactionAuditStorePath:JQ}=Ye(),Ep=lt(),Due=fp();eI.exports=XQ;async function XQ(e){let t;try{let r=JQ(e.schema,e.table);await zQ.mkdirp(r),t=await B_.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{B_.createDBI(t,Ep.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),B_.createDBI(t,Ep.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),B_.createDBI(t,Ep.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(XQ,"createTransactionsAuditEnvironment")});var iI=T((Uue,sI)=>{"use strict";var hp=U(),rI=Ve(),jQ=Ho(),{getSystemSchemaPath:ZQ,getSchemaPath:ez}=Ye(),tz=Li(),rz=i_(),mp=s_(),nz=W(),sz=tI(),Sp=tz.hdb_table,nI=[];for(let e=0;e<Sp.attributes.length;e++)nI.push(Sp.attributes[e].attribute);sI.exports=iz;async function iz(e,t){let r=ez(t.schema,t.table),n=new mp(t.schema,t.table,hp.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new mp(t.schema,t.table,hp.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new mp(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await rI.createEnvironment(r,t.table),e!==void 0){let o=await rI.openEnvironment(ZQ(),hp.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await jQ.insertRecords(o,Sp.hash_attribute,nI,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await pp(n),await pp(s),await pp(i)}await sz(t)}catch(o){throw o}}a(iz,"lmdbCreateTable");async function pp(e){try{await rz(e)}catch(t){nz.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(pp,"createAttribute")});var aI=T((vue,oI)=>{"use strict";var oz=Ac(),az=wc(),cz=I_(),kc=U(),uz=Ho().updateRecords,lz=Ve(),{getSchemaPath:_z}=Ye(),dz=Pc(),fz=W();oI.exports=Ez;async function Ez(e){try{let{schema_table:t,attributes:r}=oz(e);az(e,r,t.hash_attribute),e.schema!==kc.SYSTEM_SCHEMA_NAME&&(r.includes(kc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(kc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(kc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(kc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await cz(e.hdb_auth_header,t,r),s=_z(e.schema,e.table),i=await lz.openEnvironment(s,e.table),o=await uz(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await dz(e,o)}catch(c){fz.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(Ez,"lmdbUpdateRecords")});var uI=T((Hue,cI)=>{"use strict";var hz=U().OPERATIONS_ENUM,Tp=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=hz.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};cI.exports=Tp});var _I=T((que,lI)=>{"use strict";var Fue=uI(),mz=Ac(),pz=wc(),Sz=I_(),Vc=U(),Tz=Ho().upsertRecords,gz=Ve(),{getSchemaPath:Rz}=Ye(),Az=Pc(),Oz=W(),{handleHDBError:bz,hdb_errors:Nz}=ee();lI.exports=yz;async function yz(e){let t;try{t=mz(e)}catch(u){throw bz(u,u.message,Nz.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;pz(e,n,r.hash_attribute),e.schema!==Vc.SYSTEM_SCHEMA_NAME&&(n.includes(Vc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(Vc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(Vc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(Vc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await Sz(e.hdb_auth_header,r,n),i=Rz(e.schema,e.table),o=await gz.openEnvironment(i,e.table),c=await Tz(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await Az(e,c)}catch(u){Oz.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(yz,"lmdbUpsertRecords")});var fI=T((kue,dI)=>{"use strict";var gp=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};dI.exports=gp});var hI=T(($ue,EI)=>{"use strict";var Rp=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}};EI.exports=Rp});var SI=T((Wue,pI)=>{"use strict";var Ap=Ve(),{getTransactionAuditStorePath:wz}=Ye(),Kue=fI(),$c=lt(),Iz=J(),mI=hI(),Cz=require("util").promisify,Dz=Cz(setTimeout),Lz=1e4,Mz=100;pI.exports=Uz;async function Uz(e){let t=wz(e.schema,e.table),r=await Ap.openEnvironment(t,e.table,!0),n=Ap.listDBIs(r);Ap.initializeDBIs(r,$c.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new mI;do s=await Pz(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 Dz(Mz);while(s.transactions_deleted>0);return i}a(Uz,"deleteAuditLogsBefore");async function Pz(e,t){let r=new mI;try{let n=e.dbis[$c.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[$c.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Iz.isEmpty(c)||(s=e.dbis[$c.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let u=0;u<o.hash_values.length;u++)s=e.dbis[$c.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[u],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>Lz)break}return await s,r}catch(n){throw n}}a(Pz,"deleteTransactions")});var gI=T((zue,TI)=>{"use strict";var Op=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};TI.exports=Op});var AI=T((jue,RI)=>{"use strict";var vz=Qn(),Bz=Gc(),Xue=gI(),zn=U(),Hz=J(),bp=Ve(),xz=Li(),Fz=qc(),qz=Bc(),{getSchemaPath:Gz}=Ye();RI.exports=kz;async function kz(e,t=!0){let r;e.schema===zn.SYSTEM_SCHEMA_NAME?r=xz[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await $z(e),s=Gz(e.schema,e.table),i=await bp.openEnvironment(s,e.table);return t===!0&&await Vz(e,i,r.hash_attribute),bp.dropDBI(i,e.attribute),n}a(kz,"lmdbDropAttribute");async function Vz(e,t,r){let n=bp.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(Vz,"removeAttributeFromAllObjects");async function $z(e){let t=new vz(zn.SYSTEM_SCHEMA_NAME,zn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,zn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[zn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,zn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await Fz(t)).filter(o=>o[zn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(Hz.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[zn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new Bz(zn.SYSTEM_SCHEMA_NAME,zn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return qz(i)}a($z,"dropAttributeFromSystem")});var II=T((tle,wI)=>{"use strict";var Np=Ve(),jo=lt(),ele=Nr(),yp=U(),OI=J(),{getTransactionAuditStorePath:Yz}=Ye(),Kz=zo(),H_=Ko(),Wz=W();wI.exports=Qz;async function Qz(e){let t=Yz(e.schema,e.table),r=await Np.openEnvironment(t,e.table,!0),n=Np.listDBIs(r);Np.initializeDBIs(r,jo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case yp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return bI(r,e.search_values);case yp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,Jz(r,e.search_values,s);case yp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return zz(r,e.search_values);default:return bI(r)}}a(Qz,"readAuditLog");function bI(e,t=[0,Date.now()]){OI.isEmpty(t[0])&&(t[0]=0),OI.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[jo.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 H_,s))}a(bI,"searchTransactionsByTimestamp");function zz(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[jo.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,yI(e,i))}return Object.fromEntries(r)}a(zz,"searchTransactionsByUsername");function Jz(e,t,r){let n=new Map;for(let c=0,u=t.length;c<u;c++){let _=t[c],l=Kz.equals(e,jo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,jo.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,_);for(let{value:d}of l){let f=Number(d);n.has(f)?n.get(f).push(_.toString()):n.set(f,[_.toString()])}}let s=Array.from(n.keys()),i=yI(e,s),o=new Map;for(let c=0;c<i.length;c++){let u=i[c],_=u.timestamp,l=n.get(_);NI(u,"records",r,l,o),NI(u,"original_records",r,l,o)}return Object.fromEntries(o)}a(Jz,"searchTransactionsByHashValues");function NI(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 H_(e.operation,e.user_name,i,void 0);d[t]=[c],_.push(d)}}else{let _=new H_(e.operation,e.user_name,i,void 0);_[t]=[c],s.set(u,[_])}}}a(NI,"loopRecords");function yI(e,t){let r=[];try{let n=e.dbis[jo.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 H_,i);r.push(o)}}catch(i){Wz.warn(i)}return r}catch(n){throw n}}a(yI,"batchSearchTransactions")});var DI=T((ile,CI)=>{"use strict";var{getSchemaPath:nle}=Ye(),sle=Ve(),{database:Xz}=(be(),te(Fe));CI.exports={writeTransaction:jz};async function jz(e,t,r){return Xz({database:e,table:t}).transaction(r)}a(jz,"writeTransaction")});var PI=T((ale,UI)=>{"use strict";var{getSchemaPath:LI}=Ye(),MI=Ve();UI.exports={flush:Zz,resetReadTxn:eJ};async function Zz(e,t){return(await MI.openEnvironment(LI(e,t),t.toString())).flushed}a(Zz,"flush");async function eJ(e,t){try{(await MI.openEnvironment(LI(e,t),t.toString())).resetReadTxn()}catch{}}a(eJ,"resetReadTxn")});var xI=T((ule,HI)=>{"use strict";var{Readable:tJ}=require("stream"),{getDatabases:rJ}=(be(),te(Fe)),{readSync:nJ,openSync:sJ,createReadStream:vI}=require("fs"),{open:iJ}=require("lmdb"),BI=Ql(),oJ=Jl(),{AUDIT_STORE_OPTIONS:aJ}=(Ci(),te(FI)),{INTERNAL_DBIS_NAME:cJ,AUDIT_STORE_NAME:uJ}=lt();HI.exports=_J;var wp=32768,lJ=100;async function _J(e){let t=e.database||e.schema||"data",r=rJ()[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=iJ({noSync:!0,maxDbs:oJ.MAX_DBS}),f,E=d.openDB(cJ,new BI(!1)),h=l.useReadTransaction(),p=0,S=a(async function(g,R){R.encoding="binary",R.encoder=void 0;let B=d.openDB(g,R),H=l.openDB(g,R);for(let{key:v,version:M,value:$}of H.getRange({transaction:h,versions:H.useVersions}))f=B.put(v,$,M),p++%lJ===0&&(await new Promise(K=>setTimeout(K,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:g,value:R}of l.getRange({transaction:h,start:!1}))if(s.some(B=>g.startsWith?.(B+"/"))){E.put(g,R);let[,B]=g.split("/"),H=!B,v=new BI(!H,H);await S(g,v)}e.include_audit&&await S(uJ,Object.assign({},aJ)),await f;let O=vI(d.path);return O.headers=u(),O.on("close",()=>{h.done(),d.close()}),O}let o=r[Object.keys(r)[0]].primaryStore,c=sJ(o.path);return o.transaction(()=>{let _=Buffer.alloc(wp);nJ(c,_,0,wp),o.resetReadTxn();let l=o.useReadTransaction();l.renew();let d=vI(null,{fd:c,start:wp}),f=new tJ.from(async function*(){yield _;for await(let E of d)l.openTimer&&(l.openTimer=0),yield E;l.done()}());return f.headers=u(),f});function u(){let _=new Map;return _.set("content-type","application/octet-stream"),_.set("content-disposition",`attachment; filename="${t}"`),_.set("date",n),_}}a(_J,"getBackup")});var kI=T((_le,GI)=>{"use strict";var dJ=W(),{handleHDBError:fJ}=ee(),EJ=rb(),hJ=i_(),mJ=zm(),pJ=jy(),SJ=Bc(),TJ=rp(),gJ=bw(),RJ=Uw(),AJ=qc(),OJ=Gw(),bJ=jw(),NJ=iI(),yJ=aI(),wJ=_I(),IJ=SI(),CJ=_p(),DJ=AI(),LJ=II(),MJ=DI(),qI=PI(),UJ=xI(),Ip=class extends EJ{static{a(this,"LMDBBridge")}async searchByConditions(t){return OJ(t)}async getDataByHash(t){return await TJ(t)}async searchByHash(t){return await gJ(t)}async getDataByValue(t,r){return await RJ(t,r)}async searchByValue(t){return await AJ(t)}async createSchema(t){return await pJ(t)}async dropSchema(t){return await bJ(t)}async createTable(t,r){return await NJ(t,r)}async dropTable(t){return await CJ(t)}async createAttribute(t){return await hJ(t)}async createRecords(t){return await mJ(t)}async updateRecords(t){return await yJ(t)}async upsertRecords(t){try{return await wJ(t)}catch(r){throw fJ(r,null,null,dJ.ERR,r)}}async deleteRecords(t){return await SJ(t)}async dropAttribute(t){return await DJ(t)}async deleteAuditLogsBefore(t){return await IJ(t)}async readAuditLog(t){return await LJ(t)}writeTransaction(t,r,n){return MJ.writeTransaction(t,r,n)}flush(t,r){return qI.flush(t,r)}resetReadTxn(t,r){return qI.resetReadTxn(t,r)}getBackup(t){return UJ(t)}};GI.exports=Ip});function HJ(){BJ=setInterval(function(){for(let e of Cp)if(e.stale){let t=e[Ne]?.url;VI.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},vJ).unref()}var Dp,VI,PJ,Cp,Wi,x_,vJ,BJ,Lp=Oe(()=>{Dp=x(Nr()),VI=x(W());gn();vo();PJ=100,Cp=new Set,Wi=class{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;open=!0;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)throw new Error("Can not start a read on a transaction that is no longer open");return this.readTxnsUsed=1,Kl(()=>{this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxn.openTimer&&(this.readTxn.openTimer=0)}),Cp.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),Kl(()=>{this.readTxn.use()}),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(Cp.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}addWrite(t){if(!this.open&&!this.autoCommitMode)throw new Error("Can not use a transaction that is no longer open");this.writes.push(t),this.autoCommitMode&&this.commit()}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp=t.timestamp||(0,Dp.getNextMonotonicTime)());let n=t.retries||0;if(this.validated<this.writes.length)try{let l=this.validated;this.validated=this.writes.length;for(let f=l;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let d;for(let f=l;f<this.validated;f++){let E=this.writes[f];E&&(E.before||E.beforeIntermediate)&&(d=!0)}if(d)return(async()=>{try{for(let f=0;f<2;f++){let E;for(let h=l;h<this.validated;h++){let p=this.writes[h];if(!p)continue;let S=p[f===0?"before":"beforeIntermediate"];if(S){let O=S();E?E.push?E.push(O):E=[E,O]:E=O}}E&&await(E.push?Promise.all(E):E)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(l){throw this.abort(),l}n||this.doneReadTxn(),t?.prepared?.(),this.open=!1;let s,i=[],o=0;this.writes=this.writes.filter(l=>l);let c=a(l=>{l.commit(r,l.entry,n)},"doWrite"),u=a(()=>{let l=this.writes[o++];if(l)if(l.key){n>0&&(l.entry=l.store.getEntry(l.key));let d=l.store.ifVersion(l.key,l.entry?.version??null,u);s=s||d}else u();else for(let d of this.writes)c(d)},"nextCondition");if(this.writes.length<PJ>>n?u():s=this.writes[0].store.transaction(()=>{for(let l of this.writes)l.entry=l.store.getEntry(l.key),c(l);return!0}),s)return s.then(l=>l?(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))):(t?t.retries=n+1:t={retries:1},this.commit(t)));let _={txnTime:r};if(this.next){let l=this.next?.commit(t);if(l?.then)return l?.then(d=>({txnTime:r,next:d}));_.next=l}return _}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=!1,this.writes=[]}},x_=class extends Wi{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,Dp.getNextMonotonicTime)())}getReadTxn(){}},vJ=3e4;a(HJ,"startMonitoringTxns");HJ()});function Ke(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open&&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 Wi;e.timestamp&&(n.timestamp=e.timestamp),n[Ne]=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(r?.resetTransaction?{prepared(){n.autoCommitMode=!0}}:{});return u.then?u.then(()=>c):c}function o(c){throw n.abort({}),c}}var $I,Qi=Oe(()=>{$I=require("../../index");gn();Lp();a(Ke,"transaction");(0,$I._assignPackageExport)("transaction",Ke);Ke.commit=function(e){let t=(e[Ne]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Ke.abort=function(e){let t=(e[Ne]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var ZI={};ke(ZI,{ResourceBridge:()=>Pp});function vp({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 KI(e,t){let r=Jn(e),n=vp(e,r);if(!r)throw new wn.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user},o;Ke(i,()=>new Promise(_=>o=_));let c=e.ids||e.hash_values,u=0;return{[Symbol.asyncIterator](){return{async next(){if(u<c.length){let _=c[u++],l=await r.get({id:_,lazy:s,select:n},i);return l=l&&q_(l),t?{value:{key:_,value:l}}:{value:l}}else return o(),{done:!0}},return(_){return o(),{value:_,done:!0}},throw(_){return o(),{done:!0}}}}}}function Jn(e){let t=e.database||e.schema||FJ,r=In()[t];if(!r)throw(0,wn.handleHDBError)(new Error,xJ.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function WI(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*QI(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 zI,F_,wn,JI,XI,Cn,Mp,Up,jI,xJ,FJ,qJ,GJ,YI,Pp,eC=Oe(()=>{"use strict";zI=x(kI()),F_=x(Jo()),wn=x(ee());be();JI=x(Ac()),XI=x(wc()),Cn=x(U()),Mp=x(ps()),Up=x(yn()),jI=x(J());Qi();G_();({HDB_ERROR_MSGS:xJ}=wn.hdb_errors),FJ="data",qJ=1e4,GJ=10,Pp=class extends zI.default{static{a(this,"ResourceBridge")}constructor(t){super(t),YI=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,F_.default)(t,"conditions");if(r)throw(0,wn.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Jn(t);if(!n)throw new wn.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:vp(t,n),sort:t.sort,allowFullScan:!0})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new wn.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}]}ot({database:r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await Jn(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Jn(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,u)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,u,()=>r.primaryStore.put(o,c,u)).then(_=>{if(!_){let{value:l,version:d}=r.primaryStore.getEntry(o);return i(o,l,d)}})),"deleteRecord");for(let{key:o,value:c,version:u}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,u),await new Promise(_=>setImmediate(_));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){Jn(t).dropTable()}createSchema(t){return Yc({database:t.schema,table:null}),Mp.signalSchemaChange(new Up.SchemaEventMsg(process.pid,Cn.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Bp(t.schema),Mp.signalSchemaChange(new Up.SchemaEventMsg(process.pid,Cn.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,YI.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,JI.default)(t);(0,XI.default)(t,n,r.primaryKey);let s,i=In()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt};return Ke(o,async c=>{if(!i.schemaDefined){s=[];for(let l of n)i.attributes.find(f=>f.name==l)||s.push(l);s.length>0&&await i.addAttributes(s.map(l=>({name:l,indexed:!0})))}let u=[],_=[];for(let l of t.records){let d=await i.get(l[i.primaryKey],o);if(t.requires_existing&&!d||t.requires_no_existing&&d){_.push(l[i.primaryKey]);continue}d&&(d=q_(d));for(let f in l)if(Object.prototype.hasOwnProperty.call(l,f)){let E=l[f];if(typeof E=="function")try{let h=E([[d]]);Array.isArray(h)&&(E=h[0].func_val,l[f]=E)}catch(h){throw h.message+="Trying to set key "+f+" on object"+JSON.stringify(l),h}}if(d)for(let f in d)Object.prototype.hasOwnProperty.call(l,f)||(l[f]=d[f]);await i.put(l,o),u.push(l[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:u,new_attributes:s,skipped_hashes:_}})}async deleteRecords(t){let r=In()[t.schema][t.table],n={user:t.hdb_user};return Ke(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 WI(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=In()[t.schema][t.table];if(!r.createdTimeProperty)throw new wn.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:Cn.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,jI.async_set_timeout)(GJ),u=[],s=!0},"chunkDelete");for await(let l of n)u.push(l[r.primaryKey]),c++,c%qJ===0&&await _();return u.length>0&&await _(),s?WI(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,F_.default)(t,"hashes");if(r)throw r;return KI(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of KI(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Cn.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,F_.default)(t,"value");if(n)throw n;let s=Jn(t);if(!s)throw new wn.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===Cn.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:vp(t,s)})}async getDataByValue(t,r){let n=new Map,s=Jn(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){Jn({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Jn(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=Jn(t),n={};switch(t.search_type){case Cn.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 Cn.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of QI(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return QI(r,t.search_values?.[0],t.search_values?.[1])}}};a(vp,"getSelect");a(KI,"getRecords");a(Jn,"getTable");a(WI,"createDeleteResponse");a(QI,"groupRecordsInHistory")});var On=T((yle,tC)=>{"use strict";var{ResourceBridge:kJ}=(eC(),te(ZI)),VJ=Z();VJ.initSync();var k_;function $J(){return k_||(k_=new kJ,k_)}a($J,"getBridge");tC.exports=$J()});var iC=T((Ile,sC)=>{"use strict";var rC=require("lodash"),Kc=require("mathjs"),YJ=require("jsonata"),nC=J();sC.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?rC.uniqWith(e,rC.isEqual):e,searchJSON:KJ,mad:Wc.bind(null,Kc.mad),mean:Wc.bind(null,Kc.mean),mode:Wc.bind(null,Kc.mode),prod:Wc.bind(null,Kc.prod),median:Wc.bind(null,Kc.median)};function Wc(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(Wc,"aggregateFunction");function KJ(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(nC.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),nC.isEmpty(this.__ala__.res[r])){let n=YJ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(KJ,"searchJSON")});var aC=T((Dle,oC)=>{"use strict";var dt=require("moment"),Hp="YYYY-MM-DDTHH:mm:ss.SSSZZ";dt.suppressDeprecationWarnings=!0;oC.exports={current_date:()=>dt().utc().format("YYYY-MM-DD"),current_time:()=>dt().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return dt(e).utc().format("YYYY");case"month":return dt(e).utc().format("MM");case"day":return dt(e).utc().format("DD");case"hour":return dt(e).utc().format("HH");case"minute":return dt(e).utc().format("mm");case"second":return dt(e).utc().format("ss");case"millisecond":return dt(e).utc().format("SSS");default:break}},date:e=>dt(e).utc().format(Hp),date_format:(e,t)=>dt(e).utc().format(t),date_add:(e,t,r)=>dt(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>dt(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=dt(e).utc(),s=dt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>dt().utc().valueOf(),get_server_time:()=>dt().format(Hp),offset_utc:(e,t)=>dt(e).utc().utcOffset(t).format(Hp)}});var _C=T((Lle,lC)=>{"use strict";var WJ=require("@turf/area"),QJ=require("@turf/length"),zJ=require("@turf/circle"),JJ=require("@turf/difference"),XJ=require("@turf/distance"),jJ=require("@turf/boolean-contains"),ZJ=require("@turf/boolean-equal"),e2=require("@turf/boolean-disjoint"),t2=require("@turf/helpers"),cC=U(),ge=J(),gs=W();lC.exports={geoArea:r2,geoLength:n2,geoCircle:s2,geoDifference:i2,geoDistance:uC,geoNear:o2,geoContains:a2,geoEqual:c2,geoCrosses:u2,geoConvert:l2};function r2(e){if(ge.isEmpty(e))return NaN;typeof e=="string"&&(e=ge.autoCastJSON(e));try{return WJ.default(e)}catch(t){return gs.trace(t,e),NaN}}a(r2,"geoArea");function n2(e,t){if(ge.isEmpty(e))return NaN;typeof e=="string"&&(e=ge.autoCastJSON(e));try{return QJ.default(e,{units:t||"kilometers"})}catch(r){return gs.trace(r,e),NaN}}a(n2,"geoLength");function s2(e,t,r){if(ge.isEmpty(e))return NaN;if(ge.isEmpty(t))return NaN;typeof e=="string"&&(e=ge.autoCastJSON(e));try{return zJ.default(e,t,{units:r||"kilometers"})}catch(n){return gs.trace(n,e,t),NaN}}a(s2,"geoCircle");function i2(e,t){if(ge.isEmpty(e))return NaN;if(ge.isEmpty(t))return NaN;typeof e=="string"&&(e=ge.autoCastJSON(e)),typeof t=="string"&&(t=ge.autoCastJSON(t));try{return JJ(e,t)}catch(r){return gs.trace(r,e,t),NaN}}a(i2,"geoDifference");function uC(e,t,r){if(ge.isEmpty(e))return NaN;if(ge.isEmpty(t))return NaN;typeof e=="string"&&(e=ge.autoCastJSON(e)),typeof t=="string"&&(t=ge.autoCastJSON(t));try{return XJ.default(e,t,{units:r||"kilometers"})}catch(n){return gs.trace(n,e,t),NaN}}a(uC,"geoDistance");function o2(e,t,r,n){if(ge.isEmpty(e)||ge.isEmpty(t))return!1;if(ge.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=ge.autoCastJSON(e)),typeof t=="string"&&(t=ge.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return uC(e,t,n)<=r}catch(s){return gs.trace(s,e,t),!1}}a(o2,"geoNear");function a2(e,t){if(ge.isEmpty(e)||ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=ge.autoCastJSON(e)),typeof t=="string"&&(t=ge.autoCastJSON(t));try{return jJ.default(e,t)}catch(r){return gs.trace(r,e,t),!1}}a(a2,"geoContains");function c2(e,t){if(ge.isEmpty(e)||ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=ge.autoCastJSON(e)),typeof t=="string"&&(t=ge.autoCastJSON(t));try{return ZJ.default(e,t)}catch(r){return gs.trace(r,e,t),!1}}a(c2,"geoEqual");function u2(e,t){if(ge.isEmpty(e)||ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=ge.autoCastJSON(e)),typeof t=="string"&&(t=ge.autoCastJSON(t));try{return!e2.default(e,t)}catch(r){return gs.trace(r,e,t),!1}}a(u2,"geoCrosses");function l2(e,t,r){if(ge.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(ge.isEmpty(t))throw new Error("geo_type is required");if(ge.isEmpty(cC.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(cC.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=ge.autoCastJSON(e)),t2[t](e,r)}a(l2,"geoConvert")});var V_=T((Ule,dC)=>{var zi=iC(),vr=aC(),Xn=_C();dC.exports=e=>{e.aggr.mad=e.aggr.MAD=zi.mad,e.aggr.mean=e.aggr.MEAN=zi.mean,e.aggr.mode=e.aggr.MODE=zi.mode,e.aggr.prod=e.aggr.PROD=zi.prod,e.aggr.median=e.aggr.MEDIAN=zi.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=zi.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=zi.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=vr.current_date,e.fn.current_time=e.fn.CURRENT_TIME=vr.current_time,e.fn.extract=e.fn.EXTRACT=vr.extract,e.fn.date=e.fn.DATE=vr.date,e.fn.date_format=e.fn.DATE_FORMAT=vr.date_format,e.fn.date_add=e.fn.DATE_ADD=vr.date_add,e.fn.date_sub=e.fn.DATE_SUB=vr.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=vr.date_diff,e.fn.now=e.fn.NOW=vr.now,e.fn.offset_utc=e.fn.OFFSET_UTC=vr.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=vr.get_server_time,e.fn.getdate=e.fn.GETDATE=vr.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=vr.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Xn.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Xn.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Xn.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Xn.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Xn.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Xn.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Xn.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Xn.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Xn.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Xn.geoNear}});var mC=T((Ple,hC)=>{"use strict";var Qc=require("lodash"),nr=require("alasql");nr.options.cache=!1;var _2=V_(),fC=require("clone"),$_=require("recursive-iterator"),Ee=W(),Ce=J(),Zo=On(),d2=U(),{hdb_errors:f2}=ee(),{getDatabases:EC}=(be(),te(Fe)),E2="IS NULL",Dn="There was a problem performing this search. Please check the logs and try again.";_2(nr);var xp=class{static{a(this,"SQLSearch")}constructor(t,r){if(Ce.isEmpty(t))throw Ee.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),Ce.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Ce.isEmptyOrZeroLength(n))return Ee.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw Ee.error("Error thrown from checkEmptySQL in SQLSearch class method search."),Ee.error(n),new Error(Dn)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw Ee.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),Ee.error(n),new Error(Dn)}if(Object.keys(this.data).length===0)return Ee.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw Ee.error("Error thrown from processJoins in SQLSearch class method search."),Ee.error(n),new Error(Dn)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw Ee.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),Ee.error(n),new Error(Dn)}try{return t=await this._finalSQL(),t}catch(n){throw Ee.error("Error thrown from finalSQL in SQLSearch class method search."),Ee.error(n),new Error(Dn)}}_getColumns(){let t=new $_(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(fC(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=Qc.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=EC()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Ce.isEmpty(this.statement.where)){Ee.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new $_(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Ce.isEmpty(r)&&r.right)if(Ce.isNotEmptyAndHasValue(r.right.value)){let n=Ce.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new nr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Ce.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new nr.yy.LogicValue({value:i}):n instanceof nr.yy.StringValue&&Ce.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new nr.yy.NumValue({value:i}))});if(t){Ee.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new $_(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!Ce.isEmpty(d2.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Ce.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Ce.isEmptyOrZeroLength(r.left.columnid)||Ce.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(Ce.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!Ce.isEmpty(r.right.value)||!Ce.isEmpty(r.left.value)?n.add(Ce.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let u=Array.isArray(r.right)?r.right:r.left;for(let _=0;_<u.length;_++)if(u[_].value)n.add(u[_].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(Ce.isEmptyOrZeroLength(this.all_table_attributes)&&Ce.isEmptyOrZeroLength(this.statement.from)&&Ce.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&Qc.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(Ce.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Ce.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(Ce.isEmptyOrZeroLength(this.all_table_attributes)&&!Ce.isEmptyOrZeroLength(this.columns.columns))return t;if(Ce.isEmptyOrZeroLength(this.all_table_attributes)&&Ce.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await nr.promise(r)}catch(r){throw Ee.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),Ee.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(fC(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(Ce.isEmptyOrZeroLength(Object.keys(this.columns)))return[];this._addFetchColumns(this.columns.joins);let t=null;try{t=this.statement.where?this.statement.where.toString():""}catch{throw new Error("Could not generate proper where clause")}this.columns.where&&this._addFetchColumns(this.columns.where);let r=this._isSimpleSelect();if(r?this._addFetchColumns(this.columns.columns):(!this.columns.where&&this.fetch_attributes.length===0)|t.indexOf(E2)>-1&&this.tables.forEach(s=>{let i={columnid:EC()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=Qc.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},u=!1,_=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(u=!0),!Ce.isEmpty(this.exact_search_values[_])&&!this.exact_search_values[_].ignore&&!Ce.isEmptyOrZeroLength(this.exact_search_values[_].values))if(u)try{c.hash_values=Array.from(this.exact_search_values[_].values);let l=await Zo.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 Ee.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Ee.error(l),new Error(Dn)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[_].values).map(async l=>{let d=Object.assign({},c);d.search_value=l;let f=await Zo.getDataByValue(d);for(let[E,h]of f)this.data[i].__merged_data[E]?this._updateMergedAttribute(i,E,s.attribute,h[s.attribute]):(this.data[i].__merged_data[E]=[...n[i]],this._updateMergedAttribute(i,E,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,E))}))}catch(l){throw Ee.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Ee.error(l),new Error(Dn)}else if(!Ce.isEmpty(this.comparator_search_values[_])&&!this.comparator_search_values[_].ignore&&!Ce.isEmptyOrZeroLength(this.comparator_search_values[_].comparators))try{let l=this.comparator_search_values[_].comparators;for(let d=0,f=l.length;d<f;d++){let E=l[d];c.search_attribute=E.attribute,c.search_value=E.search_value;let h=await Zo.getDataByValue(c,E.operation);if(u)for(let[p]of h)this.data[i].__merged_data[p]||(this.data[i].__merged_data[p]=[...n[i]],this._setMergedHashAttribute(i,p));else for(let[p,S]of h)this.data[i].__merged_data[p]?this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]):(this.data[i].__merged_data[p]=[...n[i]],this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]),this._setMergedHashAttribute(i,p))}}catch(l){throw Ee.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Ee.error(l),new Error(Dn)}else try{c.search_attribute=s.attribute,c.search_value="*";let l=await Zo.getDataByValue(c);if(u)for(let[d]of l)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,f]of l)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,f[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,f[s.attribute]),this._setMergedHashAttribute(i,d))}catch(l){throw Ee.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Ee.error(l),new Error(Dn)}}}_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 nr.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 nr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new nr.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 nr.yy.FuncValue:new nr.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(E=>{E.joinmode&&E.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(E.table);let h=E.joinmode+" JOIN ? AS "+(E.as?E.as:E.table.tableid);E.on&&(h+=" ON "+E.on.toString()),i.push(h),t.push(Object.values(this.data[`${E.table.databaseid_orig}_${E.table.as?E.table.as_orig:E.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(E=>{let h=this.data[`${E.databaseid_orig}_${E.as?E.as_orig:E.tableid_orig}`].__hash_name,p=E.as?E.as_orig:E.tableid_orig;o.push({key:`'${p}.${h}'`,schema:E.databaseid_orig,table:E.as?E.as_orig:E.tableid_orig,keys:new Set}),r.push(`${E.as?E.as:E.tableid}.\`${h}\` AS "${p}.${h}"`),c[E.as?E.as_orig:E.tableid_orig]=this.data[`${E.databaseid_orig}_${E.as?E.as_orig:E.tableid_orig}`].__merged_attributes});let u=this.statement.where?"WHERE "+this.statement.where:"";u=u.replace(/NOT\(NULL\)/g,"NOT NULL");let _="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(_="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(E=>{E.is_func?r.push(E.initial_select_column.toString()):E.initial_select_column.tableid?r.push(`${E.initial_select_column.tableid}.${E.initial_select_column.columnid} AS ${E.expression.columnid}`):r.push(`${E.initial_select_column.columnid} AS ${E.expression.columnid}`)}));let l="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(l=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let f=[];try{let E=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${u} ${_} ${l} ${d}`,h=this._convertColumnsToIndexes(E,s);f=await nr.promise(h,t),t=null}catch(E){throw Ee.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Ee.error(E),new Error("There was a problem processing the data.")}if(f&&f.length>0){for(let E=0,h=f.length;E<h;E++){let p=f[E];o.forEach(S=>{p[S.key]!==null&&p[S.key]!==void 0&&S.keys.add(p[S.key])})}o.forEach(E=>{let h=Object.keys(this.data[`${E.schema}_${E.table}`].__merged_data),p=Qc.difference(h,[...E.keys].map(S=>S.toString()));for(let S=0,O=p.length;S<O;S++){let g=p[S];delete this.data[`${E.schema}_${E.table}`].__merged_data[g]}})}return{existing_attributes:c,joined_length:f?f.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new $_(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=Qc.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 Ee.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),Ee.error(i),new Error(Dn)}}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 Zo.getDataByHash(c),_=s.columns.length;for(let l=0,d=o.length;l<d;l++){let f=o[l],E=u.get(f);for(let h=0;h<_;h++){let p=s.columns[h],S=E[p]===void 0?null:E[p];this.data[n].__merged_data[f].push(S)}}}}catch(r){throw Ee.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Ee.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();Ee.trace(`Final SQL: ${s}`),n=await nr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Ee.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Ee.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Ee.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 Ee.error(f2.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Ee.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 Zo.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 Ee.error("There was an error when processing this SQL operation. Check your logs"),Ee.error(o),new Error(Dn)}}return Object.values(Object.values(this.data)[0].__merged_data)}};hC.exports=xp});var jr=T((Ble,pC)=>{"use strict";var h2=eb();pC.exports={searchByConditions:p2,searchByHash:S2,searchByValue:T2,search:g2};var Fp=On(),{transformReq:qp}=J(),m2=mC();async function p2(e){return qp(e),Fp.searchByConditions(e)}a(p2,"searchByConditions");async function S2(e){qp(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of Fp.searchByHash(e))r&&t.push(r);return t}a(S2,"searchByHash");async function T2(e){qp(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of Fp.searchByValue(e))t.push(r);return t}a(T2,"searchByValue");function g2(e,t){try{let r=new h2(e);r.validate(),new m2(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(g2,"search")});var Y_=T((xle,SC)=>{"use strict";var R2=On();SC.exports={writeTransaction:A2};function A2(e,t,r){return R2.writeTransaction(e,t,r)}a(A2,"writeTransaction")});var AC=T((Gle,RC)=>{"use strict";var O2=jr(),b2=zs(),TC=W(),N2=Zr(),qle=Y_(),y2=require("clone"),kp=require("alasql"),w2=V_(),gC=require("util"),I2=gC.promisify(b2.getTableSchema),C2=gC.promisify(O2.search),D2=U(),Gp=J();w2(kp);RC.exports={update:M2};var L2="There was a problem performing this update. Please check the logs and try again.";async function M2({statement:e,hdb_user:t}){let r=await I2(e.table.databaseid,e.table.tableid),n=U2(e.columns);Gp.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=y2(s),c=Gp.isEmpty(i)?"":` WHERE ${i.toString()}`,u=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,_=kp.parse(u).statements[0],l=await C2(_),d=P2(n,l);return v2(o,d,t)}a(M2,"update");function U2(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=kp.compile(`SELECT ${r.expression.toString()} AS [${D2.FUNC_VAL}] FROM ?`)}),t}catch(t){throw TC.error(t),new Error(L2)}}a(U2,"createUpdateRecord");function P2(e,t){return Gp.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(P2,"buildUpdateRecords");async function v2(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await N2.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){TC.error(`Error delete new_attributes from update response: ${i}`)}return s}a(v2,"updateRecords")});var bC=T((Yle,OC)=>{var B2=require("alasql"),H2=jr(),x2=W(),F2=On(),$p=require("util"),Vp=J(),q2=U(),G2=zs(),Vle=Y_(),$le=Zr(),k2="record",V2="successfully deleted",$2=$p.callbackify(Q2),Y2=$p.promisify(H2.search),K2=$p.promisify(G2.getTableSchema);OC.exports={convertDelete:$2};function W2(e){return`${e.deleted_hashes.length} ${k2}${e.deleted_hashes.length===1?"":"s"} ${V2}`}a(W2,"generateReturnMessage");async function Q2({statement:e,hdb_user:t}){let r=await K2(e.table.databaseid,e.table.tableid);Vp.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=Vp.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=B2.parse(o).statements[0],u={operation:q2.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{u.records=await Y2(c);let _=await F2.deleteRecords(u);return Vp.isEmptyOrZeroLength(_.message)&&(_.message=W2(_)),delete _.txn_time,_}catch(_){throw x2.error(_),_.hdb_code?_.message:_}}a(Q2,"convertDelete")});var CC=T((Wle,IC)=>{"use strict";var z2=Ui(),{hdb_errors:NC}=ee(),{getDatabases:yC}=(be(),te(Fe));IC.exports={checkSchemaExists:wC,checkSchemaTableExists:J2,schema_describe:z2};async function wC(e){if(!yC()[e])return NC.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(wC,"checkSchemaExists");async function J2(e,t){let r=await wC(e);if(r)return r;if(!yC()[e][t])return NC.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(J2,"checkSchemaTableExists")});var zc=T((zle,X2)=>{X2.exports={name:"harperdb",version:"4.3.0-beta.3",description:"HarperDB is a distributed SQL & NoSQL data platform focused on speed, flexibility, and ease of use.",keywords:["database","sql","nosql","api","distributed","cloud","enterprise","Fastify","NATS"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.1","nats-server":"2.10.1"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive",build:"eslint -c ./.eslintbuild bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",pretty:"eslint --fix bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test"},dependencies:{"@aws-sdk/abort-controller":"3.374.0","@aws-sdk/client-s3":"3.477.0","@aws-sdk/lib-storage":"3.477.0","@endo/static-module-record":"^1.0.0","@fastify/autoload":"5.7.1","@fastify/compress":"~6.5.0","@fastify/cors":"~8.5.0","@fastify/static":"~6.11.2","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.5.4",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.1",fastify:"~4.25.1","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.8.1","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.11.0","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.6",jsonwebtoken:"9.0.2",lmdb:"2.10.0-beta.1",lodash:"4.17.21",mathjs:"11.11.2",minimist:"1.2.8",mkcert:"1.5.1",moment:"2.29.4","mqtt-packet":"~8.2.1",msgpackr:"1.10.1",nats:"2.17.0",needle:"3.2.0","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.1",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.3.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^0.18.0","serve-static":"1.15.0",ses:"1.0.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.21.20","tar-fs":"2.1.1",ulidx:"0.5.0",uuid:"9.0.1","validate.js":"0.13.1",ws:"8.15.1",yaml:"2.3.4"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"latest","@typescript-eslint/eslint-plugin":"^5.55.0","@typescript-eslint/parser":"^5.55.0",axios:"1.6.2",chai:"4.3.7","chai-integer":"0.1.0",esbuild:"^0.19.1",eslint:"8.22.0","eslint-config-prettier":"8.3.0","eslint-plugin-prettier":"3.4.1","eslint-plugin-radar":"0.2.1",eventsource:"^2.0.2","hook-std":"3.0.0","intercept-stdout":"0.1.2",mocha:"^10.2.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.7",newman:"5.3.2","newman-reporter-html":"1.0.5","newman-reporter-htmlextra":"^1.22.11","newman-reporter-teamcity":"^0.1.12","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"2.8.4",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.3.3","why-is-node-still-running":"^1.0.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},"newman-reporter-html":{newman:"5.3.2"},alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","utf-8-validate":"^5.0.10"}}});var Zc={};ke(Zc,{addAnalyticsListener:()=>jc,recordAction:()=>Br,recordActionBinary:()=>tn,setAnalyticsEnabled:()=>j2});function j2(e){FC=e}function Br(e,t,r,n,s){if(!FC)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=Q_.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},Q_.set(i,o)}K_||Z2()}function tn(e,t,r,n,s){Br(!!e,t,r,n,s)}function jc(e){kC.push(e)}function Z2(){K_=performance.now(),setTimeout(async()=>{let e=performance.now()-K_;K_=0;let t=[],r={time:Date.now(),period:e,threadId:Ji.threadId,metrics:t};for(let[s,i]of Q_){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 VC){let f=Math.floor(c*d),E=o[f-1];if(f>u){let h=f-u;if(E===l){let p=_[_.length-1];typeof p=="number"?_[_.length-1]={value:p,count:1+h}:p.count+=h}else _.push(h>1?{value:E,count:h}:E),l=E;u=f}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:_,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await $C()}let n=process.memoryUsage();t.push({metric:"memory",threadId:Ji.threadId,byThread:!0,...n});for(let s of kC)s(t);Q_=new Map,Ji.parentPort?Ji.parentPort.postMessage({type:GC,report:r}):WC({report:r})},qC).unref()}async function e4(e,t=6e4){let r=Wp(),n=YC(),s;for(let h of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(h.value?.time){s=h.value.time;break}if(Date.now()-t<s)return;let i,o=new Map,c=new Map,u=[],_;for(let{key:h,value:p}of r.primaryStore.getRange({start:s||!1,exclusiveStart:!0,end:1/0})){if(!p)continue;if(i){if(h>i+t)break}else i=h;_=h;let{metrics:S,threadId:O}=p;for(let g of S||[]){let{path:R,method:B,type:H,metric:v,count:M,total:$,distribution:K,threads:z,...se}=g;M||(M=1);let Te=v+(R?"-"+R:"");B!==void 0&&(Te+="-"+B),H!==void 0&&(Te+="-"+H);let oe=o.get(Te);if(oe){if(oe.threads){let de=oe.threads[O];if(de)oe=de;else{oe.threads[O]=Object.assign({},se);continue}}oe.count||(oe.count=1);let xe=oe.count;for(let de in se){let It=se[de];typeof It=="number"&&(oe[de]=(oe[de]*xe+It*M)/(xe+M))}oe.count+=M,$>=0&&(oe.total+=$,oe.ratio=oe.total/oe.count)}else oe=Object.assign({period:t},g),delete oe.distribution,o.set(Te,oe),oe.byThread&&(oe.threads=[],oe.threads[O]=Object.assign({},se),u.push(oe));if(K){K=K.map(de=>typeof de=="number"?{value:de,count:1}:de);let xe=c.get(Te);xe?xe.push(...K):c.set(Te,K)}}await $C()}for(let h of u){let{path:p,method:S,type:O,metric:g,count:R,total:B,distribution:H,threads:v,...M}=h;v=v.filter($=>$);for(let $ in M){if(typeof h[$]!="number")continue;let K=0;for(let z of v){let se=z[$];typeof se=="number"&&(K+=se)}h[$]=K}h.count=v.length,delete h.threads,delete h.byThread}for(let[h,p]of c){let S=o.get(h);p.sort((de,It)=>de.value>It.value?1:-1);let O=S.count-1,g=[],R=0,B=0,H;for(let de of VC){let It=O*de;for(;R<It;)H=p[B++],R+=H.count,B===1&&R--;let bl=p[B>1?B-2:0];H||(H=p[0]),g.push(H.value-(H.value-bl.value)*(R-It)/H.count)}let[v,M,$,K,z,se,Te,oe,xe]=g;Object.assign(S,{p1:v,p10:M,p25:$,median:K,p75:z,p90:se,p95:Te,p99:oe,p999:xe})}let l;for(let[h,p]of o)p.id=(0,W_.getNextMonotonicTime)(),p.time=_,n.primaryStore.put(p.id,p,{append:!0}).then(S=>{S||n.primaryStore.put(p.id,p)}),l=!0;let d=Date.now(),{idle:f,active:E}=performance.eventLoopUtilization();if(l||E*10>f){let h=(0,W_.getNextMonotonicTime)(),p={id:h,metric:"main-thread-utilization",idle:f-DC,active:E-LC,time:d,...process.memoryUsage()};n.primaryStore.put(h,p,{append:!0}).then(S=>{S||n.primaryStore.put(h,p)})}DC=f,LC=E}async function MC(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function Wp(){return UC||(UC=ot({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function YC(){return PC||(PC=ot({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function n4(){KC=!0;let e=(0,Xc.get)(Kp.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await e4(qC,e),await MC(Wp(),t4),await MC(YC(),r4)},Math.min(e/2,2147483647)).unref()}function WC(e,t){let r=e.report;r.threadId=t?.threadId||Ji.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(vC+=n.mean*n.count);r.totalBytesProcessed=vC,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(BC.get(t))}),BC.set(t,t.performance.eventLoopUtilization())),r.id=(0,W_.getNextMonotonicTime)(),Wp().primaryStore.put(r.id,r),KC||n4(),s4&&(QC=o4(r))}async function o4(e){if(await QC,!ri){let r=(0,Jc.dirname)((0,xC.getLogFilePath)());try{ri=await(0,Yp.open)((0,Jc.join)(r,"analytics.log"),"r+")}catch{ri=await(0,Yp.open)((0,Jc.join)(r,"analytics.log"),"w+")}}let t=(await ri.stat()).size;if(t>i4){let r=Buffer.alloc(t);await ri.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await ri.write(r,{position:0}),await ri.truncate(r.length),t=r.length}await ri.write(JSON.stringify(e)+`
|
|
8
|
+
`,t)}var Ji,HC,xC,Jc,Yp,W_,Xc,Kp,Q_,FC,K_,qC,GC,kC,VC,DC,LC,$C,t4,r4,UC,PC,KC,vC,BC,s4,QC,ri,i4,Rs=Oe(()=>{Ji=require("worker_threads"),HC=x(je());be();xC=x(W()),Jc=require("path"),Yp=require("fs/promises"),W_=x(Nr()),Xc=x(Z()),Kp=x(U());jt();(0,Xc.initSync)();Q_=new Map,FC=(0,Xc.get)(Kp.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(j2,"setAnalyticsEnabled");a(Br,"recordAction");Xe.recordAnalytics=Br;a(tn,"recordActionBinary");K_=0,qC=1e3,GC="analytics-report",kC=[];a(jc,"addAnalyticsListener");VC=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(Z2,"sendAnalytics");a(e4,"aggregation");DC=0,LC=0,$C=a(()=>new Promise(setImmediate),"rest");a(MC,"cleanup");t4=36e5,r4=31536e6;a(Wp,"getRawAnalyticsTable");a(YC,"getAnalyticsTable");(0,HC.setChildListenerByType)(GC,WC);a(n4,"startScheduledTasks");vC=0,BC=new Map,s4=!1;a(WC,"recordAnalytics");i4=1e6;a(o4,"logAnalytics")});var At=T((u_e,ED)=>{"use strict";var Ht=Z();Ht.initSync();var a4=require("fs-extra"),c4=require("semver"),ru=require("path"),{monotonicFactory:u4}=require("ulidx"),JC=u4(),l4=require("util"),XC=require("child_process"),_4=l4.promisify(XC.exec),d4=XC.spawn,ye=tt(),Pe=U(),Xp=J(),Hr=W(),z_=ms(),f4=Y_(),eu=Lr(),{onMessageByType:E4}=je(),{isMainThread:h4}=require("worker_threads"),{Encoder:m4,decode:jp}=require("msgpackr"),jC=new m4,{isEmpty:eo}=Xp,ZC=en(),p4=48*36e11,S4=5e9;h4&&E4(Pe.ITC_EVENT_TYPES.RESTART,()=>{rn=void 0,Zi=void 0});var{connect:T4,StorageType:eD,RetentionPolicy:tD,AckPolicy:J_,DeliverPolicy:X_,DiscardPolicy:g4,NatsConnection:i_e,JetStreamManager:o_e,JetStreamClient:a_e,StringCodec:c_e,JSONCodec:R4,createInbox:Zp,headers:A4,ErrorCode:zC}=require("nats"),{PACKAGE_ROOT:O4}=U(),b4=zc(),{recordAction:N4}=(Rs(),te(Zc)),rD=R4(),y4="clustering",w4=b4.engines[ye.NATS_SERVER_NAME],I4=ru.join(O4,"dependencies"),Jp=ru.join(I4,`${process.platform}-${process.arch}`,ye.NATS_BINARY_NAME),Qp,zp,tu,Xi,ji;ED.exports={runCommand:nD,checkNATSServerInstalled:C4,createConnection:eS,getConnection:j_,getJetStreamManager:nu,getJetStream:iD,getNATSReferences:sr,getServerList:L4,createLocalStream:tS,listStreams:oD,deleteLocalStream:M4,getServerConfig:su,listRemoteStreams:U4,viewStream:P4,viewStreamIterator:v4,publishToStream:B4,createWorkQueueStream:H4,addSourceToWorkStream:cD,request:F4,removeSourceFromWorkStream:lD,reloadNATS:rS,reloadNATSHub:q4,reloadNATSLeaf:G4,extractServerName:uD,requestErrorHandler:k4,updateWorkStream:V4,createLocalTableStream:dD,createTableStreams:$4,purgeTableStream:fD,purgeSchemaTableStreams:Y4,getStreamInfo:K4,updateLocalStreams:Q4,closeConnection:D4,getJsmServerName:iu,addNatsMsgHeader:aD,updateIngestStreamConsumer:x4,clearClientCache:sD};async function nD(e,t=void 0){let{stdout:r,stderr:n}=await _4(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
9
9
|
`,""));return r.replace(`
|
|
10
|
-
`,"")}a(eD,"runCommand");async function y4(){try{await s4.access(Jp)}catch{return!1}let e=await eD(`${Jp} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return i4.eq(t,b4)}a(y4,"checkNATSServerInstalled");async function eS(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await JC.getClusterUser();if(ji(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}Br.trace("create nats connection called");let i=await m4({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:xt.get(Pe.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:xt.get(Pe.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:xt.get(Pe.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),Br.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&Br.error("Error with Nats client connection, connection closed",o),tD()}),i}a(eS,"createConnection");function tD(){tn=void 0,zi=void 0,Ji=void 0,Xi=void 0}a(tD,"clearClientCache");async function w4(){tn&&(await tn.drain(),tn=void 0,zi=void 0,Ji=void 0,Xi=void 0)}a(w4,"closeConnection");var tn,Xi;async function j_(){return Xi||(Xi=eS(xt.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),tn=await Xi),tn||Xi}a(j_,"getConnection");async function eu(){if(zi)return zi;ji(tn)&&await j_();let{domain:e}=tu(Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ji(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return zi=await tn.jetstreamManager({domain:e,timeout:6e4}),zi}a(eu,"getJetStreamManager");async function rD(){if(Ji)return Ji;ji(tn)&&await j_();let{domain:e}=tu(Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ji(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Ji=tn.jetstream({domain:e,timeout:6e4}),Ji}a(rD,"getJetStream");async function ir(){let e=tn||await j_(),t=zi||await eu(),r=Ji||await rD();return{connection:e,jsm:t,js:r}}a(ir,"getNATSReferences");async function I4(e){let t=xt.get(Pe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await JC.getClusterUser(),s=await eS(t,r,n),i=Zp(),o=s.subscribe(i),c=[],u,_=(async()=>{for await(let l of o){let d=ZC.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 Xp.async_set_timeout(e),await o.drain(),await s.close(),await _,c}a(I4,"getServerList");async function tS(e,t){let{jsm:r}=await ir(),n=xt.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=xt.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=xt.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:XC.File,retention:jC.Limits,subjects:t,discard:p4.Old,max_msgs:s,max_bytes:i,max_age:n})}a(tS,"createLocalStream");async function nD(){let{jsm:e}=await ir(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(nD,"listStreams");async function C4(e){let{jsm:t}=await ir();await t.streams.delete(e)}a(C4,"deleteLocalStream");async function D4(e){let{connection:t}=await ir(),r=[],n=Zp(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(ZC.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(D4,"listRemoteStreams");async function L4(e,t=void 0,r=void 0){let{jsm:n,js:s}=await ir(),i=WC(),o={durable_name:i,ack_policy:J_.Explicit};t&&(o.deliver_policy=X_.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=jp(l.data),f={nats_timestamp:l.info.timestampNanos,nats_sequence:l.info.streamSequence,entry:d};if(l.headers&&(f.origin=l.headers.get(ye.MSG_HEADERS.ORIGIN)),_.push(f),l.ack(),l.info.pending===0)break}return await c.delete(),_}a(L4,"viewStream");async function*M4(e,t=void 0,r=void 0){let{jsm:n,js:s}=await ir(),i=WC(),o={durable_name:i,ack_policy:J_.Explicit};t&&(o.deliver_policy=X_.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=jp(_.data);l[0]||(l=[l]);for(let d of l){let f={nats_timestamp:_.info.timestampNanos,nats_sequence:_.info.streamSequence,entry:d};_.headers&&(f.origin=_.headers.get(ye.MSG_HEADERS.ORIGIN)),yield f}if(_.ack(),_.info.pending===0)break}await c.delete()}a(M4,"viewStreamIterator");async function U4(e,t,r,n){Br.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=sD(n,r);let{js:s}=await ir(),i=await ru(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:zC.encode(n);try{Br.trace(`publishToStream publishing to subject: ${o}`),A4(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 cD(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(u.code&&u.code.toString()==="503"){Br.trace(`publishToStream creating stream: ${t}`);let l=o.split(".");l[2]="*",await tS(t,[o]),await s.publish(o,c,{headers:r})}else throw u}});throw u}}a(U4,"publishToStream");function sD(e,t){t===void 0&&(t=T4());let r=xt.get(Pe.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(ye.MSG_HEADERS.ORIGIN)&&r&&t.append(ye.MSG_HEADERS.ORIGIN,r),t}a(sD,"addNatsMsgHeader");function tu(e){e=e.toLowerCase();let t=Zc.join(xt.get(Pe.CONFIG_PARAMS.ROOTPATH),O4);if(e===Pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return ji(zp)&&(zp={port:Xc.getConfigFromFile(Pe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:Xc.getConfigFromFile(Pe.CONFIG_PARAMS.CLUSTERING_NODENAME)+ye.SERVER_SUFFIX.HUB,config_file:ye.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:Zc.join(t,ye.PID_FILES.HUB),hdb_nats_path:t}),zp;if(e===Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return ji(Qp)&&(Qp={port:Xc.getConfigFromFile(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:Xc.getConfigFromFile(Pe.CONFIG_PARAMS.CLUSTERING_NODENAME)+ye.SERVER_SUFFIX.LEAF,config_file:ye.NATS_CONFIG_FILES.LEAF_SERVER,domain:Xc.getConfigFromFile(Pe.CONFIG_PARAMS.CLUSTERING_NODENAME)+ye.SERVER_SUFFIX.LEAF,pid_file_path:Zc.join(t,ye.PID_FILES.LEAF),hdb_nats_path:t}),Qp;Br.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(tu,"getServerConfig");async function P4(e){let{jsm:t}=await ir(),r=await ru();try{await t.streams.add({name:e.stream_name,storage:XC.File,retention:jC.Limits,max_age:E4,max_bytes:h4,subjects:[`${ye.SUBJECT_PREFIXES.TXN}.${e.stream_name}.${r}`]})}catch(n){if(n.code!=="400")throw n}try{await t.consumers.info(e.stream_name,e.durable_name)}catch(n){if(n.code.toString()==="404")await t.consumers.add(e.stream_name,{ack_policy:J_.Explicit,durable_name:e.durable_name,deliver_policy:X_.All,max_ack_pending:1e4});else throw n}}a(P4,"createWorkQueueStream");async function v4(){let{jsm:e}=await ir();(await e.consumers.info(ye.WORK_QUEUE_CONSUMER_NAMES.stream_name,ye.WORK_QUEUE_CONSUMER_NAMES.durable_name)).config.deliver_subject&&(Br.info("Removing old nats push consumer from ingest stream"),await e.consumers.delete(ye.WORK_QUEUE_CONSUMER_NAMES.stream_name,ye.WORK_QUEUE_CONSUMER_NAMES.durable_name),Br.info("Adding pull consumer to ingest stream"),await e.consumers.add(ye.WORK_QUEUE_CONSUMER_NAMES.stream_name,{ack_policy:J_.Explicit,durable_name:ye.WORK_QUEUE_CONSUMER_NAMES.durable_name,deliver_policy:X_.All,max_ack_pending:1e4}))}a(v4,"updateIngestStreamConsumer");async function iD(e,t,r){let{jsm:n}=await ir(),s=await n.streams.info(t),i=oD(n.prefix),o=r.start_time?r.start_time:new Date(Date.now()).toISOString(),{schema:c,table:u}=r,_=z_.createNatsTableStreamName(c,u),l=i===e,d,f,E=!1;if(!Array.isArray(s.config.sources)||s.config.sources.length===0)s.config.sources=[];else for(let p=0,S=s.config.sources.length;p<S;p++)if(d=s.config.sources[p],f=p,l&&d.name===_||!l&&d.name===_&&d.external&&d.external.api===`$JS.${e}.API`){E=!0;break}if(E===!0){if(d.opt_start_time===o)return;let p=`txn.${c}.${u}.${e}`;await n.streams.purge(t,{filter:p}),s.config.sources.splice(f,1),await n.streams.update(t,s.config)}let h={name:_,opt_start_time:o,filter_subject:`${ye.SUBJECT_PREFIXES.TXN}.>`};l||(h.external={api:`$JS.${e}.API`,deliver:""}),s.config.sources.push(h),await n.streams.update(t,s.config)}a(iD,"addSourceToWorkStream");function oD(e){return e.split(".")[1]}a(oD,"extractServerName");async function aD(e,t,r){let{jsm:n}=await ir(),{schema:s,table:i}=r,o=`txn.${s}.${i}.${e}`;await n.streams.purge(t,{filter:o});let c=z_.createNatsTableStreamName(s,i),u=await n.streams.info(t);if(!Array.isArray(u.config.sources)||u.config.sources.length===0)return;let _=u.config.sources.length,l;for(;_--;)if(l=u.config.sources[_],l.name===c&&l.external.api===`$JS.${e}.API`){u.config.sources.splice(_,1);break}await n.streams.update(t,u.config)}a(aD,"removeSourceFromWorkStream");async function B4(e,t,r=6e4,n=Zp()){if(!Xp.isObject(t))throw new Error("data param must be an object");let s=zC.encode(t),{connection:i}=await ir(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return jp(c.data)}a(B4,"request");function rS(e){return new Promise(async(t,r)=>{let n=u4(Jp,["--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(rS,"reloadNATS");async function H4(){let{pid_file_path:e}=tu(Pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await rS(e)}a(H4,"reloadNATSHub");async function x4(){let{pid_file_path:e}=tu(Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await rS(e)}a(x4,"reloadNATSLeaf");function F4(e,t,r){let n;switch(e.code){case KC.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case KC.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(F4,"requestErrorHandler");async function q4(e,t){let r=t+ye.SERVER_SUFFIX.LEAF;await cD(async()=>{e.subscribe===!0?await iD(r,ye.WORK_QUEUE_CONSUMER_NAMES.stream_name,e):await aD(r,ye.WORK_QUEUE_CONSUMER_NAMES.stream_name,e)})}a(q4,"updateWorkStream");function cD(e){return l4.writeTransaction(Pe.SYSTEM_SCHEMA_NAME,Pe.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(cD,"exclusiveLock");async function uD(e,t){let r=z_.createNatsTableStreamName(e,t),n=await ru(),s=$4(e,t,n);await tS(r,[s])}a(uD,"createLocalTableStream");async function G4(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await uD(n,s)}}a(G4,"createTableStreams");async function lD(e,t,r=!1){if(xt.get(Pe.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=z_.createNatsTableStreamName(e,t),{jsm:s}=await ir();r?await s.streams.purge(ye.WORK_QUEUE_CONSUMER_NAMES.stream_name):await s.streams.purge(n)}catch(n){if(n.message==="stream not found")Br.warn(n);else throw n}}a(lD,"purgeTableStream");async function k4(e,t){if(xt.get(Pe.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await lD(e,t[r])}a(k4,"purgeSchemaTableStreams");async function V4(e){return(await eu()).streams.info(e)}a(V4,"getStreamInfo");function $4(e,t,r){return`${ye.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a($4,"createSubjectName");async function ru(){if(jc)return jc;if(jc=(await eu())?.nc?.info?.server_name,jc===void 0)throw new Error("Unable to get jetstream manager server name");return jc}a(ru,"getJsmServerName");async function Y4(){let e=await eu(),t=await ru(),r=await nD();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=K4(n),c=i.split(".");if(!(c[c.length-1]===t&&!o)){if(s.name===ye.SCHEMA_QUEUE_CONSUMER_NAMES.stream_name){let _=`${ye.SCHEMA_QUEUE_CONSUMER_NAMES.deliver_subject}.${t}`;Br.trace(`Updating stream subject name from: ${i} to: ${_}`),s.subjects[0]=_}else if(s.name===ye.WORK_QUEUE_CONSUMER_NAMES.stream_name){let _=`${ye.WORK_QUEUE_CONSUMER_NAMES.stream_name}.${t}`;Br.trace(`Updating stream subject name from: ${i} to: ${_}`),s.subjects[0]=_}else{let _=i.split(".");_[_.length-1]=t;let l=_.join(".");Br.trace(`Updating stream subject name from: ${i} to: ${l}`),s.subjects[0]=l}await e.streams.update(s.name,s)}}}a(Y4,"updateLocalStreams");function K4(e){let{config:t}=e,r=!1;if(t.name===ye.SCHEMA_QUEUE_CONSUMER_NAMES.stream_name||t.name===ye.WORK_QUEUE_CONSUMER_NAMES.stream_name)return r;let n=xt.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=xt.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=xt.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(K4,"updateStreamLimits")});var rd=g((d_e,hD)=>{"use strict";var jo=n_(),Zo=yC(),W4=Y(),Q4=require("uuid").v4,__e=require("clone"),ed=hs(),ea=M(),z4=require("util"),ti=Rn(),{handleHDBError:or,hdb_errors:J4}=ee(),{HDB_ERROR_MSGS:Z_,HTTP_STATUS_CODES:ar}=J4,{SchemaEventMsg:td}=bn(),dD=Rt(),{getDatabases:X4}=(be(),te(Fe)),{transformReq:ta}=J();hD.exports={createSchema:j4,createSchemaStructure:fD,createTable:Z4,createTableStructure:ED,createAttribute:s3,dropSchema:e3,dropTable:t3,dropAttribute:r3,getBackup:i3};async function j4(e){let t=await fD(e);return ed.signalSchemaChange(new td(process.pid,e.operation,e.schema)),t}a(j4,"createSchema");async function fD(e){let t=jo.schema_object(e);if(t)throw or(t,t.message,ar.BAD_REQUEST,void 0,void 0,!0);if(ta(e),!await Zo.checkSchemaExists(e.schema))throw or(new Error,Z_.SCHEMA_EXISTS_ERR(e.schema),ar.BAD_REQUEST,ea.LOG_LEVELS.ERROR,Z_.SCHEMA_EXISTS_ERR(e.schema),!0);return await ti.createSchema(e),`database '${e.schema}' successfully created`}a(fD,"createSchemaStructure");async function Z4(e){return ta(e),e.hash_attribute=e.primary_key??e.hash_attribute,await ED(e)}a(Z4,"createTable");async function ED(e){let t=jo.create_table_object(e);if(t)throw or(t,t.message,ar.BAD_REQUEST,void 0,void 0,!0);if(jo.validateTableResidence(e.residence),!await Zo.checkSchemaTableExists(e.schema,e.table))throw or(new Error,Z_.TABLE_EXISTS_ERR(e.schema,e.table),ar.BAD_REQUEST,ea.LOG_LEVELS.ERROR,Z_.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Q4(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await ti.createTable(n,e);else throw or(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",ar.BAD_REQUEST);else await ti.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(ED,"createTableStructure");async function e3(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=jo.schema_object(e),n=t??r;if(n)throw or(n,n.message,ar.BAD_REQUEST,void 0,void 0,!0);ta(e);let s=await Zo.checkSchemaExists(e.schema);if(s)throw or(new Error,s,ar.NOT_FOUND,ea.LOG_LEVELS.ERROR,s,!0);let i=await Zo.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);return await ti.dropSchema(e),ed.signalSchemaChange(new td(process.pid,e.operation,e.schema)),await dD.purgeSchemaTableStreams(e.schema,o),`successfully deleted '${e.schema}'`}a(e3,"dropSchema");async function t3(e){let t=jo.table_object(e);if(t)throw or(t,t.message,ar.BAD_REQUEST,void 0,void 0,!0);ta(e);let r=await Zo.checkSchemaTableExists(e.schema,e.table);if(r)throw or(new Error,r,ar.NOT_FOUND,ea.LOG_LEVELS.ERROR,r,!0);return await ti.dropTable(e),await dD.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(t3,"dropTable");async function r3(e){let t=jo.attribute_object(e);if(t)throw or(t,t.message,ar.BAD_REQUEST,void 0,void 0,!0);ta(e);let r=await Zo.checkSchemaTableExists(e.schema,e.table);if(r)throw or(new Error,r,ar.NOT_FOUND,ea.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw or(new Error,"You cannot drop a hash attribute",ar.BAD_REQUEST,void 0,void 0,!0);if(ea.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw or(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,ar.BAD_REQUEST,void 0,void 0,!0);try{return await ti.dropAttribute(e),n3(e),ed.signalSchemaChange(new td(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw W4.error(`Got an error deleting attribute ${z4.inspect(e)}.`),n}}a(r3,"dropAttribute");function n3(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(n3,"dropAttributeFromGlobal");async function s3(e){ta(e);let t=X4()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw or(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,ar.BAD_REQUEST,void 0,void 0,!0);return await ti.createAttribute(e),ed.signalSchemaChange(new td(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(s3,"createAttribute");function i3(e){return ti.getBackup(e)}a(i3,"getBackup")});var pD=g((E_e,mD)=>{"use strict";var{OPERATIONS_ENUM:o3}=M(),nS=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=o3.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};mD.exports=nS});var sS=g((p_e,AD)=>{"use strict";var a3=Rn(),m_e=pD(),nd=J(),sd=M(),c3=Z(),{handleHDBError:SD,hdb_errors:u3}=ee(),{HDB_ERROR_MSGS:TD,HTTP_STATUS_CODES:gD}=u3,l3=Object.values(sd.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),RD="To use this operation audit log must be enabled in harperdb-config.yaml";AD.exports=_3;async function _3(e){if(nd.isEmpty(e.schema))throw new Error(TD.SCHEMA_REQUIRED_ERR);if(nd.isEmpty(e.table))throw new Error(TD.TABLE_REQUIRED_ERR);if(!c3.get(sd.CONFIG_PARAMS.LOGGING_AUDITLOG))throw SD(new Error,RD,gD.BAD_REQUEST,sd.LOG_LEVELS.ERROR,RD,!0);let t=nd.checkSchemaTableExist(e.schema,e.table);if(t)throw SD(new Error,t,gD.NOT_FOUND,sd.LOG_LEVELS.ERROR,t,!0);if(!nd.isEmpty(e.search_type)&&l3.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await a3.readAuditLog(e)}a(_3,"readAuditLog")});var bD=g((T_e,OD)=>{"use strict";var{OPERATIONS_ENUM:d3}=M(),iS=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=d3.GET_BACKUP,this.schema=t,this.table=r}};OD.exports=iS});var wD=g((O_e,yD)=>{"use strict";var f3=Rn(),R_e=bD(),oS=J(),E3=M(),A_e=Z(),{handleHDBError:h3,hdb_errors:m3}=ee(),{HDB_ERROR_MSGS:ND,HTTP_STATUS_CODES:p3}=m3;yD.exports=S3;async function S3(e){if(oS.isEmpty(e.schema))throw new Error(ND.SCHEMA_REQUIRED_ERR);if(oS.isEmpty(e.table))throw new Error(ND.TABLE_REQUIRED_ERR);let t=oS.checkSchemaTableExist(e.schema,e.table);if(t)throw h3(new Error,t,p3.NOT_FOUND,E3.LOG_LEVELS.ERROR,t,!0);return await f3.getBackup(read_audit_log_object)}a(S3,"getBackup")});var UD=g((N_e,MD)=>{var ri=require("validate.js"),CD=et(),ra=M(),{handleHDBError:T3,hdb_errors:g3}=ee(),{HDB_ERROR_MSGS:ct,HTTP_STATUS_CODES:R3}=g3,aS=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),A3={STRUCTURE_USER:"structure_user"},ID=Object.values(ra.ROLE_TYPES_ENUM),O3="attribute_permissions",b3="attribute_name",{PERMS_CRUD_ENUM:na}=ra,N3=[O3,...Object.values(na)],DD=[na.READ,na.INSERT,na.UPDATE],y3=[b3,...DD];function w3(e){let t=aS();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,LD(e,t)}a(w3,"addRoleValidation");function I3(e){let t=aS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,LD(e,t)}a(I3,"alterRoleValidation");function C3(e){let t=aS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,CD.validateObject(e,t)}a(C3,"dropRoleValidation");var D3=["operation","role","id","permission","hdb_user","hdb_auth_header"];function LD(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)D3.includes(n[o])||s.push(n[o]);s.length>0&&ft(ct.INVALID_ROLE_JSON_KEYS(s),r);let i=CD.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{ft(o,r)}),e.permission){let o=L3(e);o&&ft(o,r),ID.forEach(c=>{e.permission[c]&&!ri.isBoolean(e.permission[c])&&ft(ct.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(ID.indexOf(o)<0){if(o===A3.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]||ft(ct.SCHEMA_NOT_FOUND(d),r)}continue}ft(ct.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){ft(ct.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]){ft(ct.TABLE_NOT_FOUND(o,u),r);continue}if(Object.keys(_).forEach(l=>{N3.includes(l)||ft(ct.INVALID_PERM_KEY(l),r,o,u)}),Object.values(na).forEach(l=>{ri.isDefined(_[l])?ri.isBoolean(_[l])||ft(ct.TABLE_PERM_NOT_BOOLEAN(l),r,o,u):ft(ct.TABLE_PERM_MISSING(l),r,o,u)}),ri.isDefined(_.attribute_permissions)){if(!ri.isArray(_.attribute_permissions)){ft(ct.ATTR_PERMS_NOT_ARRAY,r,o,u);continue}}else{ft(ct.ATTR_PERMS_ARRAY_MISSING,r,o,u);continue}if(_.attribute_permissions){let l=global.hdb_schema[o][u].attributes.map(({attribute:f})=>f),d={read:!1,insert:!1,update:!1};for(let f in _.attribute_permissions){let E=_.attribute_permissions[f];if(Object.keys(E).forEach(p=>{!y3.includes(p)&&p!==na.DELETE&&ft(ct.INVALID_ATTR_PERM_KEY(p),r,o,u)}),!ri.isDefined(E.attribute_name)){ft(ct.ATTR_PERM_MISSING_NAME,r,o,u);continue}let h=E.attribute_name;if(!l.includes(h)){ft(ct.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,u);continue}DD.forEach(p=>{ri.isDefined(E[p])?ri.isBoolean(E[p])||ft(ct.ATTR_PERM_NOT_BOOLEAN(p,h),r,o,u):ft(ct.ATTR_PERM_MISSING(p,h),r,o,u)}),!d.read&&E.read===!0&&(d.read=!0),!d.insert&&E.insert===!0&&(d.insert=!0),!d.update&&E.update===!0&&(d.update=!0)}if(_.read===!1&&d.read===!0||_.insert===!1&&d.insert===!0||_.update===!1&&d.update===!0){let f=`${o}.${u}`;ft(ct.MISMATCHED_TABLE_ATTR_PERMS(f),r,o,u)}}}}return M3(r)}a(LD,"customValidate");MD.exports={addRoleValidation:w3,alterRoleValidation:I3,dropRoleValidation:C3};function L3(e){let{operation:t,permission:r}=e;if(t===ra.OPERATIONS_ENUM.ADD_ROLE||t===ra.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 ct.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?ra.ROLE_TYPES_ENUM.SUPER_USER:ra.ROLE_TYPES_ENUM.CLUSTER_USER;return ct.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(L3,"validateNoSUPerms");function M3(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:ct.ROLE_PERMS_ERROR,...e};return T3(new Error,n,R3.BAD_REQUEST)}else return null}a(M3,"generateRolePermResponse");function ft(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(ft,"addPermError")});var fS=g((w_e,HD)=>{"use strict";var PD=jr(),vD=Xr(),U3=Bi(),uS=UD(),lS=hs(),P3=require("uuid").v4,v3=require("util"),id=M(),B3=J(),_S=vD.searchByValue,H3=vD.searchByHash,x3=v3.promisify(U3.delete),F3=Kn(),q3=zo(),{hdb_errors:G3,handleHDBError:Zi}=ee(),{HDB_ERROR_MSGS:BD,HTTP_STATUS_CODES:nu}=G3,{UserEventMsg:dS}=bn();HD.exports={addRole:k3,alterRole:V3,dropRole:$3,listRoles:Y3};function cS(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(cS,"scrubRoleDetails");async function k3(e){let t=uS.addRoleValidation(e);if(t)throw t;e=cS(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 _S(r)||[])}catch(i){throw Zi(i)}if(n&&n.length>0)throw Zi(new Error,BD.ROLE_ALREADY_EXISTS(e.role),nu.CONFLICT,void 0,void 0,!0);e.id||(e.id=P3());let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await PD.insert(s),lS.signalUserChange(new dS(process.pid)),e=cS(e),e}a(k3,"addRole");async function V3(e){let t=uS.alterRoleValidation(e);if(t)throw t;e=cS(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await PD.update(r)}catch(s){throw Zi(s)}if(n&&n?.message==="updated 0 of 1 records")throw Zi(new Error,"Invalid role id",nu.BAD_REQUEST,void 0,void 0,!0);return await lS.signalUserChange(new dS(process.pid)),e}a(V3,"alterRole");async function $3(e){let t=uS.dropRoleValidation(e);if(t)throw Zi(new Error,t,nu.BAD_REQUEST,void 0,void 0,!0);let r=new q3(id.SYSTEM_SCHEMA_NAME,id.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await H3(r));if(n.length===0)throw Zi(new Error,BD.ROLE_NOT_FOUND,nu.NOT_FOUND,void 0,void 0,!0);let s=new F3(id.SYSTEM_SCHEMA_NAME,id.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await _S(s)),o=!1;if(B3.isEmptyOrZeroLength(i)===!1){for(let u=0;u<i.length;u++)if(i[u].active===!0){o=!0;break}}if(o===!0)throw Zi(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 x3(c),lS.signalUserChange(new dS(process.pid)),`${n[0].role} successfully deleted`}a($3,"dropRole");async function Y3(){return _S({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Y3,"listRoles")});var GD=g((C_e,qD)=>{"use strict";var K3=Z(),ni=require("joi"),W3=et(),xD=require("moment"),Q3=require("fs-extra"),ES=require("path"),z3=require("lodash"),su=M(),{LOG_LEVELS:eo}=M(),J3="YYYY-MM-DD hh:mm:ss",X3=ES.resolve(__dirname,"../logs");qD.exports=function(e){return W3.validateBySchema(e,j3)};var j3=ni.object({from:ni.custom(FD),until:ni.custom(FD),level:ni.valid(eo.NOTIFY,eo.FATAL,eo.ERROR,eo.WARN,eo.INFO,eo.DEBUG,eo.TRACE),order:ni.valid("asc","desc"),limit:ni.number().min(1),start:ni.number().min(0),log_name:ni.custom(Z3)});function FD(e,t){if(xD(e,xD.ISO_8601).format(J3)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(FD,"validateDatetime");function Z3(e,t){if(z3.invert(su.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=K3.get(su.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?su.LOG_NAMES.HDB:e,i=s===su.LOG_NAMES.INSTALL?ES.join(X3,su.LOG_NAMES.INSTALL):ES.join(n,s);return Q3.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Z3,"validateReadLogPath")});var mS=g((L_e,VD)=>{"use strict";var od=M(),eX=Y(),tX=Z(),rX=GD(),hS=require("path"),kD=require("fs-extra"),{once:nX}=require("events"),{handleHDBError:sX,hdb_errors:iX}=ee(),{PACKAGE_ROOT:oX}=M(),aX=hS.join(oX,"logs"),cX=1e3,uX=200;VD.exports=lX;async function lX(e){let t=rX(e);if(t)throw sX(t,t.message,iX.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=tX.get(od.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?od.LOG_NAMES.HDB:e.log_name,s=n===od.LOG_NAMES.INSTALL?hS.join(aX,od.LOG_NAMES.INSTALL):hS.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?cX:e.limit,f=e.order===void 0?void 0:e.order,E=e.start===void 0?0:e.start,h=E+d,p=0;f==="desc"&&!u&&!l&&(p=Math.max(kD.statSync(s).size-(h+5)*uX,0));let S=kD.createReadStream(s,{start:p});S.on("error",v=>{eX.error(v)});let T=0,A=[],b="",H;S.on("data",v=>{let P=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;v=b+v;let z=0,W;for(;(W=P.exec(v))&&!S.destroyed;){H&&(H.message=v.slice(z,W.index),F(H));let[Q,se,pe]=W,oe=pe.split("] ["),xe=oe[0],le=oe[1];oe.splice(0,2),H={timestamp:se,thread:xe,level:le,tags:oe,message:""},z=W.index+Q.length}b=v.slice(z)}),S.on("end",v=>{S.destroyed||H&&(H.message=b.trim(),F(H))}),S.resume();function F(v){let P,z,W;switch(!0){case(i&&c&&_):P=new Date(v.timestamp),z=new Date(u),W=new Date(l),v.level===o&&P>=z&&P<=W&&T<E?T++:v.level===o&&P>=z&&P<=W&&(si(v,f,A),T++,T===h&&S.destroy());break;case(i&&c):P=new Date(v.timestamp),z=new Date(u),v.level===o&&P>=z&&T<E?T++:v.level===o&&P>=z&&(si(v,f,A),T++,T===h&&S.destroy());break;case(i&&_):P=new Date(v.timestamp),W=new Date(l),v.level===o&&P<=W&&T<E?T++:v.level===o&&P<=W&&(si(v,f,A),T++,T===h&&S.destroy());break;case(c&&_):P=new Date(v.timestamp),z=new Date(u),W=new Date(l),P>=z&&P<=W&&T<E?T++:P>=z&&P<=W&&(si(v,f,A),T++,T===h&&S.destroy());break;case i:v.level===o&&T<E?T++:v.level===o&&(si(v,f,A),T++,T===h&&S.destroy());break;case c:P=new Date(v.timestamp),z=new Date(u),P>=z&&T<E?T++:P>=z&&T>=E&&(si(v,f,A),T++,T===h&&S.destroy());break;case _:P=new Date(v.timestamp),W=new Date(l),P<=W&&T<E?T++:P<=W&&T>=E&&(si(v,f,A),T++,T===h&&S.destroy());break;default:T<E?T++:(si(v,f,A),T++,T===h&&S.destroy())}}return a(F,"onLogMessage"),await nX(S,"close"),A}a(lX,"readLog");function si(e,t,r){t==="desc"?_X(e,r):t==="asc"?dX(e,r):r.push(e)}a(si,"pushLineToResult");function _X(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(_X,"insertDescending");function dX(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(dX,"insertAscending")});var ad=g((B_e,WD)=>{"use strict";var pS=require("joi"),{string:iu,boolean:$D,date:fX}=pS.types(),EX=et(),{validateSchemaExists:U_e,validateTableExists:P_e,validateSchemaName:v_e}=Gn(),hX=M(),mX=tt(),YD=Z();YD.initSync();var pX=iu.invalid(YD.get(hX.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(mX.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(),KD={operation:iu.valid("add_node","update_node","set_node_replication"),node_name:pX,subscriptions:pS.array().items({table:iu.optional(),schema:iu.optional(),database:iu.optional(),subscribe:$D.required(),publish:$D.required().custom(TX),start_time:fX.iso()}).min(1).required()};function SX(e){return EX.validateBySchema(e,pS.object(KD))}a(SX,"addUpdateNodeValidator");function TX(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(TX,"checkForFalsy");WD.exports={addUpdateNodeValidator:SX,validation_schema:KD}});var zD=g((x_e,QD)=>{var gX=et(),RX={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};QD.exports=function(e){return gX.validateObject(e,RX)}});var TS=g((F_e,JD)=>{"use strict";var AX=M().OPERATIONS_ENUM,SS=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=AX.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};JD.exports=SS});var jD=g((G_e,XD)=>{"use strict";var OX={OPERATION:"operation",REFRESH:"refresh"},gS=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},RS=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};XD.exports={JWTTokens:gS,TOKEN_TYPE_ENUM:OX,JWTRSAKeys:RS}});var cu=g((V_e,rL)=>{"use strict";var au=require("jsonwebtoken"),AS=require("fs-extra"),OS=J(),rn=M(),{handleHDBError:cr,hdb_errors:bX}=ee(),{HTTP_STATUS_CODES:ur,AUTHENTICATION_ERROR_MSGS:lr}=bX,ou=Y(),ZD=m_(),yS=Zr(),NX=jr().update,yX=TS(),wX=hs(),{UserEventMsg:IX}=bn(),ii=Z();ii.initSync();var bS=require("path"),{JWTTokens:CX,JWTRSAKeys:DX,TOKEN_TYPE_ENUM:cd}=jD(),LX=ii.get(rn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?ii.get(rn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",MX=ii.get(rn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?ii.get(rn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",ud="RS256",NS;rL.exports={createTokens:UX,validateOperationToken:vX,refreshOperationToken:PX,validateRefreshToken:tL};async function UX(e){if(OS.isEmpty(e)||typeof e!="object")throw cr(new Error,lr.INVALID_AUTH_OBJECT,ur.BAD_REQUEST,void 0,void 0,!0);if(OS.isEmpty(e.username))throw cr(new Error,lr.USERNAME_REQUIRED,ur.BAD_REQUEST,void 0,void 0,!0);if(OS.isEmpty(e.password))throw cr(new Error,lr.PASSWORD_REQUIRED,ur.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await yS.findAndValidateUser(e.username,e.password),!t)throw cr(new Error,lr.INVALID_CREDENTIALS,ur.UNAUTHORIZED,void 0,void 0,!0)}catch(f){throw ou.error(f),cr(new Error,lr.INVALID_CREDENTIALS,ur.UNAUTHORIZED,void 0,void 0,!0)}let r=await ld(),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 eL(i,r.private_key,r.passphrase),c=await au.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:MX,algorithm:ud,subject:cd.REFRESH}),u=ZD.hash(c),_=new yX(rn.SYSTEM_SCHEMA_NAME,rn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]),l,d;try{l=await NX(_)}catch(f){ou.error(f),d=f}if(d!==void 0||l.skipped_hashes.length>0)throw cr(new Error,lr.REFRESH_TOKEN_SAVE_FAILED,ur.INTERNAL_SERVER_ERROR);return wX.signalUserChange(new IX(process.pid)),new CX(o,c)}a(UX,"createTokens");async function eL(e,t,r){return await au.sign(e,{key:t,passphrase:r},{expiresIn:LX,algorithm:ud,subject:cd.OPERATION})}a(eL,"signOperationToken");async function ld(){if(NS===void 0)try{let e=bS.join(ii.getHdbBasePath(),rn.LICENSE_KEY_DIR_NAME,rn.JWT_ENUM.JWT_PASSPHRASE_NAME),t=bS.join(ii.getHdbBasePath(),rn.LICENSE_KEY_DIR_NAME,rn.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=bS.join(ii.getHdbBasePath(),rn.LICENSE_KEY_DIR_NAME,rn.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await AS.readFile(e)).toString(),s=(await AS.readFile(t)).toString(),i=(await AS.readFile(r)).toString();NS=new DX(i,s,n)}catch(e){throw ou.error(e),cr(new Error,lr.NO_ENCRYPTION_KEYS,ur.INTERNAL_SERVER_ERROR)}return NS}a(ld,"getJWTRSAKeys");async function PX(e){if(!e)throw cr(new Error,lr.INVALID_BODY,ur.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw cr(new Error,lr.REFRESH_TOKEN_REQUIRED,ur.BAD_REQUEST,void 0,void 0,!0);await tL(e.refresh_token);let t=await ld(),r=await au.decode(e.refresh_token);return{operation_token:await eL({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(PX,"refreshOperationToken");async function vX(e){try{let t=await ld(),r=await au.verify(e,t.public_key,{algorithms:ud,subject:cd.OPERATION});return await yS.findAndValidateUser(r.username,void 0,!1)}catch(t){throw ou.warn(t),t.name&&t.name==="TokenExpiredError"?cr(new Error,lr.TOKEN_EXPIRED,ur.FORBIDDEN):cr(new Error,lr.INVALID_TOKEN,ur.UNAUTHORIZED)}}a(vX,"validateOperationToken");async function tL(e){let t;try{let r=await ld(),n=await au.verify(e,r.public_key,{algorithms:ud,subject:cd.REFRESH});t=await yS.findAndValidateUser(n.username,void 0,!1)}catch(r){throw ou.warn(r),r.name&&r.name==="TokenExpiredError"?cr(new Error,lr.TOKEN_EXPIRED,ur.FORBIDDEN):cr(new Error,lr.INVALID_TOKEN,ur.UNAUTHORIZED)}if(!ZD.validate(t.refresh_token,e))throw cr(new Error,lr.INVALID_TOKEN,ur.UNAUTHORIZED);return t}a(tL,"validateRefreshToken")});var wS=g((K_e,iL)=>{"use strict";var BX=zD(),sa=require("passport"),HX=require("passport-local").Strategy,xX=require("passport-http").BasicStrategy,FX=require("util"),qX=Zr(),sL=FX.callbackify(qX.findAndValidateUser),Y_e=Or(),GX=M(),nL=cu();sa.use(new HX(function(e,t,r){sL(e,t,r)}));sa.use(new xX(function(e,t,r){sL(e,t,r)}));sa.serializeUser(function(e,t){t(null,e)});sa.deserializeUser(function(e,t){t(null,e)});function kX(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":sa.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===GX.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?nL.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):nL.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:sa.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(kX,"authorize");function VX(e,t){let r=BX(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(VX,"checkPermissions");iL.exports={authorize:kX,checkPermissions:VX}});var ia=g((Q_e,oL)=>{"use strict";var IS=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},CS=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};oL.exports={Node:IS,NodeSubscription:CS}});var cL=g((J_e,aL)=>{"use strict";var $X=M().OPERATIONS_ENUM,DS=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=$X.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};aL.exports=DS});var uu=g((j_e,uL)=>{"use strict";var LS=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},MS=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)}};uL.exports={RemotePayloadObject:LS,RemotePayloadSubscription:MS}});var _L=g((ede,lL)=>{"use strict";var US=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}};lL.exports=US});var EL=g((ide,fL)=>{"use strict";var YX=_L(),rde=lt(),dL=$e(),KX=Y(),{getSchemaPath:nde,getTransactionAuditStorePath:sde}=Ke(),{getDatabases:WX}=(be(),te(Fe));fL.exports=QX;async function QX(e){let t=new YX;try{let r=WX()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats(),i=await dL.environmentDataSize(schema_path,e.name),o=await dL.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){KX.warn(`unable to stat table dbi due to ${r}`)}return t}a(QX,"lmdbGetTableSize")});var mL=g((ade,hL)=>{"use strict";var PS=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}};hL.exports=PS});var oa=g((_de,gL)=>{"use strict";var zX=require("fs-extra"),JX=require("path"),Wt=require("systeminformation"),oi=Y(),XX=Rt(),vS=tt(),dd=M(),jX=EL(),TL=Li(),{getThreadInfo:pL}=je(),YS=Z();YS.initSync();var ZX=mL(),{openEnvironment:ude}=$e(),{getSchemaPath:lde}=Ke(),{database:ej}=(be(),te(Fe)),_d;gL.exports={getHDBProcessInfo:FS,getNetworkInfo:GS,getDiskInfo:qS,getMemoryInfo:xS,getCPUInfo:HS,getTimeInfo:BS,getSystemInformation:kS,systemInformation:tj,getTableSize:VS,getMetrics:$S};function BS(){return Wt.time()}a(BS,"getTimeInfo");async function HS(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:u,cache:_,...l}=await Wt.cpu();l.cpu_speed=await Wt.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:f,raw_currentload_irq:E,raw_currentload_nice:h,raw_currentload_system:p,raw_currentload_user:S,cpus:T,...A}=await Wt.currentLoad();return A.cpus=[],T.forEach(b=>{let{raw_load:H,raw_load_idle:F,raw_load_irq:v,raw_load_nice:P,raw_load_system:z,raw_load_user:W,...Q}=b;A.cpus.push(Q)}),l.current_load=A,l}catch(e){return oi.error(`error in getCPUInfo: ${e}`),{}}}a(HS,"getCPUInfo");async function xS(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Wt.mem();return Object.assign(s,process.memoryUsage())}catch(e){return oi.error(`error in getMemoryInfo: ${e}`),{}}}a(xS,"getMemoryInfo");async function FS(){let e={core:[],clustering:[]};try{let t=await Wt.processes(),r;try{r=Number.parseInt(await zX.readFile(JX.join(YS.get(dd.CONFIG_PARAMS.ROOTPATH),dd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===dd.NODE_ERROR_CODES.ENOENT)oi.error("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return oi.error(`error in getHDBProcessInfo: ${t}`),e}}a(FS,"getHDBProcessInfo");async function qS(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Wt.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:u,..._}=await Wt.fsStats();return e.read_write=_,e.size=await Wt.fsSize(),e}catch(t){return oi.error(`error in getDiskInfo: ${t}`),e}}a(qS,"getDiskInfo");async function GS(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await Wt.networkInterfaceDefault(),e.latency=await Wt.inetChecksite("google.com"),(await Wt.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:u,ieee8021xAuth:_,ieee8021xState:l,carrier_changes:d,...f}=n;e.interfaces.push(f)}),(await Wt.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)}),e}catch(t){return oi.error(`error in getNetworkInfo: ${t}`),e}}a(GS,"getNetworkInfo");async function kS(){if(_d!==void 0)return _d;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Wt.osInfo();e=c;let u=await Wt.versions("node, npm");return e.node_version=u.node,e.npm_version=u.npm,_d=e,_d}catch(t){return oi.error(`error in getSystemInformation: ${t}`),e}}a(kS,"getSystemInformation");async function VS(){let e=[],t=await TL.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await jX(n));return e}a(VS,"getTableSize");async function $S(){let e=await TL.describeAll(),t={};for(let r in e){let n=t[r]={};for(let s in e[r])try{let i=ej({database:r,table:s}),o=i.getStats();o.readers=i.readerList().split(/\n\s+/).slice(1).map(c=>{let[u,_,l]=c.trim().split(" ");return{pid:u,thread:_,txnid:l}}),n[s]=o}catch(i){oi.notify(`Error getting stats for table ${s}: ${i}`)}}return t}a($S,"getMetrics");async function SL(){if(YS.get(dd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{js:e,jsm:t}=await XX.getNATSReferences(),r=await t.streams.info(vS.WORK_QUEUE_CONSUMER_NAMES.stream_name),n=await e.consumers.get(vS.WORK_QUEUE_CONSUMER_NAMES.stream_name,vS.WORK_QUEUE_CONSUMER_NAMES.durable_name),s={ingest:{stream:{...r.state},consumer:{num_ack_pending:n._info.num_ack_pending,num_redelivered:n._info.num_redelivered,num_waiting:n._info.num_waiting,num_pending:n._info.num_pending}}};return r.sources&&(s.ingest.stream.sources=r.sources),s}}a(SL,"getNatsStreamInfo");async function tj(e){let t=new ZX;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await kS(),t.time=BS(),t.cpu=await HS(),t.memory=await xS(),t.disk=await qS(),t.network=await GS(),t.harperdb_processes=await FS(),t.table_size=await VS(),t.metrics=await $S(),t.threads=await pL(),t.replication=await SL(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await kS();break;case"time":t.time=BS();break;case"cpu":t.cpu=await HS();break;case"memory":t.memory=await xS();break;case"disk":t.disk=await qS();break;case"network":t.network=await GS();break;case"harperdb_processes":t.harperdb_processes=await FS();break;case"table_size":t.table_size=await VS();break;case"database_metrics":case"metrics":t.metrics=await $S();break;case"threads":t.threads=await pL();break;case"replication":t.replication=await SL();break;default:break}return t}a(tj,"systemInformation")});var Ed=g((fde,RL)=>{"use strict";RL.exports={version:rj,printVersion:nj};var fd=Kc();function rj(){if(fd)return fd.version}a(rj,"version");function nj(){fd&&console.log(`HarperDB Version ${fd.version}`)}a(nj,"printVersion")});var gs=g((pde,NL)=>{"use strict";var sj=jr(),KS=J(),ij=require("util"),to=M(),AL=Z();AL.initSync();var oj=wS(),OL=Xr(),{Node:hde,NodeSubscription:mde}=ia(),aj=zo(),cj=cL(),{RemotePayloadObject:uj,RemotePayloadSubscription:lj}=uu(),{handleHDBError:_j,hdb_errors:dj}=ee(),{HTTP_STATUS_CODES:fj,HDB_ERROR_MSGS:Ej}=dj,hj=Kn(),mj=oa(),pj=Ed(),{getDatabases:Sj}=(be(),te(Fe)),Tj=ij.promisify(oj.authorize),gj=OL.searchByHash,Rj=OL.searchByValue;NL.exports={authHeaderToUser:Aj,isEmpty:Oj,getNodeRecord:bj,upsertNodeRecord:Nj,buildNodePayloads:yj,checkClusteringEnabled:wj,getAllNodeRecords:Ij,getSystemInfo:Cj,reverseSubscription:bL};async function Aj(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Tj(t,null),e}a(Aj,"authHeaderToUser");function Oj(e){return e==null}a(Oj,"isEmpty");async function bj(e){let t=new aj(to.SYSTEM_SCHEMA_NAME,to.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return gj(t)}a(bj,"getNodeRecord");async function Nj(e){let t=new cj(to.SYSTEM_SCHEMA_NAME,to.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return sj.upsert(t)}a(Nj,"upsertNodeRecord");function bL(e){if(KS.isEmpty(e.subscribe)||KS.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(bL,"reverseSubscription");function yj(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=KS.getTableHashAttribute(u,_),{subscribe:d,publish:f}=bL(c),E=Sj()[u]?.[_],h=new lj(u,_,l,f,d,c.start_time,E.schemaDefined?E.attributes:void 0);s.push(h)}return new uj(r,t,s,n)}a(yj,"buildNodePayloads");function wj(){if(!AL.get(to.CONFIG_PARAMS.CLUSTERING_ENABLED))throw _j(new Error,Ej.CLUSTERING_NOT_ENABLED,fj.BAD_REQUEST,void 0,void 0,!0)}a(wj,"checkClusteringEnabled");async function Ij(){let e=new hj(to.SYSTEM_SCHEMA_NAME,to.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Rj(e))}a(Ij,"getAllNodeRecords");async function Cj(){let e=await mj.getSystemInformation();return{hdb_version:pj.version(),node_version:e.node_version,platform:e.platform}}a(Cj,"getSystemInfo")});var WS=g((Tde,UL)=>{"use strict";var hd=Rt(),yL=J(),wL=tt(),IL=M(),md=Y(),CL=rd(),Dj=fp(),{RemotePayloadObject:Lj}=uu(),{handleHDBError:DL,hdb_errors:Mj}=ee(),{HTTP_STATUS_CODES:LL}=Mj,{NodeSubscription:ML}=ia();UL.exports=Uj;async function Uj(e,t){let r;try{r=await hd.request(`${t}.${wL.REQUEST_SUFFIX}`,new Lj(IL.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),md.trace("Response from remote describe all request:",r)}catch(o){md.error(`addNode received error from describe all request to remote node: ${o}`);let c=hd.requestErrorHandler(o,"add_node",t);throw DL(new Error,c,LL.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===wL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw DL(new Error,o,LL.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===IL.SYSTEM_SCHEMA_NAME){await hd.createLocalTableStream(u,c);let h=new ML(u,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let _=yL.doesSchemaExist(u),l=n[u]!==void 0,d=c?yL.doesTableExist(u,c):!0,f=c?n?.[u]?.[c]!==void 0:!0;if(!_&&!l||!d&&!f){s.push(o);continue}if(!_&&l&&(md.trace(`addNode creating schema: ${u}`),await CL.createSchema({operation:"create_schema",schema:u})),!d&&f){md.trace(`addNode creating table: ${c} in schema: ${u} with attributes ${JSON.stringify(n[u][c].attributes)}`);let h=new Dj(u,c,n[u][c].hash_attribute);n[u][c].attributes&&(h.attributes=n[u][c].attributes),await CL.createTable(h)}await hd.createLocalTableStream(u,c);let E=new ML(u,c,o.publish,o.subscribe);E.start_time=o.start_time,i.push(E)}return{added:i,skipped:s}}a(Uj,"reviewSubscriptions")});var Td=g((Rde,BL)=>{"use strict";var{handleHDBError:pd,hdb_errors:Pj}=ee(),{HTTP_STATUS_CODES:Sd}=Pj,{addUpdateNodeValidator:vj}=ad(),lu=Y(),vL=M(),PL=tt(),Bj=J(),QS=Rt(),_u=gs(),Hj=Z(),xj=WS(),{Node:Fj,NodeSubscription:qj}=ia(),{broadcast:Gj}=je(),kj="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Vj="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",$j=Hj.get(vL.CONFIG_PARAMS.CLUSTERING_NODENAME);BL.exports=Yj;async function Yj(e,t=!1){lu.trace("addNode called with:",e),_u.checkClusteringEnabled();let r=vj(e);if(r)throw pd(r,r.message,Sd.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await _u.getNodeRecord(n);if(!Bj.isEmptyOrZeroLength(d))throw pd(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,Sd.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await xj(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=kj,o;let c=_u.buildNodePayloads(s,$j,vL.OPERATIONS_ENUM.ADD_NODE,await _u.getSystemInfo());lu.trace("addNode sending remote payload:",c);let u;try{u=await QS.request(`${n}.${PL.REQUEST_SUFFIX}`,c)}catch(d){lu.error(`addNode received error from request: ${d}`);let f=QS.requestErrorHandler(d,"add_node",n);throw pd(new Error,f,Sd.INTERNAL_SERVER_ERROR,"error",f)}if(u.status===PL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${u.message}`;throw pd(new Error,d,Sd.INTERNAL_SERVER_ERROR,"error",d)}lu.trace(u);let _=[];for(let d=0,f=s.length;d<f;d++){let E=s[d];lu.trace("Add node updating work stream for node:",n,"subscriptions:",E),await QS.updateWorkStream(E,n),s[d].start_time===void 0&&delete s[d].start_time,_.push(new qj(E.schema,E.table,E.publish,E.subscribe))}let l=new Fj(n,_,u.system_info);return await _u.upsertNodeRecord(l),Gj({type:"nats_update"}),i.length>0?o.message=Vj:o.message=`Successfully added '${n}' to manifest`,o}a(Yj,"addNode")});var jS=g((bde,FL)=>{"use strict";var{handleHDBError:zS,hdb_errors:Kj}=ee(),{HTTP_STATUS_CODES:JS}=Kj,{addUpdateNodeValidator:Wj}=ad(),du=Y(),xL=M(),HL=tt(),Ode=J(),XS=Rt(),fu=gs(),Qj=Z(),{cloneDeep:zj}=require("lodash"),Jj=WS(),{Node:Xj,NodeSubscription:jj}=ia(),{broadcast:Zj}=je(),eZ="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",tZ="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",rZ=Qj.get(xL.CONFIG_PARAMS.CLUSTERING_NODENAME);FL.exports=nZ;async function nZ(e){du.trace("updateNode called with:",e),fu.checkClusteringEnabled();let t=Wj(e);if(t)throw zS(t,t.message,JS.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await fu.getNodeRecord(r);s.length>0&&(n=zj(s));let{added:i,skipped:o}=await Jj(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=eZ,c;let u=fu.buildNodePayloads(i,rZ,xL.OPERATIONS_ENUM.UPDATE_NODE,await fu.getSystemInfo());du.trace("updateNode sending remote payload:",u);let _;try{_=await XS.request(`${r}.${HL.REQUEST_SUFFIX}`,u)}catch(l){du.error(`updateNode received error from request: ${l}`);let d=XS.requestErrorHandler(l,"update_node",r);throw zS(new Error,d,JS.INTERNAL_SERVER_ERROR,"error",d)}if(_.status===HL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let l=`Error returned from remote node ${r}: ${_.message}`;throw zS(new Error,l,JS.INTERNAL_SERVER_ERROR,"error",l)}du.trace(_);for(let l=0,d=i.length;l<d;l++){let f=i[l];du.trace(`updateNode updating work stream for node: ${r} subscription:`,f),await XS.updateWorkStream(f,r),i[l].start_time===void 0&&delete i[l].start_time}return n||(n=[new Xj(r,[],_.system_info)]),await sZ(n[0],i,_.system_info),o.length>0?c.message=tZ:c.message=`Successfully updated '${r}'`,c}a(nZ,"updateNode");async function sZ(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 jj(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await fu.upsertNodeRecord(n),Zj({type:"nats_update"})}a(sZ,"updateNodeTable")});var $L=g((yde,VL)=>{"use strict";var kL=require("joi"),{string:qL}=kL.types(),iZ=et(),GL=M(),oZ=Z(),aZ=tt();VL.exports=cZ;function cZ(e){let t=qL.invalid(oZ.get(GL.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(aZ.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=kL.object({operation:qL.valid(GL.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return iZ.validateBySchema(e,r)}a(cZ,"removeNodeValidator")});var Rd=g((Ide,JL)=>{"use strict";var{handleHDBError:YL,hdb_errors:uZ}=ee(),{HTTP_STATUS_CODES:KL}=uZ,lZ=$L(),Eu=Y(),WL=gs(),_Z=J(),gd=M(),QL=tt(),zL=Rt(),dZ=Z(),{RemotePayloadObject:fZ}=uu(),{NodeSubscription:EZ}=ia(),hZ=xc(),mZ=Bi(),{broadcast:pZ}=je(),SZ=dZ.get(gd.CONFIG_PARAMS.CLUSTERING_NODENAME);JL.exports=TZ;async function TZ(e){Eu.trace("removeNode called with:",e),WL.checkClusteringEnabled();let t=lZ(e);if(t)throw YL(t,t.message,KL.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await WL.getNodeRecord(r);if(_Z.isEmptyOrZeroLength(n))throw YL(new Error,`Node '${r}' was not found.`,KL.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new fZ(gd.OPERATIONS_ENUM.REMOVE_NODE,SZ,[]),i,o=!1;try{i=await zL.request(`${r}.${QL.REQUEST_SUFFIX}`,s),Eu.trace("Remove node reply from remote node:",r,i)}catch(u){Eu.error("removeNode received error from request:",u),o=!0}for(let u=0,_=n.subscriptions.length;u<_;u++){let l=n.subscriptions[u];Eu.trace(`Remove node removing subscription: ${l.schema}.${l.table} for node: ${r}`);let d=new EZ(l.schema,l.table,!1,!1);await zL.updateWorkStream(d,r)}let c=new hZ(gd.SYSTEM_SCHEMA_NAME,gd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await mZ.deleteRecord(c),pZ({type:"nats_update"}),i?.status===QL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(Eu.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(TZ,"removeNode")});var ZL=g((Dde,jL)=>{"use strict";var XL=require("joi"),{string:gZ,array:RZ}=XL.types(),AZ=et(),OZ=ad();jL.exports=bZ;function bZ(e){let t=XL.object({operation:gZ.valid("configure_cluster").required(),connections:RZ.items(OZ.validation_schema).required()});return AZ.validateBySchema(e,t)}a(bZ,"configureClusterValidator")});var ZS=g((Mde,sM)=>{"use strict";var NZ=M(),Ad=Y(),yZ=J(),wZ=Rd(),IZ=Td(),eM=gs(),CZ=ZL(),{handleHDBError:tM,hdb_errors:DZ}=ee(),{HTTP_STATUS_CODES:rM}=DZ,LZ="Configure cluster complete.",MZ="Failed to configure the cluster. Check the logs for more details.",UZ="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";sM.exports=PZ;async function PZ(e){Ad.trace("configure cluster called with:",e),eM.checkClusteringEnabled();let t=CZ(e);if(t)throw tM(t,t.message,rM.BAD_REQUEST,void 0,void 0,!0);let r=await eM.getAllNodeRecords(),n=[];for(let f=0,E=r.length;f<E;f++)n.push(nM(wZ,{operation:NZ.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[f].name},r[f].name));let s=await Promise.allSettled(n);Ad.trace("All results from configure_cluster remove node:",s);let i=[],o=e.connections.length;for(let f=0;f<o;f++){let E=e.connections[f];i.push(nM(IZ,E,E.node_name))}let c=await Promise.allSettled(i);Ad.trace("All results from configure_cluster add node:",c);let u=[],_=[],l=!1,d=s.concat(c);for(let f=0,E=d.length;f<E;f++){let h=d[f];h.status==="rejected"&&(Ad.error(h.reason),u.includes(h.reason.node_name)||u.push(h.reason.node_name)),h.status==="fulfilled"&&(l=!0);let p=h?.value?.result;typeof p=="string"&&p.includes("Successfully removed")||h.status==="rejected"||_.push({node_name:h?.value?.node_name,subscriptions:h?.value?.result})}if(yZ.isEmptyOrZeroLength(u))return{message:LZ,connections:_};if(l)return{message:UZ,failed_nodes:u,connections:_};throw tM(new Error,MZ,rM.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(PZ,"configureCluster");async function nM(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){throw{node_name:r,error:n}}}a(nM,"functionWrapper")});var oM=g((Pde,iM)=>{"use strict";var Od=require("joi"),vZ=et(),{validateSchemaExists:BZ,validateTableExists:HZ,validateSchemaName:xZ}=Gn(),FZ=Od.object({operation:Od.string().valid("purge_stream"),schema:Od.string().custom(BZ).custom(xZ).required(),table:Od.string().custom(HZ).required()});function qZ(e){return vZ.validateBySchema(e,FZ)}a(qZ,"purgeStreamValidator");iM.exports=qZ});var eT=g((Bde,aM)=>{"use strict";var{handleHDBError:GZ,hdb_errors:kZ}=ee(),{HTTP_STATUS_CODES:VZ}=kZ,$Z=oM(),YZ=Rt(),KZ=gs();aM.exports=WZ;async function WZ(e){if(e.purge_ingest!==!0){let s=$Z(e);if(s)throw GZ(s,s.message,VZ.BAD_REQUEST,void 0,void 0,!0)}KZ.checkClusteringEnabled();let{schema:t,table:r,purge_ingest:n}=e;return await YZ.purgeTableStream(t,r,n),n?"Successfully purged ingest":`Successfully purged table '${t}.${r}'`}a(WZ,"purgeStream")});var nT=g((xde,fM)=>{"use strict";var rT=gs(),QZ=Rt(),lM=Z(),bd=M(),ro=tt(),zZ=J(),tT=Y(),{RemotePayloadObject:JZ}=uu(),{ErrorCode:cM}=require("nats"),uM=lM.get(bd.CONFIG_PARAMS.CLUSTERING_ENABLED),_M=lM.get(bd.CONFIG_PARAMS.CLUSTERING_NODENAME);fM.exports={clusterStatus:XZ,buildNodeStatus:dM};async function XZ(){let e={node_name:_M,is_enabled:uM,connections:[]};if(!uM)return e;let t=await rT.getAllNodeRecords();if(zZ.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(dM(t[n],e.connections));return await Promise.allSettled(r),e}a(XZ,"clusterStatus");async function dM(e,t){let r=e.name,n=new JZ(bd.OPERATIONS_ENUM.CLUSTER_STATUS,_M,void 0,await rT.getSystemInfo()),s,i,o=ro.CLUSTER_STATUS_STATUSES.OPEN;try{let u=Date.now();s=await QZ.request(ro.REQUEST_SUBJECT(r),n),i=Date.now()-u,s.status===ro.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=ro.CLUSTER_STATUS_STATUSES.CLOSED,tT.error(`Error getting node status from ${r} `,s))}catch(u){tT.warn(`Error getting node status from ${r}`,u),u.code===cM.NoResponders?o=ro.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:u.code===cM.Timeout?o=ro.CLUSTER_STATUS_STATUSES.TIMEOUT:o=ro.CLUSTER_STATUS_STATUSES.CLOSED}let c=new jZ(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!==bd.PRE_4_0_0_VERSION&&await rT.upsertNodeRecord(u)}catch(u){tT.error("Cluster status encountered an error updating system info for node:",r,u)}t.push(c)}a(dM,"buildNodeStatus");function jZ(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(jZ,"NodeStatusObject")});var iT=g((qde,EM)=>{"use strict";var{handleHDBError:ZZ,hdb_errors:e5}=ee(),{HTTP_STATUS_CODES:t5}=e5,r5=Rt(),n5=gs(),sT=J(),Nd=require("joi"),s5=et(),i5=2e3,o5=Nd.object({timeout:Nd.number().min(1),connected_nodes:Nd.boolean(),routes:Nd.boolean()});EM.exports=a5;async function a5(e){n5.checkClusteringEnabled();let t=s5.validateBySchema(e,o5);if(t)throw ZZ(t,t.message,t5.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||sT.autoCastBoolean(n),o=s===void 0||sT.autoCastBoolean(s),c={nodes:[]},u=await r5.getServerList(r??i5),_={};if(i)for(let l=0,d=u.length;l<d;l++){let f=u[l].statsz;f&&(_[u[l].server.name]=f.routes)}for(let l=0,d=u.length;l<d;l++){if(u[l].statsz)continue;let f=u[l].server,E=u[l].data;if(f.name.endsWith("-hub")){let h={name:f.name.slice(0,-4),response_time:u[l].response_time};i&&(h.connected_nodes=[],_[f.name]&&_[f.name].forEach(p=>{h.connected_nodes.includes(p.name.slice(0,-4))||h.connected_nodes.push(p.name.slice(0,-4))})),o&&(h.routes=E.cluster?.urls?E.cluster?.urls.map(p=>({host:p.split(":")[0],port:sT.autoCast(p.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(a5,"clusterNetwork")});var SM=g((kde,pM)=>{"use strict";var oT=require("joi"),hM=et(),{route_constraints:mM}=Nm();pM.exports={setRoutesValidator:c5,deleteRoutesValidator:u5};function c5(e){let t=oT.object({server:oT.valid("hub","leaf").required(),routes:mM.required()});return hM.validateBySchema(e,t)}a(c5,"setRoutesValidator");function u5(e){let t=oT.object({routes:mM.required()});return hM.validateBySchema(e,t)}a(u5,"deleteRoutesValidator")});var cT=g(($de,AM)=>{"use strict";var no=Dr(),aT=J(),yd=M(),TM=SM(),{handleHDBError:gM,hdb_errors:l5}=ee(),{HTTP_STATUS_CODES:RM}=l5,_5="cluster routes successfully set",d5="cluster routes successfully deleted";AM.exports={setRoutes:f5,getRoutes:E5,deleteRoutes:h5};function f5(e){let t=TM.setRoutesValidator(e);if(t)throw gM(t,t.message,RM.BAD_REQUEST,void 0,void 0,!0);let r=no.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=aT.autoCast(_.port);let l=n.some(f=>f.host===_.host&&f.port===_.port),d=s.some(f=>f.host===_.host&&f.port===_.port);l||d?i.push(_):(n.push(_),o.push(_))}return e.server==="hub"?no.updateConfigValue(yd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n):no.updateConfigValue(yd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n),{message:_5,set:o,skipped:i}}a(f5,"setRoutes");function E5(){let e=no.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}a(E5,"getRoutes");function h5(e){let t=TM.deleteRoutesValidator(e);if(t)throw gM(t,t.message,RM.BAD_REQUEST,void 0,void 0,!0);let r=no.getClusteringRoutes(),n=r.hub_routes,s=r.leaf_routes,i=[],o=[],c=!1,u=!1;for(let _=0,l=e.routes.length;_<l;_++){let d=e.routes[_],f=!1;for(let E=0,h=n.length;E<h;E++){let p=n[E];if(d.host===p.host&&d.port===p.port){n.splice(E,1),f=!0,c=!0,i.push(d);break}}if(!f){let E=!0;for(let h=0,p=s.length;h<p;h++){let S=s[h];if(d.host===S.host&&d.port===S.port){s.splice(h,1),u=!0,E=!1,i.push(d);break}}E&&o.push(d)}}return c&&(n=aT.isEmptyOrZeroLength(n)?null:n,no.updateConfigValue(yd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n)),u&&(s=aT.isEmptyOrZeroLength(s)?null:s,no.updateConfigValue(yd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,s)),{message:d5,deleted:i,skipped:o}}a(h5,"deleteRoutes")});var bM=g((Kde,OM)=>{"use strict";var hu=require("alasql"),so=require("recursive-iterator"),Cn=Y(),m5=J(),mu=M(),uT=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,S5(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=>mu.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=>!mu.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][mu.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=p5(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(_=>!mu.SEARCH_WILDCARDS.includes(_));c.forEach(({attribute_name:_})=>{let l=new hu.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 p5(e){return e.filter(t=>t[mu.PERMS_CRUD_ENUM.READ])}a(p5,"filterReadRestrictedAttrs");function S5(e,t,r,n,s){T5(e,t,r,n,s)}a(S5,"interpretAST");function pu(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(pu,"addSchemaTableToMap");function T5(e,t,r,n,s){if(!e){Cn.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof hu.yy.Insert?O5(e,t,r):e instanceof hu.yy.Select?g5(e,t,r,n,s):e instanceof hu.yy.Update?R5(e,t,r):e instanceof hu.yy.Delete?A5(e,t,r):Cn.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(T5,"getRecordAttributesAST");function g5(e,t,r,n,s){if(!e){Cn.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(m5.isEmptyOrZeroLength(i)){Cn.error("No schema specified");return}e.from.forEach(c=>{pu(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),pu(c.table,t,r,n,s)});let o=new so(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{Cn.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 so(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{Cn.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 so(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{Cn.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 so(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{Cn.info(`table specified as ${_} not found.`);return}t.get(l).get(_).indexOf(u.columnid)<0&&t.get(l).get(_).push(u.columnid)}}}a(g5,"getSelectAttributes");function R5(e,t,r){if(!e){Cn.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new so(e.columns),s=e.table.databaseid;pu(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&lT(e.table.tableid,s,i.columnid,t,r)}a(R5,"getUpdateAttributes");function A5(e,t,r){if(!e){Cn.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new so(e.where),s=e.table.databaseid;pu(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&lT(e.table.tableid,s,i.columnid,t,r)}a(A5,"getDeleteAttributes");function O5(e,t,r){if(!e){Cn.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new so(e.columns),s=e.into.databaseid;pu(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&lT(e.into.tableid,s,i.columnid,t,r)}a(O5,"getInsertAttributes");function lT(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(lT,"pushAttribute");OM.exports=uT});var fT=g((Qde,IM)=>{var wd=qi(),NM=require("chalk"),Hr=Y(),yM=require("prompt"),{promisify:b5}=require("util"),_T=M(),N5=require("fs-extra"),y5=require("path"),w5=J(),I5=Ed(),wM=Z();wM.initSync();var C5=require("moment"),D5=b5(yM.get),L5=y5.join(wM.getHdbBasePath(),_T.LICENSE_KEY_DIR_NAME,_T.LICENSE_FILE_NAME,_T.LICENSE_FILE_NAME);IM.exports={getFingerprint:U5,setLicense:M5,parseLicense:dT,register:P5,getRegistrationInfo:B5};async function M5(e){if(e&&e.key&&e.company){try{Hr.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await dT(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Hr.error(r),Hr.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(M5,"setLicense");async function U5(){let e={};try{e=await wd.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Hr.error(r),Hr.error(t),new Error(r)}return e}a(U5,"getFingerprint");async function dT(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Hr.info("Validating license input...");let r=wd.validateLicense(e,t);if(Hr.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Hr.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Hr.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Hr.info("writing license to disk"),await N5.writeFile(L5,JSON.stringify({license_key:e,company:t}))}catch(n){throw Hr.error("Failed to write License"),n}return"Registration successful."}a(dT,"parseLicense");async function P5(){let e=await v5();return dT(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(P5,"register");async function v5(){let e=await wd.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:NM.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:NM.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{yM.start()}catch(n){Hr.error(n)}let r;try{r=await D5(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(v5,"promptForRegistration");async function B5(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await wd.getLicense()}catch(r){throw Hr.error(`There was an error when searching licenses due to: ${r.message}`),r}if(w5.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=I5.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=C5.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(B5,"getRegistrationInfo")});var DM=g((Jde,CM)=>{"use strict";var H5=tt(),ET=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,u,_,l,d,f,E,h){this.port=t,o===null&&(o=void 0),this.server_name=r+H5.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:u},this.leafnodes={port:_,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:l,port:d,routes:f,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:u}},this.accounts={SYS:{users:E},HDB:{users:h}},this.system_account="SYS"}};CM.exports=ET});var UM=g((jde,MM)=>{"use strict";var LM=tt(),hT=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+LM.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+LM.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"}};MM.exports=hT});var vM=g((efe,PM)=>{"use strict";var mT=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};PM.exports=mT});var HM=g((rfe,BM)=>{"use strict";var x5=tt(),pT=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+x5.SERVER_SUFFIX.ADMIN,this.password=r}};BM.exports=pT});var gT=g((sfe,qM)=>{"use strict";var aa=require("path"),Dd=require("fs-extra"),F5=DM(),q5=UM(),G5=vM(),k5=HM(),ST=Zr(),ua=J(),_r=Dr(),Cd=M(),Su=tt(),{CONFIG_PARAMS:ut}=Cd,Tu=Y(),gu=Z(),xM=Es(),TT=Rt(),ca="clustering",V5=1e4,FM=5;qM.exports={generateNatsConfig:Y5,removeNatsConfig:K5,getHubConfigPath:$5};function $5(){let e=gu.get(ut.ROOTPATH);return aa.join(e,ca,Su.NATS_CONFIG_FILES.HUB_SERVER)}a($5,"getHubConfigPath");async function Y5(e=!1,t=void 0){gu.initSync();let r=gu.get(ut.ROOTPATH),n=aa.join(r,ca,Su.PID_FILES.HUB),s=aa.join(r,ca,Su.PID_FILES.LEAF),i=_r.getConfigFromFile(ut.CLUSTERING_LEAFSERVER_STREAMS_PATH),o=aa.join(r,ca,Su.NATS_CONFIG_FILES.HUB_SERVER),c=aa.join(r,ca,Su.NATS_CONFIG_FILES.LEAF_SERVER),u=_r.getConfigFromFile(ut.CLUSTERING_TLS_CERTIFICATE),_=_r.getConfigFromFile(ut.CLUSTERING_TLS_PRIVATEKEY),l=_r.getConfigFromFile(ut.CLUSTERING_TLS_CERT_AUTH),d=_r.getConfigFromFile(ut.CLUSTERING_TLS_INSECURE),f=_r.getConfigFromFile(ut.CLUSTERING_TLS_VERIFY),E=_r.getConfigFromFile(ut.CLUSTERING_NODENAME),h=_r.getConfigFromFile(ut.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await TT.checkNATSServerInstalled()||Ld("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let p=await ST.listUsers(),S=_r.getConfigFromFile(ut.CLUSTERING_USER),T=await ST.getClusterUser();(ua.isEmpty(T)||T.active!==!0)&&Ld(`Invalid cluster user '${S}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Id(ut.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Id(ut.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Id(ut.CLUSTERING_HUBSERVER_NETWORK_PORT),await Id(ut.CLUSTERING_LEAFSERVER_NETWORK_PORT));let A=[],b=[];for(let[Q,se]of p.entries())se.role.role===Cd.ROLE_TYPES_ENUM.CLUSTER_USER&&se.active&&(A.push(new k5(se.username,xM.decrypt(se.hash))),b.push(new G5(se.username,xM.decrypt(se.hash))));let H=[],{hub_routes:F}=_r.getClusteringRoutes();if(!ua.isEmptyOrZeroLength(F))for(let Q of F)H.push(`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@${Q.host}:${Q.port}`);let v=new F5(_r.getConfigFromFile(ut.CLUSTERING_HUBSERVER_NETWORK_PORT),E,n,u,_,l,d,f,h,_r.getConfigFromFile(ut.CLUSTERING_HUBSERVER_CLUSTER_NAME),_r.getConfigFromFile(ut.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),H,A,b);l==null&&(delete v.tls.ca_file,delete v.leafnodes.tls.ca_file),t=ua.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===Cd.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Dd.writeJson(o,v),Tu.trace(`Hub server config written to ${o}`));let P=`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,z=`tls://${T.uri_encoded_name}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,W=new q5(_r.getConfigFromFile(ut.CLUSTERING_LEAFSERVER_NETWORK_PORT),E,s,i,[P],[z],A,b,u,_,l,d);l==null&&delete W.tls.ca_file,(t===void 0||t===Cd.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Dd.writeJson(c,W),Tu.trace(`Leaf server config written to ${c}`))}a(Y5,"generateNatsConfig");async function Id(e){let t=gu.get(e);return ua.isEmpty(t)&&Ld(`port undefined for '${e}'`),await ua.isPortTaken(t)&&Ld(`'${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(Id,"isPortAvailable");function Ld(e){let t=`Error generating clustering config: ${e}`;Tu.error(t),console.error(t),process.exit(1)}a(Ld,"generateNatsConfigError");async function K5(e){let{port:t,config_file:r}=TT.getServerConfig(e),{username:n,decrypt_hash:s}=await ST.getClusterUser(),i=0,o=2e3;for(;i<FM;){try{let _=await TT.createConnection(t,n,s,!1);if(_.protocol.connected===!0){_.close();break}}catch(_){Tu.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${_}`)}if(i++,i>=FM)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);await ua.async_set_timeout(o*(i*2))}let c="0".repeat(V5),u=aa.join(gu.get(ut.ROOTPATH),ca,r);await Dd.writeFile(u,c),await Dd.remove(u),Tu.notify(e,"started.")}a(K5,"removeNatsConfig")});var KM=g((ofe,YM)=>{"use strict";var xr=Z(),W5=qi(),me=M(),Ru=tt(),Rs=require("path"),{PACKAGE_ROOT:Ud}=M(),GM=Z(),Md=J(),la="/dev/null",Q5=Rs.join(Ud,"launchServiceScripts"),kM=Rs.join(Ud,"utility/scripts"),z5=Rs.join(kM,me.HDB_RESTART_SCRIPT),VM=Rs.resolve(Ud,"dependencies",`${process.platform}-${process.arch}`,Ru.NATS_BINARY_NAME);function $M(){let t=W5.licenseSearch().ram_allocation||me.RAM_ALLOCATION_ENUM.DEFAULT,r=me.MEM_SETTING_KEY+t,n={[me.PROCESS_NAME_ENV_PROP]:me.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Md.noBootFile()&&(n[me.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Md.getEnvCliRootPath()),{name:me.PROCESS_DESCRIPTORS.HDB,script:me.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:Ud}}a($M,"generateMainServerConfig");var J5=9930;function X5(){xr.initSync(!0);let e=xr.get(me.CONFIG_PARAMS.ROOTPATH),t=Rs.join(e,"clustering",Ru.NATS_CONFIG_FILES.HUB_SERVER),r=Rs.join(xr.get(me.HDB_SETTINGS_NAMES.LOG_PATH_KEY),me.LOG_NAMES.HDB),n=GM.get(me.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Ru.LOG_LEVEL_FLAGS[xr.get(me.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:me.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==J5?"-"+n:""),script:VM,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[me.PROCESS_NAME_ENV_PROP]:me.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return xr.get(me.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=la,i.error_file=la),i}a(X5,"generateNatsHubServerConfig");var j5=9940;function Z5(){xr.initSync(!0);let e=xr.get(me.CONFIG_PARAMS.ROOTPATH),t=Rs.join(e,"clustering",Ru.NATS_CONFIG_FILES.LEAF_SERVER),r=Rs.join(xr.get(me.HDB_SETTINGS_NAMES.LOG_PATH_KEY),me.LOG_NAMES.HDB),n=GM.get(me.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Ru.LOG_LEVEL_FLAGS[xr.get(me.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:me.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==j5?"-"+n:""),script:VM,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[me.PROCESS_NAME_ENV_PROP]:me.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return xr.get(me.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=la,i.error_file=la),i}a(Z5,"generateNatsLeafServerConfig");function e8(){xr.initSync();let e=Rs.join(xr.get(me.CONFIG_PARAMS.LOGGING_ROOT),me.LOG_NAMES.HDB),t={name:me.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:me.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[me.PROCESS_NAME_ENV_PROP]:me.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Q5,autorestart:!1};return xr.get(me.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=la,t.error_file=la),t}a(e8,"generateClusteringUpgradeV4ServiceConfig");function t8(){let e={[me.PROCESS_NAME_ENV_PROP]:me.PROCESS_DESCRIPTORS.RESTART_HDB};return Md.noBootFile()&&(e[me.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Md.getEnvCliRootPath()),{...{name:me.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:kM},script:z5}}a(t8,"generateRestart");function r8(){return{apps:[$M()]}}a(r8,"generateAllServiceConfigs");YM.exports={generateAllServiceConfigs:r8,generateMainServerConfig:$M,generateRestart:t8,generateNatsHubServerConfig:X5,generateNatsLeafServerConfig:Z5,generateClusteringUpgradeV4ServiceConfig:e8}});var oU=g((ufe,iU)=>{"use strict";var Le=M(),n8=J(),As=gT(),Au=Rt(),Jn=tt(),ai=KM(),Pd=Z(),ci=Y(),s8=gs(),{startWorker:WM,onMessageFromWorkers:i8}=je(),o8=oa(),cfe=require("util"),a8=require("child_process"),c8=require("fs"),{execFile:u8}=a8,we;iU.exports={enterPM2Mode:l8,start:ui,stop:RT,reload:zM,restart:JM,list:AT,describe:jM,connect:Os,kill:h8,startAllServices:m8,startService:OT,getUniqueServicesList:ZM,restartAllServices:p8,isServiceRegistered:eU,reloadStopStart:tU,restartHdb:XM,deleteProcess:f8,startClusteringProcesses:nU,startClusteringThreads:sU,isHdbRestartRunning:E8,isClusteringRunning:T8,stopClustering:S8,reloadClustering:g8};var Ou=!1;i8(e=>{e.type==="restart"&&Pd.initSync(!0)});function l8(){Ou=!0}a(l8,"enterPM2Mode");function Os(){return we||(we=require("pm2")),new Promise((e,t)=>{we.connect((r,n)=>{ci.setupConsoleLogging(),r&&t(r),e(n)})})}a(Os,"connect");var dr,_8=10,QM;function ui(e,t=!1){if(Ou)return d8(e);let r=u8(e.script,e.args.split(" "),e);r.name=e.name,r.on("exit",async i=>{let o=dr.indexOf(r);o>-1&&dr.splice(o,1),!QM&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<_8&&(c8.existsSync(As.getHubConfigPath())?ui(e):(await As.generateNatsConfig(!0),ui(e),await new Promise(c=>setTimeout(c,3e3)),await As.removeNatsConfig(Le.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await As.removeNatsConfig(Le.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Pd.get(Le.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,u,_=0,l;for(;u=c.exec(i);){if(u.index&&Jn.LOG_LEVEL_HIERARCHY[o]>=Jn.LOG_LEVEL_HIERARCHY[l||"info"]){let E=l===Jn.LOG_LEVELS.ERR||l===Jn.LOG_LEVELS.WRN?ci.OUTPUTS.STDERR:ci.OUTPUTS.STDOUT;ci.logCustomLevel(l||"info",E,n,i.slice(_,u.index).trim())}let[d,f]=u;_=u.index+d.length,l=Jn.LOG_LEVELS[f]}if(Jn.LOG_LEVEL_HIERARCHY[o]>=Jn.LOG_LEVEL_HIERARCHY[l||"info"]){let d=l===Jn.LOG_LEVELS.ERR||l===Jn.LOG_LEVELS.WRN?ci.OUTPUTS.STDERR:ci.OUTPUTS.STDOUT;ci.logCustomLevel(l||"info",d,n,i.slice(_).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),dr=[],!dr&&!t){let i=a(()=>{QM=!0,dr&&(dr.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)}dr.push(r)}a(ui,"start");function d8(e){return new Promise(async(t,r)=>{try{await Os()}catch(n){r(n)}we.start(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(d8,"startWithPM2");function RT(e){if(!Ou){for(let t of dr||[])t.name===e&&(dr.splice(dr.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Os()}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(RT,"stop");function zM(e){return new Promise(async(t,r)=>{try{await Os()}catch(n){r(n)}we.reload(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(zM,"reload");function JM(e){if(!Ou)for(let t of dr||[])t.name===e&&t.kill();return new Promise(async(t,r)=>{try{await Os()}catch(n){r(n)}we.restart(e,(n,s)=>{we.disconnect(),t(s)})})}a(JM,"restart");function f8(e){return new Promise(async(t,r)=>{try{await Os()}catch(n){r(n)}we.delete(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(f8,"deleteProcess");async function XM(){await ui(ai.generateRestart())}a(XM,"restartHdb");async function E8(){let e=await AT();for(let t in e)if(e[t].name===Le.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(E8,"isHdbRestartRunning");function AT(){return new Promise(async(e,t)=>{try{await Os()}catch(r){t(r)}we.list((r,n)=>{r&&(we.disconnect(),t(r)),we.disconnect(),e(n)})})}a(AT,"list");function jM(e){return new Promise(async(t,r)=>{try{await Os()}catch(n){r(n)}we.describe(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(jM,"describe");function h8(){if(!Ou){for(let e of dr||[])e.kill();dr=[];return}return new Promise(async(e,t)=>{try{await Os()}catch(r){t(r)}we.killDaemon((r,n)=>{r&&(we.disconnect(),t(r)),we.disconnect(),e(n)})})}a(h8,"kill");async function m8(){try{await nU(),await sU(),await ui(ai.generateAllServiceConfigs())}catch(e){throw we?.disconnect(),e}}a(m8,"startAllServices");async function OT(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case Le.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=ai.generateMainServerConfig();break;case Le.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=ai.generateNatsIngestServiceConfig();break;case Le.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=ai.generateNatsReplyServiceConfig();break;case Le.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=ai.generateNatsHubServerConfig(),await ui(r,t),await As.removeNatsConfig(e);return;case Le.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=ai.generateNatsLeafServerConfig(),await ui(r,t),await As.removeNatsConfig(e);return;case Le.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=ai.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await ui(r)}catch(r){throw we?.disconnect(),r}}a(OT,"startService");async function ZM(){try{let e=await AT(),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(ZM,"getUniqueServicesList");async function p8(e=[]){try{let t=!1,r=await ZM();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===Le.PROCESS_DESCRIPTORS.HDB?t=!0:await JM(o))}t&&await tU(Le.PROCESS_DESCRIPTORS.HDB)}catch(t){throw we?.disconnect(),t}}a(p8,"restartAllServices");async function eU(e){if(dr?.find(r=>r.name===e))return!0;let t=await o8.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(eU,"isServiceRegistered");async function tU(e){let t=e===Le.PROCESS_DESCRIPTORS.HDB?Pd.get(Le.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES):Pd.get(Le.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES),r=await jM(e),n=n8.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await RT(e),await OT(e)):e===Le.PROCESS_DESCRIPTORS.HDB?await XM():await zM(e)}a(tU,"reloadStopStart");var rU;async function nU(e=!1){for(let t in Le.CLUSTERING_PROCESSES){let r=Le.CLUSTERING_PROCESSES[t];await OT(r,e)}}a(nU,"startClusteringProcesses");async function sU(){rU=WM(Le.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:Le.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE}),await Au.createWorkQueueStream(Jn.WORK_QUEUE_CONSUMER_NAMES),await Au.updateIngestStreamConsumer(),await Au.updateLocalStreams();let e=await s8.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===Le.PRE_4_0_0_VERSION){ci.info("Starting clustering upgrade 4.0.0 process"),WM(Le.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(sU,"startClusteringThreads");async function S8(){for(let e in Le.CLUSTERING_PROCESSES)if(e!==Le.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===Le.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await rU.terminate();else{let t=Le.CLUSTERING_PROCESSES[e];await RT(t)}}a(S8,"stopClustering");async function T8(){for(let e in Le.CLUSTERING_PROCESSES){let t=Le.CLUSTERING_PROCESSES[e];if(await eU(t)===!1)return!1}return!0}a(T8,"isClusteringRunning");async function g8(){await As.generateNatsConfig(!0),await Au.reloadNATSHub(),await Au.reloadNATSLeaf(),await As.removeNatsConfig(Le.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await As.removeNatsConfig(Le.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(g8,"reloadClustering")});var xd=g((_fe,fU)=>{"use strict";var R8=require("minimist"),{isMainThread:yT,parentPort:uU}=require("worker_threads"),rt=M(),{PROCESS_DESCRIPTORS_VALIDATE:bu}=rt,Xn=Y(),wT=J(),vd=gT(),_a=Rt(),bT=tt(),lU=Dr(),jn=oU(),aU=oa(),A8=ZE(),{restartWorkers:Bd,onMessageByType:O8}=je(),{handleHDBError:b8,hdb_errors:N8}=ee(),{HTTP_STATUS_CODES:y8}=N8,Hd=Z();Hd.initSync();var Nu=`Restarting HarperDB. This may take up to ${rt.RESTART_TIMEOUT_MS/1e3} seconds.`,w8="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",cU="Clustering is not enabled so cannot be restarted",I8="Invalid service",da,nn;fU.exports={restart:_U,restartService:IT};yT&&O8(rt.ITC_EVENT_TYPES.RESTART,e=>{e.workerType?IT({service:e.workerType}):_U({operation:"restart"})});async function _U(e){nn=Object.keys(e).length===0,da=await jn.isServiceRegistered(rt.HDB_PROC_DESCRIPTOR);let t=R8(process.argv);if(t.service){await IT(t);return}if(nn&&!da){console.error(w8);return}if(nn&&console.log(Nu),da){jn.enterPM2Mode(),Xn.notify(Nu);let r=A8(Object.keys(rt.CONFIG_PARAM_MAP),!0);return wT.isEmptyOrZeroLength(Object.keys(r))||lU.updateConfigValue(void 0,void 0,r,!0,!0),D8(),Nu}return yT?(Xn.notify(Nu),setTimeout(()=>{Bd()},50)):uU.postMessage({type:rt.ITC_EVENT_TYPES.RESTART}),Nu}a(_U,"restart");async function IT(e){let{service:t}=e;if(rt.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw b8(new Error,I8,y8.BAD_REQUEST,void 0,void 0,!0);if(da=await jn.isServiceRegistered(rt.HDB_PROC_DESCRIPTOR),!yT)return uU.postMessage({type:rt.ITC_EVENT_TYPES.RESTART,workerType:t}),t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`;let r;switch(t){case bu.clustering:if(!Hd.get(rt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=cU;break}nn&&console.log("Restarting clustering"),Xn.notify("Restarting clustering"),await dU();break;case bu.clustering_config:case bu["clustering config"]:if(!Hd.get(rt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=cU;break}nn&&console.log("Restarting clustering_config"),Xn.notify("Restarting clustering_config"),await jn.reloadClustering();break;case"custom_functions":case"custom functions":case bu.harperdb:case bu.http_workers:if(nn&&!da){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}nn&&console.log("Restarting http_workers"),Xn.notify("Restarting http_workers"),nn?await jn.restart(rt.HDB_PROC_DESCRIPTOR):setTimeout(()=>{Bd("http")},200);break;default:r=`Unrecognized service: ${t}`;break}return r?(Xn.error(r),nn&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(IT,"restartService");async function C8(){await _a.publishToStream(`${bT.SUBJECT_PREFIXES.TXN}.${bT.WORK_QUEUE_CONSUMER_NAMES.stream_name}`,bT.WORK_QUEUE_CONSUMER_NAMES.stream_name,_a.addNatsMsgHeader({operation:"dummy_msg"},void 0),{operation:"dummy_msg"})}a(C8,"postDummyNatsMsg");async function D8(){await dU(),await jn.restart(rt.HDB_PROC_DESCRIPTOR),await wT.async_set_timeout(2e3),Hd.get(rt.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await NT(),nn&&(await _a.closeConnection(),process.exit(0))}a(D8,"restartPM2Mode");async function dU(){if(!lU.getConfigFromFile(rt.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await aU.getHDBProcessInfo()).clustering.length===0)Xn.trace("Clustering not running, restart will start clustering services"),await vd.generateNatsConfig(!0),await jn.startClusteringProcesses(),await jn.startClusteringThreads(),await NT(),nn&&await _a.closeConnection();else{await C8(),await vd.generateNatsConfig(!0),da?(Xn.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await jn.restart(rt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await jn.restart(rt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await aU.getHDBProcessInfo()).clustering.forEach(s=>{Xn.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await wT.async_set_timeout(3e3),await NT(),await _a.updateLocalStreams(),nn&&await _a.closeConnection(),Xn.trace("Restart clustering restarting ingest and reply service threads");let t=Bd(rt.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=Bd(rt.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(dU,"restartClustering");async function NT(){await vd.removeNatsConfig(rt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await vd.removeNatsConfig(rt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(NT,"removeNatsConfig")});var bU=g((Efe,OU)=>{"use strict";var ffe=require("lodash"),fr=M(),{handleHDBError:EU,hdb_errors:L8}=ee(),{HDB_ERROR_MSGS:M8,HTTP_STATUS_CODES:U8}=L8,CT=Y();OU.exports={getRolePermissions:v8};var io=Object.create(null),P8=a(e=>({key:e,perms:{}}),"perms_template_obj"),SU=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),TU=a((e=!1,t=!1,r=!1,n=!1)=>({[fr.PERMS_CRUD_ENUM.READ]:e,[fr.PERMS_CRUD_ENUM.INSERT]:t,[fr.PERMS_CRUD_ENUM.UPDATE]:r,[fr.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),DT=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...TU(t,r,n,s)}),"table_perms_template"),hU=a((e,t=TU())=>({attribute_name:e,describe:AU(t),[yu]:t[yu],[LT]:t[LT],[MT]:t[MT]}),"attr_perms_template"),mU=a((e,t=!1)=>({attribute_name:e,describe:t,[yu]:t}),"timestamp_attr_perms_template"),{READ:yu,INSERT:LT,UPDATE:MT}=fr.PERMS_CRUD_ENUM,gU=Object.values(fr.PERMS_CRUD_ENUM),RU=[yu,LT,MT];function v8(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[fr.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(io[t]&&io[t].key===n)return io[t].perms;let s=B8(e,r);return io[t]?io[t].key=n:io[t]=P8(n),io[t].perms=s,s}catch(r){if(!e[fr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[fr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<fr.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 CT.error(n),CT.debug(r),EU(new Error,M8.OUTDATED_PERMS_TRANSLATION_ERROR,U8.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
|
|
11
|
-
${r.stack}`;throw CT.error(n),EU(new Error)}}}a(v8,"getRolePermissions");function B8(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[fr.SYSTEM_SCHEMA_NAME]=n[fr.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]=H8(t[i]);return}r[i]=SU(),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],_=x8(c,u);r[i].describe||gU.forEach(l=>{_[l]&&(r[i].describe=!0)}),r[i].tables[o]=_}else r[i].tables[o]=DT()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=DT()})}),r}a(B8,"translateRolePermissions");function H8(e){let t=SU(!0);return Object.keys(e).forEach(r=>{t.tables[r]=DT(!0,!0,!0,!0,!0)}),t}a(H8,"createStructureUserPermissions");function x8(e,t){let{attribute_permissions:r}=e;if(r.length>0){let s=Object.assign({},e);s.attribute_permissions=[];let i=r.reduce((_,l)=>{let{attribute_name:d}=l,f=l;return fr.TIME_STAMP_NAMES.includes(d)&&(f=mU(d,l[yu])),_[d]=f,_},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],u=hU(o);return t.attributes.forEach(({attribute:_})=>{if(i[_]){let l=i[_];l.describe=AU(l),s.attribute_permissions.push(l),c||F8(l,u)}else if(_!==o){let l;fr.TIME_STAMP_NAMES.includes(_)?l=mU(_):l=hU(_),s.attribute_permissions.push(l)}}),c||s.attribute_permissions.push(u),s.describe=pU(s),s}else return e.describe=pU(e),e}a(x8,"getTableAttrPerms");function pU(e){return gU.filter(t=>e[t]).length>0}a(pU,"getSchemaTableDescribePerm");function AU(e){return RU.filter(t=>e[t]).length>0}a(AU,"getAttributeDescribePerm");function F8(e,t){RU.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(F8,"checkForHashPerms")});var NU={};Ve(NU,{Resources:()=>Fd,keyArrayToString:()=>fa,resetResources:()=>q8,resources:()=>li});function q8(){return li=new Fd}function fa(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var Fd,li,wu=Oe(()=>{Ki();Fd=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,type:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s)throw new Error(`Conflicting paths for ${t}`);super.set(t,i);for(let[c,u]of this){let _=2;for(;(_=c.indexOf("/",_))>-1;){let l=this.get(c.slice(0,_));l&&(l.hasSubPaths=!0),_+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),u=this.get(c);if(u){if(u.relativeURL=t.slice(n),!u.hasSubPaths)return u;s=u}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),s?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return We(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(q8,"resetResources");a(fa,"keyArrayToString")});var yU={};Ve(yU,{Headers:()=>_i});var _i,qd=Oe(()=>{_i=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];n?r=(typeof o=="string"?o:o.join(", "))+", "+r:typeof o=="string"?r=[o,r]:o.push(r)}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}}});var Iu={};Ve(Iu,{authentication:()=>PU,bypassAuth:()=>W8,login:()=>z8,logout:()=>J8,start:()=>Q8});function W8(){UU=!0}async function PU(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let E=e.isOperationsServer?$8?V8:[]:k8?G8:[];if(E.includes(i)||E.includes("*")){if(e.method==="OPTIONS"){let h=new _i([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Gd&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Gd&&o.push("Access-Control-Allow-Credentials","true")}}let u,_;if(Gd){let E=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.indexOf(E);if(h>=0){let p=s.indexOf(";",h),S=s.indexOf("=",h);u=s.slice(S+1,p===-1?s.length:p),_=await IU.get(u)}e.session=_||(_={})}e.user=null;let l=a((E,h,p)=>{let S=new Vd.AuthAuditLog(E,h,Ft.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===Ft.AUTH_AUDIT_STATUS.SUCCESS?wU.notify(S):wU.error(S)},"authAuditLog");if(e.mtlsConfig&&e.authorized){let E=e.mtlsConfig.user;E!==null&&((E===void 0||E==="Common Name"||E==="CN")&&(E=e.peerCertificate.subject.CN),e.user=await Xe.getUser(E,null,null))}let d;if(!e.user)if(n){if(d=oo.get(n),!d){let[E,h]=n.split(" "),p,S;try{switch(E){case"Basic":[p,S]=atob(h).split(":"),d=p||S?await Xe.getUser(p,S,e):null;break;case"Bearer":try{d=await(0,kd.validateOperationToken)(h)}catch(T){if(T.message==="invalid token")try{return await(0,kd.validateRefreshToken)(h),c({status:-1})}catch{throw T}}break}}catch(T){return K8&&(oo.get(h)||(oo.set(h,h),l(p,Ft.AUTH_AUDIT_STATUS.FAILURE,E))),c({status:401,body:di({error:T.message},e)})}oo.set(n,d),Y8&&l(d.username,Ft.AUTH_AUDIT_STATUS.SUCCESS,E)}e.user=d}else _?.user?e.user=await Xe.getUser(_.user,null,e):(UU&&(e.ip?.includes("127.0.0.1")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,DU.getSuperUser)());Gd&&(e.session.update=function(E){if(!u){u=(0,LU.v4)();let p=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${u}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",p):f?.headers?.set&&f.headers.set("Set-Cookie",p)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):f?.headers?.set&&(i&&f.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),f.headers.set("X-Hdb-Session","Secure"))),E.id=u,IU.put(E)},e.login=async function(E,h){e.user=await Xe.getUser(E,h,e),e.session.update({user:e.user.username})},(d&&!_||_?.user?.username!==d?.username)&&r["user-agent"]?.startsWith("Mozilla")&&e.session.update({user:e.user.username}));let f=await t(e);return f&&(f.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&li.loginPath?(f.status=302,f.headers.set("Location",li.loginPath(e))):f.headers.set("WWW-Authenticate","Basic")),c(f))}catch(u){throw c(u)}function c(u){let _=o.length;if(_>0){let l=u.headers;l||(u.headers=l=new _i);for(let d=0;d<_;){let f=o[d++];l.set(f,o[d++])}}return o=null,u}a(c,"applyResponseHeaders")}function Q8({server:e,port:t}){e.request(PU,{port:t||"all"}),CU||(CU=!0,setInterval(()=>{oo=new Map},sn.get(Ft.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),MU.user.addListener(()=>{oo=new Map}))}async function z8(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 J8(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var DU,kd,LU,sn,Ft,Vd,MU,wU,G8,k8,V8,$8,IU,Gd,UU,Y8,K8,oo,CU,$d=Oe(()=>{DU=B(Zr());Zt();wu();kd=B(cu());be();LU=require("uuid"),sn=B(Z()),Ft=B(M()),Vd=B(Y()),MU=B(Cc());qd();Ea();wU=(0,Vd.loggerWithTag)("auth-event");sn.initSync();G8=sn.get(Ft.CONFIG_PARAMS.HTTP_CORSACCESSLIST),k8=sn.get(Ft.CONFIG_PARAMS.HTTP_CORS),V8=sn.get(Ft.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),$8=sn.get(Ft.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),IU=ot({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Gd=sn.get(Ft.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,UU=sn.get(Ft.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,Y8=sn.get(Ft.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,K8=sn.get(Ft.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,oo=new Map;Xe.onInvalidatedUser(()=>{oo=new Map});a(W8,"bypassAuth");a(PU,"authentication");a(Q8,"start");a(z8,"login");a(J8,"logout")});var GU=g((Nfe,qU)=>{"use strict";var Ie=require("joi"),vU=require("fs-extra"),BU=require("path"),Ns=et(),HU=Z(),xU=M(),FU=Y(),{hdb_errors:X8}=ee(),{HDB_ERROR_MSGS:Qt}=X8,bs=/^[a-zA-Z0-9-_]+$/;qU.exports={getDropCustomFunctionValidator:Z8,setCustomFunctionValidator:e6,addComponentValidator:s6,dropCustomFunctionProjectValidator:i6,packageComponentValidator:o6,deployComponentValidator:a6,setComponentFileValidator:t6,getComponentFileValidator:n6,dropComponentFileValidator:r6};function Yd(e,t,r){try{let n=HU.get(xU.CONFIG_PARAMS.COMPONENTSROOT),s=BU.join(n,t);return vU.existsSync(s)?e?t:r.message(Qt.PROJECT_EXISTS):e?r.message(Qt.NO_PROJECT):t}catch(n){return FU.error(n),r.message(Qt.VALIDATION_ERR)}}a(Yd,"checkProjectExists");function Cu(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(Cu,"checkFilePath");function j8(e,t,r,n){try{let s=HU.get(xU.CONFIG_PARAMS.COMPONENTSROOT),i=BU.join(s,e,t,r+".js");return vU.existsSync(i)?r:n.message(Qt.NO_FILE)}catch(s){return FU.error(s),n.message(Qt.VALIDATION_ERR)}}a(j8,"checkFileExists");function Z8(e){let t=Ie.object({project:Ie.string().pattern(bs).custom(Yd.bind(null,!0)).required().messages({"string.pattern.base":Qt.BAD_PROJECT_NAME}),type:Ie.string().valid("helpers","routes").required(),file:Ie.string().pattern(bs).custom(j8.bind(null,e.project,e.type)).custom(Cu).required().messages({"string.pattern.base":Qt.BAD_FILE_NAME})});return Ns.validateBySchema(e,t)}a(Z8,"getDropCustomFunctionValidator");function e6(e){let t=Ie.object({project:Ie.string().pattern(bs).custom(Yd.bind(null,!0)).required().messages({"string.pattern.base":Qt.BAD_PROJECT_NAME}),type:Ie.string().valid("helpers","routes").required(),file:Ie.string().custom(Cu).required(),function_content:Ie.string().required()});return Ns.validateBySchema(e,t)}a(e6,"setCustomFunctionValidator");function t6(e){let t=Ie.object({project:Ie.string().pattern(bs).required().messages({"string.pattern.base":Qt.BAD_PROJECT_NAME}),file:Ie.string().custom(Cu).required(),payload:Ie.string().allow("").optional(),encoding:Ie.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Ns.validateBySchema(e,t)}a(t6,"setComponentFileValidator");function r6(e){let t=Ie.object({project:Ie.string().pattern(bs).required().messages({"string.pattern.base":Qt.BAD_PROJECT_NAME}),file:Ie.string().custom(Cu).optional()});return Ns.validateBySchema(e,t)}a(r6,"dropComponentFileValidator");function n6(e){let t=Ie.object({project:Ie.string().required(),file:Ie.string().custom(Cu).required(),encoding:Ie.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Ns.validateBySchema(e,t)}a(n6,"getComponentFileValidator");function s6(e){let t=Ie.object({project:Ie.string().pattern(bs).custom(Yd.bind(null,!1)).required().messages({"string.pattern.base":Qt.BAD_PROJECT_NAME})});return Ns.validateBySchema(e,t)}a(s6,"addComponentValidator");function i6(e){let t=Ie.object({project:Ie.string().pattern(bs).custom(Yd.bind(null,!0)).required().messages({"string.pattern.base":Qt.BAD_PROJECT_NAME})});return Ns.validateBySchema(e,t)}a(i6,"dropCustomFunctionProjectValidator");function o6(e){let t=Ie.object({project:Ie.string().pattern(bs).required().messages({"string.pattern.base":Qt.BAD_PROJECT_NAME}),skip_node_modules:Ie.boolean()});return Ns.validateBySchema(e,t)}a(o6,"packageComponentValidator");function a6(e){let t=Ie.object({project:Ie.string().pattern(bs).required().messages({"string.pattern.base":Qt.BAD_PROJECT_NAME}),payload:Ie.string().optional().messages({"string.pattern.base":Qt.BAD_PACKAGE}),package:Ie.string().optional()});return Ns.validateBySchema(e,t)}a(a6,"deployComponentValidator")});var zd=g((wfe,QU)=>{"use strict";var Kd=require("joi"),Wd=require("path"),kU=require("fs-extra"),{exec:c6}=require("child_process"),u6=require("util"),VU=u6.promisify(c6),Du=M(),{handleHDBError:ha,hdb_errors:l6}=ee(),{HTTP_STATUS_CODES:ma}=l6,Lu=Z(),_6=et(),pa=Y();Lu.initSync();var UT=Lu.get(Du.CONFIG_PARAMS.COMPONENTSROOT),$U="npm install --omit=dev --json",d6=`${$U} --dry-run`;QU.exports={installModules:m6,auditModules:p6,installAllRootModules:f6,uninstallRootModule:E6,linkHarperdb:h6};async function f6(e=!1){await Qd(),await Mu(e?"npm install --ignore-scripts":"npm install",Lu.get(Du.CONFIG_PARAMS.ROOTPATH))}a(f6,"installAllRootModules");async function E6(e){await Mu(`npm uninstall ${e}`,Lu.get(Du.CONFIG_PARAMS.ROOTPATH))}a(E6,"uninstallRootModule");async function h6(){await Qd(),await Mu(`npm link ${Du.PACKAGE_ROOT}`,Lu.get(Du.CONFIG_PARAMS.ROOTPATH))}a(h6,"linkHarperdb");async function Mu(e,t=void 0){let r,n;try{({stdout:r,stderr:n}=await VU(e,{cwd:t}))}catch(s){throw new Error(s.stderr.replace(`
|
|
12
|
-
`,""))}return n&&!n.includes("Debugger listening")&&
|
|
13
|
-
`,"")}a(
|
|
10
|
+
`,"")}a(nD,"runCommand");async function C4(){try{await a4.access(Jp)}catch{return!1}let e=await nD(`${Jp} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return c4.eq(t,w4)}a(C4,"checkNATSServerInstalled");async function eS(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await ZC.getClusterUser();if(eo(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}Hr.trace("create nats connection called");let i=await T4({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Ht.get(Pe.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Ht.get(Pe.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Ht.get(Pe.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),Hr.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&Hr.error("Error with Nats client connection, connection closed",o),sD()}),i}a(eS,"createConnection");function sD(){rn=void 0,Xi=void 0,ji=void 0,Zi=void 0}a(sD,"clearClientCache");async function D4(){rn&&(await rn.drain(),rn=void 0,Xi=void 0,ji=void 0,Zi=void 0)}a(D4,"closeConnection");var rn,Zi;async function j_(){return Zi||(Zi=eS(Ht.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),rn=await Zi),rn||Zi}a(j_,"getConnection");async function nu(){if(Xi)return Xi;eo(rn)&&await j_();let{domain:e}=su(Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(eo(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Xi=await rn.jetstreamManager({domain:e,timeout:6e4}),Xi}a(nu,"getJetStreamManager");async function iD(){if(ji)return ji;eo(rn)&&await j_();let{domain:e}=su(Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(eo(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ji=rn.jetstream({domain:e,timeout:6e4}),ji}a(iD,"getJetStream");async function sr(){let e=rn||await j_(),t=Xi||await nu(),r=ji||await iD();return{connection:e,jsm:t,js:r}}a(sr,"getNATSReferences");async function L4(e){let t=Ht.get(Pe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await ZC.getClusterUser(),s=await eS(t,r,n),i=Zp(),o=s.subscribe(i),c=[],u,_=(async()=>{for await(let l of o){let d=rD.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 Xp.async_set_timeout(e),await o.drain(),await s.close(),await _,c}a(L4,"getServerList");async function tS(e,t){let{jsm:r}=await sr(),n=Ht.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Ht.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Ht.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:eD.File,retention:tD.Limits,subjects:t,discard:g4.Old,max_msgs:s,max_bytes:i,max_age:n})}a(tS,"createLocalStream");async function oD(){let{jsm:e}=await sr(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(oD,"listStreams");async function M4(e){let{jsm:t}=await sr();await t.streams.delete(e)}a(M4,"deleteLocalStream");async function U4(e){let{connection:t}=await sr(),r=[],n=Zp(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(rD.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(U4,"listRemoteStreams");async function P4(e,t=void 0,r=void 0){let{jsm:n,js:s}=await sr(),i=JC(),o={durable_name:i,ack_policy:J_.Explicit};t&&(o.deliver_policy=X_.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=jp(l.data),f={nats_timestamp:l.info.timestampNanos,nats_sequence:l.info.streamSequence,entry:d};if(l.headers&&(f.origin=l.headers.get(ye.MSG_HEADERS.ORIGIN)),_.push(f),l.ack(),l.info.pending===0)break}return await c.delete(),_}a(P4,"viewStream");async function*v4(e,t=void 0,r=void 0){let{jsm:n,js:s}=await sr(),i=JC(),o={durable_name:i,ack_policy:J_.Explicit};t&&(o.deliver_policy=X_.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=jp(_.data);l[0]||(l=[l]);for(let d of l){let f={nats_timestamp:_.info.timestampNanos,nats_sequence:_.info.streamSequence,entry:d};_.headers&&(f.origin=_.headers.get(ye.MSG_HEADERS.ORIGIN)),yield f}if(_.ack(),_.info.pending===0)break}await c.delete()}a(v4,"viewStreamIterator");async function B4(e,t,r,n){Hr.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=aD(n,r);let{js:s}=await sr(),i=await iu(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:jC.encode(n);try{Hr.trace(`publishToStream publishing to subject: ${o}`),N4(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 _D(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(u.code&&u.code.toString()==="503"){Hr.trace(`publishToStream creating stream: ${t}`);let l=o.split(".");l[2]="*",await tS(t,[o]),await s.publish(o,c,{headers:r})}else throw u}});throw u}}a(B4,"publishToStream");function aD(e,t){t===void 0&&(t=A4());let r=Ht.get(Pe.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(ye.MSG_HEADERS.ORIGIN)&&r&&t.append(ye.MSG_HEADERS.ORIGIN,r),t}a(aD,"addNatsMsgHeader");function su(e){e=e.toLowerCase();let t=ru.join(Ht.get(Pe.CONFIG_PARAMS.ROOTPATH),y4);if(e===Pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return eo(zp)&&(zp={port:eu.getConfigFromFile(Pe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:eu.getConfigFromFile(Pe.CONFIG_PARAMS.CLUSTERING_NODENAME)+ye.SERVER_SUFFIX.HUB,config_file:ye.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:ru.join(t,ye.PID_FILES.HUB),hdb_nats_path:t}),zp;if(e===Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return eo(Qp)&&(Qp={port:eu.getConfigFromFile(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:eu.getConfigFromFile(Pe.CONFIG_PARAMS.CLUSTERING_NODENAME)+ye.SERVER_SUFFIX.LEAF,config_file:ye.NATS_CONFIG_FILES.LEAF_SERVER,domain:eu.getConfigFromFile(Pe.CONFIG_PARAMS.CLUSTERING_NODENAME)+ye.SERVER_SUFFIX.LEAF,pid_file_path:ru.join(t,ye.PID_FILES.LEAF),hdb_nats_path:t}),Qp;Hr.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(su,"getServerConfig");async function H4(e){let{jsm:t}=await sr(),r=await iu();try{await t.streams.add({name:e.stream_name,storage:eD.File,retention:tD.Limits,max_age:p4,max_bytes:S4,subjects:[`${ye.SUBJECT_PREFIXES.TXN}.${e.stream_name}.${r}`]})}catch(n){if(n.code!=="400")throw n}try{await t.consumers.info(e.stream_name,e.durable_name)}catch(n){if(n.code.toString()==="404")await t.consumers.add(e.stream_name,{ack_policy:J_.Explicit,durable_name:e.durable_name,deliver_policy:X_.All,max_ack_pending:1e4});else throw n}}a(H4,"createWorkQueueStream");async function x4(){let{jsm:e}=await sr();(await e.consumers.info(ye.WORK_QUEUE_CONSUMER_NAMES.stream_name,ye.WORK_QUEUE_CONSUMER_NAMES.durable_name)).config.deliver_subject&&(Hr.info("Removing old nats push consumer from ingest stream"),await e.consumers.delete(ye.WORK_QUEUE_CONSUMER_NAMES.stream_name,ye.WORK_QUEUE_CONSUMER_NAMES.durable_name),Hr.info("Adding pull consumer to ingest stream"),await e.consumers.add(ye.WORK_QUEUE_CONSUMER_NAMES.stream_name,{ack_policy:J_.Explicit,durable_name:ye.WORK_QUEUE_CONSUMER_NAMES.durable_name,deliver_policy:X_.All,max_ack_pending:1e4}))}a(x4,"updateIngestStreamConsumer");async function cD(e,t,r){let{jsm:n}=await sr(),s=await n.streams.info(t),i=uD(n.prefix),o=r.start_time?r.start_time:new Date(Date.now()).toISOString(),{schema:c,table:u}=r,_=z_.createNatsTableStreamName(c,u),l=i===e,d,f,E=!1;if(!Array.isArray(s.config.sources)||s.config.sources.length===0)s.config.sources=[];else for(let p=0,S=s.config.sources.length;p<S;p++)if(d=s.config.sources[p],f=p,l&&d.name===_||!l&&d.name===_&&d.external&&d.external.api===`$JS.${e}.API`){E=!0;break}if(E===!0){if(d.opt_start_time===o)return;let p=`txn.${c}.${u}.${e}`;await n.streams.purge(t,{filter:p}),s.config.sources.splice(f,1),await n.streams.update(t,s.config)}let h={name:_,opt_start_time:o,filter_subject:`${ye.SUBJECT_PREFIXES.TXN}.>`};l||(h.external={api:`$JS.${e}.API`,deliver:""}),s.config.sources.push(h),await n.streams.update(t,s.config)}a(cD,"addSourceToWorkStream");function uD(e){return e.split(".")[1]}a(uD,"extractServerName");async function lD(e,t,r){let{jsm:n}=await sr(),{schema:s,table:i}=r,o=`txn.${s}.${i}.${e}`;await n.streams.purge(t,{filter:o});let c=z_.createNatsTableStreamName(s,i),u=await n.streams.info(t);if(!Array.isArray(u.config.sources)||u.config.sources.length===0)return;let _=u.config.sources.length,l;for(;_--;)if(l=u.config.sources[_],l.name===c&&l.external.api===`$JS.${e}.API`){u.config.sources.splice(_,1);break}await n.streams.update(t,u.config)}a(lD,"removeSourceFromWorkStream");async function F4(e,t,r=6e4,n=Zp()){if(!Xp.isObject(t))throw new Error("data param must be an object");let s=jC.encode(t),{connection:i}=await sr(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return jp(c.data)}a(F4,"request");function rS(e){return new Promise(async(t,r)=>{let n=d4(Jp,["--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(rS,"reloadNATS");async function q4(){let{pid_file_path:e}=su(Pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await rS(e)}a(q4,"reloadNATSHub");async function G4(){let{pid_file_path:e}=su(Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await rS(e)}a(G4,"reloadNATSLeaf");function k4(e,t,r){let n;switch(e.code){case zC.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case zC.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(k4,"requestErrorHandler");async function V4(e,t){let r=t+ye.SERVER_SUFFIX.LEAF;await _D(async()=>{e.subscribe===!0?await cD(r,ye.WORK_QUEUE_CONSUMER_NAMES.stream_name,e):await lD(r,ye.WORK_QUEUE_CONSUMER_NAMES.stream_name,e)})}a(V4,"updateWorkStream");function _D(e){return f4.writeTransaction(Pe.SYSTEM_SCHEMA_NAME,Pe.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(_D,"exclusiveLock");async function dD(e,t){let r=z_.createNatsTableStreamName(e,t),n=await iu(),s=W4(e,t,n);await tS(r,[s])}a(dD,"createLocalTableStream");async function $4(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await dD(n,s)}}a($4,"createTableStreams");async function fD(e,t,r=!1){if(Ht.get(Pe.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=z_.createNatsTableStreamName(e,t),{jsm:s}=await sr();r?await s.streams.purge(ye.WORK_QUEUE_CONSUMER_NAMES.stream_name):await s.streams.purge(n)}catch(n){if(n.message==="stream not found")Hr.warn(n);else throw n}}a(fD,"purgeTableStream");async function Y4(e,t){if(Ht.get(Pe.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await fD(e,t[r])}a(Y4,"purgeSchemaTableStreams");async function K4(e){return(await nu()).streams.info(e)}a(K4,"getStreamInfo");function W4(e,t,r){return`${ye.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(W4,"createSubjectName");async function iu(){if(tu)return tu;if(tu=(await nu())?.nc?.info?.server_name,tu===void 0)throw new Error("Unable to get jetstream manager server name");return tu}a(iu,"getJsmServerName");async function Q4(){let e=await nu(),t=await iu(),r=await oD();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=z4(n),c=i.split(".");if(!(c[c.length-1]===t&&!o)){if(s.name===ye.SCHEMA_QUEUE_CONSUMER_NAMES.stream_name){let _=`${ye.SCHEMA_QUEUE_CONSUMER_NAMES.deliver_subject}.${t}`;Hr.trace(`Updating stream subject name from: ${i} to: ${_}`),s.subjects[0]=_}else if(s.name===ye.WORK_QUEUE_CONSUMER_NAMES.stream_name){let _=`${ye.WORK_QUEUE_CONSUMER_NAMES.stream_name}.${t}`;Hr.trace(`Updating stream subject name from: ${i} to: ${_}`),s.subjects[0]=_}else{let _=i.split(".");_[_.length-1]=t;let l=_.join(".");Hr.trace(`Updating stream subject name from: ${i} to: ${l}`),s.subjects[0]=l}await e.streams.update(s.name,s)}}}a(Q4,"updateLocalStreams");function z4(e){let{config:t}=e,r=!1;if(t.name===ye.SCHEMA_QUEUE_CONSUMER_NAMES.stream_name||t.name===ye.WORK_QUEUE_CONSUMER_NAMES.stream_name)return r;let n=Ht.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Ht.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Ht.get(Pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(z4,"updateStreamLimits")});var rd=T((d_e,SD)=>{"use strict";var ea=n_(),ta=CC(),J4=W(),X4=require("uuid").v4,__e=require("clone"),ed=ps(),ra=U(),j4=require("util"),ni=On(),{handleHDBError:ir,hdb_errors:Z4}=ee(),{HDB_ERROR_MSGS:Z_,HTTP_STATUS_CODES:or}=Z4,{SchemaEventMsg:td}=yn(),hD=At(),{getDatabases:e3}=(be(),te(Fe)),{transformReq:na}=J();SD.exports={createSchema:t3,createSchemaStructure:mD,createTable:r3,createTableStructure:pD,createAttribute:a3,dropSchema:n3,dropTable:s3,dropAttribute:i3,getBackup:c3};async function t3(e){let t=await mD(e);return ed.signalSchemaChange(new td(process.pid,e.operation,e.schema)),t}a(t3,"createSchema");async function mD(e){let t=ea.schema_object(e);if(t)throw ir(t,t.message,or.BAD_REQUEST,void 0,void 0,!0);if(na(e),!await ta.checkSchemaExists(e.schema))throw ir(new Error,Z_.SCHEMA_EXISTS_ERR(e.schema),or.BAD_REQUEST,ra.LOG_LEVELS.ERROR,Z_.SCHEMA_EXISTS_ERR(e.schema),!0);return await ni.createSchema(e),`database '${e.schema}' successfully created`}a(mD,"createSchemaStructure");async function r3(e){return na(e),e.hash_attribute=e.primary_key??e.hash_attribute,await pD(e)}a(r3,"createTable");async function pD(e){let t=ea.create_table_object(e);if(t)throw ir(t,t.message,or.BAD_REQUEST,void 0,void 0,!0);if(ea.validateTableResidence(e.residence),!await ta.checkSchemaTableExists(e.schema,e.table))throw ir(new Error,Z_.TABLE_EXISTS_ERR(e.schema,e.table),or.BAD_REQUEST,ra.LOG_LEVELS.ERROR,Z_.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:X4(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await ni.createTable(n,e);else throw ir(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",or.BAD_REQUEST);else await ni.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(pD,"createTableStructure");async function n3(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 ir(n,n.message,or.BAD_REQUEST,void 0,void 0,!0);na(e);let s=await ta.checkSchemaExists(e.schema);if(s)throw ir(new Error,s,or.NOT_FOUND,ra.LOG_LEVELS.ERROR,s,!0);let i=await ta.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);return await ni.dropSchema(e),ed.signalSchemaChange(new td(process.pid,e.operation,e.schema)),await hD.purgeSchemaTableStreams(e.schema,o),`successfully deleted '${e.schema}'`}a(n3,"dropSchema");async function s3(e){let t=ea.table_object(e);if(t)throw ir(t,t.message,or.BAD_REQUEST,void 0,void 0,!0);na(e);let r=await ta.checkSchemaTableExists(e.schema,e.table);if(r)throw ir(new Error,r,or.NOT_FOUND,ra.LOG_LEVELS.ERROR,r,!0);return await ni.dropTable(e),await hD.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(s3,"dropTable");async function i3(e){let t=ea.attribute_object(e);if(t)throw ir(t,t.message,or.BAD_REQUEST,void 0,void 0,!0);na(e);let r=await ta.checkSchemaTableExists(e.schema,e.table);if(r)throw ir(new Error,r,or.NOT_FOUND,ra.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw ir(new Error,"You cannot drop a hash attribute",or.BAD_REQUEST,void 0,void 0,!0);if(ra.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw ir(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,or.BAD_REQUEST,void 0,void 0,!0);try{return await ni.dropAttribute(e),o3(e),ed.signalSchemaChange(new td(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw J4.error(`Got an error deleting attribute ${j4.inspect(e)}.`),n}}a(i3,"dropAttribute");function o3(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(o3,"dropAttributeFromGlobal");async function a3(e){na(e);let t=e3()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw ir(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,or.BAD_REQUEST,void 0,void 0,!0);return await ni.createAttribute(e),ed.signalSchemaChange(new td(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(a3,"createAttribute");function c3(e){return ni.getBackup(e)}a(c3,"getBackup")});var gD=T((E_e,TD)=>{"use strict";var{OPERATIONS_ENUM:u3}=U(),nS=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=u3.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};TD.exports=nS});var sS=T((p_e,ND)=>{"use strict";var l3=On(),m_e=gD(),nd=J(),sd=U(),_3=Z(),{handleHDBError:RD,hdb_errors:d3}=ee(),{HDB_ERROR_MSGS:AD,HTTP_STATUS_CODES:OD}=d3,f3=Object.values(sd.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),bD="To use this operation audit log must be enabled in harperdb-config.yaml";ND.exports=E3;async function E3(e){if(nd.isEmpty(e.schema))throw new Error(AD.SCHEMA_REQUIRED_ERR);if(nd.isEmpty(e.table))throw new Error(AD.TABLE_REQUIRED_ERR);if(!_3.get(sd.CONFIG_PARAMS.LOGGING_AUDITLOG))throw RD(new Error,bD,OD.BAD_REQUEST,sd.LOG_LEVELS.ERROR,bD,!0);let t=nd.checkSchemaTableExist(e.schema,e.table);if(t)throw RD(new Error,t,OD.NOT_FOUND,sd.LOG_LEVELS.ERROR,t,!0);if(!nd.isEmpty(e.search_type)&&f3.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await l3.readAuditLog(e)}a(E3,"readAuditLog")});var wD=T((T_e,yD)=>{"use strict";var{OPERATIONS_ENUM:h3}=U(),iS=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=h3.GET_BACKUP,this.schema=t,this.table=r}};yD.exports=iS});var DD=T((O_e,CD)=>{"use strict";var m3=On(),R_e=wD(),oS=J(),p3=U(),A_e=Z(),{handleHDBError:S3,hdb_errors:T3}=ee(),{HDB_ERROR_MSGS:ID,HTTP_STATUS_CODES:g3}=T3;CD.exports=R3;async function R3(e){if(oS.isEmpty(e.schema))throw new Error(ID.SCHEMA_REQUIRED_ERR);if(oS.isEmpty(e.table))throw new Error(ID.TABLE_REQUIRED_ERR);let t=oS.checkSchemaTableExist(e.schema,e.table);if(t)throw S3(new Error,t,g3.NOT_FOUND,p3.LOG_LEVELS.ERROR,t,!0);return await m3.getBackup(read_audit_log_object)}a(R3,"getBackup")});var BD=T((N_e,vD)=>{var si=require("validate.js"),MD=et(),sa=U(),{handleHDBError:A3,hdb_errors:O3}=ee(),{HDB_ERROR_MSGS:ct,HTTP_STATUS_CODES:b3}=O3,aS=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),N3={STRUCTURE_USER:"structure_user"},LD=Object.values(sa.ROLE_TYPES_ENUM),y3="attribute_permissions",w3="attribute_name",{PERMS_CRUD_ENUM:ia}=sa,I3=[y3,...Object.values(ia)],UD=[ia.READ,ia.INSERT,ia.UPDATE],C3=[w3,...UD];function D3(e){let t=aS();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,PD(e,t)}a(D3,"addRoleValidation");function L3(e){let t=aS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,PD(e,t)}a(L3,"alterRoleValidation");function M3(e){let t=aS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,MD.validateObject(e,t)}a(M3,"dropRoleValidation");var U3=["operation","role","id","permission","hdb_user","hdb_auth_header"];function PD(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)U3.includes(n[o])||s.push(n[o]);s.length>0&&ft(ct.INVALID_ROLE_JSON_KEYS(s),r);let i=MD.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{ft(o,r)}),e.permission){let o=P3(e);o&&ft(o,r),LD.forEach(c=>{e.permission[c]&&!si.isBoolean(e.permission[c])&&ft(ct.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(LD.indexOf(o)<0){if(o===N3.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]||ft(ct.SCHEMA_NOT_FOUND(d),r)}continue}ft(ct.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){ft(ct.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]){ft(ct.TABLE_NOT_FOUND(o,u),r);continue}if(Object.keys(_).forEach(l=>{I3.includes(l)||ft(ct.INVALID_PERM_KEY(l),r,o,u)}),Object.values(ia).forEach(l=>{si.isDefined(_[l])?si.isBoolean(_[l])||ft(ct.TABLE_PERM_NOT_BOOLEAN(l),r,o,u):ft(ct.TABLE_PERM_MISSING(l),r,o,u)}),si.isDefined(_.attribute_permissions)){if(!si.isArray(_.attribute_permissions)){ft(ct.ATTR_PERMS_NOT_ARRAY,r,o,u);continue}}else{ft(ct.ATTR_PERMS_ARRAY_MISSING,r,o,u);continue}if(_.attribute_permissions){let l=global.hdb_schema[o][u].attributes.map(({attribute:f})=>f),d={read:!1,insert:!1,update:!1};for(let f in _.attribute_permissions){let E=_.attribute_permissions[f];if(Object.keys(E).forEach(p=>{!C3.includes(p)&&p!==ia.DELETE&&ft(ct.INVALID_ATTR_PERM_KEY(p),r,o,u)}),!si.isDefined(E.attribute_name)){ft(ct.ATTR_PERM_MISSING_NAME,r,o,u);continue}let h=E.attribute_name;if(!l.includes(h)){ft(ct.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,u);continue}UD.forEach(p=>{si.isDefined(E[p])?si.isBoolean(E[p])||ft(ct.ATTR_PERM_NOT_BOOLEAN(p,h),r,o,u):ft(ct.ATTR_PERM_MISSING(p,h),r,o,u)}),!d.read&&E.read===!0&&(d.read=!0),!d.insert&&E.insert===!0&&(d.insert=!0),!d.update&&E.update===!0&&(d.update=!0)}if(_.read===!1&&d.read===!0||_.insert===!1&&d.insert===!0||_.update===!1&&d.update===!0){let f=`${o}.${u}`;ft(ct.MISMATCHED_TABLE_ATTR_PERMS(f),r,o,u)}}}}return v3(r)}a(PD,"customValidate");vD.exports={addRoleValidation:D3,alterRoleValidation:L3,dropRoleValidation:M3};function P3(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 ct.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?sa.ROLE_TYPES_ENUM.SUPER_USER:sa.ROLE_TYPES_ENUM.CLUSTER_USER;return ct.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(P3,"validateNoSUPerms");function v3(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:ct.ROLE_PERMS_ERROR,...e};return A3(new Error,n,b3.BAD_REQUEST)}else return null}a(v3,"generateRolePermResponse");function ft(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(ft,"addPermError")});var fS=T((w_e,qD)=>{"use strict";var HD=Zr(),xD=jr(),B3=xi(),uS=BD(),lS=ps(),H3=require("uuid").v4,x3=require("util"),id=U(),F3=J(),_S=xD.searchByValue,q3=xD.searchByHash,G3=x3.promisify(B3.delete),k3=Qn(),V3=Xo(),{hdb_errors:$3,handleHDBError:to}=ee(),{HDB_ERROR_MSGS:FD,HTTP_STATUS_CODES:ou}=$3,{UserEventMsg:dS}=yn();qD.exports={addRole:Y3,alterRole:K3,dropRole:W3,listRoles:Q3};function cS(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(cS,"scrubRoleDetails");async function Y3(e){let t=uS.addRoleValidation(e);if(t)throw t;e=cS(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 _S(r)||[])}catch(i){throw to(i)}if(n&&n.length>0)throw to(new Error,FD.ROLE_ALREADY_EXISTS(e.role),ou.CONFLICT,void 0,void 0,!0);e.id||(e.id=H3());let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await HD.insert(s),lS.signalUserChange(new dS(process.pid)),e=cS(e),e}a(Y3,"addRole");async function K3(e){let t=uS.alterRoleValidation(e);if(t)throw t;e=cS(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await HD.update(r)}catch(s){throw to(s)}if(n&&n?.message==="updated 0 of 1 records")throw to(new Error,"Invalid role id",ou.BAD_REQUEST,void 0,void 0,!0);return await lS.signalUserChange(new dS(process.pid)),e}a(K3,"alterRole");async function W3(e){let t=uS.dropRoleValidation(e);if(t)throw to(new Error,t,ou.BAD_REQUEST,void 0,void 0,!0);let r=new V3(id.SYSTEM_SCHEMA_NAME,id.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await q3(r));if(n.length===0)throw to(new Error,FD.ROLE_NOT_FOUND,ou.NOT_FOUND,void 0,void 0,!0);let s=new k3(id.SYSTEM_SCHEMA_NAME,id.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await _S(s)),o=!1;if(F3.isEmptyOrZeroLength(i)===!1){for(let u=0;u<i.length;u++)if(i[u].active===!0){o=!0;break}}if(o===!0)throw to(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,ou.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await G3(c),lS.signalUserChange(new dS(process.pid)),`${n[0].role} successfully deleted`}a(W3,"dropRole");async function Q3(){return _S({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Q3,"listRoles")});var $D=T((C_e,VD)=>{"use strict";var z3=Z(),ii=require("joi"),J3=et(),GD=require("moment"),X3=require("fs-extra"),ES=require("path"),j3=require("lodash"),au=U(),{LOG_LEVELS:ro}=U(),Z3="YYYY-MM-DD hh:mm:ss",eX=ES.resolve(__dirname,"../logs");VD.exports=function(e){return J3.validateBySchema(e,tX)};var tX=ii.object({from:ii.custom(kD),until:ii.custom(kD),level:ii.valid(ro.NOTIFY,ro.FATAL,ro.ERROR,ro.WARN,ro.INFO,ro.DEBUG,ro.TRACE),order:ii.valid("asc","desc"),limit:ii.number().min(1),start:ii.number().min(0),log_name:ii.custom(rX)});function kD(e,t){if(GD(e,GD.ISO_8601).format(Z3)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(kD,"validateDatetime");function rX(e,t){if(j3.invert(au.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=z3.get(au.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?au.LOG_NAMES.HDB:e,i=s===au.LOG_NAMES.INSTALL?ES.join(eX,au.LOG_NAMES.INSTALL):ES.join(n,s);return X3.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(rX,"validateReadLogPath")});var mS=T((L_e,KD)=>{"use strict";var od=U(),nX=W(),sX=Z(),iX=$D(),hS=require("path"),YD=require("fs-extra"),{once:oX}=require("events"),{handleHDBError:aX,hdb_errors:cX}=ee(),{PACKAGE_ROOT:uX}=U(),lX=hS.join(uX,"logs"),_X=1e3,dX=200;KD.exports=fX;async function fX(e){let t=iX(e);if(t)throw aX(t,t.message,cX.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=sX.get(od.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?od.LOG_NAMES.HDB:e.log_name,s=n===od.LOG_NAMES.INSTALL?hS.join(lX,od.LOG_NAMES.INSTALL):hS.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?_X:e.limit,f=e.order===void 0?void 0:e.order,E=e.start===void 0?0:e.start,h=E+d,p=0;f==="desc"&&!u&&!l&&(p=Math.max(YD.statSync(s).size-(h+5)*dX,0));let S=YD.createReadStream(s,{start:p});S.on("error",v=>{nX.error(v)});let O=0,g=[],R="",B;S.on("data",v=>{let M=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;v=R+v;let $=0,K;for(;(K=M.exec(v))&&!S.destroyed;){B&&(B.message=v.slice($,K.index),H(B));let[z,se,Te]=K,oe=Te.split("] ["),xe=oe[0],de=oe[1];oe.splice(0,2),B={timestamp:se,thread:xe,level:de,tags:oe,message:""},$=K.index+z.length}R=v.slice($)}),S.on("end",v=>{S.destroyed||B&&(B.message=R.trim(),H(B))}),S.resume();function H(v){let M,$,K;switch(!0){case(i&&c&&_):M=new Date(v.timestamp),$=new Date(u),K=new Date(l),v.level===o&&M>=$&&M<=K&&O<E?O++:v.level===o&&M>=$&&M<=K&&(oi(v,f,g),O++,O===h&&S.destroy());break;case(i&&c):M=new Date(v.timestamp),$=new Date(u),v.level===o&&M>=$&&O<E?O++:v.level===o&&M>=$&&(oi(v,f,g),O++,O===h&&S.destroy());break;case(i&&_):M=new Date(v.timestamp),K=new Date(l),v.level===o&&M<=K&&O<E?O++:v.level===o&&M<=K&&(oi(v,f,g),O++,O===h&&S.destroy());break;case(c&&_):M=new Date(v.timestamp),$=new Date(u),K=new Date(l),M>=$&&M<=K&&O<E?O++:M>=$&&M<=K&&(oi(v,f,g),O++,O===h&&S.destroy());break;case i:v.level===o&&O<E?O++:v.level===o&&(oi(v,f,g),O++,O===h&&S.destroy());break;case c:M=new Date(v.timestamp),$=new Date(u),M>=$&&O<E?O++:M>=$&&O>=E&&(oi(v,f,g),O++,O===h&&S.destroy());break;case _:M=new Date(v.timestamp),K=new Date(l),M<=K&&O<E?O++:M<=K&&O>=E&&(oi(v,f,g),O++,O===h&&S.destroy());break;default:O<E?O++:(oi(v,f,g),O++,O===h&&S.destroy())}}return a(H,"onLogMessage"),await oX(S,"close"),g}a(fX,"readLog");function oi(e,t,r){t==="desc"?EX(e,r):t==="asc"?hX(e,r):r.push(e)}a(oi,"pushLineToResult");function EX(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(EX,"insertDescending");function hX(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(hX,"insertAscending")});var ad=T((B_e,JD)=>{"use strict";var pS=require("joi"),{string:cu,boolean:WD,date:mX}=pS.types(),pX=et(),{validateSchemaExists:U_e,validateTableExists:P_e,validateSchemaName:v_e}=Vn(),SX=U(),TX=tt(),QD=Z();QD.initSync();var gX=cu.invalid(QD.get(SX.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(TX.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(),zD={operation:cu.valid("add_node","update_node","set_node_replication"),node_name:gX,subscriptions:pS.array().items({table:cu.optional(),schema:cu.optional(),database:cu.optional(),subscribe:WD.required(),publish:WD.required().custom(AX),start_time:mX.iso()}).min(1).required()};function RX(e){return pX.validateBySchema(e,pS.object(zD))}a(RX,"addUpdateNodeValidator");function AX(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(AX,"checkForFalsy");JD.exports={addUpdateNodeValidator:RX,validation_schema:zD}});var jD=T((x_e,XD)=>{var OX=et(),bX={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};XD.exports=function(e){return OX.validateObject(e,bX)}});var TS=T((F_e,ZD)=>{"use strict";var NX=U().OPERATIONS_ENUM,SS=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=NX.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};ZD.exports=SS});var tL=T((G_e,eL)=>{"use strict";var yX={OPERATION:"operation",REFRESH:"refresh"},gS=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},RS=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};eL.exports={JWTTokens:gS,TOKEN_TYPE_ENUM:yX,JWTRSAKeys:RS}});var _u=T((V_e,iL)=>{"use strict";var lu=require("jsonwebtoken"),AS=require("fs-extra"),OS=J(),nn=U(),{handleHDBError:ar,hdb_errors:wX}=ee(),{HTTP_STATUS_CODES:cr,AUTHENTICATION_ERROR_MSGS:ur}=wX,uu=W(),rL=m_(),yS=en(),IX=Zr().update,CX=TS(),DX=ps(),{UserEventMsg:LX}=yn(),ai=Z();ai.initSync();var bS=require("path"),{JWTTokens:MX,JWTRSAKeys:UX,TOKEN_TYPE_ENUM:cd}=tL(),PX=ai.get(nn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?ai.get(nn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",vX=ai.get(nn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?ai.get(nn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",ud="RS256",NS;iL.exports={createTokens:BX,validateOperationToken:xX,refreshOperationToken:HX,validateRefreshToken:sL};async function BX(e){if(OS.isEmpty(e)||typeof e!="object")throw ar(new Error,ur.INVALID_AUTH_OBJECT,cr.BAD_REQUEST,void 0,void 0,!0);if(OS.isEmpty(e.username))throw ar(new Error,ur.USERNAME_REQUIRED,cr.BAD_REQUEST,void 0,void 0,!0);if(OS.isEmpty(e.password))throw ar(new Error,ur.PASSWORD_REQUIRED,cr.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await yS.findAndValidateUser(e.username,e.password),!t)throw ar(new Error,ur.INVALID_CREDENTIALS,cr.UNAUTHORIZED,void 0,void 0,!0)}catch(f){throw uu.error(f),ar(new Error,ur.INVALID_CREDENTIALS,cr.UNAUTHORIZED,void 0,void 0,!0)}let r=await ld(),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 nL(i,r.private_key,r.passphrase),c=await lu.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:vX,algorithm:ud,subject:cd.REFRESH}),u=rL.hash(c),_=new CX(nn.SYSTEM_SCHEMA_NAME,nn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]),l,d;try{l=await IX(_)}catch(f){uu.error(f),d=f}if(d!==void 0||l.skipped_hashes.length>0)throw ar(new Error,ur.REFRESH_TOKEN_SAVE_FAILED,cr.INTERNAL_SERVER_ERROR);return DX.signalUserChange(new LX(process.pid)),new MX(o,c)}a(BX,"createTokens");async function nL(e,t,r){return await lu.sign(e,{key:t,passphrase:r},{expiresIn:PX,algorithm:ud,subject:cd.OPERATION})}a(nL,"signOperationToken");async function ld(){if(NS===void 0)try{let e=bS.join(ai.getHdbBasePath(),nn.LICENSE_KEY_DIR_NAME,nn.JWT_ENUM.JWT_PASSPHRASE_NAME),t=bS.join(ai.getHdbBasePath(),nn.LICENSE_KEY_DIR_NAME,nn.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=bS.join(ai.getHdbBasePath(),nn.LICENSE_KEY_DIR_NAME,nn.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await AS.readFile(e)).toString(),s=(await AS.readFile(t)).toString(),i=(await AS.readFile(r)).toString();NS=new UX(i,s,n)}catch(e){throw uu.error(e),ar(new Error,ur.NO_ENCRYPTION_KEYS,cr.INTERNAL_SERVER_ERROR)}return NS}a(ld,"getJWTRSAKeys");async function HX(e){if(!e)throw ar(new Error,ur.INVALID_BODY,cr.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw ar(new Error,ur.REFRESH_TOKEN_REQUIRED,cr.BAD_REQUEST,void 0,void 0,!0);await sL(e.refresh_token);let t=await ld(),r=await lu.decode(e.refresh_token);return{operation_token:await nL({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(HX,"refreshOperationToken");async function xX(e){try{let t=await ld(),r=await lu.verify(e,t.public_key,{algorithms:ud,subject:cd.OPERATION});return await yS.findAndValidateUser(r.username,void 0,!1)}catch(t){throw uu.warn(t),t.name&&t.name==="TokenExpiredError"?ar(new Error,ur.TOKEN_EXPIRED,cr.FORBIDDEN):ar(new Error,ur.INVALID_TOKEN,cr.UNAUTHORIZED)}}a(xX,"validateOperationToken");async function sL(e){let t;try{let r=await ld(),n=await lu.verify(e,r.public_key,{algorithms:ud,subject:cd.REFRESH});t=await yS.findAndValidateUser(n.username,void 0,!1)}catch(r){throw uu.warn(r),r.name&&r.name==="TokenExpiredError"?ar(new Error,ur.TOKEN_EXPIRED,cr.FORBIDDEN):ar(new Error,ur.INVALID_TOKEN,cr.UNAUTHORIZED)}if(!rL.validate(t.refresh_token,e))throw ar(new Error,ur.INVALID_TOKEN,cr.UNAUTHORIZED);return t}a(sL,"validateRefreshToken")});var wS=T((K_e,cL)=>{"use strict";var FX=jD(),oa=require("passport"),qX=require("passport-local").Strategy,GX=require("passport-http").BasicStrategy,kX=require("util"),VX=en(),aL=kX.callbackify(VX.findAndValidateUser),Y_e=br(),$X=U(),oL=_u();oa.use(new qX(function(e,t,r){aL(e,t,r)}));oa.use(new GX(function(e,t,r){aL(e,t,r)}));oa.serializeUser(function(e,t){t(null,e)});oa.deserializeUser(function(e,t){t(null,e)});function YX(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":oa.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===$X.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?oL.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):oL.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:oa.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(YX,"authorize");function KX(e,t){let r=FX(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(KX,"checkPermissions");cL.exports={authorize:YX,checkPermissions:KX}});var aa=T((Q_e,uL)=>{"use strict";var IS=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},CS=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};uL.exports={Node:IS,NodeSubscription:CS}});var _L=T((J_e,lL)=>{"use strict";var WX=U().OPERATIONS_ENUM,DS=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=WX.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};lL.exports=DS});var du=T((j_e,dL)=>{"use strict";var LS=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},MS=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)}};dL.exports={RemotePayloadObject:LS,RemotePayloadSubscription:MS}});var EL=T((ede,fL)=>{"use strict";var US=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}};fL.exports=US});var pL=T((ide,mL)=>{"use strict";var QX=EL(),rde=lt(),hL=Ve(),zX=W(),{getSchemaPath:nde,getTransactionAuditStorePath:sde}=Ye(),{getDatabases:JX}=(be(),te(Fe));mL.exports=XX;async function XX(e){let t=new QX;try{let r=JX()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats(),i=await hL.environmentDataSize(schema_path,e.name),o=await hL.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){zX.warn(`unable to stat table dbi due to ${r}`)}return t}a(XX,"lmdbGetTableSize")});var TL=T((ade,SL)=>{"use strict";var PS=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}};SL.exports=PS});var ca=T((_de,OL)=>{"use strict";var jX=require("fs-extra"),ZX=require("path"),Kt=require("systeminformation"),ci=W(),ej=At(),vS=tt(),dd=U(),tj=pL(),AL=Ui(),{getThreadInfo:gL}=je(),YS=Z();YS.initSync();var rj=TL(),{openEnvironment:ude}=Ve(),{getSchemaPath:lde}=Ye(),{database:nj}=(be(),te(Fe)),_d;OL.exports={getHDBProcessInfo:FS,getNetworkInfo:GS,getDiskInfo:qS,getMemoryInfo:xS,getCPUInfo:HS,getTimeInfo:BS,getSystemInformation:kS,systemInformation:sj,getTableSize:VS,getMetrics:$S};function BS(){return Kt.time()}a(BS,"getTimeInfo");async function HS(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:u,cache:_,...l}=await Kt.cpu();l.cpu_speed=await Kt.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:f,raw_currentload_irq:E,raw_currentload_nice:h,raw_currentload_system:p,raw_currentload_user:S,cpus:O,...g}=await Kt.currentLoad();return g.cpus=[],O.forEach(R=>{let{raw_load:B,raw_load_idle:H,raw_load_irq:v,raw_load_nice:M,raw_load_system:$,raw_load_user:K,...z}=R;g.cpus.push(z)}),l.current_load=g,l}catch(e){return ci.error(`error in getCPUInfo: ${e}`),{}}}a(HS,"getCPUInfo");async function xS(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Kt.mem();return Object.assign(s,process.memoryUsage())}catch(e){return ci.error(`error in getMemoryInfo: ${e}`),{}}}a(xS,"getMemoryInfo");async function FS(){let e={core:[],clustering:[]};try{let t=await Kt.processes(),r;try{r=Number.parseInt(await jX.readFile(ZX.join(YS.get(dd.CONFIG_PARAMS.ROOTPATH),dd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===dd.NODE_ERROR_CODES.ENOENT)ci.error("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return ci.error(`error in getHDBProcessInfo: ${t}`),e}}a(FS,"getHDBProcessInfo");async function qS(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Kt.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:u,..._}=await Kt.fsStats();return e.read_write=_,e.size=await Kt.fsSize(),e}catch(t){return ci.error(`error in getDiskInfo: ${t}`),e}}a(qS,"getDiskInfo");async function GS(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await Kt.networkInterfaceDefault(),e.latency=await Kt.inetChecksite("google.com"),(await Kt.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:u,ieee8021xAuth:_,ieee8021xState:l,carrier_changes:d,...f}=n;e.interfaces.push(f)}),(await Kt.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)}),e}catch(t){return ci.error(`error in getNetworkInfo: ${t}`),e}}a(GS,"getNetworkInfo");async function kS(){if(_d!==void 0)return _d;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Kt.osInfo();e=c;let u=await Kt.versions("node, npm");return e.node_version=u.node,e.npm_version=u.npm,_d=e,_d}catch(t){return ci.error(`error in getSystemInformation: ${t}`),e}}a(kS,"getSystemInformation");async function VS(){let e=[],t=await AL.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await tj(n));return e}a(VS,"getTableSize");async function $S(){let e=await AL.describeAll(),t={};for(let r in e){let n=t[r]={};for(let s in e[r])try{let i=nj({database:r,table:s}),o=i.getStats();o.readers=i.readerList().split(/\n\s+/).slice(1).map(c=>{let[u,_,l]=c.trim().split(" ");return{pid:u,thread:_,txnid:l}}),n[s]=o}catch(i){ci.notify(`Error getting stats for table ${s}: ${i}`)}}return t}a($S,"getMetrics");async function RL(){if(YS.get(dd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{js:e,jsm:t}=await ej.getNATSReferences(),r=await t.streams.info(vS.WORK_QUEUE_CONSUMER_NAMES.stream_name),n=await e.consumers.get(vS.WORK_QUEUE_CONSUMER_NAMES.stream_name,vS.WORK_QUEUE_CONSUMER_NAMES.durable_name),s={ingest:{stream:{...r.state},consumer:{num_ack_pending:n._info.num_ack_pending,num_redelivered:n._info.num_redelivered,num_waiting:n._info.num_waiting,num_pending:n._info.num_pending}}};return r.sources&&(s.ingest.stream.sources=r.sources),s}}a(RL,"getNatsStreamInfo");async function sj(e){let t=new rj;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await kS(),t.time=BS(),t.cpu=await HS(),t.memory=await xS(),t.disk=await qS(),t.network=await GS(),t.harperdb_processes=await FS(),t.table_size=await VS(),t.metrics=await $S(),t.threads=await gL(),t.replication=await RL(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await kS();break;case"time":t.time=BS();break;case"cpu":t.cpu=await HS();break;case"memory":t.memory=await xS();break;case"disk":t.disk=await qS();break;case"network":t.network=await GS();break;case"harperdb_processes":t.harperdb_processes=await FS();break;case"table_size":t.table_size=await VS();break;case"database_metrics":case"metrics":t.metrics=await $S();break;case"threads":t.threads=await gL();break;case"replication":t.replication=await RL();break;default:break}return t}a(sj,"systemInformation")});var Ed=T((fde,bL)=>{"use strict";bL.exports={version:ij,printVersion:oj};var fd=zc();function ij(){if(fd)return fd.version}a(ij,"version");function oj(){fd&&console.log(`HarperDB Version ${fd.version}`)}a(oj,"printVersion")});var As=T((pde,IL)=>{"use strict";var aj=Zr(),KS=J(),cj=require("util"),no=U(),NL=Z();NL.initSync();var uj=wS(),yL=jr(),{Node:hde,NodeSubscription:mde}=aa(),lj=Xo(),_j=_L(),{RemotePayloadObject:dj,RemotePayloadSubscription:fj}=du(),{handleHDBError:Ej,hdb_errors:hj}=ee(),{HTTP_STATUS_CODES:mj,HDB_ERROR_MSGS:pj}=hj,Sj=Qn(),Tj=ca(),gj=Ed(),{getDatabases:Rj}=(be(),te(Fe)),Aj=cj.promisify(uj.authorize),Oj=yL.searchByHash,bj=yL.searchByValue;IL.exports={authHeaderToUser:Nj,isEmpty:yj,getNodeRecord:wj,upsertNodeRecord:Ij,buildNodePayloads:Cj,checkClusteringEnabled:Dj,getAllNodeRecords:Lj,getSystemInfo:Mj,reverseSubscription:wL};async function Nj(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Aj(t,null),e}a(Nj,"authHeaderToUser");function yj(e){return e==null}a(yj,"isEmpty");async function wj(e){let t=new lj(no.SYSTEM_SCHEMA_NAME,no.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Oj(t)}a(wj,"getNodeRecord");async function Ij(e){let t=new _j(no.SYSTEM_SCHEMA_NAME,no.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return aj.upsert(t)}a(Ij,"upsertNodeRecord");function wL(e){if(KS.isEmpty(e.subscribe)||KS.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(wL,"reverseSubscription");function Cj(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=KS.getTableHashAttribute(u,_),{subscribe:d,publish:f}=wL(c),E=Rj()[u]?.[_],h=new fj(u,_,l,f,d,c.start_time,E.schemaDefined?E.attributes:void 0);s.push(h)}return new dj(r,t,s,n)}a(Cj,"buildNodePayloads");function Dj(){if(!NL.get(no.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Ej(new Error,pj.CLUSTERING_NOT_ENABLED,mj.BAD_REQUEST,void 0,void 0,!0)}a(Dj,"checkClusteringEnabled");async function Lj(){let e=new Sj(no.SYSTEM_SCHEMA_NAME,no.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await bj(e))}a(Lj,"getAllNodeRecords");async function Mj(){let e=await Tj.getSystemInformation();return{hdb_version:gj.version(),node_version:e.node_version,platform:e.platform}}a(Mj,"getSystemInfo")});var WS=T((Tde,BL)=>{"use strict";var hd=At(),CL=J(),DL=tt(),LL=U(),md=W(),ML=rd(),Uj=fp(),{RemotePayloadObject:Pj}=du(),{handleHDBError:UL,hdb_errors:vj}=ee(),{HTTP_STATUS_CODES:PL}=vj,{NodeSubscription:vL}=aa();BL.exports=Bj;async function Bj(e,t){let r;try{r=await hd.request(`${t}.${DL.REQUEST_SUFFIX}`,new Pj(LL.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),md.trace("Response from remote describe all request:",r)}catch(o){md.error(`addNode received error from describe all request to remote node: ${o}`);let c=hd.requestErrorHandler(o,"add_node",t);throw UL(new Error,c,PL.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===DL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw UL(new Error,o,PL.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===LL.SYSTEM_SCHEMA_NAME){await hd.createLocalTableStream(u,c);let h=new vL(u,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let _=CL.doesSchemaExist(u),l=n[u]!==void 0,d=c?CL.doesTableExist(u,c):!0,f=c?n?.[u]?.[c]!==void 0:!0;if(!_&&!l||!d&&!f){s.push(o);continue}if(!_&&l&&(md.trace(`addNode creating schema: ${u}`),await ML.createSchema({operation:"create_schema",schema:u})),!d&&f){md.trace(`addNode creating table: ${c} in schema: ${u} with attributes ${JSON.stringify(n[u][c].attributes)}`);let h=new Uj(u,c,n[u][c].hash_attribute);n[u][c].attributes&&(h.attributes=n[u][c].attributes),await ML.createTable(h)}await hd.createLocalTableStream(u,c);let E=new vL(u,c,o.publish,o.subscribe);E.start_time=o.start_time,i.push(E)}return{added:i,skipped:s}}a(Bj,"reviewSubscriptions")});var Td=T((Rde,FL)=>{"use strict";var{handleHDBError:pd,hdb_errors:Hj}=ee(),{HTTP_STATUS_CODES:Sd}=Hj,{addUpdateNodeValidator:xj}=ad(),fu=W(),xL=U(),HL=tt(),Fj=J(),QS=At(),Eu=As(),qj=Z(),Gj=WS(),{Node:kj,NodeSubscription:Vj}=aa(),{broadcast:$j}=je(),Yj="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Kj="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Wj=qj.get(xL.CONFIG_PARAMS.CLUSTERING_NODENAME);FL.exports=Qj;async function Qj(e,t=!1){fu.trace("addNode called with:",e),Eu.checkClusteringEnabled();let r=xj(e);if(r)throw pd(r,r.message,Sd.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await Eu.getNodeRecord(n);if(!Fj.isEmptyOrZeroLength(d))throw pd(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,Sd.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Gj(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=Yj,o;let c=Eu.buildNodePayloads(s,Wj,xL.OPERATIONS_ENUM.ADD_NODE,await Eu.getSystemInfo());fu.trace("addNode sending remote payload:",c);let u;try{u=await QS.request(`${n}.${HL.REQUEST_SUFFIX}`,c)}catch(d){fu.error(`addNode received error from request: ${d}`);let f=QS.requestErrorHandler(d,"add_node",n);throw pd(new Error,f,Sd.INTERNAL_SERVER_ERROR,"error",f)}if(u.status===HL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${u.message}`;throw pd(new Error,d,Sd.INTERNAL_SERVER_ERROR,"error",d)}fu.trace(u);let _=[];for(let d=0,f=s.length;d<f;d++){let E=s[d];fu.trace("Add node updating work stream for node:",n,"subscriptions:",E),await QS.updateWorkStream(E,n),s[d].start_time===void 0&&delete s[d].start_time,_.push(new Vj(E.schema,E.table,E.publish,E.subscribe))}let l=new kj(n,_,u.system_info);return await Eu.upsertNodeRecord(l),$j({type:"nats_update"}),i.length>0?o.message=Kj:o.message=`Successfully added '${n}' to manifest`,o}a(Qj,"addNode")});var jS=T((bde,kL)=>{"use strict";var{handleHDBError:zS,hdb_errors:zj}=ee(),{HTTP_STATUS_CODES:JS}=zj,{addUpdateNodeValidator:Jj}=ad(),hu=W(),GL=U(),qL=tt(),Ode=J(),XS=At(),mu=As(),Xj=Z(),{cloneDeep:jj}=require("lodash"),Zj=WS(),{Node:eZ,NodeSubscription:tZ}=aa(),{broadcast:rZ}=je(),nZ="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",sZ="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",iZ=Xj.get(GL.CONFIG_PARAMS.CLUSTERING_NODENAME);kL.exports=oZ;async function oZ(e){hu.trace("updateNode called with:",e),mu.checkClusteringEnabled();let t=Jj(e);if(t)throw zS(t,t.message,JS.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await mu.getNodeRecord(r);s.length>0&&(n=jj(s));let{added:i,skipped:o}=await Zj(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=nZ,c;let u=mu.buildNodePayloads(i,iZ,GL.OPERATIONS_ENUM.UPDATE_NODE,await mu.getSystemInfo());hu.trace("updateNode sending remote payload:",u);let _;try{_=await XS.request(`${r}.${qL.REQUEST_SUFFIX}`,u)}catch(l){hu.error(`updateNode received error from request: ${l}`);let d=XS.requestErrorHandler(l,"update_node",r);throw zS(new Error,d,JS.INTERNAL_SERVER_ERROR,"error",d)}if(_.status===qL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let l=`Error returned from remote node ${r}: ${_.message}`;throw zS(new Error,l,JS.INTERNAL_SERVER_ERROR,"error",l)}hu.trace(_);for(let l=0,d=i.length;l<d;l++){let f=i[l];hu.trace(`updateNode updating work stream for node: ${r} subscription:`,f),await XS.updateWorkStream(f,r),i[l].start_time===void 0&&delete i[l].start_time}return n||(n=[new eZ(r,[],_.system_info)]),await aZ(n[0],i,_.system_info),o.length>0?c.message=sZ:c.message=`Successfully updated '${r}'`,c}a(oZ,"updateNode");async function aZ(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 tZ(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await mu.upsertNodeRecord(n),rZ({type:"nats_update"})}a(aZ,"updateNodeTable")});var WL=T((yde,KL)=>{"use strict";var YL=require("joi"),{string:VL}=YL.types(),cZ=et(),$L=U(),uZ=Z(),lZ=tt();KL.exports=_Z;function _Z(e){let t=VL.invalid(uZ.get($L.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(lZ.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=YL.object({operation:VL.valid($L.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return cZ.validateBySchema(e,r)}a(_Z,"removeNodeValidator")});var Rd=T((Ide,ZL)=>{"use strict";var{handleHDBError:QL,hdb_errors:dZ}=ee(),{HTTP_STATUS_CODES:zL}=dZ,fZ=WL(),pu=W(),JL=As(),EZ=J(),gd=U(),XL=tt(),jL=At(),hZ=Z(),{RemotePayloadObject:mZ}=du(),{NodeSubscription:pZ}=aa(),SZ=Gc(),TZ=xi(),{broadcast:gZ}=je(),RZ=hZ.get(gd.CONFIG_PARAMS.CLUSTERING_NODENAME);ZL.exports=AZ;async function AZ(e){pu.trace("removeNode called with:",e),JL.checkClusteringEnabled();let t=fZ(e);if(t)throw QL(t,t.message,zL.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await JL.getNodeRecord(r);if(EZ.isEmptyOrZeroLength(n))throw QL(new Error,`Node '${r}' was not found.`,zL.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new mZ(gd.OPERATIONS_ENUM.REMOVE_NODE,RZ,[]),i,o=!1;try{i=await jL.request(`${r}.${XL.REQUEST_SUFFIX}`,s),pu.trace("Remove node reply from remote node:",r,i)}catch(u){pu.error("removeNode received error from request:",u),o=!0}for(let u=0,_=n.subscriptions.length;u<_;u++){let l=n.subscriptions[u];pu.trace(`Remove node removing subscription: ${l.schema}.${l.table} for node: ${r}`);let d=new pZ(l.schema,l.table,!1,!1);await jL.updateWorkStream(d,r)}let c=new SZ(gd.SYSTEM_SCHEMA_NAME,gd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await TZ.deleteRecord(c),gZ({type:"nats_update"}),i?.status===XL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(pu.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(AZ,"removeNode")});var rM=T((Dde,tM)=>{"use strict";var eM=require("joi"),{string:OZ,array:bZ}=eM.types(),NZ=et(),yZ=ad();tM.exports=wZ;function wZ(e){let t=eM.object({operation:OZ.valid("configure_cluster").required(),connections:bZ.items(yZ.validation_schema).required()});return NZ.validateBySchema(e,t)}a(wZ,"configureClusterValidator")});var ZS=T((Mde,aM)=>{"use strict";var IZ=U(),Ad=W(),CZ=J(),DZ=Rd(),LZ=Td(),nM=As(),MZ=rM(),{handleHDBError:sM,hdb_errors:UZ}=ee(),{HTTP_STATUS_CODES:iM}=UZ,PZ="Configure cluster complete.",vZ="Failed to configure the cluster. Check the logs for more details.",BZ="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";aM.exports=HZ;async function HZ(e){Ad.trace("configure cluster called with:",e),nM.checkClusteringEnabled();let t=MZ(e);if(t)throw sM(t,t.message,iM.BAD_REQUEST,void 0,void 0,!0);let r=await nM.getAllNodeRecords(),n=[];for(let f=0,E=r.length;f<E;f++)n.push(oM(DZ,{operation:IZ.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[f].name},r[f].name));let s=await Promise.allSettled(n);Ad.trace("All results from configure_cluster remove node:",s);let i=[],o=e.connections.length;for(let f=0;f<o;f++){let E=e.connections[f];i.push(oM(LZ,E,E.node_name))}let c=await Promise.allSettled(i);Ad.trace("All results from configure_cluster add node:",c);let u=[],_=[],l=!1,d=s.concat(c);for(let f=0,E=d.length;f<E;f++){let h=d[f];h.status==="rejected"&&(Ad.error(h.reason),u.includes(h.reason.node_name)||u.push(h.reason.node_name)),h.status==="fulfilled"&&(l=!0);let p=h?.value?.result;typeof p=="string"&&p.includes("Successfully removed")||h.status==="rejected"||_.push({node_name:h?.value?.node_name,subscriptions:h?.value?.result})}if(CZ.isEmptyOrZeroLength(u))return{message:PZ,connections:_};if(l)return{message:BZ,failed_nodes:u,connections:_};throw sM(new Error,vZ,iM.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(HZ,"configureCluster");async function oM(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){throw{node_name:r,error:n}}}a(oM,"functionWrapper")});var uM=T((Pde,cM)=>{"use strict";var Od=require("joi"),xZ=et(),{validateSchemaExists:FZ,validateTableExists:qZ,validateSchemaName:GZ}=Vn(),kZ=Od.object({operation:Od.string().valid("purge_stream"),schema:Od.string().custom(FZ).custom(GZ).required(),table:Od.string().custom(qZ).required()});function VZ(e){return xZ.validateBySchema(e,kZ)}a(VZ,"purgeStreamValidator");cM.exports=VZ});var eT=T((Bde,lM)=>{"use strict";var{handleHDBError:$Z,hdb_errors:YZ}=ee(),{HTTP_STATUS_CODES:KZ}=YZ,WZ=uM(),QZ=At(),zZ=As();lM.exports=JZ;async function JZ(e){if(e.purge_ingest!==!0){let s=WZ(e);if(s)throw $Z(s,s.message,KZ.BAD_REQUEST,void 0,void 0,!0)}zZ.checkClusteringEnabled();let{schema:t,table:r,purge_ingest:n}=e;return await QZ.purgeTableStream(t,r,n),n?"Successfully purged ingest":`Successfully purged table '${t}.${r}'`}a(JZ,"purgeStream")});var nT=T((xde,mM)=>{"use strict";var rT=As(),XZ=At(),fM=Z(),bd=U(),so=tt(),jZ=J(),tT=W(),{RemotePayloadObject:ZZ}=du(),{ErrorCode:_M}=require("nats"),dM=fM.get(bd.CONFIG_PARAMS.CLUSTERING_ENABLED),EM=fM.get(bd.CONFIG_PARAMS.CLUSTERING_NODENAME);mM.exports={clusterStatus:e5,buildNodeStatus:hM};async function e5(){let e={node_name:EM,is_enabled:dM,connections:[]};if(!dM)return e;let t=await rT.getAllNodeRecords();if(jZ.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(hM(t[n],e.connections));return await Promise.allSettled(r),e}a(e5,"clusterStatus");async function hM(e,t){let r=e.name,n=new ZZ(bd.OPERATIONS_ENUM.CLUSTER_STATUS,EM,void 0,await rT.getSystemInfo()),s,i,o=so.CLUSTER_STATUS_STATUSES.OPEN;try{let u=Date.now();s=await XZ.request(so.REQUEST_SUBJECT(r),n),i=Date.now()-u,s.status===so.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=so.CLUSTER_STATUS_STATUSES.CLOSED,tT.error(`Error getting node status from ${r} `,s))}catch(u){tT.warn(`Error getting node status from ${r}`,u),u.code===_M.NoResponders?o=so.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:u.code===_M.Timeout?o=so.CLUSTER_STATUS_STATUSES.TIMEOUT:o=so.CLUSTER_STATUS_STATUSES.CLOSED}let c=new t5(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!==bd.PRE_4_0_0_VERSION&&await rT.upsertNodeRecord(u)}catch(u){tT.error("Cluster status encountered an error updating system info for node:",r,u)}t.push(c)}a(hM,"buildNodeStatus");function t5(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(t5,"NodeStatusObject")});var iT=T((qde,pM)=>{"use strict";var{handleHDBError:r5,hdb_errors:n5}=ee(),{HTTP_STATUS_CODES:s5}=n5,i5=At(),o5=As(),sT=J(),Nd=require("joi"),a5=et(),c5=2e3,u5=Nd.object({timeout:Nd.number().min(1),connected_nodes:Nd.boolean(),routes:Nd.boolean()});pM.exports=l5;async function l5(e){o5.checkClusteringEnabled();let t=a5.validateBySchema(e,u5);if(t)throw r5(t,t.message,s5.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||sT.autoCastBoolean(n),o=s===void 0||sT.autoCastBoolean(s),c={nodes:[]},u=await i5.getServerList(r??c5),_={};if(i)for(let l=0,d=u.length;l<d;l++){let f=u[l].statsz;f&&(_[u[l].server.name]=f.routes)}for(let l=0,d=u.length;l<d;l++){if(u[l].statsz)continue;let f=u[l].server,E=u[l].data;if(f.name.endsWith("-hub")){let h={name:f.name.slice(0,-4),response_time:u[l].response_time};i&&(h.connected_nodes=[],_[f.name]&&_[f.name].forEach(p=>{h.connected_nodes.includes(p.name.slice(0,-4))||h.connected_nodes.push(p.name.slice(0,-4))})),o&&(h.routes=E.cluster?.urls?E.cluster?.urls.map(p=>({host:p.split(":")[0],port:sT.autoCast(p.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(l5,"clusterNetwork")});var RM=T((kde,gM)=>{"use strict";var oT=require("joi"),SM=et(),{route_constraints:TM}=Nm();gM.exports={setRoutesValidator:_5,deleteRoutesValidator:d5};function _5(e){let t=oT.object({server:oT.valid("hub","leaf").required(),routes:TM.required()});return SM.validateBySchema(e,t)}a(_5,"setRoutesValidator");function d5(e){let t=oT.object({routes:TM.required()});return SM.validateBySchema(e,t)}a(d5,"deleteRoutesValidator")});var cT=T(($de,NM)=>{"use strict";var io=Lr(),aT=J(),yd=U(),AM=RM(),{handleHDBError:OM,hdb_errors:f5}=ee(),{HTTP_STATUS_CODES:bM}=f5,E5="cluster routes successfully set",h5="cluster routes successfully deleted";NM.exports={setRoutes:m5,getRoutes:p5,deleteRoutes:S5};function m5(e){let t=AM.setRoutesValidator(e);if(t)throw OM(t,t.message,bM.BAD_REQUEST,void 0,void 0,!0);let r=io.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=aT.autoCast(_.port);let l=n.some(f=>f.host===_.host&&f.port===_.port),d=s.some(f=>f.host===_.host&&f.port===_.port);l||d?i.push(_):(n.push(_),o.push(_))}return e.server==="hub"?io.updateConfigValue(yd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n):io.updateConfigValue(yd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n),{message:E5,set:o,skipped:i}}a(m5,"setRoutes");function p5(){let e=io.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}a(p5,"getRoutes");function S5(e){let t=AM.deleteRoutesValidator(e);if(t)throw OM(t,t.message,bM.BAD_REQUEST,void 0,void 0,!0);let r=io.getClusteringRoutes(),n=r.hub_routes,s=r.leaf_routes,i=[],o=[],c=!1,u=!1;for(let _=0,l=e.routes.length;_<l;_++){let d=e.routes[_],f=!1;for(let E=0,h=n.length;E<h;E++){let p=n[E];if(d.host===p.host&&d.port===p.port){n.splice(E,1),f=!0,c=!0,i.push(d);break}}if(!f){let E=!0;for(let h=0,p=s.length;h<p;h++){let S=s[h];if(d.host===S.host&&d.port===S.port){s.splice(h,1),u=!0,E=!1,i.push(d);break}}E&&o.push(d)}}return c&&(n=aT.isEmptyOrZeroLength(n)?null:n,io.updateConfigValue(yd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n)),u&&(s=aT.isEmptyOrZeroLength(s)?null:s,io.updateConfigValue(yd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,s)),{message:h5,deleted:i,skipped:o}}a(S5,"deleteRoutes")});var wM=T((Kde,yM)=>{"use strict";var Su=require("alasql"),oo=require("recursive-iterator"),Ln=W(),T5=J(),Tu=U(),uT=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,R5(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=>Tu.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=>!Tu.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][Tu.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=g5(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(_=>!Tu.SEARCH_WILDCARDS.includes(_));c.forEach(({attribute_name:_})=>{let l=new Su.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 g5(e){return e.filter(t=>t[Tu.PERMS_CRUD_ENUM.READ])}a(g5,"filterReadRestrictedAttrs");function R5(e,t,r,n,s){A5(e,t,r,n,s)}a(R5,"interpretAST");function gu(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(gu,"addSchemaTableToMap");function A5(e,t,r,n,s){if(!e){Ln.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Su.yy.Insert?y5(e,t,r):e instanceof Su.yy.Select?O5(e,t,r,n,s):e instanceof Su.yy.Update?b5(e,t,r):e instanceof Su.yy.Delete?N5(e,t,r):Ln.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(A5,"getRecordAttributesAST");function O5(e,t,r,n,s){if(!e){Ln.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(T5.isEmptyOrZeroLength(i)){Ln.error("No schema specified");return}e.from.forEach(c=>{gu(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),gu(c.table,t,r,n,s)});let o=new oo(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{Ln.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 oo(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{Ln.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 oo(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{Ln.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 oo(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{Ln.info(`table specified as ${_} not found.`);return}t.get(l).get(_).indexOf(u.columnid)<0&&t.get(l).get(_).push(u.columnid)}}}a(O5,"getSelectAttributes");function b5(e,t,r){if(!e){Ln.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new oo(e.columns),s=e.table.databaseid;gu(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&lT(e.table.tableid,s,i.columnid,t,r)}a(b5,"getUpdateAttributes");function N5(e,t,r){if(!e){Ln.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new oo(e.where),s=e.table.databaseid;gu(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&lT(e.table.tableid,s,i.columnid,t,r)}a(N5,"getDeleteAttributes");function y5(e,t,r){if(!e){Ln.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new oo(e.columns),s=e.into.databaseid;gu(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&lT(e.into.tableid,s,i.columnid,t,r)}a(y5,"getInsertAttributes");function lT(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(lT,"pushAttribute");yM.exports=uT});var fT=T((Qde,LM)=>{var wd=ki(),IM=require("chalk"),xr=W(),CM=require("prompt"),{promisify:w5}=require("util"),_T=U(),I5=require("fs-extra"),C5=require("path"),D5=J(),L5=Ed(),DM=Z();DM.initSync();var M5=require("moment"),U5=w5(CM.get),P5=C5.join(DM.getHdbBasePath(),_T.LICENSE_KEY_DIR_NAME,_T.LICENSE_FILE_NAME,_T.LICENSE_FILE_NAME);LM.exports={getFingerprint:B5,setLicense:v5,parseLicense:dT,register:H5,getRegistrationInfo:F5};async function v5(e){if(e&&e.key&&e.company){try{xr.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await dT(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw xr.error(r),xr.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(v5,"setLicense");async function B5(){let e={};try{e=await wd.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw xr.error(r),xr.error(t),new Error(r)}return e}a(B5,"getFingerprint");async function dT(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");xr.info("Validating license input...");let r=wd.validateLicense(e,t);if(xr.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(xr.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(xr.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{xr.info("writing license to disk"),await I5.writeFile(P5,JSON.stringify({license_key:e,company:t}))}catch(n){throw xr.error("Failed to write License"),n}return"Registration successful."}a(dT,"parseLicense");async function H5(){let e=await x5();return dT(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(H5,"register");async function x5(){let e=await wd.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:IM.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:IM.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{CM.start()}catch(n){xr.error(n)}let r;try{r=await U5(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(x5,"promptForRegistration");async function F5(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await wd.getLicense()}catch(r){throw xr.error(`There was an error when searching licenses due to: ${r.message}`),r}if(D5.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=L5.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=M5.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(F5,"getRegistrationInfo")});var UM=T((Jde,MM)=>{"use strict";var q5=tt(),ET=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,u,_,l,d,f,E,h){this.port=t,o===null&&(o=void 0),this.server_name=r+q5.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:u},this.leafnodes={port:_,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:l,port:d,routes:f,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:u}},this.accounts={SYS:{users:E},HDB:{users:h}},this.system_account="SYS"}};MM.exports=ET});var BM=T((jde,vM)=>{"use strict";var PM=tt(),hT=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+PM.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+PM.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"}};vM.exports=hT});var xM=T((efe,HM)=>{"use strict";var mT=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};HM.exports=mT});var qM=T((rfe,FM)=>{"use strict";var G5=tt(),pT=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+G5.SERVER_SUFFIX.ADMIN,this.password=r}};FM.exports=pT});var gT=T((sfe,VM)=>{"use strict";var ua=require("path"),Dd=require("fs-extra"),k5=UM(),V5=BM(),$5=xM(),Y5=qM(),ST=en(),_a=J(),lr=Lr(),Cd=U(),Ru=tt(),{CONFIG_PARAMS:ut}=Cd,Au=W(),Ou=Z(),GM=ms(),TT=At(),la="clustering",K5=1e4,kM=5;VM.exports={generateNatsConfig:Q5,removeNatsConfig:z5,getHubConfigPath:W5};function W5(){let e=Ou.get(ut.ROOTPATH);return ua.join(e,la,Ru.NATS_CONFIG_FILES.HUB_SERVER)}a(W5,"getHubConfigPath");async function Q5(e=!1,t=void 0){Ou.initSync();let r=Ou.get(ut.ROOTPATH),n=ua.join(r,la,Ru.PID_FILES.HUB),s=ua.join(r,la,Ru.PID_FILES.LEAF),i=lr.getConfigFromFile(ut.CLUSTERING_LEAFSERVER_STREAMS_PATH),o=ua.join(r,la,Ru.NATS_CONFIG_FILES.HUB_SERVER),c=ua.join(r,la,Ru.NATS_CONFIG_FILES.LEAF_SERVER),u=lr.getConfigFromFile(ut.CLUSTERING_TLS_CERTIFICATE),_=lr.getConfigFromFile(ut.CLUSTERING_TLS_PRIVATEKEY),l=lr.getConfigFromFile(ut.CLUSTERING_TLS_CERT_AUTH),d=lr.getConfigFromFile(ut.CLUSTERING_TLS_INSECURE),f=lr.getConfigFromFile(ut.CLUSTERING_TLS_VERIFY),E=lr.getConfigFromFile(ut.CLUSTERING_NODENAME),h=lr.getConfigFromFile(ut.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await TT.checkNATSServerInstalled()||Ld("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let p=await ST.listUsers(),S=lr.getConfigFromFile(ut.CLUSTERING_USER),O=await ST.getClusterUser();(_a.isEmpty(O)||O.active!==!0)&&Ld(`Invalid cluster user '${S}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Id(ut.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Id(ut.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Id(ut.CLUSTERING_HUBSERVER_NETWORK_PORT),await Id(ut.CLUSTERING_LEAFSERVER_NETWORK_PORT));let g=[],R=[];for(let[z,se]of p.entries())se.role.role===Cd.ROLE_TYPES_ENUM.CLUSTER_USER&&se.active&&(g.push(new Y5(se.username,GM.decrypt(se.hash))),R.push(new $5(se.username,GM.decrypt(se.hash))));let B=[],{hub_routes:H}=lr.getClusteringRoutes();if(!_a.isEmptyOrZeroLength(H))for(let z of H)B.push(`tls://${O.sys_name_encoded}:${O.uri_encoded_d_hash}@${z.host}:${z.port}`);let v=new k5(lr.getConfigFromFile(ut.CLUSTERING_HUBSERVER_NETWORK_PORT),E,n,u,_,l,d,f,h,lr.getConfigFromFile(ut.CLUSTERING_HUBSERVER_CLUSTER_NAME),lr.getConfigFromFile(ut.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),B,g,R);l==null&&(delete v.tls.ca_file,delete v.leafnodes.tls.ca_file),t=_a.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===Cd.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Dd.writeJson(o,v),Au.trace(`Hub server config written to ${o}`));let M=`tls://${O.sys_name_encoded}:${O.uri_encoded_d_hash}@0.0.0.0:${h}`,$=`tls://${O.uri_encoded_name}:${O.uri_encoded_d_hash}@0.0.0.0:${h}`,K=new V5(lr.getConfigFromFile(ut.CLUSTERING_LEAFSERVER_NETWORK_PORT),E,s,i,[M],[$],g,R,u,_,l,d);l==null&&delete K.tls.ca_file,(t===void 0||t===Cd.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Dd.writeJson(c,K),Au.trace(`Leaf server config written to ${c}`))}a(Q5,"generateNatsConfig");async function Id(e){let t=Ou.get(e);return _a.isEmpty(t)&&Ld(`port undefined for '${e}'`),await _a.isPortTaken(t)&&Ld(`'${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(Id,"isPortAvailable");function Ld(e){let t=`Error generating clustering config: ${e}`;Au.error(t),console.error(t),process.exit(1)}a(Ld,"generateNatsConfigError");async function z5(e){let{port:t,config_file:r}=TT.getServerConfig(e),{username:n,decrypt_hash:s}=await ST.getClusterUser(),i=0,o=2e3;for(;i<kM;){try{let _=await TT.createConnection(t,n,s,!1);if(_.protocol.connected===!0){_.close();break}}catch(_){Au.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${_}`)}if(i++,i>=kM)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);await _a.async_set_timeout(o*(i*2))}let c="0".repeat(K5),u=ua.join(Ou.get(ut.ROOTPATH),la,r);await Dd.writeFile(u,c),await Dd.remove(u),Au.notify(e,"started.")}a(z5,"removeNatsConfig")});var zM=T((ofe,QM)=>{"use strict";var Fr=Z(),J5=ki(),Se=U(),bu=tt(),Os=require("path"),{PACKAGE_ROOT:Ud}=U(),$M=Z(),Md=J(),da="/dev/null",X5=Os.join(Ud,"launchServiceScripts"),YM=Os.join(Ud,"utility/scripts"),j5=Os.join(YM,Se.HDB_RESTART_SCRIPT),KM=Os.resolve(Ud,"dependencies",`${process.platform}-${process.arch}`,bu.NATS_BINARY_NAME);function WM(){let t=J5.licenseSearch().ram_allocation||Se.RAM_ALLOCATION_ENUM.DEFAULT,r=Se.MEM_SETTING_KEY+t,n={[Se.PROCESS_NAME_ENV_PROP]:Se.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Md.noBootFile()&&(n[Se.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Md.getEnvCliRootPath()),{name:Se.PROCESS_DESCRIPTORS.HDB,script:Se.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:Ud}}a(WM,"generateMainServerConfig");var Z5=9930;function e8(){Fr.initSync(!0);let e=Fr.get(Se.CONFIG_PARAMS.ROOTPATH),t=Os.join(e,"clustering",bu.NATS_CONFIG_FILES.HUB_SERVER),r=Os.join(Fr.get(Se.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Se.LOG_NAMES.HDB),n=$M.get(Se.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=bu.LOG_LEVEL_FLAGS[Fr.get(Se.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Se.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Z5?"-"+n:""),script:KM,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Se.PROCESS_NAME_ENV_PROP]:Se.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Fr.get(Se.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=da,i.error_file=da),i}a(e8,"generateNatsHubServerConfig");var t8=9940;function r8(){Fr.initSync(!0);let e=Fr.get(Se.CONFIG_PARAMS.ROOTPATH),t=Os.join(e,"clustering",bu.NATS_CONFIG_FILES.LEAF_SERVER),r=Os.join(Fr.get(Se.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Se.LOG_NAMES.HDB),n=$M.get(Se.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=bu.LOG_LEVEL_FLAGS[Fr.get(Se.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Se.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==t8?"-"+n:""),script:KM,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Se.PROCESS_NAME_ENV_PROP]:Se.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Fr.get(Se.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=da,i.error_file=da),i}a(r8,"generateNatsLeafServerConfig");function n8(){Fr.initSync();let e=Os.join(Fr.get(Se.CONFIG_PARAMS.LOGGING_ROOT),Se.LOG_NAMES.HDB),t={name:Se.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Se.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Se.PROCESS_NAME_ENV_PROP]:Se.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:X5,autorestart:!1};return Fr.get(Se.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=da,t.error_file=da),t}a(n8,"generateClusteringUpgradeV4ServiceConfig");function s8(){let e={[Se.PROCESS_NAME_ENV_PROP]:Se.PROCESS_DESCRIPTORS.RESTART_HDB};return Md.noBootFile()&&(e[Se.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Md.getEnvCliRootPath()),{...{name:Se.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:YM},script:j5}}a(s8,"generateRestart");function i8(){return{apps:[WM()]}}a(i8,"generateAllServiceConfigs");QM.exports={generateAllServiceConfigs:i8,generateMainServerConfig:WM,generateRestart:s8,generateNatsHubServerConfig:e8,generateNatsLeafServerConfig:r8,generateClusteringUpgradeV4ServiceConfig:n8}});var uU=T((ufe,cU)=>{"use strict";var Le=U(),o8=J(),bs=gT(),Nu=At(),jn=tt(),ui=zM(),Pd=Z(),li=W(),a8=As(),{startWorker:JM,onMessageFromWorkers:c8}=je(),u8=ca(),cfe=require("util"),l8=require("child_process"),_8=require("fs"),{execFile:d8}=l8,we;cU.exports={enterPM2Mode:f8,start:_i,stop:RT,reload:jM,restart:ZM,list:AT,describe:tU,connect:Ns,kill:S8,startAllServices:T8,startService:OT,getUniqueServicesList:rU,restartAllServices:g8,isServiceRegistered:nU,reloadStopStart:sU,restartHdb:eU,deleteProcess:m8,startClusteringProcesses:oU,startClusteringThreads:aU,isHdbRestartRunning:p8,isClusteringRunning:A8,stopClustering:R8,reloadClustering:O8};var yu=!1;c8(e=>{e.type==="restart"&&Pd.initSync(!0)});function f8(){yu=!0}a(f8,"enterPM2Mode");function Ns(){return we||(we=require("pm2")),new Promise((e,t)=>{we.connect((r,n)=>{li.setupConsoleLogging(),r&&t(r),e(n)})})}a(Ns,"connect");var _r,E8=10,XM;function _i(e,t=!1){if(yu)return h8(e);let r=d8(e.script,e.args.split(" "),e);r.name=e.name,r.on("exit",async i=>{let o=_r.indexOf(r);o>-1&&_r.splice(o,1),!XM&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<E8&&(_8.existsSync(bs.getHubConfigPath())?_i(e):(await bs.generateNatsConfig(!0),_i(e),await new Promise(c=>setTimeout(c,3e3)),await bs.removeNatsConfig(Le.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await bs.removeNatsConfig(Le.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Pd.get(Le.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,u,_=0,l;for(;u=c.exec(i);){if(u.index&&jn.LOG_LEVEL_HIERARCHY[o]>=jn.LOG_LEVEL_HIERARCHY[l||"info"]){let E=l===jn.LOG_LEVELS.ERR||l===jn.LOG_LEVELS.WRN?li.OUTPUTS.STDERR:li.OUTPUTS.STDOUT;li.logCustomLevel(l||"info",E,n,i.slice(_,u.index).trim())}let[d,f]=u;_=u.index+d.length,l=jn.LOG_LEVELS[f]}if(jn.LOG_LEVEL_HIERARCHY[o]>=jn.LOG_LEVEL_HIERARCHY[l||"info"]){let d=l===jn.LOG_LEVELS.ERR||l===jn.LOG_LEVELS.WRN?li.OUTPUTS.STDERR:li.OUTPUTS.STDOUT;li.logCustomLevel(l||"info",d,n,i.slice(_).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),_r=[],!_r&&!t){let i=a(()=>{XM=!0,_r&&(_r.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)}_r.push(r)}a(_i,"start");function h8(e){return new Promise(async(t,r)=>{try{await Ns()}catch(n){r(n)}we.start(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(h8,"startWithPM2");function RT(e){if(!yu){for(let t of _r||[])t.name===e&&(_r.splice(_r.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Ns()}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(RT,"stop");function jM(e){return new Promise(async(t,r)=>{try{await Ns()}catch(n){r(n)}we.reload(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(jM,"reload");function ZM(e){if(!yu)for(let t of _r||[])t.name===e&&t.kill();return new Promise(async(t,r)=>{try{await Ns()}catch(n){r(n)}we.restart(e,(n,s)=>{we.disconnect(),t(s)})})}a(ZM,"restart");function m8(e){return new Promise(async(t,r)=>{try{await Ns()}catch(n){r(n)}we.delete(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(m8,"deleteProcess");async function eU(){await _i(ui.generateRestart())}a(eU,"restartHdb");async function p8(){let e=await AT();for(let t in e)if(e[t].name===Le.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(p8,"isHdbRestartRunning");function AT(){return new Promise(async(e,t)=>{try{await Ns()}catch(r){t(r)}we.list((r,n)=>{r&&(we.disconnect(),t(r)),we.disconnect(),e(n)})})}a(AT,"list");function tU(e){return new Promise(async(t,r)=>{try{await Ns()}catch(n){r(n)}we.describe(e,(n,s)=>{n&&(we.disconnect(),r(n)),we.disconnect(),t(s)})})}a(tU,"describe");function S8(){if(!yu){for(let e of _r||[])e.kill();_r=[];return}return new Promise(async(e,t)=>{try{await Ns()}catch(r){t(r)}we.killDaemon((r,n)=>{r&&(we.disconnect(),t(r)),we.disconnect(),e(n)})})}a(S8,"kill");async function T8(){try{await oU(),await aU(),await _i(ui.generateAllServiceConfigs())}catch(e){throw we?.disconnect(),e}}a(T8,"startAllServices");async function OT(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case Le.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=ui.generateMainServerConfig();break;case Le.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=ui.generateNatsIngestServiceConfig();break;case Le.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=ui.generateNatsReplyServiceConfig();break;case Le.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=ui.generateNatsHubServerConfig(),await _i(r,t),await bs.removeNatsConfig(e);return;case Le.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=ui.generateNatsLeafServerConfig(),await _i(r,t),await bs.removeNatsConfig(e);return;case Le.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=ui.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await _i(r)}catch(r){throw we?.disconnect(),r}}a(OT,"startService");async function rU(){try{let e=await AT(),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(rU,"getUniqueServicesList");async function g8(e=[]){try{let t=!1,r=await rU();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===Le.PROCESS_DESCRIPTORS.HDB?t=!0:await ZM(o))}t&&await sU(Le.PROCESS_DESCRIPTORS.HDB)}catch(t){throw we?.disconnect(),t}}a(g8,"restartAllServices");async function nU(e){if(_r?.find(r=>r.name===e))return!0;let t=await u8.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(nU,"isServiceRegistered");async function sU(e){let t=e===Le.PROCESS_DESCRIPTORS.HDB?Pd.get(Le.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES):Pd.get(Le.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES),r=await tU(e),n=o8.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await RT(e),await OT(e)):e===Le.PROCESS_DESCRIPTORS.HDB?await eU():await jM(e)}a(sU,"reloadStopStart");var iU;async function oU(e=!1){for(let t in Le.CLUSTERING_PROCESSES){let r=Le.CLUSTERING_PROCESSES[t];await OT(r,e)}}a(oU,"startClusteringProcesses");async function aU(){iU=JM(Le.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:Le.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE}),await Nu.createWorkQueueStream(jn.WORK_QUEUE_CONSUMER_NAMES),await Nu.updateIngestStreamConsumer(),await Nu.updateLocalStreams();let e=await a8.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===Le.PRE_4_0_0_VERSION){li.info("Starting clustering upgrade 4.0.0 process"),JM(Le.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(aU,"startClusteringThreads");async function R8(){for(let e in Le.CLUSTERING_PROCESSES)if(e!==Le.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===Le.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await iU.terminate();else{let t=Le.CLUSTERING_PROCESSES[e];await RT(t)}}a(R8,"stopClustering");async function A8(){for(let e in Le.CLUSTERING_PROCESSES){let t=Le.CLUSTERING_PROCESSES[e];if(await nU(t)===!1)return!1}return!0}a(A8,"isClusteringRunning");async function O8(){await bs.generateNatsConfig(!0),await Nu.reloadNATSHub(),await Nu.reloadNATSLeaf(),await bs.removeNatsConfig(Le.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await bs.removeNatsConfig(Le.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(O8,"reloadClustering")});var xd=T((_fe,mU)=>{"use strict";var b8=require("minimist"),{isMainThread:yT,parentPort:dU}=require("worker_threads"),rt=U(),{PROCESS_DESCRIPTORS_VALIDATE:wu}=rt,Zn=W(),wT=J(),vd=gT(),fa=At(),bT=tt(),fU=Lr(),es=uU(),lU=ca(),N8=jE(),{restartWorkers:Bd,onMessageByType:y8}=je(),{handleHDBError:w8,hdb_errors:I8}=ee(),{HTTP_STATUS_CODES:C8}=I8,Hd=Z();Hd.initSync();var Iu=`Restarting HarperDB. This may take up to ${rt.RESTART_TIMEOUT_MS/1e3} seconds.`,D8="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",_U="Clustering is not enabled so cannot be restarted",L8="Invalid service",Ea,sn;mU.exports={restart:EU,restartService:IT};yT&&y8(rt.ITC_EVENT_TYPES.RESTART,e=>{e.workerType?IT({service:e.workerType}):EU({operation:"restart"})});async function EU(e){sn=Object.keys(e).length===0,Ea=await es.isServiceRegistered(rt.HDB_PROC_DESCRIPTOR);let t=b8(process.argv);if(t.service){await IT(t);return}if(sn&&!Ea){console.error(D8);return}if(sn&&console.log(Iu),Ea){es.enterPM2Mode(),Zn.notify(Iu);let r=N8(Object.keys(rt.CONFIG_PARAM_MAP),!0);return wT.isEmptyOrZeroLength(Object.keys(r))||fU.updateConfigValue(void 0,void 0,r,!0,!0),U8(),Iu}return yT?(Zn.notify(Iu),setTimeout(()=>{Bd()},50)):dU.postMessage({type:rt.ITC_EVENT_TYPES.RESTART}),Iu}a(EU,"restart");async function IT(e){let{service:t}=e;if(rt.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw w8(new Error,L8,C8.BAD_REQUEST,void 0,void 0,!0);if(Ea=await es.isServiceRegistered(rt.HDB_PROC_DESCRIPTOR),!yT)return dU.postMessage({type:rt.ITC_EVENT_TYPES.RESTART,workerType:t}),t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`;let r;switch(t){case wu.clustering:if(!Hd.get(rt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=_U;break}sn&&console.log("Restarting clustering"),Zn.notify("Restarting clustering"),await hU();break;case wu.clustering_config:case wu["clustering config"]:if(!Hd.get(rt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=_U;break}sn&&console.log("Restarting clustering_config"),Zn.notify("Restarting clustering_config"),await es.reloadClustering();break;case"custom_functions":case"custom functions":case wu.harperdb:case wu.http_workers:if(sn&&!Ea){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}sn&&console.log("Restarting http_workers"),Zn.notify("Restarting http_workers"),sn?await es.restart(rt.HDB_PROC_DESCRIPTOR):setTimeout(()=>{Bd("http")},200);break;default:r=`Unrecognized service: ${t}`;break}return r?(Zn.error(r),sn&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(IT,"restartService");async function M8(){await fa.publishToStream(`${bT.SUBJECT_PREFIXES.TXN}.${bT.WORK_QUEUE_CONSUMER_NAMES.stream_name}`,bT.WORK_QUEUE_CONSUMER_NAMES.stream_name,fa.addNatsMsgHeader({operation:"dummy_msg"},void 0),{operation:"dummy_msg"})}a(M8,"postDummyNatsMsg");async function U8(){await hU(),await es.restart(rt.HDB_PROC_DESCRIPTOR),await wT.async_set_timeout(2e3),Hd.get(rt.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await NT(),sn&&(await fa.closeConnection(),process.exit(0))}a(U8,"restartPM2Mode");async function hU(){if(!fU.getConfigFromFile(rt.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await lU.getHDBProcessInfo()).clustering.length===0)Zn.trace("Clustering not running, restart will start clustering services"),await vd.generateNatsConfig(!0),await es.startClusteringProcesses(),await es.startClusteringThreads(),await NT(),sn&&await fa.closeConnection();else{await M8(),await vd.generateNatsConfig(!0),Ea?(Zn.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await es.restart(rt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await es.restart(rt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await lU.getHDBProcessInfo()).clustering.forEach(s=>{Zn.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await wT.async_set_timeout(3e3),await NT(),await fa.updateLocalStreams(),sn&&await fa.closeConnection(),Zn.trace("Restart clustering restarting ingest and reply service threads");let t=Bd(rt.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=Bd(rt.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(hU,"restartClustering");async function NT(){await vd.removeNatsConfig(rt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await vd.removeNatsConfig(rt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(NT,"removeNatsConfig")});var wU=T((Efe,yU)=>{"use strict";var ffe=require("lodash"),dr=U(),{handleHDBError:pU,hdb_errors:P8}=ee(),{HDB_ERROR_MSGS:v8,HTTP_STATUS_CODES:B8}=P8,CT=W();yU.exports={getRolePermissions:x8};var ao=Object.create(null),H8=a(e=>({key:e,perms:{}}),"perms_template_obj"),RU=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),AU=a((e=!1,t=!1,r=!1,n=!1)=>({[dr.PERMS_CRUD_ENUM.READ]:e,[dr.PERMS_CRUD_ENUM.INSERT]:t,[dr.PERMS_CRUD_ENUM.UPDATE]:r,[dr.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),DT=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...AU(t,r,n,s)}),"table_perms_template"),SU=a((e,t=AU())=>({attribute_name:e,describe:NU(t),[Cu]:t[Cu],[LT]:t[LT],[MT]:t[MT]}),"attr_perms_template"),TU=a((e,t=!1)=>({attribute_name:e,describe:t,[Cu]:t}),"timestamp_attr_perms_template"),{READ:Cu,INSERT:LT,UPDATE:MT}=dr.PERMS_CRUD_ENUM,OU=Object.values(dr.PERMS_CRUD_ENUM),bU=[Cu,LT,MT];function x8(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[dr.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(ao[t]&&ao[t].key===n)return ao[t].perms;let s=F8(e,r);return ao[t]?ao[t].key=n:ao[t]=H8(n),ao[t].perms=s,s}catch(r){if(!e[dr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[dr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<dr.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 CT.error(n),CT.debug(r),pU(new Error,v8.OUTDATED_PERMS_TRANSLATION_ERROR,B8.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
|
|
11
|
+
${r.stack}`;throw CT.error(n),pU(new Error)}}}a(x8,"getRolePermissions");function F8(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[dr.SYSTEM_SCHEMA_NAME]=n[dr.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=q8(t[i]);return}r[i]=RU(),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],_=G8(c,u);r[i].describe||OU.forEach(l=>{_[l]&&(r[i].describe=!0)}),r[i].tables[o]=_}else r[i].tables[o]=DT()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=DT()})}),r}a(F8,"translateRolePermissions");function q8(e){let t=RU(!0);return Object.keys(e).forEach(r=>{t.tables[r]=DT(!0,!0,!0,!0,!0)}),t}a(q8,"createStructureUserPermissions");function G8(e,t){let{attribute_permissions:r}=e;if(r.length>0){let s=Object.assign({},e);s.attribute_permissions=[];let i=r.reduce((_,l)=>{let{attribute_name:d}=l,f=l;return dr.TIME_STAMP_NAMES.includes(d)&&(f=TU(d,l[Cu])),_[d]=f,_},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],u=SU(o);return t.attributes.forEach(({attribute:_})=>{if(i[_]){let l=i[_];l.describe=NU(l),s.attribute_permissions.push(l),c||k8(l,u)}else if(_!==o){let l;dr.TIME_STAMP_NAMES.includes(_)?l=TU(_):l=SU(_),s.attribute_permissions.push(l)}}),c||s.attribute_permissions.push(u),s.describe=gU(s),s}else return e.describe=gU(e),e}a(G8,"getTableAttrPerms");function gU(e){return OU.filter(t=>e[t]).length>0}a(gU,"getSchemaTableDescribePerm");function NU(e){return bU.filter(t=>e[t]).length>0}a(NU,"getAttributeDescribePerm");function k8(e,t){bU.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(k8,"checkForHashPerms")});var IU={};ke(IU,{Resources:()=>Fd,keyArrayToString:()=>ha,resetResources:()=>V8,resources:()=>di});function V8(){return di=new Fd}function ha(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var Fd,di,Du=Oe(()=>{Qi();Fd=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,type:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s)throw new Error(`Conflicting paths for ${t}`);super.set(t,i);for(let[c,u]of this){let _=2;for(;(_=c.indexOf("/",_))>-1;){let l=this.get(c.slice(0,_));l&&(l.hasSubPaths=!0),_+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),u=this.get(c);if(u){if(u.relativeURL=t.slice(n),!u.hasSubPaths)return u;s=u}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),s?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Ke(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(V8,"resetResources");a(ha,"keyArrayToString")});var CU={};ke(CU,{Headers:()=>fi});var fi,qd=Oe(()=>{fi=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];n?r=(typeof o=="string"?o:o.join(", "))+", "+r:typeof o=="string"?r=[o,r]:o.push(r)}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}}});var Lu={};ke(Lu,{authentication:()=>HU,bypassAuth:()=>J8,login:()=>j8,logout:()=>Z8,start:()=>X8});function J8(){BU=!0}async function HU(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let E=e.isOperationsServer?W8?K8:[]:Y8?$8:[];if(E.includes(i)||E.includes("*")){if(e.method==="OPTIONS"){let h=new fi([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Gd&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Gd&&o.push("Access-Control-Allow-Credentials","true")}}let u,_;if(Gd){let E=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.indexOf(E);if(h>=0){let p=s.indexOf(";",h),S=s.indexOf("=",h);u=s.slice(S+1,p===-1?s.length:p),_=await LU.get(u)}e.session=_||(_={})}e.user=null;let l=a((E,h,p)=>{let S=new Vd.AuthAuditLog(E,h,xt.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===xt.AUTH_AUDIT_STATUS.SUCCESS?DU.notify(S):DU.error(S)},"authAuditLog");if(e.mtlsConfig&&e.authorized){let E=e.mtlsConfig.user;E!==null&&((E===void 0||E==="Common Name"||E==="CN")&&(E=e.peerCertificate.subject.CN),e.user=await Xe.getUser(E,null,null))}let d;if(!e.user)if(n){if(d=co.get(n),!d){let[E,h]=n.split(" "),p,S;try{switch(E){case"Basic":[p,S]=atob(h).split(":"),d=p||S?await Xe.getUser(p,S,e):null;break;case"Bearer":try{d=await(0,kd.validateOperationToken)(h)}catch(O){if(O.message==="invalid token")try{return await(0,kd.validateRefreshToken)(h),c({status:-1})}catch{throw O}}break}}catch(O){return z8&&(co.get(h)||(co.set(h,h),l(p,xt.AUTH_AUDIT_STATUS.FAILURE,E))),c({status:401,body:Ei({error:O.message},e)})}co.set(n,d),Q8&&l(d.username,xt.AUTH_AUDIT_STATUS.SUCCESS,E)}e.user=d}else _?.user?e.user=await Xe.getUser(_.user,null,e):(BU&&(e.ip?.includes("127.0.0.1")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,UU.getSuperUser)());Gd&&(e.session.update=function(E){if(!u){u=(0,PU.v4)();let p=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${u}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",p):f?.headers?.set&&f.headers.set("Set-Cookie",p)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):f?.headers?.set&&(i&&f.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),f.headers.set("X-Hdb-Session","Secure"))),E.id=u,LU.put(E)},e.login=async function(E,h){e.user=await Xe.getUser(E,h,e),e.session.update({user:e.user.username})},(d&&!_||_?.user?.username!==d?.username)&&r["user-agent"]?.startsWith("Mozilla")&&e.session.update({user:e.user.username}));let f=await t(e);return f&&(f.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&di.loginPath?(f.status=302,f.headers.set("Location",di.loginPath(e))):f.headers.set("WWW-Authenticate","Basic")),c(f))}catch(u){throw c(u)}function c(u){let _=o.length;if(_>0){let l=u.headers;l||(u.headers=l=new fi);for(let d=0;d<_;){let f=o[d++];l.set(f,o[d++])}}return o=null,u}a(c,"applyResponseHeaders")}function X8({server:e,port:t}){e.request(HU,{port:t||"all"}),MU||(MU=!0,setInterval(()=>{co=new Map},on.get(xt.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),vU.user.addListener(()=>{co=new Map}))}async function j8(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 Z8(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var UU,kd,PU,on,xt,Vd,vU,DU,$8,Y8,K8,W8,LU,Gd,BU,Q8,z8,co,MU,$d=Oe(()=>{UU=x(en());jt();Du();kd=x(_u());be();PU=require("uuid"),on=x(Z()),xt=x(U()),Vd=x(W()),vU=x(Mc());qd();ma();DU=(0,Vd.loggerWithTag)("auth-event");on.initSync();$8=on.get(xt.CONFIG_PARAMS.HTTP_CORSACCESSLIST),Y8=on.get(xt.CONFIG_PARAMS.HTTP_CORS),K8=on.get(xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),W8=on.get(xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),LU=ot({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Gd=on.get(xt.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,BU=on.get(xt.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,Q8=on.get(xt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,z8=on.get(xt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,co=new Map;Xe.onInvalidatedUser(()=>{co=new Map});a(J8,"bypassAuth");a(HU,"authentication");a(X8,"start");a(j8,"login");a(Z8,"logout")});var $U=T((Nfe,VU)=>{"use strict";var Ie=require("joi"),xU=require("fs-extra"),FU=require("path"),ws=et(),qU=Z(),GU=U(),kU=W(),{hdb_errors:e6}=ee(),{HDB_ERROR_MSGS:Wt}=e6,ys=/^[a-zA-Z0-9-_]+$/;VU.exports={getDropCustomFunctionValidator:r6,setCustomFunctionValidator:n6,addComponentValidator:a6,dropCustomFunctionProjectValidator:c6,packageComponentValidator:u6,deployComponentValidator:l6,setComponentFileValidator:s6,getComponentFileValidator:o6,dropComponentFileValidator:i6};function Yd(e,t,r){try{let n=qU.get(GU.CONFIG_PARAMS.COMPONENTSROOT),s=FU.join(n,t);return xU.existsSync(s)?e?t:r.message(Wt.PROJECT_EXISTS):e?r.message(Wt.NO_PROJECT):t}catch(n){return kU.error(n),r.message(Wt.VALIDATION_ERR)}}a(Yd,"checkProjectExists");function Mu(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(Mu,"checkFilePath");function t6(e,t,r,n){try{let s=qU.get(GU.CONFIG_PARAMS.COMPONENTSROOT),i=FU.join(s,e,t,r+".js");return xU.existsSync(i)?r:n.message(Wt.NO_FILE)}catch(s){return kU.error(s),n.message(Wt.VALIDATION_ERR)}}a(t6,"checkFileExists");function r6(e){let t=Ie.object({project:Ie.string().pattern(ys).custom(Yd.bind(null,!0)).required().messages({"string.pattern.base":Wt.BAD_PROJECT_NAME}),type:Ie.string().valid("helpers","routes").required(),file:Ie.string().pattern(ys).custom(t6.bind(null,e.project,e.type)).custom(Mu).required().messages({"string.pattern.base":Wt.BAD_FILE_NAME})});return ws.validateBySchema(e,t)}a(r6,"getDropCustomFunctionValidator");function n6(e){let t=Ie.object({project:Ie.string().pattern(ys).custom(Yd.bind(null,!0)).required().messages({"string.pattern.base":Wt.BAD_PROJECT_NAME}),type:Ie.string().valid("helpers","routes").required(),file:Ie.string().custom(Mu).required(),function_content:Ie.string().required()});return ws.validateBySchema(e,t)}a(n6,"setCustomFunctionValidator");function s6(e){let t=Ie.object({project:Ie.string().pattern(ys).required().messages({"string.pattern.base":Wt.BAD_PROJECT_NAME}),file:Ie.string().custom(Mu).required(),payload:Ie.string().allow("").optional(),encoding:Ie.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return ws.validateBySchema(e,t)}a(s6,"setComponentFileValidator");function i6(e){let t=Ie.object({project:Ie.string().pattern(ys).required().messages({"string.pattern.base":Wt.BAD_PROJECT_NAME}),file:Ie.string().custom(Mu).optional()});return ws.validateBySchema(e,t)}a(i6,"dropComponentFileValidator");function o6(e){let t=Ie.object({project:Ie.string().required(),file:Ie.string().custom(Mu).required(),encoding:Ie.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return ws.validateBySchema(e,t)}a(o6,"getComponentFileValidator");function a6(e){let t=Ie.object({project:Ie.string().pattern(ys).custom(Yd.bind(null,!1)).required().messages({"string.pattern.base":Wt.BAD_PROJECT_NAME})});return ws.validateBySchema(e,t)}a(a6,"addComponentValidator");function c6(e){let t=Ie.object({project:Ie.string().pattern(ys).custom(Yd.bind(null,!0)).required().messages({"string.pattern.base":Wt.BAD_PROJECT_NAME})});return ws.validateBySchema(e,t)}a(c6,"dropCustomFunctionProjectValidator");function u6(e){let t=Ie.object({project:Ie.string().pattern(ys).required().messages({"string.pattern.base":Wt.BAD_PROJECT_NAME}),skip_node_modules:Ie.boolean()});return ws.validateBySchema(e,t)}a(u6,"packageComponentValidator");function l6(e){let t=Ie.object({project:Ie.string().pattern(ys).required().messages({"string.pattern.base":Wt.BAD_PROJECT_NAME}),payload:Ie.string().optional().messages({"string.pattern.base":Wt.BAD_PACKAGE}),package:Ie.string().optional()});return ws.validateBySchema(e,t)}a(l6,"deployComponentValidator")});var zd=T((wfe,XU)=>{"use strict";var Kd=require("joi"),Wd=require("path"),YU=require("fs-extra"),{exec:_6}=require("child_process"),d6=require("util"),KU=d6.promisify(_6),Uu=U(),{handleHDBError:pa,hdb_errors:f6}=ee(),{HTTP_STATUS_CODES:Sa}=f6,Pu=Z(),E6=et(),Ta=W();Pu.initSync();var UT=Pu.get(Uu.CONFIG_PARAMS.COMPONENTSROOT),WU="npm install --omit=dev --json",h6=`${WU} --dry-run`;XU.exports={installModules:T6,auditModules:g6,installAllRootModules:m6,uninstallRootModule:p6,linkHarperdb:S6};async function m6(e=!1){await Qd(),await vu(e?"npm install --ignore-scripts":"npm install",Pu.get(Uu.CONFIG_PARAMS.ROOTPATH))}a(m6,"installAllRootModules");async function p6(e){await vu(`npm uninstall ${e}`,Pu.get(Uu.CONFIG_PARAMS.ROOTPATH))}a(p6,"uninstallRootModule");async function S6(){await Qd(),await vu(`npm link ${Uu.PACKAGE_ROOT}`,Pu.get(Uu.CONFIG_PARAMS.ROOTPATH))}a(S6,"linkHarperdb");async function vu(e,t=void 0){let r,n;try{({stdout:r,stderr:n}=await KU(e,{cwd:t}))}catch(s){throw new Error(s.stderr.replace(`
|
|
12
|
+
`,""))}return n&&!n.includes("Debugger listening")&&Ta.error("Error running NPM command:",e,n),Ta.trace(r,n),r?.replace(`
|
|
13
|
+
`,"")}a(vu,"runCommand");async function T6(e){Ta.info(`starting installModules for request: ${e}`);let t=JU(e);if(t)throw pa(t,t.message,Sa.BAD_REQUEST);let{projects:r,dry_run:n}=e,s=n===!0?h6:WU;await Qd(),await zU(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 _=Wd.join(UT,u),l,d=null;try{let{stdout:f,stderr:E}=await KU(s,{cwd:_});l=f?f.replace(`
|
|
14
14
|
`,""):null,d=E?E.replace(`
|
|
15
|
-
`,""):null}catch(f){f.stderr?i[u].npm_error=
|
|
16
|
-
`);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(YU,"parseNPMStdErr");async function p6(e){pa.info(`starting auditModules for request: ${e}`);let t=WU(e);if(t)throw ha(t,t.message,ma.BAD_REQUEST);let{projects:r}=e;await Qd(),await KU(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=Wd.join(UT,o);n[o]={npm_output:null,npm_error:null};try{let u=await Mu("npm audit --json",c);n[o].npm_output=JSON.parse(u)}catch(u){n[o].npm_error=YU(u.stderr)}}return pa.info(`finished auditModules with response ${n}`),n}a(p6,"auditModules");async function Qd(){try{return await Mu("npm -v"),!0}catch{throw ha(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(Qd,"checkNPMInstalled");async function KU(e){if(!Array.isArray(e)||e.length===0)throw ha(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=Wd.join(UT,i.toString());if(!await kU.pathExists(o)){t.push(i);continue}let u=Wd.join(o,"package.json");await kU.pathExists(u)||r.push(i)}if(t.length>0)throw ha(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 ha(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(KU,"checkProjectPaths");function WU(e){let t=Kd.object({projects:Kd.array().min(1).items(Kd.string()).required(),dry_run:Kd.boolean().default(!1)});return _6.validateBySchema(e,t)}a(WU,"modulesValidator")});var vT=g((Cfe,ZU)=>{"use strict";var Sa=require("fs-extra"),PT=require("path"),Jd=Y(),zU=J(),Xd=M(),jU=Z(),S6=Dr();ZU.exports=T6;async function T6(){let e=g6(),t=jU.get(Xd.CONFIG_PARAMS.ROOTPATH),r=PT.join(t,"package.json"),n={dependencies:{harperdb:"file:"+Xd.PACKAGE_ROOT}},s=PT.join(t,"node_modules");await Sa.ensureDir(s);let i,o=!0,c=!1;try{i=await Sa.readJson(r)}catch(u){if(zU.isEmptyOrZeroLength(e))return;if(u.code!==Xd.NODE_ERROR_CODES.ENOENT)throw u;o=!1}if(!zU.isEmptyOrZeroLength(e)){for(let{name:u,package:_}of e){let l=await JU(_);n.dependencies[u]=l+_}if(!o){Jd.notify("Installing components"),await XU(r,n,null);return}for(let{name:u,package:_}of e){let l=i.dependencies[u],d=await JU(_);if(l===void 0||l!==d+_){c=!0;break}}}for(let u in i.dependencies)n.dependencies[u]===void 0&&(Jd.notify("Removing component",u),c=!0);c&&(Jd.notify("Updating components."),await XU(r,n,i))}a(T6,"installComponents");function g6(){let e=S6.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(g6,"getComponentsConfig");async function JU(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":PT.extname(e)||await Sa.pathExists(e)?"file:":"github:"}a(JU,"getPkgPrefix");async function XU(e,t,r){Jd.trace("npm installing components package.json",t),await Sa.writeFile(e,JSON.stringify(t,null," "));try{await zd().installAllRootModules(jU.get(Xd.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?await Sa.writeFile(e,JSON.stringify(r,null," ")):await Sa.unlink(e),n}}a(XU,"installPackages")});var xT=g((Mfe,nP)=>{"use strict";var qe=require("fs-extra"),BT=require("fast-glob"),ge=require("path"),tP=require("tar-fs"),Lfe=require("uuid").v4,HT=require("normalize-path"),Zn=GU(),At=Y(),Ye=M(),Et=Z(),Uu=Dr(),R6=J(),{PACKAGE_ROOT:A6}=M(),{handleHDBError:Lt,hdb_errors:O6}=ee(),{basename:b6}=require("path"),N6=vT(),rP=Z(),y6=M(),{Readable:w6}=require("stream"),{isMainThread:I6}=require("worker_threads"),{HDB_ERROR_MSGS:ao,HTTP_STATUS_CODES:Mt}=O6,C6=ge.join(A6,"application-template"),eP=ge.join(Et.get(Ye.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp");function D6(){At.trace("getting custom api status");let e={};try{e={port:Et.get(Ye.CONFIG_PARAMS.HTTP_PORT),directory:Et.get(Ye.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Lt(new Error,ao.FUNCTION_STATUS,Mt.INTERNAL_SERVER_ERROR,At.ERR,t)}return e}a(D6,"customFunctionsStatus");function L6(){At.trace("getting custom api endpoints");let e={},t=Et.get(Ye.CONFIG_PARAMS.COMPONENTSROOT);try{BT.sync(HT(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:BT.sync(HT(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:BT.sync(HT(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Lt(new Error,ao.GET_FUNCTIONS,Mt.INTERNAL_SERVER_ERROR,At.ERR,r)}return e}a(L6,"getCustomFunctions");function M6(e){e.project&&(e.project=ge.parse(e.project).name),e.file&&(e.file=ge.parse(e.file).name);let t=Zn.getDropCustomFunctionValidator(e);if(t)throw Lt(t,t.message,Mt.BAD_REQUEST);At.trace("getting custom api endpoint file content");let r=Et.get(Ye.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=ge.join(r,n,s,i+".js");try{return qe.readFileSync(o,{encoding:"utf8"})}catch(c){throw Lt(new Error,ao.GET_FUNCTION,Mt.INTERNAL_SERVER_ERROR,At.ERR,c)}}a(M6,"getCustomFunction");function U6(e){e.project&&(e.project=ge.parse(e.project).name),e.file&&(e.file=ge.parse(e.file).name);let t=Zn.setCustomFunctionValidator(e);if(t)throw Lt(t,t.message,Mt.BAD_REQUEST);At.trace("setting custom function file content");let r=Et.get(Ye.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{return qe.outputFileSync(ge.join(r,n,s,i+".js"),o),`Successfully updated custom function: ${i}.js`}catch(c){throw Lt(new Error,ao.SET_FUNCTION,Mt.INTERNAL_SERVER_ERROR,At.ERR,c)}}a(U6,"setCustomFunction");function P6(e){e.project&&(e.project=ge.parse(e.project).name),e.file&&(e.file=ge.parse(e.file).name);let t=Zn.getDropCustomFunctionValidator(e);if(t)throw Lt(t,t.message,Mt.BAD_REQUEST);At.trace("dropping custom function file");let r=Et.get(Ye.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{return qe.unlinkSync(ge.join(r,n,s,i+".js")),`Successfully deleted custom function: ${i}.js`}catch(o){throw Lt(new Error,ao.DROP_FUNCTION,Mt.INTERNAL_SERVER_ERROR,At.ERR,o)}}a(P6,"dropCustomFunction");function v6(e){e.project&&(e.project=ge.parse(e.project).name);let t=Zn.addComponentValidator(e);if(t)throw Lt(t,t.message,Mt.BAD_REQUEST);At.trace("adding component");let r=Et.get(Ye.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=ge.join(r,n);return qe.mkdirSync(s,{recursive:!0}),qe.copySync(C6,s),`Successfully added project: ${n}`}catch(s){throw Lt(new Error,ao.ADD_FUNCTION,Mt.INTERNAL_SERVER_ERROR,At.ERR,s)}}a(v6,"addComponent");function B6(e){e.project&&(e.project=ge.parse(e.project).name);let t=Zn.dropCustomFunctionProjectValidator(e);if(t)throw Lt(t,t.message,Mt.BAD_REQUEST);At.trace("dropping custom function project");let r=Et.get(Ye.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Et.get(Ye.CONFIG_PARAMS.APPS);if(!R6.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 Uu.updateConfigValue(Ye.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=ge.join(r,n);return qe.rmSync(i,{recursive:!0}),`Successfully deleted project: ${n}`}catch(i){throw Lt(new Error,ao.DROP_FUNCTION_PROJECT,Mt.INTERNAL_SERVER_ERROR,At.ERR,i)}}a(B6,"dropCustomFunctionProject");async function H6(e){e.project&&(e.project=ge.parse(e.project).name);let t=Zn.packageComponentValidator(e);if(t)throw Lt(t,t.message,Mt.BAD_REQUEST);let r=Et.get(Ye.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;At.trace("packaging component",n);let s;try{s=await qe.realpath(ge.join(r,n))}catch(u){if(u.code!==Ye.NODE_ERROR_CODES.ENOENT)throw u;try{s=await qe.realpath(ge.join(Et.get(Ye.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(_){if(_.code===Ye.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}await qe.ensureDir(eP);let i=ge.join(eP,`${n}.tar`),o={};(e.skip_node_modules===!0||e.skip_node_modules==="true")&&(o={ignore:u=>u.includes(ge.join(s,"node_modules"))}),tP.pack(s,o).pipe(qe.createWriteStream(i,{overwrite:!0})),await new Promise(u=>setTimeout(u,2e3));let c=qe.readFileSync(i,{encoding:"base64"});return await qe.remove(i),{project:n,payload:c}}a(H6,"packageComponent");async function x6(e){e.project&&(e.project=ge.parse(e.project).name);let t=Zn.deployComponentValidator(e);if(t)throw Lt(t,t.message,Mt.BAD_REQUEST);let r=Et.get(Ye.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i}=e;if(At.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 qe.ensureDir(o);let f=w6.from(Buffer.from(s,"base64"));await new Promise((h,p)=>{f.pipe(tP.extract(o,{finish:h})).on("error",p)});let E=await qe.readdir(o);E.length===1&&E[0]==="package"&&(await qe.copy(ge.join(o,"package"),o),await qe.remove(ge.join(o,"package")))}if(await Uu.addConfig(n,{package:i}),!s){await N6();let f=rP.get(y6.CONFIG_PARAMS.ROOTPATH);o=ge.join(f,"node_modules",n)}if(I6)return;let c=new Map;c.isWorker=!0;let u=(Zd(),te(jd)),_;u.setErrorReporter(f=>_=f);let l=b6(o),d=u.component_errors.get(l);try{await u.loadComponent(o,c)}finally{u.component_errors.set(l,d)}if(_)throw _;return At.info("Installed component"),`Successfully deployed: ${n}`}a(x6,"deployComponent");async function F6(){let e=Uu.getConfiguration(),t=[];for(let o in e)if(e[o]?.package){if(e[o].package.startsWith("file:"))continue;t.push(Object.assign({},e[o],{name:o}))}let r=a(async(o,c)=>{try{let u=await qe.readdir(o,{withFileTypes:!0});for(let _ of u){let l=_.name;if(l.startsWith(".")||l==="node_modules")continue;let d=ge.join(o,l);if(_.isDirectory()||_.isSymbolicLink()){let f={name:l,entries:[]};c.entries.push(f),await r(d,f)}else{let f=await qe.stat(d),E={name:ge.basename(l),mtime:f.mtime,size:f.size};c.entries.push(E)}}return c}catch(u){return At.warn("Error loading package",u),{error:u.toString(),entries:[]}}},"walk_dir"),n=await r(Et.get(Ye.CONFIG_PARAMS.COMPONENTSROOT),{name:Et.get(Ye.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(Et.get(Ye.CONFIG_PARAMS.ROOTPATH),"node_modules",o.name),{name:o.name,entries:[]});Object.assign(o,c)}let i=(Zd(),te(jd)).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(F6,"getComponents");async function q6(e){let t=Zn.getComponentFileValidator(e);if(t)throw Lt(t,t.message,Mt.BAD_REQUEST);let n=Uu.getConfigObj()[e.project]||e.project==="harperdb"?ge.join(rP.get(Ye.CONFIG_PARAMS.ROOTPATH),"node_modules"):Et.get(Ye.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await qe.stat(ge.join(n,e.project,e.file));return{message:await qe.readFile(ge.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===Ye.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${ge.join(e.project,e.file)}'`):i}}a(q6,"getComponentFile");async function G6(e){let t=Zn.setComponentFileValidator(e);if(t)throw Lt(t,t.message,Mt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=ge.join(Et.get(Ye.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);return e.payload!==void 0?(await qe.ensureFile(n),await qe.outputFile(n,e.payload,r)):await qe.ensureDir(n),"Successfully set component: "+e.file}a(G6,"setComponentFile");async function k6(e){let t=Zn.dropComponentFileValidator(e);if(t)throw Lt(t,t.message,Mt.BAD_REQUEST);let r=e.file?ge.join(e.project,e.file):e.project,n=ge.join(Et.get(Ye.CONFIG_PARAMS.COMPONENTSROOT),r);return await qe.pathExists(n)&&await qe.remove(n),Uu.deleteConfigFromFile([e.project]),"Successfully dropped: "+r}a(k6,"dropComponent");nP.exports={customFunctionsStatus:D6,getCustomFunctions:L6,getCustomFunction:M6,setCustomFunction:U6,dropCustomFunction:P6,addComponent:v6,dropCustomFunctionProject:B6,packageComponent:H6,deployComponent:x6,getComponents:F6,getComponentFile:q6,setComponentFile:G6,dropComponent:k6}});var FT=g((Pfe,iP)=>{"use strict";var es=require("joi"),sP=et();iP.exports={readTransactionLogValidator:V6,deleteTransactionLogsBeforeValidator:$6};function V6(e){let t=es.object({schema:es.string().required(),table:es.string().required(),from:es.date().timestamp(),to:es.date().timestamp(),limit:es.number().min(1)});return sP.validateBySchema(e,t)}a(V6,"readTransactionLogValidator");function $6(e){let t=es.object({schema:es.string().required(),table:es.string().required(),timestamp:es.date().timestamp().required()});return sP.validateBySchema(e,t)}a($6,"deleteTransactionLogsBeforeValidator")});var tf=g((Bfe,lP)=>{"use strict";var qT=M(),ef=Rt(),oP=J(),aP=Z(),cP=Es(),{handleHDBError:Ta,hdb_errors:Y6}=ee(),{HTTP_STATUS_CODES:ga}=Y6,{readTransactionLogValidator:K6,deleteTransactionLogsBeforeValidator:W6}=FT(),uP="This operation relies on clustering and cannot run with it disable.",Q6="Logs successfully deleted from transaction log.",z6="All logs successfully deleted from transaction log.";lP.exports={readTransactionLog:J6,deleteTransactionLogsBefore:X6};async function*J6(e){let t=K6(e);if(t)throw Ta(t,t.message,ga.BAD_REQUEST,void 0,void 0,!0);if(!aP.get(qT.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Ta(new Error,uP,ga.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:n}=e,s=oP.checkSchemaTableExist(r,n);if(s)throw Ta(new Error,s,ga.NOT_FOUND,void 0,void 0,!0);let i=cP.createNatsTableStreamName(r,n),o=await ef.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===qT.OPERATIONS_ENUM.DELETE&&(_.hash_values=c?.entry?.hash_values),yield _}}a(J6,"readTransactionLog");async function X6(e){let t=W6(e);if(t)throw Ta(t,t.message,ga.BAD_REQUEST,void 0,void 0,!0);if(!aP.get(qT.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Ta(new Error,uP,ga.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:n,timestamp:s}=e,i=oP.checkSchemaTableExist(r,n);if(i)throw Ta(new Error,i,ga.NOT_FOUND,void 0,void 0,!0);let o=cP.createNatsTableStreamName(r,n),{jsm:c}=await ef.getNATSReferences(),u=await ef.getStreamInfo(o),_=new Date(u.state.first_ts).getTime();if(s<=_)return`No transactions exist before: ${s}`;let l=Q6,d,f=new Date(u.state.last_ts).getTime();return s>f?(d=u.state.last_seq+1,l=z6):d=(await ef.viewStream(o,parseInt(s),1))[0].nats_sequence,await c.streams.purge(o,{seq:d}),l}a(X6,"deleteTransactionLogsBefore")});var dP=g((xfe,_P)=>{"use strict";var GT=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}};_P.exports=GT});var EP=g((qfe,fP)=>{"use strict";var kT=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};fP.exports=kT});var $T=g((kfe,mP)=>{"use strict";var hP=dP(),j6=EP(),{HDB_ERROR_MSGS:Z6}=Or(),VT=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=Z6.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 hP(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let u=new j6(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 hP(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}};mP.exports=VT});var of=g(($fe,MP)=>{"use strict";var YT=jr(),rf=Xr(),an=rd(),Bu=Li(),KT=Bi(),e9=sS(),t9=wD(),Hu=Zr(),nf=fS(),Ot=Y(),r9=mS(),n9=Td(),s9=jS(),i9=Rd(),o9=ZS(),a9=eT(),c9=nT(),u9=iT(),WT=cT(),ys=J(),l9=bM(),QT=fT(),TP=xd(),on=M(),gP=bU(),_9=oa(),RP=cu(),AP=($d(),te(Iu)),OP=Dr(),Fr=xT(),d9=require("alasql"),bP=tf(),NP=zd(),yP=$T(),{handleHDBError:Er,hdb_errors:wP}=ee(),{HDB_ERROR_MSGS:qt,HTTP_STATUS_CODES:Pu}=wP,G=new Map,IP="delete",fi="insert",ws="read",co="update",vu="describe",pP=Bu.describeSchema.name,SP=Bu.describeTable.name,CP={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},f9="catchup",E9="handleGetJob",h9="handleGetJobsByStartDate",sf={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},m9=[an.createTable.name,an.createAttribute.name,an.dropTable.name,an.dropAttribute.name],DP={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},K=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};G.set(YT.insert.name,new K(!1,[fi]));G.set(YT.update.name,new K(!1,[co]));G.set(YT.upsert.name,new K(!1,[fi,co]));G.set(rf.searchByConditions.name,new K(!1,[ws]));G.set(rf.searchByHash.name,new K(!1,[ws]));G.set(rf.searchByValue.name,new K(!1,[ws]));G.set(rf.search.name,new K(!1,[ws]));G.set(an.createSchema.name,new K(!0,[]));G.set(an.createTable.name,new K(!0,[]));G.set(an.createAttribute.name,new K(!1,[fi]));G.set(an.dropSchema.name,new K(!0,[]));G.set(an.dropTable.name,new K(!0,[]));G.set(an.dropAttribute.name,new K(!0,[]));G.set(Bu.describeSchema.name,new K(!1,[ws]));G.set(Bu.describeTable.name,new K(!1,[ws]));G.set(KT.deleteRecord.name,new K(!1,[IP]));G.set(Hu.addUser.name,new K(!0,[]));G.set(Hu.alterUser.name,new K(!0,[]));G.set(Hu.dropUser.name,new K(!0,[]));G.set(Hu.listUsersExternal.name,new K(!0,[]));G.set(nf.listRoles.name,new K(!0,[]));G.set(nf.addRole.name,new K(!0,[]));G.set(nf.alterRole.name,new K(!0,[]));G.set(nf.dropRole.name,new K(!0,[]));G.set(r9.name,new K(!0,[]));G.set(n9.name,new K(!0,[]));G.set(s9.name,new K(!0,[]));G.set(i9.name,new K(!0,[]));G.set(o9.name,new K(!0,[]));G.set(a9.name,new K(!0,[]));G.set(WT.setRoutes.name,new K(!0,[]));G.set(WT.getRoutes.name,new K(!0,[]));G.set(WT.deleteRoutes.name,new K(!0,[]));G.set(OP.setConfiguration.name,new K(!0,[]));G.set(c9.clusterStatus.name,new K(!0,[]));G.set(u9.name,new K(!0,[]));G.set(QT.getFingerprint.name,new K(!0,[]));G.set(QT.setLicense.name,new K(!0,[]));G.set(KT.deleteFilesBefore.name,new K(!0,[]));G.set(KT.deleteAuditLogsBefore.name,new K(!0,[]));G.set(TP.restart.name,new K(!0,[]));G.set(TP.restartService.name,new K(!0,[]));G.set(e9.name,new K(!0,[]));G.set(t9.name,new K(!0,[ws]));G.set(_9.systemInformation.name,new K(!0,[]));G.set(OP.getConfiguration.name,new K(!0,[]));G.set(bP.readTransactionLog.name,new K(!0,[]));G.set(bP.deleteTransactionLogsBefore.name,new K(!0,[]));G.set(NP.installModules.name,new K(!0,[]));G.set(NP.auditModules.name,new K(!0,[]));G.set(RP.createTokens.name,new K(!1,[]));G.set(RP.refreshOperationToken.name,new K(!1,[]));G.set(AP.login.name,new K(!1,[]));G.set(AP.logout.name,new K(!1,[]));G.set(Fr.customFunctionsStatus.name,new K(!0,[]));G.set(Fr.getCustomFunctions.name,new K(!0,[]));G.set(Fr.getComponents.name,new K(!0,[]));G.set(Fr.getComponentFile.name,new K(!0,[]));G.set(Fr.setComponentFile.name,new K(!0,[]));G.set(Fr.dropComponent.name,new K(!0,[]));G.set(Fr.getCustomFunction.name,new K(!0,[]));G.set(Fr.setCustomFunction.name,new K(!0,[]));G.set(Fr.dropCustomFunction.name,new K(!0,[]));G.set(Fr.addComponent.name,new K(!0,[]));G.set(Fr.dropCustomFunctionProject.name,new K(!0,[]));G.set(Fr.packageComponent.name,new K(!0,[]));G.set(Fr.deployComponent.name,new K(!0,[]));G.set(QT.getRegistrationInfo.name,new K(!1,[]));G.set(Hu.userInfo.name,new K(!1,[]));G.set(Bu.describeAll.name,new K(!1,[]));G.set(E9,new K(!1,[]));G.set(h9,new K(!0,[]));G.set(f9,new K(!0,[]));G.set(sf.CSV_DATA_LOAD,new K(!1,[fi,co]));G.set(sf.CSV_URL_LOAD,new K(!1,[fi,co]));G.set(sf.CSV_FILE_LOAD,new K(!1,[fi,co]));G.set(sf.IMPORT_FROM_S3,new K(!1,[fi,co]));G.set(DP.EXPORT_TO_S3,new K(!0,[]));G.set(DP.EXPORT_LOCAL,new K(!0,[]));G.set(on.VALID_SQL_OPS_ENUM.DELETE,new K(!1,[IP]));G.set(on.VALID_SQL_OPS_ENUM.SELECT,new K(!1,[ws]));G.set(on.VALID_SQL_OPS_ENUM.INSERT,new K(!1,[fi]));G.set(on.VALID_SQL_OPS_ENUM.UPDATE,new K(!1,[co]));MP.exports={verifyPerms:S9,verifyPermsAst:p9,verifyBulkLoadAttributePerms:g9};function p9(e,t,r){if(ys.isEmptyOrZeroLength(e))throw Ot.info("verify_perms_ast has an empty user parameter"),Er(new Error);if(ys.isEmptyOrZeroLength(t))throw Ot.info("verify_perms_ast has an empty user parameter"),Er(new Error);if(ys.isEmptyOrZeroLength(r))throw Ot.info("verify_perms_ast has a null operation parameter"),Er(new Error);try{let n=new yP,s=new l9(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw Ot.info("No schemas defined in verifyPermsAst(), will not continue."),Er(new Error);let c=!!t.role.permission.super_user,u=i.includes("system");if(u&&CP[r])throw Er(new Error,qt.DROP_SYSTEM,Pu.FORBIDDEN);if(c&&!u)return null;let _=gP.getRolePermissions(t.role);t.role.permission=_,!c&&e instanceof d9.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(_));for(let d=0;d<i.length;d++){let f=s.getTablesBySchemaName(i[d]);f&&o.set(i[d],f)}let l=LP(t,r,o,n);return l||(o.forEach((d,f)=>{for(let E=0;E<d.length;E++){let h=s.getAttributesBySchemaTableName(f,d[E]),p=JT(t.role.permission,f,d[E]);zT(h,p,r,d[E],f,n)}}),n.getPermsResponse())}catch(n){throw Er(n)}}a(p9,"verifyPermsAst");function S9(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw Ot.info("null required parameter in verifyPerms"),Er(new Error,qt.DEFAULT_INVALID_REQUEST,Pu.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 yP;if(ys.isEmptyOrZeroLength(e.hdb_user.role)||ys.isEmptyOrZeroLength(e.hdb_user.role.permission))return Ot.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(on.SYSTEM_SCHEMA_NAME)||s===on.SYSTEM_SCHEMA_NAME;if(l&&CP[r])throw Er(new Error,qt.DROP_SYSTEM,Pu.FORBIDDEN);if(u&&!l||_===!0&&(r===an.createSchema.name||r===an.dropSchema.name))return null;if(m9.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=gP.getRolePermissions(e.hdb_user.role);if(e.hdb_user.role.permission=d,r===pP||r===SP){if(s===on.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(qt.SCHEMA_PERM_ERROR(s));if(!d.super_user){if(r===pP&&(!d[s]||!d[s][vu]))return c.handleInvalidItem(qt.SCHEMA_NOT_FOUND(s));if(r===SP&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][vu]))return c.handleInvalidItem(qt.TABLE_NOT_FOUND(s,i))}}let f=LP(e.hdb_user,r,o,c,n);if(f)return f;if(G.get(r)&&G.get(r).perms.length===0)return null;if(!u&&e.get_attributes&&on.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let p=[],S=d[s].tables[i];S[on.PERMS_CRUD_ENUM.READ]&&(S.attribute_permissions.length>0?S.attribute_permissions.filter(A=>A[on.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 E=T9(e),h=JT(e.hdb_user.role.permission,s,i);return zT(E,h,r,i,s,c,n),c.getPermsResponse()}a(S9,"verifyPerms");function LP(e,t,r,n,s){if(ys.arrayHasEmptyValues([e,t,r]))throw Ot.info("hasPermissions has an invalid parameter"),Er(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||G.get(t).requires_su))return null;if(!G.get(t))throw Ot.info(`operation ${t} not found.`),Er(new Error,qt.OP_NOT_FOUND(t),Pu.BAD_REQUEST);if(G.get(t)&&G.get(t).requires_su)return Ot.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][vu]===!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[vu]===!1)n.addInvalidItem(qt.TABLE_NOT_FOUND(u,l));else try{let f=[],E=G.get(t).perms;!ys.isEmpty(s)&&E.includes(s)&&(E=[s]);for(let h=0;h<E.length;h++){let p=E[h],S=d[p];(S==null||S===!1)&&(Ot.info(`Required ${p} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),f.push(p))}f.length>0&&n.addUnauthorizedTable(u,l,f)}catch(f){let E=qt.UNKNOWN_OP_AUTH_ERROR(t,u,l);throw Ot.error(E),Ot.error(f),Er(wP.CHECK_LOGS_WRAPPER(E))}}}return r.size<2?n.getPermsResponse():null}a(LP,"hasPermissions");function zT(e,t,r,n,s,i,o){if(!e||!t)throw Ot.info("no attributes specified in checkAttributePerms."),Er(new Error);let c=G.get(r).perms;if(!c||c==="")throw Ot.info(`no permissions found for ${r} in checkAttributePerms().`),Er(new Error);if(ys.isEmptyOrZeroLength(t))return Ot.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let u={};for(let l of e){let d=t.get(l);if(d){if(d[vu]===!1){i.addInvalidItem(qt.ATTR_NOT_FOUND(s,n,l),s,n);continue}if(c)for(let f of c){if(on.TIME_STAMP_NAMES.includes(d.attribute_name)&&f!==ws)throw Er(new Error,qt.SYSTEM_TIMESTAMP_PERMS_ERR,Pu.FORBIDDEN);d[f]===!1&&(u[d.attribute_name]?u[d.attribute_name].push(f):u[d.attribute_name]=[f])}}else i.addInvalidItem(qt.ATTR_NOT_FOUND(s,n,l),s,n)}let _=Object.keys(u);_.length>0&&i.addUnauthorizedAttributes(_,s,n,u)}a(zT,"checkAttributePerms");function T9(e){let t=new Set;try{if(e.action)return t;if(e.operation===on.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){Ot.info(r)}return t}a(T9,"getRecordAttributes");function JT(e,t,r){let n=new Map;if(ys.isEmpty(e))return Ot.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{Ot.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(JT,"getAttributePermissions");function g9(e,t,r,n,s,i,o){let c=new Set(i),u=JT(e,n,s);zT(c,u,t,s,n,o,r)}a(g9,"verifyBulkLoadAttributePerms")});var cf=g((Kfe,HP)=>{"use strict";HP.exports={evaluateSQL:U9,processAST:BP,convertSQLToAST:vP,checkASTPermissions:PP};var R9=jr(),UP=require("util"),A9=UP.callbackify(R9.insert),O9=Xr().search,b9=TC().update,N9=UP.callbackify(b9),y9=RC().convertDelete,Ei=require("alasql"),w9=of(),af=Y(),I9=V_(),C9=J(),xu=M(),{hdb_errors:D9,handleHDBError:XT}=ee(),{HTTP_STATUS_CODES:jT}=D9;I9(Ei);var L9=403,M9="There was a problem performing this insert. Please check the logs and try again.",ZT=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function U9(e,t){let r=e.parsed_sql_object;if(!r){r=vP(e.sql);let n,s=r.ast.statements[0];if(s instanceof Ei.yy.Insert?n=s.into.databaseid:s instanceof Ei.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Ei.yy.Update||s instanceof Ei.yy.Delete?n=s.table.databaseid:af.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Ei.yy.Select)&&C9.isEmptyOrZeroLength(n))return t("No schema specified",null)}BP(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(U9,"evaluateSQL");function PP(e,t){let r;try{r=w9.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(PP,"checkASTPermissions");function vP(e){let t=new ZT;if(!e)throw XT(new Error,"The 'sql' parameter is missing from the request body",jT.BAD_REQUEST);try{let r=e.trim(),n=Ei.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
|
|
17
|
-
`);throw n[1]?XT(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,jT.BAD_REQUEST):XT(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",jT.BAD_REQUEST)}return t}a(vP,"convertSQLToAST");function BP(e,t,r){try{let n=P9;if(!e.bypass_auth&&!t.permissions_checked){let i=PP(e,t);if(i&&i.length>0)return r(L9,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case xu.VALID_SQL_OPS_ENUM.SELECT:n=O9,s=t.ast.statements[0];break;case xu.VALID_SQL_OPS_ENUM.INSERT:n=v9;break;case xu.VALID_SQL_OPS_ENUM.UPDATE:n=N9;break;case xu.VALID_SQL_OPS_ENUM.DELETE:n=y9;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(BP,"processAST");function P9(e,t){af.info(e),t("unknown sql statement")}a(P9,"nullFunction");function v9({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=B9(i,e.values)}catch(o){return r(o)}A9(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(u){af.error(`Error delete new_attributes from insert response: ${u}`)}r(null,c)})}a(v9,"convertInsert");function B9(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]]=Ei.compile(`SELECT ${s.toString()} AS [${xu.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw af.error(r),new Error(M9)}}a(B9,"createDataObjects")});var eg=g((Qfe,FP)=>{"use strict";var{S3:H9,GetObjectCommand:x9}=require("@aws-sdk/client-s3");FP.exports={getFileStreamFromS3:F9,getS3AuthObj:xP};async function F9(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await xP(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new x9(r))).Body}a(F9,"getFileStreamFromS3");function xP(e,t,r){return new H9({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(xP,"getS3AuthObj")});var uf=g((Jfe,QP)=>{"use strict";var rg=Xr(),q9=cf(),G9=eg(),{AsyncParser:k9,Transform:V9}=require("json2csv"),qu=require("stream"),qr=J(),tg=require("fs-extra"),$9=require("path"),cn=Y(),{promisify:kP}=require("util"),Fu=J(),{handleHDBError:ht,hdb_errors:Y9}=ee(),{HDB_ERROR_MSGS:hr,HTTP_STATUS_CODES:mt}=Y9,{streamAsJSON:K9}=(Th(),te(xO)),{Upload:W9}=require("@aws-sdk/lib-storage"),qP=["search_by_value","search_by_hash","sql","search_by_conditions"],GP=["json","csv"],VP="json",$P="csv",Q9="Successfully exported JSON locally.",z9="Successfully exported CSV locally.",J9=1e3,X9=rg.searchByHash,j9=rg.searchByValue,Z9=kP(q9.evaluateSQL),e7=kP(qu.finished);QP.exports={export_to_s3:s7,export_local:t7,toCsvStream:YP};async function t7(e){cn.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=KP(e);if(!qr.isEmpty(t))throw cn.error(t),ht(new Error,t,mt.BAD_REQUEST,void 0,void 0,!0);if(qr.isEmpty(e.path))throw cn.error(hr.MISSING_VALUE("path")),ht(new Error,hr.MISSING_VALUE("path"),mt.BAD_REQUEST,void 0,void 0,!0);let r=(qr.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith($9.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=qr.buildFolderPath(e.path,r);await r7(e.path);let s=await WP(e);return await n7(n,e.format,s)}a(t7,"export_local");async function r7(e){if(cn.trace("in confirmPath"),qr.isEmptyOrZeroLength(e))throw ht(new Error,`Invalid path: ${e}`,mt.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await tg.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,cn.error(n),ht(new Error,n,mt.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 cn.error(r),ht(new Error,r,mt.BAD_REQUEST,void 0,void 0,!0)}return!0}a(r7,"confirmPath");async function n7(e,t,r){if(cn.trace("in saveToLocal"),Fu.isEmptyOrZeroLength(e))throw ht(new Error,hr.INVALID_VALUE("file_path"),mt.BAD_REQUEST,void 0,void 0,!0);if(Fu.isEmptyOrZeroLength(t))throw ht(new Error,hr.INVALID_VALUE("Source format"),mt.BAD_REQUEST,void 0,void 0,!0);if(Fu.isEmpty(r))throw ht(new Error,hr.NOT_FOUND("Data"),mt.BAD_REQUEST,void 0,void 0,!0);if(t===VP){let n=tg.createWriteStream(e);return K9(r).pipe(n),await e7(n),{message:Q9,path:e}}else if(t===$P){let n=tg.createWriteStream(e),s=qu.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(l=>({label:l,value:l})));let c={objectMode:!0};return await new k9(i,c).fromInput(s).toOutput(n).promise(!1),{message:z9,path:e}}throw ht(new Error,hr.INVALID_VALUE("format"),mt.BAD_REQUEST)}a(n7,"saveToLocal");async function s7(e){if(!e.s3||Object.keys(e.s3).length===0)throw ht(new Error,hr.MISSING_VALUE("S3 object"),mt.BAD_REQUEST);if(qr.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw ht(new Error,hr.MISSING_VALUE("aws_access_key_id"),mt.BAD_REQUEST);if(qr.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw ht(new Error,hr.MISSING_VALUE("aws_secret_access_key"),mt.BAD_REQUEST);if(qr.isEmptyOrZeroLength(e.s3.bucket))throw ht(new Error,hr.MISSING_VALUE("bucket"),mt.BAD_REQUEST);if(qr.isEmptyOrZeroLength(e.s3.key))throw ht(new Error,hr.MISSING_VALUE("key"),mt.BAD_REQUEST);if(qr.isEmptyOrZeroLength(e.s3.region))throw ht(new Error,hr.MISSING_VALUE("region"),mt.BAD_REQUEST);let t=KP(e);if(!qr.isEmpty(t))throw ht(new Error,t,mt.BAD_REQUEST);cn.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await WP(e)}catch(u){throw cn.error(u),u}let n,s=await G9.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new qu.PassThrough;if(e.format===$P){i=e.s3.key+".csv";let u=YP(r,r.getColumns?.());u.on("error",_=>{throw _}),u.pipe(o)}else if(e.format===VP){i=e.s3.key+".json";let u=new qu.Readable;u.pipe(o),u.on("error",d=>{throw d}),u.push("[");let _=r.length,l="";for(let[d,f]of r.entries()){let E=d===_-1?JSON.stringify(f):JSON.stringify(f)+",";l+=E,d!==0&&d%J9===0&&(u.push(l),l="")}l.length!==0&&u.push(l),u.push("]"),u.push(null)}else throw ht(new Error,hr.INVALID_VALUE("format"),mt.BAD_REQUEST);return new W9({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(s7,"export_to_s3");function YP(e,t){let r=qu.Readable.from(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator]?e:[e]),n={};t&&(n.fields=t.map(o=>({label:o,value:o})));let s={objectMode:!0},i=new V9(n,s);return r.pipe(i)}a(YP,"toCsvStream");function KP(e){if(cn.trace("in exportCoreValidation"),qr.isEmpty(e.format))return"format missing";if(GP.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${GP.join(", ")}`;let t=e.search_operation.operation;if(qr.isEmpty(t))return"search_operation.operation missing";if(qP.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${qP.join(", ")}`}a(KP,"exportCoreValidation");async function WP(e){cn.trace("in getRecords");let t,r;if(Fu.isEmpty(e.search_operation)||Fu.isEmptyOrZeroLength(e.search_operation.operation))throw ht(new Error,hr.INVALID_VALUE("Search operation"),mt.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=j9;break;case"search_by_hash":t=X9;break;case"search_by_conditions":t=rg.searchByConditions;break;case"sql":t=Z9;break;default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,cn.error(r),ht(new Error,r,mt.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(WP,"getRecords")});var rv={};Ve(rv,{contentTypes:()=>ag,findBestSerializer:()=>_f,getDeserializer:()=>lo,registerContentHandlers:()=>cg,serialize:()=>df,serializeMessage:()=>di});function i7(e){try{return e?.[0]===123?og(e):e}catch{return e}}function cg(e){e.register(a7,{serializers:[{regex:/^application\/json$/,serializer:cc},{regex:/^application\/cbor$/,serializer:function(t){return new uo.EncoderStream(ku).end(t)}},{regex:/^application\/(x-)?msgpack$/,serializer:function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?lf.Readable.from((0,ts.encodeIter)(t,ku)):(0,ts.pack)(t)}},{regex:/^text\/csv$/,serializer:function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,ng.toCsvStream)(t)}}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,ts.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,uo.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function _f(e){let r=(e.headers.asObject||e.headers).accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let u of c){let[_,...l]=u.split(/\s*;\s*/),d=1,f={q:1};for(let h of l){let p=h.indexOf("=");f[h.substring(0,p)]=h.substring(p+1)}d=+f.q;let E=Ut.get(_);if(E){let h=(E.q||1)*d;h>s&&(n=E,i=E.type||_,s=h,o=f)}}if(!n){if(r)return{serializer(){this.code(406).send("No supported content types found in Accept header, supported types include: "+Array.from(Ut.keys()).join(", "))}};n=Ut.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function df(e,t,r){let n=JP&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=_f(t);if(i.serializer.compressible===!1&&(n=!1),r.headers.set("Vary","Accept, Accept-Encoding"),r.headers.set("Content-Type",i.type),typeof e=="object"&&(e[Symbol.iterator]||e[Symbol.asyncIterator])&&i.serializer.serializeStream){let o=i.serializer.serializeStream(e,r);return n&&(r.headers.set("Content-Encoding","br"),o=o.pipe((0,Is.createBrotliCompress)({params:{[Is.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?Is.constants.BROTLI_MODE_TEXT:Is.constants.BROTLI_MODE_GENERIC,[Is.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>JP?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,Is.brotliCompress)(s,(c,u)=>{c?o(c):i(u)}))):s}function di(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return Gu(e);let r=t.serialize;if(r)return r(e);let n=_f(t);return r=t.serialize=n.serializer.serialize,r(e)}function c7(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 lo(e,t){e||(e="");let r=e.indexOf(";"),n;r>-1&&(n=e.slice(r+1),e=e.slice(0,r));let s=Ut.get(e);if(t){if(s?.deserializeStream)return s.deserializeStream;let i=Ut.get(e)?.deserialize||XP(e,n);return o=>c7(o).then(i)}return e&&Ut.get(e)?.deserialize||XP(e,n)}function XP(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 og(r)}catch{}return{contentType:e||"application/octet-stream",data:r}}}function u7(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 ng,ts,uo,Is,lf,jP,sg,ig,ZP,ev,Gu,og,ku,Ut,ag,zP,tv,o7,a7,JP,Ea=Oe(()=>{Th();ng=B(uf()),ts=require("msgpackr"),uo=require("cbor-x"),Is=require("zlib"),lf=require("stream");Zt();jP=require("../../index"),sg=B(Z()),ig=B(M()),ZP=B(require("yaml")),ev=sg.default.get(ig.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,Gu=ev?Ni:JSON.stringify,og=ev?Sh:JSON.parse,ku={useRecords:!1,useToJSON:!0},Ut=new Map,ag=Ut;Xe.contentTypes=ag;(0,jP._assignPackageExport)("contentTypes",ag);Ut.set("application/json",{serializeStream:cc,serialize:Gu,deserialize:og,q:.8});zP=new uo.Encoder(ku);Ut.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new uo.EncoderStream(ku).end(e)},serialize:zP.encode,deserialize:zP.decode,q:1});Ut.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?lf.Readable.from((0,ts.encodeIter)(e,ku)):(0,ts.pack)(e)},serialize:ts.pack,deserialize:ts.unpack,q:.9});Ut.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,ng.toCsvStream)(e,e?.getColumns?.())},q:.1});Ut.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.01});Ut.set("text/yaml",{serialize(e){return ZP.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Ut.set("text/event-stream",{serializeStream:function(e){return lf.Readable.from(u7(e,this.serialize))},serialize:function(e){if(e.acknowledge&&e.acknowledge(),typeof e=="object"&&"value"in e&&e.timestamp&&(e={data:e.value,event:e.type,id:e.timestamp}),e.data||e.event){let t="";if(e.event&&(t+="event: "+e.event+`
|
|
18
|
-
`),e.data){let r=e.data;typeof r=="object"&&(r
|
|
15
|
+
`,""):null}catch(f){f.stderr?i[u].npm_error=QU(f.stderr):i[u].npm_error=f.message;continue}try{i[u].npm_output=JSON.parse(l)}catch{i[u].npm_output=l}try{i[u].npm_error=JSON.parse(d)}catch{i[u].npm_error=d}}return Ta.info(`finished installModules with response ${i}`),i}a(T6,"installModules");function QU(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
|
|
16
|
+
`);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(QU,"parseNPMStdErr");async function g6(e){Ta.info(`starting auditModules for request: ${e}`);let t=JU(e);if(t)throw pa(t,t.message,Sa.BAD_REQUEST);let{projects:r}=e;await Qd(),await zU(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=Wd.join(UT,o);n[o]={npm_output:null,npm_error:null};try{let u=await vu("npm audit --json",c);n[o].npm_output=JSON.parse(u)}catch(u){n[o].npm_error=QU(u.stderr)}}return Ta.info(`finished auditModules with response ${n}`),n}a(g6,"auditModules");async function Qd(){try{return await vu("npm -v"),!0}catch{throw pa(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",Sa.BAD_REQUEST,void 0,void 0,!0)}}a(Qd,"checkNPMInstalled");async function zU(e){if(!Array.isArray(e)||e.length===0)throw pa(new Error,"projects argument must be an array with at least 1 element",Sa.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=Wd.join(UT,i.toString());if(!await YU.pathExists(o)){t.push(i);continue}let u=Wd.join(o,"package.json");await YU.pathExists(u)||r.push(i)}if(t.length>0)throw pa(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Sa.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw pa(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Sa.BAD_REQUEST,void 0,void 0,!0)}a(zU,"checkProjectPaths");function JU(e){let t=Kd.object({projects:Kd.array().min(1).items(Kd.string()).required(),dry_run:Kd.boolean().default(!1)});return E6.validateBySchema(e,t)}a(JU,"modulesValidator")});var vT=T((Cfe,rP)=>{"use strict";var ga=require("fs-extra"),PT=require("path"),Jd=W(),jU=J(),Xd=U(),tP=Z(),R6=Lr();rP.exports=A6;async function A6(){let e=O6(),t=tP.get(Xd.CONFIG_PARAMS.ROOTPATH),r=PT.join(t,"package.json"),n={dependencies:{harperdb:"file:"+Xd.PACKAGE_ROOT}},s=PT.join(t,"node_modules");await ga.ensureDir(s);let i,o=!0,c=!1;try{i=await ga.readJson(r)}catch(u){if(jU.isEmptyOrZeroLength(e))return;if(u.code!==Xd.NODE_ERROR_CODES.ENOENT)throw u;o=!1}if(!jU.isEmptyOrZeroLength(e)){for(let{name:u,package:_}of e){let l=await ZU(_);n.dependencies[u]=l+_}if(!o){Jd.notify("Installing components"),await eP(r,n,null);return}for(let{name:u,package:_}of e){let l=i.dependencies[u],d=await ZU(_);if(l===void 0||l!==d+_){c=!0;break}}}for(let u in i.dependencies)n.dependencies[u]===void 0&&(Jd.notify("Removing component",u),c=!0);c&&(Jd.notify("Updating components."),await eP(r,n,i))}a(A6,"installComponents");function O6(){let e=R6.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(O6,"getComponentsConfig");async function ZU(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":PT.extname(e)||await ga.pathExists(e)?"file:":"github:"}a(ZU,"getPkgPrefix");async function eP(e,t,r){Jd.trace("npm installing components package.json",t),await ga.writeFile(e,JSON.stringify(t,null," "));try{await zd().installAllRootModules(tP.get(Xd.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?await ga.writeFile(e,JSON.stringify(r,null," ")):await ga.unlink(e),n}}a(eP,"installPackages")});var xT=T((Mfe,oP)=>{"use strict";var qe=require("fs-extra"),BT=require("fast-glob"),Re=require("path"),sP=require("tar-fs"),Lfe=require("uuid").v4,HT=require("normalize-path"),ts=$U(),Ot=W(),$e=U(),Et=Z(),Bu=Lr(),b6=J(),{PACKAGE_ROOT:N6}=U(),{handleHDBError:Mt,hdb_errors:y6}=ee(),{basename:w6}=require("path"),I6=vT(),iP=Z(),C6=U(),{Readable:D6}=require("stream"),{isMainThread:L6}=require("worker_threads"),{HDB_ERROR_MSGS:uo,HTTP_STATUS_CODES:Ut}=y6,M6=Re.join(N6,"application-template"),nP=Re.join(Et.get($e.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp");function U6(){Ot.trace("getting custom api status");let e={};try{e={port:Et.get($e.CONFIG_PARAMS.HTTP_PORT),directory:Et.get($e.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Mt(new Error,uo.FUNCTION_STATUS,Ut.INTERNAL_SERVER_ERROR,Ot.ERR,t)}return e}a(U6,"customFunctionsStatus");function P6(){Ot.trace("getting custom api endpoints");let e={},t=Et.get($e.CONFIG_PARAMS.COMPONENTSROOT);try{BT.sync(HT(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:BT.sync(HT(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:BT.sync(HT(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Mt(new Error,uo.GET_FUNCTIONS,Ut.INTERNAL_SERVER_ERROR,Ot.ERR,r)}return e}a(P6,"getCustomFunctions");function v6(e){e.project&&(e.project=Re.parse(e.project).name),e.file&&(e.file=Re.parse(e.file).name);let t=ts.getDropCustomFunctionValidator(e);if(t)throw Mt(t,t.message,Ut.BAD_REQUEST);Ot.trace("getting custom api endpoint file content");let r=Et.get($e.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=Re.join(r,n,s,i+".js");try{return qe.readFileSync(o,{encoding:"utf8"})}catch(c){throw Mt(new Error,uo.GET_FUNCTION,Ut.INTERNAL_SERVER_ERROR,Ot.ERR,c)}}a(v6,"getCustomFunction");function B6(e){e.project&&(e.project=Re.parse(e.project).name),e.file&&(e.file=Re.parse(e.file).name);let t=ts.setCustomFunctionValidator(e);if(t)throw Mt(t,t.message,Ut.BAD_REQUEST);Ot.trace("setting custom function file content");let r=Et.get($e.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{return qe.outputFileSync(Re.join(r,n,s,i+".js"),o),`Successfully updated custom function: ${i}.js`}catch(c){throw Mt(new Error,uo.SET_FUNCTION,Ut.INTERNAL_SERVER_ERROR,Ot.ERR,c)}}a(B6,"setCustomFunction");function H6(e){e.project&&(e.project=Re.parse(e.project).name),e.file&&(e.file=Re.parse(e.file).name);let t=ts.getDropCustomFunctionValidator(e);if(t)throw Mt(t,t.message,Ut.BAD_REQUEST);Ot.trace("dropping custom function file");let r=Et.get($e.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{return qe.unlinkSync(Re.join(r,n,s,i+".js")),`Successfully deleted custom function: ${i}.js`}catch(o){throw Mt(new Error,uo.DROP_FUNCTION,Ut.INTERNAL_SERVER_ERROR,Ot.ERR,o)}}a(H6,"dropCustomFunction");function x6(e){e.project&&(e.project=Re.parse(e.project).name);let t=ts.addComponentValidator(e);if(t)throw Mt(t,t.message,Ut.BAD_REQUEST);Ot.trace("adding component");let r=Et.get($e.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=Re.join(r,n);return qe.mkdirSync(s,{recursive:!0}),qe.copySync(M6,s),`Successfully added project: ${n}`}catch(s){throw Mt(new Error,uo.ADD_FUNCTION,Ut.INTERNAL_SERVER_ERROR,Ot.ERR,s)}}a(x6,"addComponent");function F6(e){e.project&&(e.project=Re.parse(e.project).name);let t=ts.dropCustomFunctionProjectValidator(e);if(t)throw Mt(t,t.message,Ut.BAD_REQUEST);Ot.trace("dropping custom function project");let r=Et.get($e.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Et.get($e.CONFIG_PARAMS.APPS);if(!b6.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 Bu.updateConfigValue($e.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=Re.join(r,n);return qe.rmSync(i,{recursive:!0}),`Successfully deleted project: ${n}`}catch(i){throw Mt(new Error,uo.DROP_FUNCTION_PROJECT,Ut.INTERNAL_SERVER_ERROR,Ot.ERR,i)}}a(F6,"dropCustomFunctionProject");async function q6(e){e.project&&(e.project=Re.parse(e.project).name);let t=ts.packageComponentValidator(e);if(t)throw Mt(t,t.message,Ut.BAD_REQUEST);let r=Et.get($e.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Ot.trace("packaging component",n);let s;try{s=await qe.realpath(Re.join(r,n))}catch(u){if(u.code!==$e.NODE_ERROR_CODES.ENOENT)throw u;try{s=await qe.realpath(Re.join(Et.get($e.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(_){if(_.code===$e.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}await qe.ensureDir(nP);let i=Re.join(nP,`${n}.tar`),o={};(e.skip_node_modules===!0||e.skip_node_modules==="true")&&(o={ignore:u=>u.includes(Re.join(s,"node_modules"))}),sP.pack(s,o).pipe(qe.createWriteStream(i,{overwrite:!0})),await new Promise(u=>setTimeout(u,2e3));let c=qe.readFileSync(i,{encoding:"base64"});return await qe.remove(i),{project:n,payload:c}}a(q6,"packageComponent");async function G6(e){e.project&&(e.project=Re.parse(e.project).name);let t=ts.deployComponentValidator(e);if(t)throw Mt(t,t.message,Ut.BAD_REQUEST);let r=Et.get($e.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i}=e;if(Ot.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let o;if(s){o=Re.join(r,n),i="file:"+o,await qe.ensureDir(o);let f=D6.from(Buffer.from(s,"base64"));await new Promise((h,p)=>{f.pipe(sP.extract(o,{finish:h})).on("error",p)});let E=await qe.readdir(o);E.length===1&&E[0]==="package"&&(await qe.copy(Re.join(o,"package"),o),await qe.remove(Re.join(o,"package")))}if(await Bu.addConfig(n,{package:i}),!s){await I6();let f=iP.get(C6.CONFIG_PARAMS.ROOTPATH);o=Re.join(f,"node_modules",n)}if(L6)return;let c=new Map;c.isWorker=!0;let u=(Zd(),te(jd)),_;u.setErrorReporter(f=>_=f);let l=w6(o),d=u.component_errors.get(l);try{await u.loadComponent(o,c)}finally{u.component_errors.set(l,d)}if(_)throw _;return Ot.info("Installed component"),`Successfully deployed: ${n}`}a(G6,"deployComponent");async function k6(){let e=Bu.getConfiguration(),t=[];for(let o in e)if(e[o]?.package){if(e[o].package.startsWith("file:"))continue;t.push(Object.assign({},e[o],{name:o}))}let r=a(async(o,c)=>{try{let u=await qe.readdir(o,{withFileTypes:!0});for(let _ of u){let l=_.name;if(l.startsWith(".")||l==="node_modules")continue;let d=Re.join(o,l);if(_.isDirectory()||_.isSymbolicLink()){let f={name:l,entries:[]};c.entries.push(f),await r(d,f)}else{let f=await qe.stat(d),E={name:Re.basename(l),mtime:f.mtime,size:f.size};c.entries.push(E)}}return c}catch(u){return Ot.warn("Error loading package",u),{error:u.toString(),entries:[]}}},"walk_dir"),n=await r(Et.get($e.CONFIG_PARAMS.COMPONENTSROOT),{name:Et.get($e.CONFIG_PARAMS.COMPONENTSROOT).split(Re.sep).slice(-1).pop(),entries:t});for(let o of n.entries)if(o.package){let c=await r(Re.join(Et.get($e.CONFIG_PARAMS.ROOTPATH),"node_modules",o.name),{name:o.name,entries:[]});Object.assign(o,c)}let i=(Zd(),te(jd)).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(k6,"getComponents");async function V6(e){let t=ts.getComponentFileValidator(e);if(t)throw Mt(t,t.message,Ut.BAD_REQUEST);let n=Bu.getConfigObj()[e.project]||e.project==="harperdb"?Re.join(iP.get($e.CONFIG_PARAMS.ROOTPATH),"node_modules"):Et.get($e.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await qe.stat(Re.join(n,e.project,e.file));return{message:await qe.readFile(Re.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===$e.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${Re.join(e.project,e.file)}'`):i}}a(V6,"getComponentFile");async function $6(e){let t=ts.setComponentFileValidator(e);if(t)throw Mt(t,t.message,Ut.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=Re.join(Et.get($e.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);return e.payload!==void 0?(await qe.ensureFile(n),await qe.outputFile(n,e.payload,r)):await qe.ensureDir(n),"Successfully set component: "+e.file}a($6,"setComponentFile");async function Y6(e){let t=ts.dropComponentFileValidator(e);if(t)throw Mt(t,t.message,Ut.BAD_REQUEST);let r=e.file?Re.join(e.project,e.file):e.project,n=Re.join(Et.get($e.CONFIG_PARAMS.COMPONENTSROOT),r);return await qe.pathExists(n)&&await qe.remove(n),Bu.deleteConfigFromFile([e.project]),"Successfully dropped: "+r}a(Y6,"dropComponent");oP.exports={customFunctionsStatus:U6,getCustomFunctions:P6,getCustomFunction:v6,setCustomFunction:B6,dropCustomFunction:H6,addComponent:x6,dropCustomFunctionProject:F6,packageComponent:q6,deployComponent:G6,getComponents:k6,getComponentFile:V6,setComponentFile:$6,dropComponent:Y6}});var FT=T((Pfe,cP)=>{"use strict";var rs=require("joi"),aP=et();cP.exports={readTransactionLogValidator:K6,deleteTransactionLogsBeforeValidator:W6};function K6(e){let t=rs.object({schema:rs.string().required(),table:rs.string().required(),from:rs.date().timestamp(),to:rs.date().timestamp(),limit:rs.number().min(1)});return aP.validateBySchema(e,t)}a(K6,"readTransactionLogValidator");function W6(e){let t=rs.object({schema:rs.string().required(),table:rs.string().required(),timestamp:rs.date().timestamp().required()});return aP.validateBySchema(e,t)}a(W6,"deleteTransactionLogsBeforeValidator")});var tf=T((Bfe,fP)=>{"use strict";var qT=U(),ef=At(),uP=J(),lP=Z(),_P=ms(),{handleHDBError:Ra,hdb_errors:Q6}=ee(),{HTTP_STATUS_CODES:Aa}=Q6,{readTransactionLogValidator:z6,deleteTransactionLogsBeforeValidator:J6}=FT(),dP="This operation relies on clustering and cannot run with it disable.",X6="Logs successfully deleted from transaction log.",j6="All logs successfully deleted from transaction log.";fP.exports={readTransactionLog:Z6,deleteTransactionLogsBefore:e9};async function*Z6(e){let t=z6(e);if(t)throw Ra(t,t.message,Aa.BAD_REQUEST,void 0,void 0,!0);if(!lP.get(qT.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Ra(new Error,dP,Aa.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:n}=e,s=uP.checkSchemaTableExist(r,n);if(s)throw Ra(new Error,s,Aa.NOT_FOUND,void 0,void 0,!0);let i=_P.createNatsTableStreamName(r,n),o=await ef.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===qT.OPERATIONS_ENUM.DELETE&&(_.hash_values=c?.entry?.hash_values),yield _}}a(Z6,"readTransactionLog");async function e9(e){let t=J6(e);if(t)throw Ra(t,t.message,Aa.BAD_REQUEST,void 0,void 0,!0);if(!lP.get(qT.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Ra(new Error,dP,Aa.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:n,timestamp:s}=e,i=uP.checkSchemaTableExist(r,n);if(i)throw Ra(new Error,i,Aa.NOT_FOUND,void 0,void 0,!0);let o=_P.createNatsTableStreamName(r,n),{jsm:c}=await ef.getNATSReferences(),u=await ef.getStreamInfo(o),_=new Date(u.state.first_ts).getTime();if(s<=_)return`No transactions exist before: ${s}`;let l=X6,d,f=new Date(u.state.last_ts).getTime();return s>f?(d=u.state.last_seq+1,l=j6):d=(await ef.viewStream(o,parseInt(s),1))[0].nats_sequence,await c.streams.purge(o,{seq:d}),l}a(e9,"deleteTransactionLogsBefore")});var hP=T((xfe,EP)=>{"use strict";var GT=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}};EP.exports=GT});var pP=T((qfe,mP)=>{"use strict";var kT=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};mP.exports=kT});var $T=T((kfe,TP)=>{"use strict";var SP=hP(),t9=pP(),{HDB_ERROR_MSGS:r9}=br(),VT=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=r9.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 SP(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let u=new t9(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 SP(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}};TP.exports=VT});var of=T(($fe,vP)=>{"use strict";var YT=Zr(),rf=jr(),cn=rd(),Fu=Ui(),KT=xi(),n9=sS(),s9=DD(),qu=en(),nf=fS(),bt=W(),i9=mS(),o9=Td(),a9=jS(),c9=Rd(),u9=ZS(),l9=eT(),_9=nT(),d9=iT(),WT=cT(),Is=J(),f9=wM(),QT=fT(),AP=xd(),an=U(),OP=wU(),E9=ca(),bP=_u(),NP=($d(),te(Lu)),yP=Lr(),qr=xT(),h9=require("alasql"),wP=tf(),IP=zd(),CP=$T(),{handleHDBError:fr,hdb_errors:DP}=ee(),{HDB_ERROR_MSGS:Ft,HTTP_STATUS_CODES:Hu}=DP,k=new Map,LP="delete",hi="insert",Cs="read",lo="update",xu="describe",gP=Fu.describeSchema.name,RP=Fu.describeTable.name,MP={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},m9="catchup",p9="handleGetJob",S9="handleGetJobsByStartDate",sf={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},T9=[cn.createTable.name,cn.createAttribute.name,cn.dropTable.name,cn.dropAttribute.name],UP={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},Q=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};k.set(YT.insert.name,new Q(!1,[hi]));k.set(YT.update.name,new Q(!1,[lo]));k.set(YT.upsert.name,new Q(!1,[hi,lo]));k.set(rf.searchByConditions.name,new Q(!1,[Cs]));k.set(rf.searchByHash.name,new Q(!1,[Cs]));k.set(rf.searchByValue.name,new Q(!1,[Cs]));k.set(rf.search.name,new Q(!1,[Cs]));k.set(cn.createSchema.name,new Q(!0,[]));k.set(cn.createTable.name,new Q(!0,[]));k.set(cn.createAttribute.name,new Q(!1,[hi]));k.set(cn.dropSchema.name,new Q(!0,[]));k.set(cn.dropTable.name,new Q(!0,[]));k.set(cn.dropAttribute.name,new Q(!0,[]));k.set(Fu.describeSchema.name,new Q(!1,[Cs]));k.set(Fu.describeTable.name,new Q(!1,[Cs]));k.set(KT.deleteRecord.name,new Q(!1,[LP]));k.set(qu.addUser.name,new Q(!0,[]));k.set(qu.alterUser.name,new Q(!0,[]));k.set(qu.dropUser.name,new Q(!0,[]));k.set(qu.listUsersExternal.name,new Q(!0,[]));k.set(nf.listRoles.name,new Q(!0,[]));k.set(nf.addRole.name,new Q(!0,[]));k.set(nf.alterRole.name,new Q(!0,[]));k.set(nf.dropRole.name,new Q(!0,[]));k.set(i9.name,new Q(!0,[]));k.set(o9.name,new Q(!0,[]));k.set(a9.name,new Q(!0,[]));k.set(c9.name,new Q(!0,[]));k.set(u9.name,new Q(!0,[]));k.set(l9.name,new Q(!0,[]));k.set(WT.setRoutes.name,new Q(!0,[]));k.set(WT.getRoutes.name,new Q(!0,[]));k.set(WT.deleteRoutes.name,new Q(!0,[]));k.set(yP.setConfiguration.name,new Q(!0,[]));k.set(_9.clusterStatus.name,new Q(!0,[]));k.set(d9.name,new Q(!0,[]));k.set(QT.getFingerprint.name,new Q(!0,[]));k.set(QT.setLicense.name,new Q(!0,[]));k.set(KT.deleteFilesBefore.name,new Q(!0,[]));k.set(KT.deleteAuditLogsBefore.name,new Q(!0,[]));k.set(AP.restart.name,new Q(!0,[]));k.set(AP.restartService.name,new Q(!0,[]));k.set(n9.name,new Q(!0,[]));k.set(s9.name,new Q(!0,[Cs]));k.set(E9.systemInformation.name,new Q(!0,[]));k.set(yP.getConfiguration.name,new Q(!0,[]));k.set(wP.readTransactionLog.name,new Q(!0,[]));k.set(wP.deleteTransactionLogsBefore.name,new Q(!0,[]));k.set(IP.installModules.name,new Q(!0,[]));k.set(IP.auditModules.name,new Q(!0,[]));k.set(bP.createTokens.name,new Q(!1,[]));k.set(bP.refreshOperationToken.name,new Q(!1,[]));k.set(NP.login.name,new Q(!1,[]));k.set(NP.logout.name,new Q(!1,[]));k.set(qr.customFunctionsStatus.name,new Q(!0,[]));k.set(qr.getCustomFunctions.name,new Q(!0,[]));k.set(qr.getComponents.name,new Q(!0,[]));k.set(qr.getComponentFile.name,new Q(!0,[]));k.set(qr.setComponentFile.name,new Q(!0,[]));k.set(qr.dropComponent.name,new Q(!0,[]));k.set(qr.getCustomFunction.name,new Q(!0,[]));k.set(qr.setCustomFunction.name,new Q(!0,[]));k.set(qr.dropCustomFunction.name,new Q(!0,[]));k.set(qr.addComponent.name,new Q(!0,[]));k.set(qr.dropCustomFunctionProject.name,new Q(!0,[]));k.set(qr.packageComponent.name,new Q(!0,[]));k.set(qr.deployComponent.name,new Q(!0,[]));k.set(QT.getRegistrationInfo.name,new Q(!1,[]));k.set(qu.userInfo.name,new Q(!1,[]));k.set(Fu.describeAll.name,new Q(!1,[]));k.set(p9,new Q(!1,[]));k.set(S9,new Q(!0,[]));k.set(m9,new Q(!0,[]));k.set(sf.CSV_DATA_LOAD,new Q(!1,[hi,lo]));k.set(sf.CSV_URL_LOAD,new Q(!1,[hi,lo]));k.set(sf.CSV_FILE_LOAD,new Q(!1,[hi,lo]));k.set(sf.IMPORT_FROM_S3,new Q(!1,[hi,lo]));k.set(UP.EXPORT_TO_S3,new Q(!0,[]));k.set(UP.EXPORT_LOCAL,new Q(!0,[]));k.set(an.VALID_SQL_OPS_ENUM.DELETE,new Q(!1,[LP]));k.set(an.VALID_SQL_OPS_ENUM.SELECT,new Q(!1,[Cs]));k.set(an.VALID_SQL_OPS_ENUM.INSERT,new Q(!1,[hi]));k.set(an.VALID_SQL_OPS_ENUM.UPDATE,new Q(!1,[lo]));vP.exports={verifyPerms:R9,verifyPermsAst:g9,verifyBulkLoadAttributePerms:O9};function g9(e,t,r){if(Is.isEmptyOrZeroLength(e))throw bt.info("verify_perms_ast has an empty user parameter"),fr(new Error);if(Is.isEmptyOrZeroLength(t))throw bt.info("verify_perms_ast has an empty user parameter"),fr(new Error);if(Is.isEmptyOrZeroLength(r))throw bt.info("verify_perms_ast has a null operation parameter"),fr(new Error);try{let n=new CP,s=new f9(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw bt.info("No schemas defined in verifyPermsAst(), will not continue."),fr(new Error);let c=!!t.role.permission.super_user,u=i.includes("system");if(u&&MP[r])throw fr(new Error,Ft.DROP_SYSTEM,Hu.FORBIDDEN);if(c&&!u)return null;let _=OP.getRolePermissions(t.role);t.role.permission=_,!c&&e instanceof h9.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(_));for(let d=0;d<i.length;d++){let f=s.getTablesBySchemaName(i[d]);f&&o.set(i[d],f)}let l=PP(t,r,o,n);return l||(o.forEach((d,f)=>{for(let E=0;E<d.length;E++){let h=s.getAttributesBySchemaTableName(f,d[E]),p=JT(t.role.permission,f,d[E]);zT(h,p,r,d[E],f,n)}}),n.getPermsResponse())}catch(n){throw fr(n)}}a(g9,"verifyPermsAst");function R9(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw bt.info("null required parameter in verifyPerms"),fr(new Error,Ft.DEFAULT_INVALID_REQUEST,Hu.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 CP;if(Is.isEmptyOrZeroLength(e.hdb_user.role)||Is.isEmptyOrZeroLength(e.hdb_user.role.permission))return bt.info(`User ${e.hdb_user.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(Ft.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(an.SYSTEM_SCHEMA_NAME)||s===an.SYSTEM_SCHEMA_NAME;if(l&&MP[r])throw fr(new Error,Ft.DROP_SYSTEM,Hu.FORBIDDEN);if(u&&!l||_===!0&&(r===cn.createSchema.name||r===cn.dropSchema.name))return null;if(T9.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=OP.getRolePermissions(e.hdb_user.role);if(e.hdb_user.role.permission=d,r===gP||r===RP){if(s===an.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(Ft.SCHEMA_PERM_ERROR(s));if(!d.super_user){if(r===gP&&(!d[s]||!d[s][xu]))return c.handleInvalidItem(Ft.SCHEMA_NOT_FOUND(s));if(r===RP&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][xu]))return c.handleInvalidItem(Ft.TABLE_NOT_FOUND(s,i))}}let f=PP(e.hdb_user,r,o,c,n);if(f)return f;if(k.get(r)&&k.get(r).perms.length===0)return null;if(!u&&e.get_attributes&&an.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let p=[],S=d[s].tables[i];S[an.PERMS_CRUD_ENUM.READ]&&(S.attribute_permissions.length>0?S.attribute_permissions.filter(g=>g[an.PERMS_CRUD_ENUM.READ]).forEach(g=>{p.push(g.attribute_name)}):p=global.hdb_schema[s][i].attributes.map(O=>O.attribute),e.get_attributes=p)}let E=A9(e),h=JT(e.hdb_user.role.permission,s,i);return zT(E,h,r,i,s,c,n),c.getPermsResponse()}a(R9,"verifyPerms");function PP(e,t,r,n,s){if(Is.arrayHasEmptyValues([e,t,r]))throw bt.info("hasPermissions has an invalid parameter"),fr(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||k.get(t).requires_su))return null;if(!k.get(t))throw bt.info(`operation ${t} not found.`),fr(new Error,Ft.OP_NOT_FOUND(t),Hu.BAD_REQUEST);if(k.get(t)&&k.get(t).requires_su)return bt.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(Ft.OP_IS_SU_ONLY(t));let c=r.keys();for(let u of c){try{if(u&&!o[u]||o[u][xu]===!1){n.addInvalidItem(Ft.SCHEMA_NOT_FOUND(u));continue}}catch{n.addInvalidItem(Ft.SCHEMA_NOT_FOUND(u));continue}let _=r.get(u);for(let l of _){let d=o[u].tables[l];if(!d||d[xu]===!1)n.addInvalidItem(Ft.TABLE_NOT_FOUND(u,l));else try{let f=[],E=k.get(t).perms;!Is.isEmpty(s)&&E.includes(s)&&(E=[s]);for(let h=0;h<E.length;h++){let p=E[h],S=d[p];(S==null||S===!1)&&(bt.info(`Required ${p} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),f.push(p))}f.length>0&&n.addUnauthorizedTable(u,l,f)}catch(f){let E=Ft.UNKNOWN_OP_AUTH_ERROR(t,u,l);throw bt.error(E),bt.error(f),fr(DP.CHECK_LOGS_WRAPPER(E))}}}return r.size<2?n.getPermsResponse():null}a(PP,"hasPermissions");function zT(e,t,r,n,s,i,o){if(!e||!t)throw bt.info("no attributes specified in checkAttributePerms."),fr(new Error);let c=k.get(r).perms;if(!c||c==="")throw bt.info(`no permissions found for ${r} in checkAttributePerms().`),fr(new Error);if(Is.isEmptyOrZeroLength(t))return bt.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[xu]===!1){i.addInvalidItem(Ft.ATTR_NOT_FOUND(s,n,l),s,n);continue}if(c)for(let f of c){if(an.TIME_STAMP_NAMES.includes(d.attribute_name)&&f!==Cs)throw fr(new Error,Ft.SYSTEM_TIMESTAMP_PERMS_ERR,Hu.FORBIDDEN);d[f]===!1&&(u[d.attribute_name]?u[d.attribute_name].push(f):u[d.attribute_name]=[f])}}else i.addInvalidItem(Ft.ATTR_NOT_FOUND(s,n,l),s,n)}let _=Object.keys(u);_.length>0&&i.addUnauthorizedAttributes(_,s,n,u)}a(zT,"checkAttributePerms");function A9(e){let t=new Set;try{if(e.action)return t;if(e.operation===an.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){bt.info(r)}return t}a(A9,"getRecordAttributes");function JT(e,t,r){let n=new Map;if(Is.isEmpty(e))return bt.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{bt.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(JT,"getAttributePermissions");function O9(e,t,r,n,s,i,o){let c=new Set(i),u=JT(e,n,s);zT(c,u,t,s,n,o,r)}a(O9,"verifyBulkLoadAttributePerms")});var cf=T((Kfe,qP)=>{"use strict";qP.exports={evaluateSQL:B9,processAST:FP,convertSQLToAST:xP,checkASTPermissions:HP};var b9=Zr(),BP=require("util"),N9=BP.callbackify(b9.insert),y9=jr().search,w9=AC().update,I9=BP.callbackify(w9),C9=bC().convertDelete,mi=require("alasql"),D9=of(),af=W(),L9=V_(),M9=J(),Gu=U(),{hdb_errors:U9,handleHDBError:XT}=ee(),{HTTP_STATUS_CODES:jT}=U9;L9(mi);var P9=403,v9="There was a problem performing this insert. Please check the logs and try again.",ZT=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function B9(e,t){let r=e.parsed_sql_object;if(!r){r=xP(e.sql);let n,s=r.ast.statements[0];if(s instanceof mi.yy.Insert?n=s.into.databaseid:s instanceof mi.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof mi.yy.Update||s instanceof mi.yy.Delete?n=s.table.databaseid:af.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof mi.yy.Select)&&M9.isEmptyOrZeroLength(n))return t("No schema specified",null)}FP(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(B9,"evaluateSQL");function HP(e,t){let r;try{r=D9.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(HP,"checkASTPermissions");function xP(e){let t=new ZT;if(!e)throw XT(new Error,"The 'sql' parameter is missing from the request body",jT.BAD_REQUEST);try{let r=e.trim(),n=mi.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
|
|
17
|
+
`);throw n[1]?XT(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,jT.BAD_REQUEST):XT(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",jT.BAD_REQUEST)}return t}a(xP,"convertSQLToAST");function FP(e,t,r){try{let n=H9;if(!e.bypass_auth&&!t.permissions_checked){let i=HP(e,t);if(i&&i.length>0)return r(P9,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case Gu.VALID_SQL_OPS_ENUM.SELECT:n=y9,s=t.ast.statements[0];break;case Gu.VALID_SQL_OPS_ENUM.INSERT:n=x9;break;case Gu.VALID_SQL_OPS_ENUM.UPDATE:n=I9;break;case Gu.VALID_SQL_OPS_ENUM.DELETE:n=C9;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(FP,"processAST");function H9(e,t){af.info(e),t("unknown sql statement")}a(H9,"nullFunction");function x9({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=F9(i,e.values)}catch(o){return r(o)}N9(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(u){af.error(`Error delete new_attributes from insert response: ${u}`)}r(null,c)})}a(x9,"convertInsert");function F9(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]]=mi.compile(`SELECT ${s.toString()} AS [${Gu.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw af.error(r),new Error(v9)}}a(F9,"createDataObjects")});var eg=T((Qfe,kP)=>{"use strict";var{S3:q9,GetObjectCommand:G9}=require("@aws-sdk/client-s3");kP.exports={getFileStreamFromS3:k9,getS3AuthObj:GP};async function k9(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await GP(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new G9(r))).Body}a(k9,"getFileStreamFromS3");function GP(e,t,r){return new q9({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(GP,"getS3AuthObj")});var uf=T((Jfe,XP)=>{"use strict";var rg=jr(),V9=cf(),$9=eg(),{AsyncParser:Y9,Transform:K9}=require("json2csv"),Vu=require("stream"),Gr=J(),tg=require("fs-extra"),W9=require("path"),un=W(),{promisify:YP}=require("util"),ku=J(),{handleHDBError:ht,hdb_errors:Q9}=ee(),{HDB_ERROR_MSGS:Er,HTTP_STATUS_CODES:mt}=Q9,{streamAsJSON:z9}=(Th(),te(GO)),{Upload:J9}=require("@aws-sdk/lib-storage"),VP=["search_by_value","search_by_hash","sql","search_by_conditions"],$P=["json","csv"],KP="json",WP="csv",X9="Successfully exported JSON locally.",j9="Successfully exported CSV locally.",Z9=1e3,e7=rg.searchByHash,t7=rg.searchByValue,r7=YP(V9.evaluateSQL),n7=YP(Vu.finished);XP.exports={export_to_s3:a7,export_local:s7,toCsvStream:QP};async function s7(e){un.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=zP(e);if(!Gr.isEmpty(t))throw un.error(t),ht(new Error,t,mt.BAD_REQUEST,void 0,void 0,!0);if(Gr.isEmpty(e.path))throw un.error(Er.MISSING_VALUE("path")),ht(new Error,Er.MISSING_VALUE("path"),mt.BAD_REQUEST,void 0,void 0,!0);let r=(Gr.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(W9.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=Gr.buildFolderPath(e.path,r);await i7(e.path);let s=await JP(e);return await o7(n,e.format,s)}a(s7,"export_local");async function i7(e){if(un.trace("in confirmPath"),Gr.isEmptyOrZeroLength(e))throw ht(new Error,`Invalid path: ${e}`,mt.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await tg.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,un.error(n),ht(new Error,n,mt.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 un.error(r),ht(new Error,r,mt.BAD_REQUEST,void 0,void 0,!0)}return!0}a(i7,"confirmPath");async function o7(e,t,r){if(un.trace("in saveToLocal"),ku.isEmptyOrZeroLength(e))throw ht(new Error,Er.INVALID_VALUE("file_path"),mt.BAD_REQUEST,void 0,void 0,!0);if(ku.isEmptyOrZeroLength(t))throw ht(new Error,Er.INVALID_VALUE("Source format"),mt.BAD_REQUEST,void 0,void 0,!0);if(ku.isEmpty(r))throw ht(new Error,Er.NOT_FOUND("Data"),mt.BAD_REQUEST,void 0,void 0,!0);if(t===KP){let n=tg.createWriteStream(e);return z9(r).pipe(n),await n7(n),{message:X9,path:e}}else if(t===WP){let n=tg.createWriteStream(e),s=Vu.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(l=>({label:l,value:l})));let c={objectMode:!0};return await new Y9(i,c).fromInput(s).toOutput(n).promise(!1),{message:j9,path:e}}throw ht(new Error,Er.INVALID_VALUE("format"),mt.BAD_REQUEST)}a(o7,"saveToLocal");async function a7(e){if(!e.s3||Object.keys(e.s3).length===0)throw ht(new Error,Er.MISSING_VALUE("S3 object"),mt.BAD_REQUEST);if(Gr.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw ht(new Error,Er.MISSING_VALUE("aws_access_key_id"),mt.BAD_REQUEST);if(Gr.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw ht(new Error,Er.MISSING_VALUE("aws_secret_access_key"),mt.BAD_REQUEST);if(Gr.isEmptyOrZeroLength(e.s3.bucket))throw ht(new Error,Er.MISSING_VALUE("bucket"),mt.BAD_REQUEST);if(Gr.isEmptyOrZeroLength(e.s3.key))throw ht(new Error,Er.MISSING_VALUE("key"),mt.BAD_REQUEST);if(Gr.isEmptyOrZeroLength(e.s3.region))throw ht(new Error,Er.MISSING_VALUE("region"),mt.BAD_REQUEST);let t=zP(e);if(!Gr.isEmpty(t))throw ht(new Error,t,mt.BAD_REQUEST);un.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await JP(e)}catch(u){throw un.error(u),u}let n,s=await $9.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new Vu.PassThrough;if(e.format===WP){i=e.s3.key+".csv";let u=QP(r,r.getColumns?.());u.on("error",_=>{throw _}),u.pipe(o)}else if(e.format===KP){i=e.s3.key+".json";let u=new Vu.Readable;u.pipe(o),u.on("error",d=>{throw d}),u.push("[");let _=r.length,l="";for(let[d,f]of r.entries()){let E=d===_-1?JSON.stringify(f):JSON.stringify(f)+",";l+=E,d!==0&&d%Z9===0&&(u.push(l),l="")}l.length!==0&&u.push(l),u.push("]"),u.push(null)}else throw ht(new Error,Er.INVALID_VALUE("format"),mt.BAD_REQUEST);return new J9({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(a7,"export_to_s3");function QP(e,t){let r=Vu.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 K9(n,s);return r.pipe(i)}a(QP,"toCsvStream");function zP(e){if(un.trace("in exportCoreValidation"),Gr.isEmpty(e.format))return"format missing";if($P.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${$P.join(", ")}`;let t=e.search_operation.operation;if(Gr.isEmpty(t))return"search_operation.operation missing";if(VP.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${VP.join(", ")}`}a(zP,"exportCoreValidation");async function JP(e){un.trace("in getRecords");let t,r;if(ku.isEmpty(e.search_operation)||ku.isEmptyOrZeroLength(e.search_operation.operation))throw ht(new Error,Er.INVALID_VALUE("Search operation"),mt.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=t7;break;case"search_by_hash":t=e7;break;case"search_by_conditions":t=rg.searchByConditions;break;case"sql":t=r7;break;default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,un.error(r),ht(new Error,r,mt.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(JP,"getRecords")});var iv={};ke(iv,{contentTypes:()=>ag,findBestSerializer:()=>_f,getDeserializer:()=>fo,registerContentHandlers:()=>cg,serialize:()=>df,serializeMessage:()=>Ei});function c7(e){try{return e?.[0]===123?og(e):e}catch{return e}}function cg(e){e.register(l7,{serializers:[{regex:/^application\/json$/,serializer:_c},{regex:/^application\/cbor$/,serializer:function(t){return new _o.EncoderStream(Yu).end(t)}},{regex:/^application\/(x-)?msgpack$/,serializer:function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?lf.Readable.from((0,ns.encodeIter)(t,Yu)):(0,ns.pack)(t)}},{regex:/^text\/csv$/,serializer:function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,ng.toCsvStream)(t)}}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,ns.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,_o.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function _f(e){let r=(e.headers.asObject||e.headers).accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let u of c){let[_,...l]=u.split(/\s*;\s*/),d=1,f={q:1};for(let h of l){let p=h.indexOf("=");f[h.substring(0,p)]=h.substring(p+1)}d=+f.q;let E=Pt.get(_);if(E){let h=(E.q||1)*d;h>s&&(n=E,i=E.type||_,s=h,o=f)}}if(!n){if(r)return{serializer(){this.code(406).send("No supported content types found in Accept header, supported types include: "+Array.from(Pt.keys()).join(", "))}};n=Pt.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function df(e,t,r){let n=ZP&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=_f(t);if(i.serializer.compressible===!1&&(n=!1),r.headers.set("Vary","Accept, Accept-Encoding"),r.headers.set("Content-Type",i.type),typeof e=="object"&&(e[Symbol.iterator]||e[Symbol.asyncIterator])&&i.serializer.serializeStream){let o=i.serializer.serializeStream(e,r);return n&&(r.headers.set("Content-Encoding","br"),o=o.pipe((0,Ds.createBrotliCompress)({params:{[Ds.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?Ds.constants.BROTLI_MODE_TEXT:Ds.constants.BROTLI_MODE_GENERIC,[Ds.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>ZP?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,Ds.brotliCompress)(s,(c,u)=>{c?o(c):i(u)}))):s}function Ei(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return $u(e);let r=t.serialize;if(r)return r(e);let n=_f(t);return r=t.serialize=n.serializer.serialize,r(e)}function _7(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 fo(e,t){e||(e="");let r=e.indexOf(";"),n;r>-1&&(n=e.slice(r+1),e=e.slice(0,r));let s=Pt.get(e);if(t){if(s?.deserializeStream)return s.deserializeStream;let i=Pt.get(e)?.deserialize||ev(e,n);return o=>_7(o).then(i)}return e&&Pt.get(e)?.deserialize||ev(e,n)}function ev(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 og(r)}catch{}return{contentType:e||"application/octet-stream",data:r}}}function d7(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 ng,ns,_o,Ds,lf,tv,sg,ig,rv,nv,$u,og,Yu,Pt,ag,jP,sv,u7,l7,ZP,ma=Oe(()=>{Th();ng=x(uf()),ns=require("msgpackr"),_o=require("cbor-x"),Ds=require("zlib"),lf=require("stream");jt();tv=require("../../index"),sg=x(Z()),ig=x(U()),rv=x(require("yaml")),nv=sg.default.get(ig.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,$u=nv?wi:JSON.stringify,og=nv?Sh:JSON.parse,Yu={useRecords:!1,useToJSON:!0},Pt=new Map,ag=Pt;Xe.contentTypes=ag;(0,tv._assignPackageExport)("contentTypes",ag);Pt.set("application/json",{serializeStream:_c,serialize:$u,deserialize:og,q:.8});jP=new _o.Encoder(Yu);Pt.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new _o.EncoderStream(Yu).end(e)},serialize:jP.encode,deserialize:jP.decode,q:1});Pt.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?lf.Readable.from((0,ns.encodeIter)(e,Yu)):(0,ns.pack)(e)},serialize:ns.pack,deserialize:ns.unpack,q:.9});Pt.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,ng.toCsvStream)(e,e?.getColumns?.())},q:.1});Pt.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.01});Pt.set("text/yaml",{serialize(e){return rv.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Pt.set("text/event-stream",{serializeStream:function(e){return lf.Readable.from(d7(e,this.serialize))},serialize:function(e){if(e.acknowledge&&e.acknowledge(),typeof e=="object"&&"value"in e&&e.timestamp&&(e={data:e.value,event:e.type,id:e.timestamp}),e.data||e.event){let t="";if(e.event&&(t+="event: "+e.event+`
|
|
18
|
+
`),e.data){let r=e.data;typeof r=="object"&&(r=$u(r)),t+="data: "+r+`
|
|
19
19
|
`}return e.id&&(t+="id: "+e.id+`
|
|
20
20
|
`),e.retry&&(t+="retry: "+e.retry+`
|
|
21
21
|
`),t+`
|
|
22
|
-
`}else return typeof e=="object"?`data: ${
|
|
22
|
+
`}else return typeof e=="object"?`data: ${$u(e)}
|
|
23
23
|
|
|
24
24
|
`:`data: ${e}
|
|
25
25
|
|
|
26
|
-
`},compressible:!1,q:.8});Ut.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()}});tv={type:"application/json",serializeStream:cc,serialize:Gu,deserialize:i7,q:.8};Ut.set("*/*",tv);Ut.set("",tv);a(i7,"tryJSONParse");a(cg,"registerContentHandlers");o7=require("fastify-plugin"),a7=o7(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=_f(n.raw);s.type(c),s.serializer(function(u){return(o.serializeStream||o.serialize)(u,{headers:{set:(_,l)=>{s.header(_,l)}}})})}),r()},{name:"content-type-negotiation"});a(_f,"findBestSerializer");JP=sg.default.get(ig.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(df,"serialize");a(di,"serializeMessage");a(c7,"streamToBuffer");a(lo,"getDeserializer");a(XP,"deserializerUnknownType");a(u7,"transformIterable")});function dg(e,t,r,n,s,i,o,c){let u=e[0];if(t==="or"){let d=_(u);for(let E=1;E<e.length;E++){let h=e[E],p=_(h);d=d.concat(p)}let f=new Set;return d.filter(E=>{let h=E.key??E;return f.has(h)?!1:(f.add(h),!0)})}else{let d=_(u),f=l(e.slice(1),!0,u.estimated_count);return f.length>0?o(d,f):d}function _(d){return d.conditions?dg(d.conditions,d.operator,r,n,s,i,o,c):Oa(d,n,d.descending||s.reverse===!0,r,s.allowFullScan,c)}a(_,"executeCondition");function l(d,f,E){return d.map((h,p)=>{if(h.conditions){let A=h.operator==="or",b=l(h.conditions,!A,E);return A?H=>b.some(F=>F(H)):H=>b.every(F=>F(H))}let S=(h.attribute||h[0])===r.primaryKey,T=Eg(h,r,i,c,S,E);return f&&p<d.length-1&&E&&(E=S7(r.primaryStore,h.estimated_count,E)),T}).filter(Boolean)}a(l,"mapConditionsToFilters")}function Oa(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 T=o[0],A=Ds(n.attributes,T);if(A.relationship){if(o.length<2)throw new Cs.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let b=A.definition?.tableClass||A.elements?.definition?.tableClass,H=new Map,F=Oa({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:u},t,r,b,s,H);if(A.relationship.to){i[o[0]]=H;let v=!!Ds(b.attributes,A.relationship.to)?.elements;F=E7(F,A,b.primaryStore,v,H)}if(A.relationship.from){let v=a(P=>Oa({attribute:A.relationship.from,value:P},t,r,n,s,H),"searchEntry");A.elements?(i[o[0]]=H,F=h7(F,A,b.primaryStore,H,v)):F=F.flatMap(v)}return F}else if(o.length===1)o=o[0];else throw new Cs.ClientError("Unable to query by attribute "+JSON.stringify(o))}let _,l,d,f;c instanceof Date&&(c=c.getTime());let E;switch(fg[u]||u){case"lt":_=!0,l=c;break;case"le":_=!0,l=c,d=!0;break;case"gt":_=c,f=!0;break;case"ge":_=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],_=c,l=c.slice(0),l[l.length-1]=rs.MAXIMUM_KEY;break;case"starts_with":_=c.toString(),l=c+"\uFFFF";break;case"between":_=c[0],_ instanceof Date&&(_=_.getTime()),l=c[1],l instanceof Date&&(l=l.getTime()),d=!0;break;case"equals":case void 0:_=c,l=c,d=!0;break;case"ne":if(c===null){_=c,f=!0;break}case"contains":case"ends_with":E=!0;break;default:throw new Cs.ClientError(`Unknown query comparator "${u}"`)}if(r){let T=_;_=l,l=T,T=!f,f=!d,d=T}let h=o===n.primaryKey||o==null,p=h?n.primaryStore:n.indices[o];if(!p||p.isIndexing||E||c===null&&!p.indexNulls){if(!s)throw new Cs.ClientError(`"${o}" is not indexed${c===null&&!p.indexNulls?" for nulls, index needs to be rebuilt to search for nulls":p?.isIndexing?" yet":""}, can not search for this attribute`,404);let T=Eg(e);if(!T)throw new Cs.ClientError(`Unknown search operator ${e.comparator}`);return n.primaryStore.getRange({start:!0,transaction:t,reverse:r}).map(({key:A,value:b})=>new Promise((H,F)=>setImmediate(()=>{try{H(b&&T(b)?A:ug.SKIP)}catch(v){F(v)}})))}let S={start:_,end:l,inclusiveEnd:d,exclusiveStart:f,values:!0,versions:h,transaction:t,reverse:r};if(h){let T=p.getRange(S).map(A=>A.value==null?ug.SKIP:A);return T.hasEntries=!0,T}else return p.getRange(S).map(({value:T})=>T)}function Ds(e,t){if(Array.isArray(t))if(t.length>1){let r=Ds(e,t[0]),n=(r?.definition?.tableClass||r?.elements.definition?.tableClass)?.attributes;return n?Ds(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 E7(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;return(async()=>{let _=a((d,f)=>{let E=d;Array.isArray(d)&&(E=Dn(d),o=!0);let h=s.get(E);h?h.push(f):s.set(E,h=[f]),d!==E&&(h.key=d)},"add_entry"),l=0;for await(let d of e){let f=d.value??r.get(d.key??d),E=f?.[u];if(E!=null&&!s.filters?.some(h=>!h(f))){if(n)for(let h=0;h<E.length;h++)_(E[h],d);else _(E,d);l++>100&&(await new Promise(setImmediate),l=0)}}return i=(o?s:s.keys())[Symbol.iterator](),this.next()})()}let c=i.next();return c.done?c:{value:o?c.value[1].key||c.value[0]:c.value}}}}})}function h7(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 _=Dn(u.value);if(!c.has(_))return c.add(_),u}if(!i)return(async()=>{let _=new Map;n.fromRecord=d=>d[t.relationship.from]?.filter?.(f=>_.has(Dn(f)));let l=0;for await(let d of e){if(n.filters){let f=r.get(d);if(n.filters.some(E=>!E(f)))continue}_.set(Dn(d),d),l++>100&&(await new Promise(setImmediate),l=0)}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 Eg(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=Ds(t.attributes,l),f=d.definition?.tableClass||d.elements.definition?.tableClass,E=n?.[l],h=Eg({attribute:c.length>2?c.slice(1):c[1],value:u,comparator:o},f,r,E?.[l]?.joined,c[1]===f.primaryKey,i);if(!h)return;if(E){E.filters||(E.filters=[]),E.filters.push(h);return}let p=t.propertyResolvers?.[l],S,T=a((A,b)=>{let H,F;if(p){if(p.from&&h.idFilter){if(!S)if(h.idFilter.idSet?.size===1){for(let P of h.idFilter.idSet)e={attribute:p.from,value:P};S=_(p.from,h.idFilter,!0)}else S=_(p.from,h.idFilter,!1);let v=S(A);return S.idFilter&&(T.idFilter=S.idFilter),v}F=p(A,r,b),H=F?.value}else H=A[l];return H?Array.isArray(H)?H.some(h):h(H,F):!1},"recordFilter");return T}}switch(u instanceof Date&&(u=u.getTime()),fg[o]||o){case lg.SEARCH_TYPES.EQUALS:case void 0:return _(c,l=>l===u,!0);case"contains":return _(c,l=>l?.toString().includes(u));case"ends_with":return _(c,l=>l?.toString().endsWith(u));case"starts_with":return _(c,l=>typeof l=="string"&&l.startsWith(u),!0);case"prefix":return Array.isArray(u)?u[u.length-1]==null&&(u=u.slice(0,-1)):u=[u],_(c,l=>{if(!Array.isArray(l))return!1;for(let d=0,f=u.length;d<f;d++)if(l[d]!==u[d])return!1;return!0},!0);case"between":return u[0]instanceof Date&&(u[0]=u[0].getTime()),u[1]instanceof Date&&(u[1]=u[1].getTime()),_(c,l=>(0,rs.compareKeys)(l,u[0])>=0&&(0,rs.compareKeys)(l,u[1])<=0,!0);case"gt":return _(c,l=>(0,rs.compareKeys)(l,u)>0);case"ge":return _(c,l=>(0,rs.compareKeys)(l,u)>=0);case"lt":return _(c,l=>(0,rs.compareKeys)(l,u)<0);case"le":return _(c,l=>(0,rs.compareKeys)(l,u)<=0);case"ne":return _(c,l=>(0,rs.compareKeys)(l,u)!==0);default:throw new Cs.ClientError(`Unknown query comparator "${o}"`)}function _(l,d,f){let E;f=f&&!s&&t?.indices[l]&&i>3,f&&(e.estimated_count==null&&Ef(t)(e),E=e.estimated_count>>4,(isNaN(E)||E>=i)&&(f=!1));let h=0,p=3;function S(T){let A=T[l],b;if(typeof A!="object"||!A?b=d(A):Array.isArray(A)?b=A.some(d):A instanceof Date&&(b=d(A.getTime())),f&&(p++,!b&&!S.idFilter&&++h/p*(i-p)>E)){let H=Oa(e,r.transaction.getReadTxn(),!1,t).map(Dn),F=new Set(H);S.idFilter=v=>F.has(Dn(v)),S.idFilter.idSet=F}return b}return a(S,"recordFilter"),s&&(S.idFilter=d),S}a(_,"attributeComparator")}function Ef(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/hi(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=fg[n]||n,n===lg.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=Ds(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=Ef(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"});r.estimated_count=c*hi(e.indices[i.relationship.from]||e.primaryStore)/(hi(o.primaryStore)||1)}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=hi(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=d7*hi(e.primaryStore)+1:n==="between"?r.estimated_count=_7*hi(e.primaryStore)+1:r.estimated_count=l7*hi(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=4)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function hf(e){if(e)if(mi=e,Ra.lastIndex=0,m7.test(e))try{let t=Vu(new Aa,"");if(mr!==mi.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 ${mr} in '${mi}'`,t}else{let t=new URLSearchParams(e);return t.conditions=t,t}}function Vu(e,t){let r=Ra,n,s,i,o,c,u=decodeURIComponent,_;for(;n=r.exec(mi);){mr=r.lastIndex;let[,l,d]=n;if(o){if(l)throw new SyntaxError(`expected operator, but encountered '${l}'`);o=!1,c=!1}else c=!0;let f;switch(d){case"=":if(s){if(l.length<=2)i=l;else throw new SyntaxError(`invalid FIQL operator ${l}`);u=nv}else{if(u=decodeURIComponent,i="equals",!l)throw new SyntaxError("attribute must be specified before equality comparator");s=$u(l)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=f7[d],u=_g[i]?nv:decodeURIComponent,!l)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=$u(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"&&sv(h,l),ff(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($u(l)),s=void 0;break;case"(":Ra.lastIndex=mr;let E=Vu(l?[]:new Aa,")");switch(l){case"":ff(e,_),e.conditions.push(E);break;case"limit":switch(E.length){case 1:e.limit=+E[0];break;case 2:e.offset=+E[0],e.limit=E[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(E[0])&&E.length===1&&!E[0].name?(e.select=E[0],e.select.asArray=!0):E.length===1?e.select=E[0]:E.length===2&&E[1]===""?e.select=E.slice(0,1):e.select=E;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=iv(E);break;default:throw new SyntaxError(`unknown query function call ${l}`)}mi[mr]===","?r.lastIndex=++mr: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");Ra.lastIndex=mr,f=Vu([],"}"),f.name=l,e.push(f),mi[mr]===","?r.lastIndex=++mr:o=!0;break;case"[":Ra.lastIndex=mr,l?(f=Vu(new Aa,"]"),f.name=l):f=Vu(e.conditions?new Aa:[],"]"),e.conditions?(ff(e,_),e.conditions.push(f),s=null):e.push(f),mi[mr]===","?r.lastIndex=++mr: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"&&sv(h,l),ff(e,_),e.conditions.push(h)}else if(l)throw new SyntaxError("no attribute or comparison specified")}else(l||e.length>0&&c)&&e.push($u(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?p7:Ra,r.lastIndex=mr),mr===mi.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function ff(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 $u(e){return e.indexOf(".")>-1?e.split(".").map($u):decodeURIComponent(e)}function nv(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(decodeURIComponent(r));if(t==="string")return decodeURIComponent(r);throw new Cs.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function sv(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new Cs.ClientError("wildcard can only be used at the end of a string")}function iv(e){let t=ov(e[0]);return e.length>1&&(t.next=iv(e.slice(1))),t}function ov(e){if(Array.isArray(e)){let t=ov(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 Dn(e){return Array.isArray(e)?e.join("\0"):e}function hi(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function S7(e,t,r){return t*r/hi(e)}var Cs,lg,rs,ug,l7,_7,d7,f7,_g,fg,m7,Ra,p7,mr,mi,Aa,mf=Oe(()=>{Cs=B(ee()),lg=B(lt()),rs=require("ordered-binary"),ug=require("lmdb"),l7=.3,_7=.1,d7=.05,f7={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},_g={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(dg,"executeConditions");a(Oa,"searchByIndex");a(Ds,"findAttribute");a(E7,"joinTo");a(h7,"joinFrom");fg={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(Eg,"filterByType");a(Ef,"estimateCondition");m7=/[()[\]|!<>.]|(=\w*=)/,Ra=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,p7=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(hf,"parseQuery");a(Vu,"parseBlock");a(ff,"assignOperator");a($u,"decodeProperty");a(nv,"typedDecoding");a(sv,"wildcardDecoding");a(iv,"toSortObject");a(ov,"toSortEntry");Aa=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(Dn,"flattenKey");a(hi,"estimatedEntryCount");a(S7,"intersectionEstimate")});function dv(e){let t={openapi:T7,info:{title:"HarperDB HTTP REST interface",version:(0,_v.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,{attributes:i,primaryKey:o,prototype:c}=n.Resource;if(o=o??"id",!o)continue;let u={},_=[];if(i)for(let{type:A,name:b}of i)u[b]=new lv(av[A],A),_.push(new pg(b,"query",u[b]));let l=Object.keys(u),d=new pg(o,"path",new lv(av.ID,"ID"));d.required=!0,d.description="primary key of record";let f=new pg("property","path",{enum:l});f.required=!0,t.components.schemas[s]=new A7(u);let E=c.post!==Resource.prototype.post||c.update,h=c.hasOwnProperty("put"),p=c.hasOwnProperty("get"),S=c.hasOwnProperty("delete"),T="/"+s+"/";E&&(t.paths[T]={},t.paths[T].post=new g7(s,r,"create a new record auto-assigning a primary key")),p&&(t.paths[T]||(t.paths[T]={}),t.paths[T].get=new hg(_,r,{200:new mg({$ref:pf+s})},"search for records by the specified property name and value")),S&&(t.paths[T]||(t.paths[T]={}),t.paths[T].delete=new uv(_,r,"delete all the records that match the provided query",{204:new cv})),T="/"+s+"/{"+o+"}",p&&(t.paths[T]={},t.paths[T].get=new hg([d],r,{200:new mg({$ref:pf+s})},"retrieve a record by its primary key")),h&&(t.paths[T]||(t.paths[T]={}),t.paths[T].put=new R7([d],r,s,"create or update the record with the URL path that maps to the record's primary key")),S&&(t.paths[T]||(t.paths[T]={}),t.paths[T].delete=new uv([d],r,"delete a record with the given primary key",{204:new cv})),p&&f.schema.enum.length>0&&(T="/"+s+"/{"+o+"}.{property}",t.paths[T]={},t.paths[T].get=new hg([d,f],r,{200:new mg({enum:l})},"used to retrieve the specified property of the specified record"))}return t}function g7(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:pf+e}}}},this.security=t,this.responses={200:{description:Sg,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function hg(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function mg(e){this.description=Sg,this.content={"application/json":{schema:e}}}function cv(){this.description="successfully processed request, no content returned to client"}function R7(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:pf+r}}}},this.responses={200:{description:Sg}}}function uv(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function A7(e){this.type="object",this.properties=e}function lv(e,t){this.type=e,this.format=t}function pg(e,t,r){this.name=e,this.in=t,this.schema=r}var _v,T7,av,pf,Sg,fv=Oe(()=>{_v=B(Ed()),T7="3.0.3",av={ID:"string",Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",Any:"string",BigInt:"integer"},pf="#/components/schemas/",Sg="successful operation";a(dv,"generateJsonApi");a(g7,"Post");a(hg,"Get");a(mg,"Response200");a(cv,"Response204");a(R7,"Put");a(uv,"Delete");a(A7,"ResourceSchema");a(lv,"Type");a(pg,"Parameter")});var Tf={};Ve(Tf,{start:()=>N7});async function b7(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream"?"CONNECT":e.method;e.search&&hf(e);let s=new _i;try{e.responseHeaders=s;let i=e.url.slice(1),o,c;if(i!==Ev){let h=Sf.getMatch(i);if(!h)return t(e);e.handlerPath=h.path,o={url:h.relativeURL,async:!0},c=h.Resource}let u=r["cache-control"];if(u){u=u.toLowerCase();let h=u.match(/max-age=(\d+)/)?.[1];h&&(e.expiresAt=h*1e3+Date.now()),u.includes("only-if-cached")&&(e.onlyIfCached=!0),u.includes("no-cache")&&(e.noCache=!0),u.includes("no-store")&&(e.noCacheStore=!0),u.includes("stale-if-error")&&(e.staleIfError=!0),u.includes("must-revalidate")&&(e.mustRevalidate=!0)}let _=await We(e,()=>{if(n==="POST"||n==="PUT"||n==="PATCH"||n==="QUERY")try{e.data=lo(r["content-type"],!0)(e.body)}catch(h){throw new Ku.ClientError(h,400)}if(e.authorize=!0,i===Ev&&n==="GET")return dv(Sf);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 Ku.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Ku.ServerError(`Method ${n} is not recognized`,501)}}),l=200,d;if(_==null)l=n==="GET"||n==="HEAD"?404:204,Tg.lastModified&&e.lastModified&&s.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d=e.lastModified){O7[0]=d;let h=String.fromCharCode(34,(Gt[0]&63)+62,(Gt[0]>>6)+(Gt[1]<<2&63)+62,(Gt[1]>>4)+(Gt[2]<<4&63)+62,(Gt[2]>>2)+62,(Gt[3]&63)+62,(Gt[3]>>6)+(Gt[4]<<2&63)+62,(Gt[4]>>4)+(Gt[5]<<4&63)+62,(Gt[5]>>2)+62,(Gt[6]&63)+62,(Gt[6]>>6)+(Gt[7]<<2&63)+62,34),p=r["if-none-match"];p&&h==p?(_?.onDone&&_.onDone(),l=304,_=void 0):s.setIfNone("ETag",h),Tg.lastModified&&s.setIfNone("Last-Modified",new Date(d).toUTCString())}e.createdResource&&(l=201),e.newLocation&&s.setIfNone("Location",e.newLocation);let f={status:l,headers:s,body:void 0},E=_?.wasLoadedFromSource?.();return E!==void 0&&(f.wasCacheMiss=E,!E&&d&&s.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||d))/1e3))),_!==void 0&&(f.body=df(_,e,f),n==="HEAD"&&(f.body=void 0)),f}catch(i){i.statusCode?i.statusCode===500?_o.warn(i):_o.info(i):_o.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=df(i.contentType?i:i.toString(),e,o),o}}function N7(e){Tg=e,!hv&&(hv=!0,Sf=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return b7(t,r)}),e.server.ws(async(t,r,n)=>{Yu++;let s=new pn;mv||(mv=!0,zc(l=>{Yu>0&&l.push({metric:"ws-connections",connections:Yu,byThread:!0})}));let i;t.on("error",l=>{i=!0,_o.warn(l)});let o;t.on("message",a(function(d){o||(o=lo(r.headers.asObject["content-type"]));let f=o(d);s.push(f)},"message"));let c;t.on("close",()=>{Yu--,en(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()}),await n;let u=r.url.slice(1),_=Sf.getMatch(u);if(en(!!_,"connection","ws","connect"),!_)t.send(di(`No resource was found to handle ${r.pathname}`,r));else{r.handlerPath=_.path,vr(h=>({count:h.count,total:Yu}),"connections",r.handlerPath,"connect","ws");let l={url:_.relativeURL,async:!0},d=_.Resource;c=(await We(r,()=>d.connect(l,s,r)))[Symbol.asyncIterator]();let E;for(;!(E=await c.next()).done;){let h=di(E.value,r);t.send(h),vr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}t.close()}))}var _o,Ku,Gt,O7,Tg,Ev,hv,Sf,mv,Yu,pv=Oe(()=>{Ea();Ts();_o=B(Y()),Ku=B(ee());mf();oc();Ki();qd();fv();Gt=new Uint8Array(8),O7=new Float64Array(Gt.buffer,0,1),Tg={},Ev="openapi";a(b7,"http");Yu=0;a(N7,"start")});var gg=g((EEe,Sv)=>{var{recordAction:gf,recordActionBinary:y7}=(Ts(),te(Jc)),w7=require("fastify-plugin"),I7=200;Sv.exports=w7(function(e,t,r){e.addHook("onResponse",async(n,s)=>{s.getResponseTime()}),e.addHook("onSend",async(n,s,i)=>{let o=s.getResponseTime(),c=performance.now(),u=s.request.routeOptions,_,l,d;u.config?.isOperation?(_=n.body?.operation,l="operation"):(_=u.url,l="fastify-route",d=u.method),gf(o,"duration",_,d,l),y7(s.raw.statusCode<400,"success",_,d,l);let f=I7;i?.pipe?(i.on("data",h=>{f+=h.length}),i.on("end",()=>{gf(performance.now()-c,"transfer",_,d,l),gf(f,"bytes-sent",_,d,l)})):(f+=i?.length||0,gf(f,"bytes-sent",_,d,l));let E=o.toFixed(3);s.header("Server-Timing",`db;dur=${E}`)}),r()},{name:"hdb-request-time"})});var bg=g((hEe,Ov)=>{var Nf=require("clone"),yf=et(),C7=J(),Of=M(),D7=Y(),Rf=require("fs"),Rg=require("joi"),{string:bf}=Rg.types(),{hdb_errors:L7,handleHDBError:Wu}=ee(),{HDB_ERROR_MSGS:M7,HTTP_STATUS_CODES:Af}=L7,{common_validators:ba}=Gn(),Tv=1e9,gv=" is required",U7=["insert","update","upsert"],Ag={database:{presence:!1,format:ba.schema_format,length:ba.schema_length},schema:{presence:!1,format:ba.schema_format,length:ba.schema_length},table:{presence:!0,format:ba.schema_format,length:ba.schema_length},action:{inclusion:{within:U7,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},P7={schema:bf.required(),table:bf.required(),action:bf.valid("insert","update","upsert")},{AWS_ACCESS_KEY:v7,AWS_SECRET:B7,AWS_BUCKET:H7,AWS_FILE_KEY:x7,REGION:F7}=Of.S3_BUCKET_AUTH_KEYS,q7={s3:{presence:!0},[`s3.${v7}`]:{presence:!0,type:"String"},[`s3.${B7}`]:{presence:!0,type:"String"},[`s3.${H7}`]:{presence:!0,type:"String"},[`s3.${x7}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${F7}`]:{presence:!0,type:"String"}},Rv=Nf(Ag);Rv.data.presence={message:gv};var Av=Nf(Ag);Av.file_path.presence={message:gv};var G7=Object.assign(Nf(Ag),q7),Og=Nf(P7);Og.csv_url=bf.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();Og.passthrough_headers=Rg.object();function k7(e){let t=yf.validateObject(e,Rv);return wf(e,t)}a(k7,"dataObject");function V7(e){let t=yf.validateBySchema(e,Rg.object(Og));return wf(e,t)}a(V7,"urlObject");function $7(e){let t=yf.validateObject(e,Av);return wf(e,t)}a($7,"fileObject");function Y7(e){let t=yf.validateObject(e,G7);return wf(e,t)}a(Y7,"s3FileObject");function wf(e,t){if(!t){let r=C7.checkGlobalSchemaTable(e.schema,e.table);if(r)return Wu(new Error,r,Af.BAD_REQUEST);if(e.operation===Of.OPERATIONS_ENUM.CSV_FILE_LOAD){try{Rf.accessSync(e.file_path,Rf.constants.R_OK|Rf.constants.F_OK)}catch(n){return n.code===Of.NODE_ERROR_CODES.ENOENT?Wu(n,`No such file or directory ${n.path}`,Af.BAD_REQUEST):n.code===Of.NODE_ERROR_CODES.EACCES?Wu(n,`Permission denied ${n.path}`,Af.BAD_REQUEST):Wu(n)}try{let n=Rf.statSync(e.file_path).size;if(n>Tv)return Wu(new Error,M7.MAX_FILE_SIZE_ERR(n,Tv),Af.BAD_REQUEST)}catch(n){D7.error(n),console.error(n)}}}return t}a(wf,"postValidateChecks");Ov.exports={dataObject:k7,urlObject:V7,fileObject:$7,s3FileObject:Y7}});var Ng=g((pEe,bv)=>{"use strict";var Qu=Y(),If=M();async function K7(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===If.OPERATIONS_ENUM.INSERT||t.operation===If.OPERATIONS_ENUM.UPDATE||t.operation===If.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===If.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(Qu.info(i.message),i):i.http_resp_msg?(Qu.error(`Error calling operation: ${e.name}`),Qu.error(i.http_resp_msg),i):(Qu.error(`Error calling operation: ${e.name}`),Qu.error(i),i)}}a(K7,"callOperationFunctionAsAwait");bv.exports={callOperationFunctionAsAwait:K7}});var yv=g((TEe,Nv)=>{"use strict";var yg=class{static{a(this,"BulkLoadFileObject")}constructor(t,r,n,s,i,o,c=null){this.op=t,this.action=r,this.schema=n,this.table=s,this.file_path=i,this.file_type=o,this.role_perms=c}},wg=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};Nv.exports={BulkLoadFileObject:yg,BulkLoadDataObject:wg}});var Iv=g((REe,wv)=>{"use strict";var Ig=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};wv.exports=Ig});var Pg=g((wEe,Yv)=>{"use strict";var Cf=jr(),Lf=bg(),W7=require("needle"),Ln=M(),OEe=tt(),Na=J(),{handleHDBError:nt,hdb_errors:Hv}=ee(),{HTTP_STATUS_CODES:kt,HDB_ERROR_MSGS:bt,CHECK_LOGS_WRAPPER:Eo}=Hv,ya=Y(),Cg=require("papaparse");Na.promisifyPapaParse();var Mn=require("fs-extra"),Q7=require("path"),{chain:Cv}=require("stream-chain"),Dv=require("stream-json/streamers/StreamArray"),Lv=require("stream-json/utils/Batch"),Mv=require("stream-chain/utils/comp"),{finished:Uv}=require("stream"),z7=Z(),xv=Ng(),J7=eg(),{BulkLoadFileObject:Lg,BulkLoadDataObject:X7}=yv(),Mg=$T(),{verifyBulkLoadAttributePerms:Fv}=of(),bEe=Iv(),NEe=Rt(),yEe=Es(),{databases:j7}=(be(),te(Fe)),{coerceType:Z7}=(Mf(),te(vg)),Pv="No records parsed from csv file.",fo=`${z7.get("HDB_ROOT")}/tmp`,{schema_regex:eee}=Gn(),vv=1024*1024*2,Bv=5e3,tee={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};Yv.exports={csvDataLoad:ree,csvURLLoad:nee,csvFileLoad:see,importFromS3:iee};async function ree(e,t){let r=Lf.dataObject(e);if(r)throw nt(r,r.message,kt.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=kv(e.schema,e.table),i=Cg.parse(e.data,{header:!0,skipEmptyLines:!0,transform:Dg.bind(null,s),dynamicTyping:!1}),o=new Mg;e.hdb_user&&e.hdb_user.role&&e.hdb_user.role.permission&&e.hdb_user.role.permission.super_user!==!0&&Fv(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 nt(new Error,c,kt.BAD_REQUEST,void 0,void 0,!0);let u=new X7(e.action,e.schema,e.table,i.data);return n=await xv.callOperationFunctionAsAwait(Vv,u,null),n.message===Pv?Pv:$v(n.records,n.number_written)}catch(s){throw ho(s)}}a(ree,"csvDataLoad");async function nee(e){let t=Lf.urlObject(e);if(t)throw nt(t,t.message,kt.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${fo}/${r}`;try{await oee(e,r)}catch(s){throw ya.error(bt.DOWNLOAD_FILE_ERR(r)+" - "+s),nt(s,Eo(bt.DOWNLOAD_FILE_ERR(r)))}try{let s=new Lg(this.job_operation_function.name,e.action,e.schema,e.table,n,Ln.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission),i=await Ug(s);return await Df(n),i}catch(s){throw await Df(n),ho(s)}}a(nee,"csvURLLoad");async function see(e){let t=Lf.fileObject(e);if(t)throw nt(t,t.message,kt.BAD_REQUEST,void 0,void 0,!0);let r=new Lg(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,Ln.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission);try{return await Ug(r)}catch(n){throw ho(n)}}a(see,"csvFileLoad");async function iee(e){let t=Lf.s3FileObject(e);if(t)throw nt(t,t.message,kt.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=Q7.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${fo}/${s}`;let i=new Lg(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user.role.permission);await aee(s,e);let o=await Ug(i);return await Df(r),o}catch(n){throw await Df(r),ho(n)}}a(iee,"importFromS3");async function oee(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await W7("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 nt(n,s,n.statusCode,Ln.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}uee(r,e.csv_url),await cee(t,r.raw)}a(oee,"downloadCSVFile");async function aee(e,t){try{let r=`${fo}/${e}`;await Mn.mkdirp(fo),await Mn.writeFile(`${fo}/${e}`,"",{flag:"a+"});let n=await Mn.createWriteStream(r),s=await J7.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(){ya.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw ya.error(bt.S3_DOWNLOAD_ERR+" - "+r),nt(r,Eo(bt.S3_DOWNLOAD_ERR))}}a(aee,"downloadFileFromS3");async function cee(e,t){try{await Mn.mkdirp(fo),await Mn.writeFile(`${fo}/${e}`,t)}catch(r){throw ya.error(bt.WRITE_TEMP_FILE_ERR),nt(r,Eo(bt.DEFAULT_BULK_LOAD_ERR))}}a(cee,"writeFileToTempFolder");async function Df(e){if(e)try{await Mn.access(e),await Mn.unlink(e)}catch{ya.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(Df,"deleteTempFile");function uee(e,t){if(e.statusCode!==Hv.HTTP_STATUS_CODES.OK)throw nt(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,kt.BAD_REQUEST);if(!tee[e.headers["content-type"]])throw nt(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,kt.BAD_REQUEST);if(!e.raw)throw nt(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,kt.BAD_REQUEST)}a(uee,"validateURLResponse");async function Ug(e){try{let t;switch(e.file_type){case Ln.VALID_S3_FILE_TYPES.CSV:t=await lee(e);break;case Ln.VALID_S3_FILE_TYPES.JSON:t=await _ee(e);break;default:throw nt(new Error,bt.DEFAULT_BULK_LOAD_ERR,kt.BAD_REQUEST,Ln.LOG_LEVELS.ERROR,bt.INVALID_FILE_EXT_ERR(e))}return $v(t.records,t.number_written)}catch(t){throw ho(t)}}a(Ug,"fileLoad");async function qv(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 Cf.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&Fv(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let u=nt(c);r(u)}}a(qv,"validateChunk");async function Gv(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Na.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Na.isEmpty(c)&&!Na.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 xv.callOperationFunctionAsAwait(Vv,c,null);t.records+=u.records,t.number_written+=u.number_written,s&&s.resume()}catch(c){let u=nt(c,Eo(bt.INSERT_CSV_ERR),kt.INTERNAL_SERVER_ERROR,Ln.LOG_LEVELS.ERROR,bt.INSERT_CSV_ERR+" - "+c);r(u)}}a(Gv,"insertChunk");async function lee(e){let t={records:0,number_written:0},r=kv(e.schema,e.table);try{let n=new Mg,s=Mn.createReadStream(e.file_path,{highWaterMark:vv});s.setEncoding("utf8"),await Cg.parsePromise(s,qv.bind(null,e,n),Dg.bind(null,r));let i=n.getPermsResponse();if(i)throw nt(new Error,i,kt.BAD_REQUEST);return s=Mn.createReadStream(e.file_path,{highWaterMark:vv}),s.setEncoding("utf8"),await Cg.parsePromise(s,Gv.bind(null,e,t),Dg.bind(null,r)),s.destroy(),t}catch(n){throw nt(n,Eo(bt.PAPA_PARSE_ERR),kt.INTERNAL_SERVER_ERROR,Ln.LOG_LEVELS.ERROR,bt.PAPA_PARSE_ERR+n)}}a(lee,"callPapaParse");function kv(e,t){let r=j7[e][t].attributes,n=new Map;for(let s of r)s.type&&n.set(s.name,i=>Z7(i,s));return n}a(kv,"createTransformMap");function Dg(e,t,r){let n=e.get(r);return n?n(t):Na.autoCast(t)}a(Dg,"typeFunction");async function _ee(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new Mg,s=Cv([Mn.createReadStream(e.file_path,{encoding:"utf-8"}),Dv.withParser(),c=>c.value,new Lv({batchSize:Bv}),Mv(async c=>{await qv(e,n,r,c)})]);await new Promise((c,u)=>{Uv(s,_=>{_?u(_):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw nt(new Error,i,kt.BAD_REQUEST);let o=Cv([Mn.createReadStream(e.file_path,{encoding:"utf-8"}),Dv.withParser(),c=>c.value,new Lv({batchSize:Bv}),Mv(async c=>{await Gv(e,t,r,c)})]);return await new Promise((c,u)=>{Uv(o,_=>{_?u(_):c()}),o.resume()}),t}catch(n){throw nt(n,Eo(bt.INSERT_JSON_ERR),kt.INTERNAL_SERVER_ERROR,Ln.LOG_LEVELS.ERROR,bt.INSERT_JSON_ERR+n)}}a(_ee,"insertJson");async function Vv(e){let t={};try{e.data&&e.data.length>0&&dee(e.data[0])?t=await fee(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",ya.info(t.message))}catch(r){throw ho(r)}return t}a(Vv,"callBulkFileLoad");function dee(e){let t=Object.keys(e);for(let r of t)if(!eee.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(dee,"validateColumnNames");async function fee(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=Cf.insert;break;case"update":i=Cf.update;break;case"upsert":i=Cf.upsert;break;default:throw nt(new Error,bt.INVALID_ACTION_PARAM_ERR(n),kt.BAD_REQUEST,Ln.LOG_LEVELS.ERROR,bt.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=Na.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:u,new_attributes:o.new_attributes}}catch(o){throw ho(o)}}a(fee,"bulkFileLoad");function $v(e,t){return`successfully loaded ${t} of ${e} records`}a($v,"buildResponseMsg");function ho(e){return nt(e,Eo(bt.DEFAULT_BULK_LOAD_ERR),kt.INTERNAL_SERVER_ERROR,Ln.LOG_LEVELS.ERROR,bt.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(ho,"buildTopLevelErrMsg")});var Wv=g((CEe,Kv)=>{"use strict";var Bg=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};Kv.exports=Bg});var Jv=g((LEe,zv)=>{"use strict";var Eee=M(),Qv=require("moment"),hee=require("uuid").v4,Hg=class{static{a(this,"JobObject")}constructor(){this.id=hee(),this.type=void 0,this.start_datetime=Qv().valueOf(),this.created_datetime=Qv().valueOf(),this.end_datetime=void 0,this.status=Eee.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};zv.exports=Hg});var xg=g((UEe,r0)=>{"use strict";var mee=require("uuid").v4,Zv=jr(),e0=Xr(),pee=Kn(),See=zo(),Tee=Wv(),st=M(),gee=Jv(),Ree=TS(),un=Y(),Aee=gc(),wa=J(),{promisify:Oee}=require("util"),mo=require("moment"),bee=cf(),Uf=bg(),Xv=Em(),{deleteTransactionLogsBeforeValidator:Nee}=FT(),{handleHDBError:yee,hdb_errors:wee}=ee(),{HTTP_STATUS_CODES:Iee}=wee,jv=e0.searchByValue,Cee=e0.searchByHash,Dee=Zv.insert,Lee=Oee(bee.evaluateSQL),Mee=Zv.update;r0.exports={addJob:vee,updateJob:Hee,handleGetJob:Uee,handleGetJobsByStartDate:Pee,getJobById:t0};async function Uee(e){try{let t=await t0(e.id);return wa.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 un.error("There was an error getting job",t),new Error(r)}}a(Uee,"handleGetJob");async function Pee(e){try{let t=await Bee(e);if(un.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=mo(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=mo(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 un.error(r),new Error(r)}}a(Pee,"handleGetJobsByStartDate");async function vee(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||wa.isEmptyOrZeroLength(e.operation)){let l="job parameter is invalid";return un.info(l),t.error=l,t}if(!st.JOB_TYPE_ENUM[e.operation])return un.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case st.OPERATIONS_ENUM.CSV_FILE_LOAD:n=Uf.fileObject(e);break;case st.OPERATIONS_ENUM.CSV_URL_LOAD:n=Uf.urlObject(e);break;case st.OPERATIONS_ENUM.CSV_DATA_LOAD:n=Uf.dataObject(e);break;case st.OPERATIONS_ENUM.IMPORT_FROM_S3:n=Uf.s3FileObject(e);break;case st.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case st.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=Xv(e,"date");break;case st.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=Xv(e,"timestamp");break;case st.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=Nee(e);break;default:break}if(n)throw yee(n,n.message,Iee.BAD_REQUEST,void 0,void 0,!0);let s=new gee;s.type=e.operation===st.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?st.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user.username;let i=new pee(st.SYSTEM_SCHEMA_NAME,st.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await jv(i))}catch(l){let d=`There was an error inserting a new job: ${l}`;return un.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=mee();try{o=await jv(i)}catch(l){let d=`There was an error inserting a new job: ${l}`;return un.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return un.error("Error creating a job, could not find a unique job id."),t}s.request=e;let u=new Aee(st.SYSTEM_SCHEMA_NAME,st.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),_;try{_=await Dee(u)}catch(l){return un.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,un.trace(l)}return t}a(vee,"addJob");async function Bee(e){let t=mo(e.from_date,mo.ISO_8601),r=mo(e.to_date,mo.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 Tee(n,e.hdb_user);try{return await Lee(s)}catch(i){throw un.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(Bee,"getJobsInDateRange");async function t0(e){if(wa.isEmptyOrZeroLength(e))return wa.errorizeMessage("Invalid job ID specified.");let t=new See(st.SYSTEM_SCHEMA_NAME,st.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await Cee(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return un.error(n),wa.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(t0,"getJobById");async function Hee(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(wa.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===st.JOB_STATUS_ENUM.COMPLETE||e.status===st.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=mo().valueOf());let t=new Ree(st.SYSTEM_SCHEMA_NAME,st.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await Mee(t),r}a(Hee,"updateJob")});var c0=g((vEe,a0)=>{"use strict";var n0=J(),pr=M(),xee=require("moment"),Pf=Pg(),vf=Y(),s0=xg(),i0=uf(),o0=Bi(),Fee=je(),qee=tf(),Fg=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function Gee(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(n0.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(n0.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case pr.JOB_TYPE_ENUM.csv_file_load:await Ls(e,Pf.csvFileLoad);break;case pr.JOB_TYPE_ENUM.csv_url_load:await Ls(e,Pf.csvURLLoad);break;case pr.JOB_TYPE_ENUM.csv_data_load:await Ls(e,Pf.csvDataLoad);break;case pr.JOB_TYPE_ENUM.import_from_s3:await Ls(e,Pf.importFromS3);break;case pr.JOB_TYPE_ENUM.empty_trash:break;case pr.JOB_TYPE_ENUM.export_local:await Ls(e,i0.export_local);break;case pr.JOB_TYPE_ENUM.export_to_s3:await Ls(e,i0.export_to_s3);break;case pr.JOB_TYPE_ENUM.delete_files_before:case pr.JOB_TYPE_ENUM.delete_records_before:await Ls(e,o0.deleteFilesBefore);break;case pr.JOB_TYPE_ENUM.delete_audit_logs_before:await Ls(e,o0.deleteAuditLogsBefore);break;case pr.JOB_TYPE_ENUM.delete_transaction_logs_before:await Ls(e,qee.deleteTransactionLogsBefore);break;default:return`Invalid operation ${e.json.operation} specified`}}a(Gee,"parseMessage");async function Ls(e,t){try{e.job.status=pr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=xee().valueOf(),await s0.updateJob(e.job),await kee(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):vf.error(`There was an error running ${t.name} job with id ${e.job.id}`),vf.error(n),e.job.message=n,e.job.status=pr.JOB_STATUS_ENUM.ERROR;try{await s0.updateJob(e.job)}catch(s){throw vf.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Ls,"runJob");async function kee(e){vf.trace("launching job thread:",e),Fee.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:Object.assign({},process.env,{[pr.PROCESS_NAME_ENV_PROP]:`JOB-${e}`})})}a(kee,"launchJobThread");a0.exports={parseMessage:Gee,RunnerMessage:Fg}});var l0=g((HEe,u0)=>{"use strict";var qg=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};u0.exports=qg});var w0=g((FEe,Kg)=>{"use strict";var Ff=Xr(),Vg=cf(),Bf=Pg(),Ms=rd(),Hf=Li(),Ju=Bi(),Vee=sS(),zu=Zr(),xf=fS(),Vt=xT(),Nt=Y(),$ee=mS(),Yee=Td(),_0=jS(),Kee=Rd(),Wee=ZS(),Qee=eT(),zee=nT(),Jee=iT(),Gg=cT(),d0=uf(),Xee=of(),$g=xg(),q=M(),{hdb_errors:ju,handleHDBError:Xu}=ee(),{HTTP_STATUS_CODES:f0}=ju,kg=fT(),E0=xd(),O0=require("util"),Ia=jr(),jee=Ws(),Zee=oa(),h0=c0(),m0=cu(),p0=($d(),te(Iu)),S0=Dr(),T0=tf(),g0=zd(),{setServerUtilities:ete}=(Mf(),te(vg)),{CONTEXT:tte}=(Sn(),te(up)),{_assignPackageExport:rte}=require("../../index"),{transformReq:nte}=J(),{server:ste}=(Zt(),te(bi)),ite=Ng(),R0=Ff.searchByHash,ote=Ff.searchByValue,ate=O0.promisify(Ff.search),cte=O0.promisify(Vg.evaluateSQL),ute={[q.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[q.OPERATIONS_ENUM.CREATE_TABLE]:!0,[q.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[q.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[q.OPERATIONS_ENUM.DROP_TABLE]:!0,[q.OPERATIONS_ENUM.DROP_SCHEMA]:!0},V=l0();async function b0(e,t){try{if(e.body.operation!=="read_log"&&(Nt.log_level===q.LOG_LEVELS.INFO||Nt.log_level===q.LOG_LEVELS.DEBUG||Nt.log_level===q.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,...o}=e.body;Nt.info(o)}}catch(n){Nt.error(n)}let r=await ite.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return ute[e.body.operation]&&jee.setSchemaDataToGlobal(n=>{n&&Nt.error(n)}),r}a(b0,"processLocalTransaction");var A0=_te();Kg.exports={chooseOperation:N0,getOperationFunction:y0,operation:Yg,processLocalTransaction:b0};ete(Kg.exports);ste.operation=Yg;function N0(e){let t;try{t=y0(e)}catch(s){throw Nt.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=Vg.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=Vg.checkASTPermissions(e,i);if(o)throw Nt.error(`${f0.FORBIDDEN} from operation ${e.operation}`),Nt.warn(`User '${e.hdb_user.username}' is not permitted to ${e.operation}`),Xu(new Error,o,ju.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==q.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==q.OPERATIONS_ENUM.LOGIN&&e.operation!==q.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=Xee.verifyPerms(i,s);if(o)throw Nt.error(`${f0.FORBIDDEN} from operation ${e.operation}`),Nt.warn(`User '${i.hdb_user.username}' is not permitted to ${i.operation}`),Xu(new Error,o,ju.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw Xu(s,"There was an error when trying to choose an operation path")}return r}a(N0,"chooseOperation");function y0(e){if(Nt.trace(`getOperationFunction with operation: ${e.operation}`),A0.has(e.operation))return A0.get(e.operation);throw Xu(new Error,ju.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),ju.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(y0,"getOperationFunction");rte("operation",Yg);function Yg(e,t){e.hdb_user=this[tte]?.user,e.bypass_auth=!t;let r=N0(e);return b0({body:e},r)}a(Yg,"operation");async function lte(e){Nt.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[q.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case q.OPERATIONS_ENUM.INSERT:o=await Ia.insert(i);break;case q.OPERATIONS_ENUM.UPDATE:o=await Ia.update(i);break;case q.OPERATIONS_ENUM.UPSERT:o=await Ia.upsert(i);break;case q.OPERATIONS_ENUM.DELETE:o=await Ju.deleteRecord(i);break;default:Nt.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){Nt.info("Invalid operation in transaction"),Nt.error(o)}}a(lte,"catchup");async function ns(e){nte(e);let t,r;try{r=await $g.addJob(e),t=r.createdJob,Nt.info("addJob result",r);let n=new h0.RunnerMessage(t,e);return await h0.parseMessage(n),{message:`Starting job with id ${t.id}`,job_id:t.id}}catch(n){let s=`There was an error executing job: ${n.http_resp_msg?n.http_resp_msg:n}`;throw Nt.error(s),Xu(n,s)}}a(ns,"executeJob");function _te(){let e=new Map;return e.set(q.OPERATIONS_ENUM.INSERT,new V(Ia.insert)),e.set(q.OPERATIONS_ENUM.UPDATE,new V(Ia.update)),e.set(q.OPERATIONS_ENUM.UPSERT,new V(Ia.upsert)),e.set(q.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new V(Ff.searchByConditions)),e.set(q.OPERATIONS_ENUM.SEARCH_BY_HASH,new V(R0)),e.set(q.OPERATIONS_ENUM.SEARCH_BY_ID,new V(R0)),e.set(q.OPERATIONS_ENUM.SEARCH_BY_VALUE,new V(ote)),e.set(q.OPERATIONS_ENUM.SEARCH,new V(ate)),e.set(q.OPERATIONS_ENUM.SQL,new V(cte)),e.set(q.OPERATIONS_ENUM.CSV_DATA_LOAD,new V(ns,Bf.csvDataLoad)),e.set(q.OPERATIONS_ENUM.CSV_FILE_LOAD,new V(ns,Bf.csvFileLoad)),e.set(q.OPERATIONS_ENUM.CSV_URL_LOAD,new V(ns,Bf.csvURLLoad)),e.set(q.OPERATIONS_ENUM.IMPORT_FROM_S3,new V(ns,Bf.importFromS3)),e.set(q.OPERATIONS_ENUM.CREATE_SCHEMA,new V(Ms.createSchema)),e.set(q.OPERATIONS_ENUM.CREATE_DATABASE,new V(Ms.createSchema)),e.set(q.OPERATIONS_ENUM.CREATE_TABLE,new V(Ms.createTable)),e.set(q.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new V(Ms.createAttribute)),e.set(q.OPERATIONS_ENUM.DROP_SCHEMA,new V(Ms.dropSchema)),e.set(q.OPERATIONS_ENUM.DROP_DATABASE,new V(Ms.dropSchema)),e.set(q.OPERATIONS_ENUM.DROP_TABLE,new V(Ms.dropTable)),e.set(q.OPERATIONS_ENUM.DROP_ATTRIBUTE,new V(Ms.dropAttribute)),e.set(q.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new V(Hf.describeSchema)),e.set(q.OPERATIONS_ENUM.DESCRIBE_DATABASE,new V(Hf.describeSchema)),e.set(q.OPERATIONS_ENUM.DESCRIBE_TABLE,new V(Hf.describeTable)),e.set(q.OPERATIONS_ENUM.DESCRIBE_ALL,new V(Hf.describeAll)),e.set(q.OPERATIONS_ENUM.DELETE,new V(Ju.deleteRecord)),e.set(q.OPERATIONS_ENUM.ADD_USER,new V(zu.addUser)),e.set(q.OPERATIONS_ENUM.ALTER_USER,new V(zu.alterUser)),e.set(q.OPERATIONS_ENUM.DROP_USER,new V(zu.dropUser)),e.set(q.OPERATIONS_ENUM.LIST_USERS,new V(zu.listUsersExternal)),e.set(q.OPERATIONS_ENUM.LIST_ROLES,new V(xf.listRoles)),e.set(q.OPERATIONS_ENUM.ADD_ROLE,new V(xf.addRole)),e.set(q.OPERATIONS_ENUM.ALTER_ROLE,new V(xf.alterRole)),e.set(q.OPERATIONS_ENUM.DROP_ROLE,new V(xf.dropRole)),e.set(q.OPERATIONS_ENUM.USER_INFO,new V(zu.userInfo)),e.set(q.OPERATIONS_ENUM.READ_LOG,new V($ee)),e.set(q.OPERATIONS_ENUM.ADD_NODE,new V(Yee)),e.set(q.OPERATIONS_ENUM.UPDATE_NODE,new V(_0)),e.set(q.OPERATIONS_ENUM.SET_NODE_REPLICATION,new V(_0)),e.set(q.OPERATIONS_ENUM.REMOVE_NODE,new V(Kee)),e.set(q.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new V(Wee)),e.set(q.OPERATIONS_ENUM.PURGE_STREAM,new V(Qee)),e.set(q.OPERATIONS_ENUM.SET_CONFIGURATION,new V(S0.setConfiguration)),e.set(q.OPERATIONS_ENUM.CLUSTER_STATUS,new V(zee.clusterStatus)),e.set(q.OPERATIONS_ENUM.CLUSTER_NETWORK,new V(Jee)),e.set(q.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new V(Gg.setRoutes)),e.set(q.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new V(Gg.getRoutes)),e.set(q.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new V(Gg.deleteRoutes)),e.set(q.OPERATIONS_ENUM.EXPORT_TO_S3,new V(ns,d0.export_to_s3)),e.set(q.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new V(ns,Ju.deleteFilesBefore)),e.set(q.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new V(ns,Ju.deleteFilesBefore)),e.set(q.OPERATIONS_ENUM.EXPORT_LOCAL,new V(ns,d0.export_local)),e.set(q.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new V($g.handleGetJobsByStartDate)),e.set(q.OPERATIONS_ENUM.GET_JOB,new V($g.handleGetJob)),e.set(q.OPERATIONS_ENUM.GET_FINGERPRINT,new V(kg.getFingerprint)),e.set(q.OPERATIONS_ENUM.SET_LICENSE,new V(kg.setLicense)),e.set(q.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new V(kg.getRegistrationInfo)),e.set(q.OPERATIONS_ENUM.RESTART,new V(E0.restart)),e.set(q.OPERATIONS_ENUM.RESTART_SERVICE,new V(E0.restartService)),e.set(q.OPERATIONS_ENUM.CATCHUP,new V(lte)),e.set(q.OPERATIONS_ENUM.SYSTEM_INFORMATION,new V(Zee.systemInformation)),e.set(q.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new V(ns,Ju.deleteAuditLogsBefore)),e.set(q.OPERATIONS_ENUM.READ_AUDIT_LOG,new V(Vee)),e.set(q.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new V(m0.createTokens)),e.set(q.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new V(m0.refreshOperationToken)),e.set(q.OPERATIONS_ENUM.LOGIN,new V(p0.login)),e.set(q.OPERATIONS_ENUM.LOGOUT,new V(p0.logout)),e.set(q.OPERATIONS_ENUM.GET_CONFIGURATION,new V(S0.getConfiguration)),e.set(q.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new V(Vt.customFunctionsStatus)),e.set(q.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new V(Vt.getCustomFunctions)),e.set(q.OPERATIONS_ENUM.GET_COMPONENT_FILE,new V(Vt.getComponentFile)),e.set(q.OPERATIONS_ENUM.GET_COMPONENTS,new V(Vt.getComponents)),e.set(q.OPERATIONS_ENUM.SET_COMPONENT_FILE,new V(Vt.setComponentFile)),e.set(q.OPERATIONS_ENUM.DROP_COMPONENT,new V(Vt.dropComponent)),e.set(q.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new V(Vt.getCustomFunction)),e.set(q.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new V(Vt.setCustomFunction)),e.set(q.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new V(Vt.dropCustomFunction)),e.set(q.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new V(Vt.addComponent)),e.set(q.OPERATIONS_ENUM.ADD_COMPONENT,new V(Vt.addComponent)),e.set(q.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new V(Vt.dropCustomFunctionProject)),e.set(q.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new V(Vt.packageComponent)),e.set(q.OPERATIONS_ENUM.PACKAGE_COMPONENT,new V(Vt.packageComponent)),e.set(q.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new V(Vt.deployComponent)),e.set(q.OPERATIONS_ENUM.DEPLOY_COMPONENT,new V(Vt.deployComponent)),e.set(q.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new V(T0.readTransactionLog)),e.set(q.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new V(ns,T0.deleteTransactionLogsBefore)),e.set(q.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new V(g0.installModules)),e.set(q.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new V(g0.auditModules)),e.set(q.OPERATIONS_ENUM.GET_BACKUP,new V(Ms.getBackup)),e}a(_te,"initializeOperationFunctionMap")});var Gf=g((GEe,D0)=>{"use strict";var Wg=M(),dte=J(),Zu=Y(),{handleHDBError:Qg,hdb_errors:qf}=ee(),{isMainThread:fte}=require("worker_threads"),{Readable:Ete}=require("stream"),I0=require("os"),hte=require("util"),mte=wS(),pte=hte.promisify(mte.authorize),C0=w0(),{createGzip:Ste,constants:Tte}=require("zlib");function gte(e){let t=`Found an uncaught exception with message: ${e.message}. ${I0.EOL}Stack: ${e.stack} ${I0.EOL}Terminating ${fte?"HDB":"thread"}.`;console.error(t),Zu.fatal(t),process.exit(1)}a(gte,"handleServerUncaughtException");function Rte(e,t,r){if(Zu[e.logLevel||"error"](e),e.statusCode)return typeof e.http_resp_msg!="object"?r.code(e.statusCode).send({error:e.http_resp_msg||e.message}):r.code(e.statusCode).send(e.http_resp_msg);let n=e.statusCode?e.statusCode:qf.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR;return typeof e=="string"?r.code(n).send({error:e}):r.code(n).send(e.message?{error:e.message}:e)}a(Rte,"serverErrorHandler");function Ate(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=Qg(new Error,"Invalid JSON.",qf.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(dte.isEmpty(e.body.operation)){let n=Qg(new Error,"Request body must include an 'operation' property.",qf.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Ate,"reqBodyValidationHandler");function Ote(e,t,r){let n;e.body.operation!==Wg.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==Wg.OPERATIONS_ENUM.LOGIN&&e.body.operation!==Wg.OPERATIONS_ENUM.LOGOUT?pte(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{Zu.warn(s),Zu.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r(Qg(s,i,qf.HTTP_STATUS_CODES.UNAUTHORIZED),null)}):(e.body.hdb_user=null,e.body.hdb_auth_header=e.headers.authorization,e.body.baseRequest=e.raw?.baseRequest,e.body.baseResponse=t.raw?.baseResponse,e.body.fastifyResponse=t,r())}a(Ote,"authHandler");async function bte(e,t,r=!1){let n;try{r&&(e.body.operation!=="configure_cluster"||e.body.operation!=="set_configuration")&&(e.body.bypass_auth=r),n=C0.chooseOperation(e.body);let s=await C0.processLocalTransaction(e,n);if(s instanceof Ete&&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(Ste({level:Tte.Z_BEST_SPEED})))}return s}catch(s){throw Zu.error(s),s}}a(bte,"handlePostRequest");D0.exports={authHandler:Ote,handlePostRequest:bte,handleServerUncaughtException:gte,serverErrorHandler:Rte,reqBodyValidationHandler:Ate}});var P0=g((VEe,U0)=>{"use strict";var Nte=require("fastify-plugin"),{handlePostRequest:L0,authHandler:yte,reqBodyValidationHandler:wte}=Gf();async function Ite(e){e.decorate("hdbCore",{preValidation:[wte,yte],request:t=>M0(L0(t,response)),requestWithoutAuthentication:(t,r)=>M0(L0(t,r,!0))})}a(Ite,"hdbCore");async function M0(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(M0,"convertAsyncIterators");U0.exports=Nte(Ite)});var H0=g((KEe,B0)=>{"use strict";var YEe=require("fs"),zg=Z();zg.initSync();var{CONFIG_PARAMS:v0}=M(),Cte=1024*1024*1024;function Dte(e){let t=zg.get(v0.HTTP_TIMEOUT),r=zg.get(v0.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:Cte,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,https:e}}a(Dte,"getServerOptions");B0.exports=Dte});var q0=g((QEe,F0)=>{"use strict";var Jg=Z();Jg.initSync();var{CONFIG_PARAMS:x0}=M();function Lte(){let e=Jg.get(x0.HTTP_CORSACCESSLIST),t=Jg.get(x0.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(Lte,"getCORSOptions");F0.exports=Lte});var V0=g((JEe,k0)=>{"use strict";var G0=Z();G0.initSync();var Mte=M();function Ute(){return G0.get(Mte.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(Ute,"getHeaderTimeoutConfig");k0.exports=Ute});var jg={};Ve(jg,{customFunctionsServer:()=>Bte,ready:()=>sB,start:()=>vte});function vte(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){Us||(Us=nB(t),Xe.http((await Us).server));let o=await Us,c=(0,Xg.dirname)(s),u=(0,Xg.dirname)(n);if(u.startsWith("/")&&(u=u.slice(1)),!$0.has(c)){$0.add(c);try{o.register(xte(c,u))}catch(_){if(_.message==="Root plugin has already booted")Ge.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw _}}},ready:sB}}async function Bte(){try{Ge.info("In Custom Functions Fastify server"+process.cwd()),Ge.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Ge.debug(`Custom Functions server process ${process.pid} starting up.`),await Hte();let e=J0.get(X0.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=Us=await nB(e)}catch(r){throw Ge.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw Ge.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){Ge.error(`Custom Functions ${process.pid} Error: ${e}`),Ge.error(e),process.exit(1)}}async function Hte(){try{Ge.info("Custom Functions starting configuration."),await j0.setUsersToGlobal(),Ge.info("Custom Functions completed configuration.")}catch(e){Ge.error(e)}}function xte(e,t){return async function(r){try{Ge.info("Custom Functions starting buildRoutes"),Ge.trace("Loading fastify routes folder "+e),(0,Y0.existsSync)(e)&&r.register(z0.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:Ge.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?Ge.error(s.message):s&&Ge.error(s),o()})}catch(n){Ge.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function nB(e){Ge.info("Custom Functions starting buildServer.");let t=(0,Z0.default)(e),r=(0,K0.default)(t);r.server.headersTimeout=(0,tB.default)(),r.setErrorHandler(rB.serverErrorHandler);let n=(0,eB.default)();return n&&r.register(W0.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,u){r.server.emit("unhandled",c.raw,u.raw)}),o()}),r.register(Q0.default),await r.register(Pte),await r.after(),cg(r),Ge.info("Custom Functions completed buildServer."),r}function sB(){if(Us)return Us.then?Us.then(e=>e.ready()):Us.ready()}var Xg,Y0,K0,W0,Q0,z0,J0,X0,Ge,Pte,j0,Z0,eB,tB,rB,Us,$0,iB=Oe(()=>{Xg=require("path"),Y0=require("fs"),K0=B(require("fastify")),W0=B(require("@fastify/cors")),Q0=B(gg()),z0=B(require("@fastify/autoload")),J0=B(Z()),X0=B(M()),Ge=B(Y()),Pte=B(P0()),j0=B(Zr()),Z0=B(H0()),eB=B(q0()),tB=B(V0()),rB=B(Gf());Ea();Zt();$0=new Set;a(vte,"start");a(Bte,"customFunctionsServer");a(Hte,"setUp");a(xte,"buildRouteFolder");a(nB,"buildServer");a(sB,"ready")});var Zg={};Ve(Zg,{start:()=>Fte});function Fte(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,lB.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){aB||(aB=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=oB.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,cB.default)(s,(0,uB.realpathSync)(o))}}return i(s)},{runFirst:!0})),oB.set(r,n)}}}var cB,uB,lB,oB,aB,_B=Oe(()=>{cB=B(require("send")),uB=require("fs"),lB=B(require("serve-static")),oB=new Map;a(Fte,"start")});function kte(e,t=1,r){if(eR++,(0,po.startWorker)("server/threads/threadServer.js",{name:$f.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function u(_){_.type===$f.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",u),o(n))}a(u,"onMessage"),n.on("message",u),n.on("error",c)});Gte.push(s),await s,Ca.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=Vf.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Ca.indexOf(n);o>-1&&Ca.splice(o,1)}if(a(i,"removeWorker"),Da){let o=Da;Da=[];for(let c of o)hB[c.localPort](null,c)}}}),r){let n=setInterval(()=>{tR?tR=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,po.shutdownWorkers)(),eR=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function mB(e=0,t){if(typeof e=="string")try{(0,Yf.existsSync)(e)&&(0,Yf.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=Vte:r=$te(t):r=nR;let n=(0,La.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=hB[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),tR=!0,r(o,(c,u)=>{if(!c){if(dB){let l=o._socket||new La.Socket({handle:o,writable:!0,readable:!0});dB.deliverSocket(l,e,u),l.resume()}else eR>0?(Da.length===0&&setTimeout(()=>{Da.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,Da.push(o)):(console.log("start up a dynamic thread to handle request"),kte(0));vr(!1,"socket-routed");return}c.requests++;let _=o.fd;if(_>=0)c.postMessage({port:e,fd:_,data:u});else{let l=o._socket||new La.Socket({handle:o,writable:!0,readable:!0});Qte(l,c,e)}vr(!0,"socket-routed")})};let s=Kc();rR.info(`HarperDB ${s.version} Server running on port ${e}`)}return n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function nR(e,t){let r,n=0;for(let s of Ca){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=kf)return kf=i,t(r);n=i}kf=0,t(r)}function Vte(e,t){let r={};e.getpeername(r);let n=r.address,s=Ma.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);nR(e,o=>{Ma.set(n,{worker:o,lastUsed:i}),t(o)})}function $te(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new La.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let u=o.toString("latin1").match(t)?.[1],_=Ma.get(u),l=Date.now();if(_&&_.worker.threadId!==-1)return _.lastUsed=l,s(_.worker);nR(n,d=>{Ma.set(u,{worker:d,lastUsed:l}),s(d,o)})})}a(r,"findByHeaderAffinity")}function Kte(){kf=0;for(let e of Ca)e.expectedIdle=e.recentELU.idle+Yte,e.requests=1;Ca.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function Qte(e,t,r){let n=Wte++;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(),Vf.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")),Vf.delete(n)),s.event=="destroy"&&(e.destroy(),Vf.delete(n))})}var po,La,$f,rR,Yf,EB,qte,Ca,Da,hB,dB,eR,Gte,tR,kf,fB,Ma,Yte,Vf,Wte,pB=Oe(()=>{po=B(je()),La=require("net"),$f=B(M()),rR=B(Y()),Yf=require("fs");Ts();EB=require("worker_threads"),qte=B(qi()),Ca=[],Da=[],hB=[],eR=0,Gte=[];EB.isMainThread&&process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)});a(kte,"startHTTPWorker");a(mB,"startSocketServer");kf=0;a(nR,"findMostIdleWorker");fB=36e5,Ma=new Map;a(Vte,"findByRemoteAddressAffinity");a($te,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of Ma)r.lastUsed+fB<e&&Ma.delete(t)},fB).unref();Yte=1e3;a(Kte,"updateWorkerIdleness");(0,po.setMonitorListener)(Kte);Vf=new Map,Wte=1;a(Qte,"proxySocket")});var aR={};Ve(aR,{Request:()=>sR,createReuseportFd:()=>Kf});var SB,sR,iR,oR,Kf,Wf=Oe(()=>{SB=require("os"),sR=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 oR(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 iR(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},iR=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}},oR=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,SB.platform)()!="win32"&&(Kf=require("node-unix-socket").createReuseportFd)});var AB=g((_he,RB)=>{"use strict";var zte=require("cluster"),So=Z();So.initSync();var gB=M(),ohe=require("util"),Ps=Y(),ahe=require("fs"),Jte=require("fastify"),che=Kc(),Xte=require("@fastify/cors"),jte=require("@fastify/compress"),Zte=require("@fastify/static"),ere=gg(),tre=require("path"),{PACKAGE_ROOT:rre}=M(),nre=Ws(),sre=J(),ire=Zr(),ore=qi(),{server:are}=(Zt(),te(bi)),{node_request_key:uhe}=(Wf(),te(aR)),{authHandler:cre,handlePostRequest:ure,serverErrorHandler:lre,reqBodyValidationHandler:_re}=Gf(),lhe=require("net"),{registerContentHandlers:dre}=(Ea(),te(rv)),fre=6e4,Ere=1024*1024*1024,hre="TRUE",{CONFIG_PARAMS:el}=gB,Ua;RB.exports={hdbServer:TB,start:TB};async function TB(e){try{Ps.info("In Fastify server"+process.cwd()),Ps.info(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Ps.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=zte.isMaster,await mre();let t=e.securePort>0;Ua=pre(t),await Ua.ready(),e||(e={}),e.isOperationsServer=!0;try{are.http(Ua.server,e),Ua.server.closeIdleConnections||await Ua.listen({port:0,host:"::"})}catch(r){throw Ua.close(),Ps.error(r),Ps.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Ps.fatal(t),process.exit(1)}}a(TB,"operationsServer");async function mre(){Ps.trace("Configuring HarperDB process."),nre.setSchemaDataToGlobal(),await ire.setUsersToGlobal(),await ore.getLicense()}a(mre,"setUp");function pre(e){Ps.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=Sre(e),r=Jte(t);r.server.headersTimeout=gre(),r.setErrorHandler(lre);let n=Tre();n&&r.register(Xte,n),r.register(function(i,o,c){i.setNotFoundHandler(function(u,_){r.server.emit("unhandled",u.raw,_.raw)}),c()}),r.register(ere),r.register(jte),r.register(Zte,{root:tre.join(rre,"studio/build-local")}),dre(r);let s=So.get(gB.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!sre.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[_re,cre],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),ure(i,o)}),r.get("/health",()=>"HarperDB is running."),Ps.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(pre,"buildServer");function Sre(e){let t=So.get(el.OPERATIONSAPI_NETWORK_TIMEOUT),r=So.get(el.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:Ere,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(Sre,"getServerOptions");function Tre(){let e=So.get(el.OPERATIONSAPI_NETWORK_CORS),t=So.get(el.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===hre)&&(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(Tre,"getCORSOpts");function gre(){return So.get(el.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??fre}a(gre,"getHeaderTimeoutConfig")});var MB=g((mhe,LB)=>{"use strict";var{decode:Rre}=require("msgpackr"),{isMainThread:fhe,parentPort:Are,threadId:Ehe}=require("worker_threads"),uR=Rt(),vs=tt(),Ore=M(),pi=Y(),OB=Z(),NB=M();je();var bre=Es(),{recordAction:Nre,recordActionBinary:yre}=(Ts(),te(Jc)),{publishToStream:wre}=uR,{ConsumerEvents:Ire}=require("nats"),hhe={durable:vs.WORK_QUEUE_CONSUMER_NAMES.durable_name,queue:vs.WORK_QUEUE_CONSUMER_NAMES.deliver_group},Cre,Dre,Lre,yB,wB;LB.exports={initialize:lR,workQueueListener:DB,setSubscription:Mre,setIgnoreOrigin:Pre,getDatabaseSubscriptions:Ure};async function lR(){wB=!0,pi.notify("Starting clustering ingest service.");let{connection:e,jsm:t,js:r}=await uR.getNATSReferences();Cre=e,Dre=e.info.server_name,Lre=t,yB=r}a(lR,"initialize");var zf=new Map;function Mre(e,t,r){let n=zf.get(e);n||zf.set(e,n=new Map),n.set(t,r),wB||lR().then(DB)}a(Mre,"setSubscription");function Ure(){return zf}a(Ure,"getDatabaseSubscriptions");var IB;function Pre(e){IB=e}a(Pre,"setIgnoreOrigin");var CB=100,bB=new Array(CB),Qf=0;async function DB(){let e=await yB.consumers.get(vs.WORK_QUEUE_CONSUMER_NAMES.stream_name,vs.WORK_QUEUE_CONSUMER_NAMES.durable_name),t=!1,r;for(Are?.on("message",async n=>{let{type:s}=n;s===NB.ITC_EVENT_TYPES.SHUTDOWN&&(t=!0,r&&r.close?.()&&r.close())});!t;){r=await e.consume(),(async()=>{for await(let n of await r.status())if(n.type===Ire.HeartbeatsMissed){let s=n.data;pi.trace(`${s} clustering ingest consumer heartbeats missed`),s===2&&(pi.warn("Restarting clustering ingest consumer due to missed heartbeat threshold being met"),r.stop())}})();try{for await(let n of r)await bB[Qf],bB[Qf]=vre(n).catch(s=>{pi.error(s)}),++Qf>=CB&&(Qf=0)}catch(n){pi.error("Error consuming clustering ingest, restarting consumer",n)}uR.clearClientCache(),await lR()}}a(DB,"workQueueListener");async function vre(e){let t=Rre(e.data);Nre(e.data.length,"bytes-received",e.subject,t.operation,"ingest");let r=e.headers,n=!1,s=OB.get(Ore.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(vs.MSG_HEADERS.TRANSACTED_NODES)&&r.values(vs.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(vs.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!IB),yre(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(vs.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:u,table:_,records:l,hash_values:d,__origin:f,expiresAt:E}=t;pi.trace("processing message:",o,c,_,(l?"records: "+l.map(b=>b?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),pi.trace(`messageProcessor nats msg id: ${e.headers.get(vs.MSG_HEADERS.NATS_MSG_ID)}`);let h;l||(l=d);let{timestamp:p,user:S,node_name:T}=f||{},A=zf.get(c)?.get(_);if(!A)throw new Error("Missing table for replication message",_);if(o==="define_schema")t.type=o,A.send(t);else if(l.length===1&&!u)A.send({type:cR(o),value:l[0],id:d?.[0],expiresAt:E,timestamp:p,table:_,onCommit:h,user:S,nodeName:T});else{let b=l.map((H,F)=>({type:cR(o),value:H,expiresAt:E,id:d?.[F],table:_}));for(;u;)b.push({type:cR(u.operation),value:u.record,expiresAt:u.expiresAt,id:u.id,table:u.table}),u=u.next;A.send({type:"transaction",writes:b,table:_,timestamp:p,onCommit:h,user:S,nodeName:T})}OB.get(NB.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&wre(e.subject.split(".").slice(0,-1).join("."),bre.createNatsTableStreamName(c,_),e.headers,e.data)}catch(o){pi.error(o)}e.ack()}a(vre,"messageProcessor");function cR(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(cR,"convertOperation")});var mR={};Ve(mR,{disableNATS:()=>Hre,publishToStream:()=>eE,setNATSReplicator:()=>_R,setPublishToStream:()=>xre,setSubscription:()=>hR,start:()=>Bre});function Bre(){Xf.default.get(jf.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&qre()}function Hre(e=!0){HB=e}function xre(e,t){eE=e,hR=t}function qre(){if(HB||process.env._DISABLE_NATS)return;let e=yn(),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];_R(s,r,i)}}pR((r,n)=>{_R(r.tableName,r.databaseName,r),n&&FB(r)}),!UB&&(UB=!0)}function _R(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 Bt{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){FB(i)}static subscribe(){let i=new pn;return hR(t,e,i),i}static subscribeOnThisThread(i){return i<Fre}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 Jf(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=xB;return i}a(n,"getNATSTransaction")}function FB(e){let t=Xf.default.get(jf.default.CONFIG_PARAMS.CLUSTERING_NODENAME);eE(`${fR.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,ER.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 PB,fR,ER,vB,BB,Xf,jf,Zf,HB,eE,hR,Fre,xB,UB,Jf,dR,qB=Oe(()=>{be();Sn();PB=B(Rt()),fR=B(tt()),ER=B(Es());oc();vB=B(MB()),BB=B(br()),Xf=B(Z()),jf=B(M()),Zf=B(Y());a(Bre,"start");a(Hre,"disableNATS");eE=PB.publishToStream,hR=vB.setSubscription;a(xre,"setPublishToStream");Fre=2;a(qre,"assignReplicationSource");a(_R,"setNATSReplicator");a(FB,"publishSchema");Jf=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=Xf.default.get(jf.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],u,_;for(let l of i){let d=l.table,f=l.operation=="put"?"upsert":l.operation;u||(Zf.trace(`Sending transaction event ${f}`),_=u={operation:f,schema:s,table:d,__origin:{user:this.user?.username,timestamp:t,node_name:r}},u.hash_values=c,f!=="delete"&&f!=="invalidate"&&(u.records=o)),u.table===d&&u.operation===f?(o.push(l.record),c.push(l.id)):_=_.next={operation:f,table:d,id:l.id,record:l.record},l.expiresAt&&(_.expiresAt=l.expiresAt)}u&&n.push(eE(`${fR.SUBJECT_PREFIXES.TXN}.${s}.${u.table}`,(0,ER.createNatsTableStreamName)(s,u.table),void 0,u)?.catch(l=>{throw Zf.error("An error has occurred trying to replicate transaction",u,l),l.statusCode=504,l}))}return Promise.all(n)}},dR=class extends Jf{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,BB.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};xB=new dR});async function $B({clientId:e,user:t,clean:r,will:n}){let s;if(e&&!r){let i=await SR.getResource(e,{});s=new RR(e,t,i),i&&(s.sessionWasPresent=!0)}else{if(e){let i=await SR.get(e);i&&i.delete()}s=new rE(e,t)}return n&&(n.id=e,n.user={username:t?.username},tl.put(n)),s}function TR(){return tE++,tE>65500&&(tE=1),tE}function gR(e,t,r=e){let{topic:n,retain:s}=e;e.data=t,e.async=!0,e.authorize=!0;let i=li.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 We(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var GB,To,kB,VB,SR,tl,tE,rE,RR,YB=Oe(()=>{be();wu();GB=B(br()),To=B(Y());Ki();kB=B(je()),VB=B(KB());Zt();SR=ot({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"}]}}]}),tl=ot({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,kB.getWorkerIndex)()===0&&(async()=>{await VB.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of tl.search({})){let t=e.data,r=Object.assign({},e);r.user?.username&&(r.user=await Xe.getUser(r.user.username)),We(r,()=>{try{gR(r,t)}finally{tl.delete(e.id,r)}})}})();a($B,"getSession");tE=1;a(TR,"getNextMessageId");rE=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;subscriptions=[];awaitingAcks;sessionWasPresent;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),u,_;if(c>-1?(u=s.slice(c),_=s.slice(0,c)):_=s,!_)throw new Error("No topic provided");if(_.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let l=this.subscriptions.find(T=>T.topic===s),d;l?(d=i>0,l.end(),this.subscriptions.splice(this.subscriptions.indexOf(l),1)):d=i===2;let f={search:u,async:!0,authorize:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,To.trace)("Resuming subscription from",s,"from",o);let E=li.getMatch(_);if(!E){let T=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw T.statusCode=404,T}if(f.url=E.relativeURL,f.url.indexOf("+")>-1||f.url.indexOf("#")>-1){let T=f.url.slice(1);if(T.indexOf("#")>-1&&T.indexOf("#")!==T.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(f.isCollection=!0,T.indexOf("+")===T.length-1)f.onlyChildren=!0,f.url="/"+T.slice(0,T.length-1);else{let A=T.split("/"),b;for(let v=0;v<A.length;v++)if(A[v].indexOf("+")>-1)if(A[v]==="+")b=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&b)throw new Error("Filters can not be combined");let H=!0;A[A.length-1]==="#"&&(A.length--,H=!1),b&&(n=a(v=>{let P=v.id;if(!Array.isArray(P)||H&&P.length!==A.length)return!1;for(let z=0;z<A.length;z++)if(A[z]!=="+"&&A[z]!==P[z])return!1;return!0},"filter"));let F=A.indexOf("+");f.url="/"+(F>-1?A.slice(0,F):A).concat("").join("/")}}let h=E.path,p=E.Resource,S=await We(f,async()=>{let T=await p.subscribe(f);if(!T)throw new Error(`No subscription was returned from subscribe for topic ${s}`);if(!T[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);return(async()=>{for await(let A of T)try{let b;if(A.type&&A.type!=="put"&&A.type!=="delete"&&A.type!=="message"&&A.type!=="patch"||n&&!n(A))continue;r?(A.topic=s,b=this.needsAcknowledge(A)):(A.acknowledge?.(),b=TR());let H=A.id;Array.isArray(H)&&(H=fa(H)),H==null&&(H=""),this.listener(h+"/"+H,A.value,b,t)}catch(b){(0,To.warn)(b)}})(),T});return S.topic=s,S.qos=t.qos,this.subscriptions.push(S),S}resume(){}needsAcknowledge(t){let r=TR();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,t.acknowledge)),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),!0}async publish(t,r){return t.user=this.user,gR(t,r)}setListener(t){this.listener=t}disconnect(t){let r={};We(r,async()=>{if(!t){let n=await tl.get(this.sessionId,r);n?.doesExist()&&await gR(n,n.data,r)}await tl.delete(this.sessionId,r)}).catch(n=>{(0,To.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}};a(gR,"publish");RR=class extends rE{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=TR(),n={topic:t.topic,timestamp:t.timestamp};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks.get(t);this.awaitingAcks.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,To.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&(this.sessionRecord.subscriptions=this.subscriptions.map(i=>{let o=i.startTime;return o||(o=i.startTime=(0,GB.getNextMonotonicTime)()),(0,To.trace)("Added durable subscription",i.topic,o),{qos:i.qos,topic:i.topic,startTime:o}}),SR.put(this.sessionRecord)),t.qos}}});var AR={};Ve(AR,{bypassAuth:()=>Gre,start:()=>kre});function Gre(){XB=!0}function kre({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){let o=e.mqtt={requireAuthentication:i,sessions:new Set},c,u=r?.mtls;return n&&(c=e.ws((_,l,d)=>{if(_.protocol==="mqtt"){let{onMessage:f,onClose:E}=zB(_,(h,p)=>{if(_.send(h),p&&_._socket.writableNeedDrain)return new Promise(S=>this._socket.once("drain",S))},l,Promise.resolve(d).then(()=>l?.user),o);_.on("message",f),_.on("close",E),_.on("error",h=>{(0,Sr.info)("WebSocket error",h)})}},Object.assign({subProtocol:"mqtt"},n))),(t||s)&&(c=e.socket(async _=>{let l;if(u){if(_.authorized)try{let E=u.user;E!==null&&((E===void 0||E==="Common Name"||E==="CN")&&(E=_.getPeerCertificate().subject.CN),l=await e.getUser(E,null,null))}catch(E){(0,Sr.error)(E)}else if(u.required)return(0,Sr.info)(`Unauthorized connection attempt, no authorized client certificate provided, error: ${_.authorizationError}`),_.end()}!l&&XB&&_.remoteAddress.includes("127.0.0.1")&&(l=await(0,JB.getSuperUser)());let{onMessage:d,onClose:f}=zB(_,E=>_.write(E),null,l,o);_.on("data",d),_.on("close",f),_.on("error",E=>{(0,Sr.info)("Socket error",E)})},{port:t,securePort:s,mtls:u})),c}function zB(e,t,r,n,s){QB||(QB=!0,zc(d=>{nE>0&&d.push({metric:"mqtt-connections",connections:nE,byThread:!0})}));let i;nE++;let o,c={protocolVersion:4},u=(0,iE.parser)({protocolVersion:5});function _(d){u.parse(d)}a(_,"onMessage");function l(){nE--,i||(i=!0,o?.disconnect(),s.sessions.delete(o),en(!1,"connection","mqtt","disconnect"))}return a(l,"onClose"),u.on("packet",async d=>{n?.then&&(n=await n),o?.then&&await o;try{switch(d.cmd){case"connect":if(c.protocolVersion=d.protocolVersion,d.username)try{n=await Xe.getUser(d.username,d.password.toString(),r),(0,sE.get)(ss.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&WB.notify({username:n.username,status:ss.AUTH_AUDIT_STATUS.SUCCESS,type:ss.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch{return(0,sE.get)(ss.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&WB.error({username:n.username,status:ss.AUTH_AUDIT_STATUS.FAILURE,type:ss.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),f({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return en(!1,"connection","mqtt","connect"),f({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let b=e.deserialize||(e.deserialize=lo(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?b(d.will.payload):void 0,delete d.will.payload}o=$B({user:n,...d}),o=await o,s.sessions.add(o)}catch(b){return(0,Sr.error)(b),en(!1,"connection","mqtt","connect"),f({cmd:"connack",reasonCode:b.code||5,returnCode:b.code||128})}en(!0,"connection","mqtt","connect"),f({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((b,H,F,v)=>{try{let P=b.indexOf("/",1),z=P>0?b.slice(0,P):b;f({cmd:"publish",topic:b,payload:E(H),messageId:F||Math.floor(Math.random()*1e8),qos:v.qos},z)}catch(P){(0,Sr.error)(P),o?.disconnect(),s.sessions.delete(o)}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let h=[];for(let b of d.subscriptions){let H;try{H=(await o.addSubscription(b,b.qos>=1)).qos||0}catch(F){(0,Sr.error)(F),H=c.protocolVersion<5?128:F.statusCode===403?135:F.statusCode===404?143:128}h.push(H)}await o.committed,f({cmd:"suback",granted:h,messageId:d.messageId});break;case"unsubscribe":{let b=[];for(let H of d.unsubscriptions)b.push(o.removeSubscription(H)?0:17);f({cmd:"unsuback",granted:b,messageId:d.messageId});break}case"pubrel":f({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let p=d.qos===2?"pubrec":"puback",S=e.deserialize||(e.deserialize=lo(r?.headers.get?.("content-type"))),T=d.payload?.length>0?S(d.payload):void 0,A;try{A=await o.publish(d,T)}catch(b){(0,Sr.warn)(b),d.qos>0&&f({cmd:p,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&f({cmd:p,messageId:d.messageId,reasonCode:A===!1?144:0},d.topic);break;case"pubrec":f({cmd:"pubrel",messageId:d.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(d.messageId);break;case"pingreq":f({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.sessions.delete(o),en(!0,"connection","mqtt","disconnect"),e.close?e.close():e.end();break}}catch(h){(0,Sr.error)(h),f({cmd:"disconnect"})}function f(h,p){let S=(0,iE.generate)(h,c);t(S),vr(S.length,"bytes-sent",p,h.cmd,"mqtt")}a(f,"sendPacket");function E(h){return di(h,r)}a(E,"serialize")}),{onMessage:_,onClose:l}}var iE,JB,sE,ss,Sr,WB,XB,QB,nE,jB=Oe(()=>{iE=require("mqtt-packet");YB();JB=B(Zr());Ea();Ts();Zt();sE=B(Z()),ss=B(M()),Sr=B(Y()),WB=(0,Sr.loggerWithTag)("auth-event"),XB=(0,sE.get)(ss.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(Gre,"bypassAuth");a(kre,"start");nE=0;a(zB,"onSocket")});var jd={};Ve(jd,{component_errors:()=>va,loadComponent:()=>oE,loadComponentDirectories:()=>aH,setErrorReporter:()=>Kre});function aH(e,t){t&&(bR=t),e&&(NR=e);let r=[];if((0,Un.existsSync)(OR)){let s=(0,Un.readdirSync)(OR,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,pt.join)(OR,o);r.push(oE(c,bR,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(oE(n,bR,n,!1,null,process.env.DEV_MODE)),Promise.all(r).then(()=>{oH=!0})}function Kre(e){nl=e}async function oE(e,t,r,n,s,i){if(!eH.has(e)){eH.set(e,!0),s&&(NR=s);try{let o;n&&(va=new Map);let c=(0,pt.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,Un.existsSync)(c)?o=n?(0,iH.getConfigObj)():(0,tH.parseDocument)((0,Un.readFileSync)(c,"utf8"),{simpleKeys:!0}).toJSON():o=yR;let u=[],_=n;for(let l in o){let d=o[l];if(va.set(n?l:(0,pt.basename)(e),!1),!d)continue;let f,E=d.package;try{if(E){let A=e,b;for(;!(0,Un.existsSync)(b=(0,pt.join)(A,"node_modules",l));)if(A=(0,pt.dirname)(A),A.length<(0,sH.getHdbBasePath)().length){b=null;break}if(b)f=await oE(b,t,r,!1),_=!0;else throw new Error(`Unable to find package ${l}:${E}`)}else f=Yre[l];if(!f)continue;u.push(f);let h=a(A=>(A.origin=r,ot(A)),"ensureTable"),p=d.network||(d.port||d.securePort)&&d,S=p?.securePort||p?.https&&p.port,T=!p?.https&&p?.port;if(Pa.isMainThread&&(f=await f.startOnMainThread?.({server:Xe,ensureTable:h,port:T,securePort:S,resources:t,...d})||f,n&&p))for(let A of[T,S])try{if(+A&&!ZB.includes(A)){let b=wR.get(IR.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);b&&rl.default.warn("Session affinity is not recommended and may cause memory leaks"),(b||!Kf)&&(ZB.push(A),mB(A,b))}}catch(b){console.error("Error listening on socket",A,b,l)}if(t.isWorker&&(f=await f.start?.({server:Xe,ensureTable:h,port:T,securePort:S,resources:t,...d})||f),NR.set(f,!0),(f.handleFile||f.handleDirectory)&&d.files){if(d.files.includes(".."))throw(0,nH.handleHDBError)("Can not reference parent directories");let A=(0,pt.join)(e,d.files).replace(/\\/g,"/"),b=A.indexOf("/*");if(b>-1&&d.files!==yR[l]?.files&&!(0,Un.existsSync)(A.slice(0,b)))throw new Error(`The path '${A.slice(0,b)}' does not exist and cannot be used as the base of the resolved 'files' path value '${d.files}'`);let H=(0,pt.basename)(e),F=d.path||"/";F=F.startsWith("/")?F:F.startsWith("./")?"/"+H+F.slice(2):F==="."?"/"+H:"/"+H+"/"+F;let v,P,z;if(d.root){let Q=d.root;Q.startsWith("/")&&(Q=Q.slice(1)),Q.endsWith("/")&&(Q=Q.slice(0,-1)),Q+="/",P=(0,pt.join)(e,Q)}else(z=A.indexOf("/*"))>-1&&(P=A.slice(0,z+1),v=(0,pt.relative)(e,P));let W=!1;if(Pa.isMainThread&&f.setupDirectory&&(W=await f.setupDirectory?.(F,P,t)),t.isWorker&&f.handleDirectory&&(W=await f.handleDirectory?.(F,P,t)),W)continue;for(let Q of await(0,rH.default)(A,{onlyFiles:!1,objectMode:!0})){let{path:se,dirent:pe}=Q;_=!0;let oe=(0,pt.relative)(e,se).replace(/\\/g,"/");if(v)if(oe.startsWith(v))oe=oe.slice(v.length+1);else throw new Error(`The root path '${d.root}' does not reference a valid part of the file path '${oe}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let xe=F+(F.endsWith("/")?"":"/")+oe;try{if(pe.isFile()){let le=await $re(se);Pa.isMainThread&&await f.setupFile?.(le,xe,se,t),t.isWorker&&await f.handleFile?.(le,xe,se,t)}else Pa.isMainThread&&await f.setupDirectory?.(xe,se,t),t.isWorker&&await f.handleDirectory?.(xe,se,t)}catch(le){le.message=`Could not load ${pe.isFile()?"file":"directory"} '${se}'${d.module?" using '"+d.module+"'":""} for application '${e}' due to: ${le.message}`,nl?.(le),((0,Ba.getWorkerIndex)()===0?console:rl.default).error(le),t.set(d.path||"/",new sl(le)),va.set(n?l:(0,pt.basename)(e),le.message)}}}}catch(h){h.message=`Could not load component '${l}' for application '${(0,pt.basename)(e)}' due to: ${h.message}`,nl?.(h),((0,Ba.getWorkerIndex)()===0?console:rl.default).error(h),t.set(d.path||"/",new sl(h),null,!0),va.set(n?l:(0,pt.basename)(e),h.message)}}if(Pa.isMainThread&&!oH&&i&&(0,Ba.watchDir)(e,async()=>aH()),o.extensionModule)return await ql((0,pt.join)(e,o.extensionModule));if(!_&&t.isWorker){let l=`${e} did not load any modules, resources, or files, is this a valid component?`;nl?.(new Error(l)),((0,Ba.getWorkerIndex)()===0?console:rl.default).error(l),va.set((0,pt.basename)(e),l)}}catch(o){console.error(`Could not load application directory ${e}`,o),o.message=`Could not load application due to ${o.message}`,nl?.(o),t.set("",new sl(o))}}}var Un,pt,Pa,tH,wR,IR,rH,Ba,rl,nH,sH,Vre,iH,$re,OR,NR,oH,bR,va,Yre,yR,ZB,eH,nl,sl,Zd=Oe(()=>{Un=require("fs"),pt=require("path"),Pa=require("worker_threads"),tH=require("yaml"),wR=B(Z()),IR=B(M());yO();DO();LO();pv();iB();_B();rH=B(require("fast-glob")),Ba=B(je()),rl=B(Y());dh();Zt();nH=B(ee());Sn();be();pB();sH=B(Z()),Vre=B(AB());$d();qB();jB();iH=B(Dr());Wf();({readFile:$re}=Un.promises),OR=wR.get(IR.CONFIG_PARAMS.COMPONENTSROOT),NR=new Map,va=new Map;a(aH,"loadComponentDirectories");Yre={REST:Tf,rest:Tf,graphqlSchema:_h,jsResource:Eh,fastifyRoutes:jg,login:mh,static:Zg,operationsApi:Vre,customFunctions:{},http:{},clustering:mR,authentication:Iu,mqtt:AR},yR={rest:!0,graphqlSchema:{files:"*.graphql"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(yR,"static",{value:{files:"web/**"}});ZB=[],eH=new Map;a(Kre,"setErrorReporter");a(oE,"loadComponent");sl=class extends Bt{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 DR=g((Khe,uH)=>{var{isMainThread:cH}=require("worker_threads"),{getTables:Wre}=(be(),te(Fe)),{loadComponentDirectories:Qre,loadComponent:zre}=(Zd(),te(jd)),{resetResources:Jre}=(wu(),te(NU)),Xre=vT(),jre=Dr(),{dirname:Zre}=require("path"),{getConnection:ene}=Rt(),tne=Z(),rne=M(),CR=new Map;async function nne(e=!1){!cH&&tne.get(rne.CONFIG_PARAMS.CLUSTERING_ENABLED)&&ene();try{cH&&await Xre()}catch(n){console.error(n)}let t=Jre();Wre(),t.isWorker=e,await zre(Zre(jre.getConfigFilePath()),t,"hdb",!0,CR),await Qre(CR,t);let r=[];for(let[n]of CR)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(nne,"loadRootComponents");uH.exports.loadRootComponents=nne});var je=g((Qhe,Ti)=>{"use strict";var{Worker:sne,MessageChannel:ine,parentPort:is,isMainThread:vR,threadId:one,workerData:Bs}=require("worker_threads"),{PACKAGE_ROOT:ane}=M(),{join:fH,isAbsolute:cne,extname:une}=require("path"),{server:EH}=(Zt(),te(bi)),{watch:lne,readdir:_ne}=require("fs/promises"),{totalmem:lH}=require("os"),il=M(),hH=Z(),Hs=Y(),{randomBytes:dne}=require("crypto"),{_assignPackageExport:fne}=require("../../index"),Ene=M(),_H=1024*1024,Si=[],ln=[],hne=50,BR=1e4,mne="restart",mH="request_thread_info",pH="resource_report",SH="thread_info",TH="added-port",pne="ack",LR;fne("threads",ln);Ti.exports={startWorker:MR,restartWorkers:xR,shutdownWorkers:Ane,workers:Si,setMonitorListener:Dne,onMessageFromWorkers:One,onMessageByType:NH,broadcast:Nne,broadcastWithAcknowledgement:wne,setChildListenerByType:Rne,getWorkerIndex:gH,getWorkerCount:RH,getTicketKeys:AH,setMainIsWorker:Tne,setTerminateTimeout:Sne,restartNumber:Bs?.restartNumber||1};ln.onMessageByType=NH;ln.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=ln.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};var HR;function Sne(e){BR=e}a(Sne,"setTerminateTimeout");function gH(){return Bs?Bs.workerIndex:HR?0:void 0}a(gH,"getWorkerIndex");function RH(){return Bs?Bs.workerCount:HR?1:void 0}a(RH,"getWorkerCount");function Tne(e){HR=e}a(Tne,"setMainIsWorker");var aE;function AH(){return aE||(aE=vR?dne(48):Bs.ticketKeys,aE)}a(AH,"getTicketKeys");Object.defineProperty(EH,"workerIndex",{get(){return gH()}});Object.defineProperty(EH,"workerCount",{get(){return RH()}});var OH={[mH](e,t){Ine(t)},[pH](e,t){Cne(t,e)}};function MR(e,t={}){let r=process.constrainedMemory?.()||lH();r=Math.min(r,lH(),2e4*_H);let n=hH.get(il.CONFIG_PARAMS.MAXHEAPMEMORY)??Math.max(Math.floor(r/_H/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let u of ln){let _=new ine;_.existingPort=u,i.push(_),o.push(_.port2)}une(e)||(e+=".js");let c=new sne(cne(e)?e:fH(ane,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:t.threadCount,name:t.name,restartNumber:Ti.exports.restartNumber,ticketKeys:AH()},transferList:o},t));for(let{port1:u,existingPort:_}of i)_.postMessage({type:TH,port:u,threadId:c.threadId},[u]);return uE(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>MR(e,t),c.on("error",u=>{console.error("Worker error:",u),Hs.error("Worker error:",u)}),c.on("exit",u=>{Si.splice(Si.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<hne?(t.unexpectedRestarts=c.unexpectedRestarts+1,MR(e,t)):Hs.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",u=>{OH[u.type]?.(u,c)}),Si.push(c),Mne(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(MR,"startWorker");var gne=[il.THREAD_TYPES.HTTP];async function xR(e=null,t=2,r=!0){if(vR){if(r){let{loadRootComponents:o}=DR();await o()}Ti.exports.restartNumber++,t<1&&(t=t*Si.length);let n=[],s=[];for(let o of Si.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Hs.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Ti.exports.restartNumber,type:il.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=gne.indexOf(o.name)>-1,u=new Promise(_=>{let l=setTimeout(()=>o.terminate(),BR*2).unref();o.on("exit",()=>{clearTimeout(l),n.splice(n.indexOf(u)),!c&&r&&o.startCopy(),_()})});if(n.push(u),c&&r){let _=o.startCopy(),l=new Promise(d=>{let f=a(E=>{E.type===Ene.ITC_EVENT_TYPES.CHILD_STARTED&&(Hs.trace("Worker has started",_.threadId),d(),s.splice(s.indexOf(l)),_.off("message",f))},"startListener");Hs.trace("Waiting for worker to start",_.threadId),_.on("message",f)});s.push(l),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=xd();r&&(e==="http"||!e)&&hH.get(il.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else is.postMessage({type:mne,workerType:e})}a(xR,"restartWorkers");function Rne(e,t){OH[e]=t}a(Rne,"setChildListenerByType");function Ane(e){return xR(e,1/0,!1)}a(Ane,"shutdownWorkers");var bH=[];function One(e){bH.push(e)}a(One,"onMessageFromWorkers");var UR=new Map;function NH(e,t){let r=UR.get(e);r||UR.set(e,r=[]),r.push(t)}a(NH,"onMessageByType");var bne=10;async function Nne(e){let t=0;for(let r of ln)try{r.postMessage(e),t++>bne&&(t=0,await new Promise(setImmediate))}catch(n){Hs.error("Unable to send message to worker",n)}}a(Nne,"broadcast");var cE=new Map,yne=1;function wne(e){return new Promise(t=>{let r=0;for(let n of ln)try{let s=yne++,i=a(()=>{cE.delete(s),--r===0&&t(),n!==is&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,cE.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of cE)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Hs.error("Unable to send message to worker",s)}r===0&&t()})}a(wne,"broadcastWithAcknowledgement");function Ine(e){e.postMessage({type:SH,workers:yH()})}a(Ine,"sendThreadInfo");function yH(){let e=Date.now();return Si.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(yH,"getChildWorkerInfo");function Cne(e,t){e.resources=t,e.resources.updated=Date.now()}a(Cne,"recordResourceReport");var PR;function Dne(e){PR=e}a(Dne,"setMonitorListener");var Lne=1e3,dH=!1;function Mne(){dH||(dH=!0,setInterval(()=>{for(let e of Si){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}PR&&PR()},Lne).unref())}a(Mne,"startMonitoring");var Une=1e3;if(is){uE(is);for(let e=0,t=Bs.addPorts.length;e<t;e++){let r=Bs.addPorts[e];r.threadId=Bs.addThreadIds[e],uE(r)}setInterval(()=>{let e=process.memoryUsage();is.postMessage({type:pH,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},Une).unref(),LR=a(()=>new Promise((e,t)=>{is.on("message",r),is.postMessage({type:mH});function r(n){n.type===SH&&(is.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else LR=yH;Ti.exports.getThreadInfo=LR;function uE(e,t){ln.push(e),e.on("message",r=>{if(r.type===TH)r.port.threadId=r.threadId,uE(r.port);else if(r.type===pne){let n=cE.get(r.id);n&&n()}else{for(let s of bH)s(r,e);let n=UR.get(r.type);if(n)for(let s of n)try{s(r,e)}catch(i){Hs.error(i)}}}).on("close",()=>{ln.splice(ln.indexOf(e),1)}).on("exit",()=>{ln.splice(ln.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(uE,"addPort");if(vR){let e,t,r=a(async(n,s)=>{s&&(e=s);for(let i of await _ne(n,{withFileTypes:!0}))i.isDirectory()&&i.name!=="node_modules"&&r(fH(n,i.name));try{for await(let{filename:i}of lne(n,{persistent:!1}))t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await xR(),console.log("Reloaded HarperDB components")},100)}catch(i){console.warn("Error trying to watch component directory",n,i)}},"watch_dir");Ti.exports.watchDir=r,process.env.WATCH_DIR&&r(process.env.WATCH_DIR)}else is.on("message",async e=>{let{type:t}=e;t===il.ITC_EVENT_TYPES.SHUTDOWN&&(Ti.exports.restartNumber=e.restartNumber,is.unref(),setTimeout(()=>{Hs.warn("Thread did not voluntarily terminate",one),process.exit(0)},BR).unref())})});var BI={};Ve(BI,{AUDIT_STORE_OPTIONS:()=>BH,createAuditEntry:()=>Yl,openAuditStore:()=>fE,readAuditEntry:()=>It,setAuditRetention:()=>vne,transactionKeyEncoder:()=>vH});function fE(e){let t=e.auditStore=e.openDB(MH.AUDIT_STORE_NAME,BH);t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,{remove(){delete r[i]}}};let n=null;function s(i=lE){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed")return;let o=0,c;try{for(let{key:u,value:_}of t.getRange({start:0,snapshot:!1,end:Date.now()-FR})){if((_[0]&15)===kR){let l=It(_),d=l.tableId;r[d]?.(l.recordId)}if(c=t.remove(u),await new Promise(setImmediate),++o>=Pne){i=10;break}}await c}finally{o===0&&(i=Math.min(i<<1,FR/10)),s(i)}},i).unref()}return a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,dE.getWorkerIndex)()===(0,dE.getWorkerCount)()-1&&s(lE),t}function vne(e,t=lE){FR=e,lE=t}function Yl(e,t,r,n,s,i,o){let c=HH[i];if(!c)throw new Error(`Invalid audit entry type ${i}`);let u=1;n&&(n>1?Ha.setFloat64(0,n):_n.set(Uh),u=9),f(0),f(t),d(r),Ha.setFloat64(u,e),u+=8,s?d(s):_n[u++]=0,_n[n?8:0]=c;let l=_n.subarray(0,u);if(o)return Buffer.concat([l,o]);return l;function d(E){let h=u;u+=1,u=(0,xa.writeKey)(E,_n,u);let p=u-h-1;p>127?p>16383?($R.error("Key or username was too large for audit entry",E),u=h+1,_n[h]=0):(_n.copyWithin(h+2,h+1,u),Ha.setUint16(h,p|32768),u++):_n[h]=p}function f(E){E<128?_n[u++]=E:E<16384?(Ha.setUint16(u,E|32768),u+=2):E<1056964608?(Ha.setUint32(u,E|3221225472),u+=4):(_n[u]=255,Ha.setUint32(u+1,E),u+=5)}}function It(e){try{let t=e.dataView||(e.dataView=new VR(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:HH[n&7],tableId:i,get recordId(){return LH(e,c,u)},version:_,previousLocalTime:r,get user(){return d>l?LH(e,l,d):void 0},getValue(f,E,h){if(n&qR||n&GR&&!E)return f.decoder.decode(e.subarray(t.position));if(n&GR&&h)return YR(f.getEntry(this.recordId),h,f)}}}catch{return $R.error("Reading audit entry error",e),{}}}function LH(e,t,r){let n=e.subarray(t,r);return(0,xa.readKey)(n,0,r-t)}var xa,_E,MH,UH,dE,PH,$R,_n,Ha,vH,BH,FR,Pne,lE,qR,GR,wH,kR,IH,CH,DH,HH,VR,wi=Oe(()=>{xa=require("ordered-binary"),_E=B(Z()),MH=B(lt()),UH=B(M()),dE=B(je()),PH=B(J());Uo();$R=B(Y());EE();(0,_E.initSync)();_n=Buffer.alloc(1024),Ha=new DataView(_n.buffer,_n.byteOffset,1024),vH={writeKey(e,t,r){return e===dc?(t.set(dc,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,xa.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,xa.readKey)(e,t,r)}},BH={encoding:"binary",keyEncoder:vH},FR=(0,PH.convertToMS)((0,_E.get)(UH.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,Pne=1e3,lE=1e4;a(fE,"openAuditStore");a(vne,"setAuditRetention");qR=16,GR=32,wH=1,kR=2,IH=3,CH=4,DH=5,HH={put:wH|qR,[wH]:"put",delete:kR,[kR]:"delete",message:IH|qR,[IH]:"message",invalidate:CH,[CH]:"invalidate",patch:DH|GR,[DH]:"patch"};a(Yl,"createAuditEntry");a(It,"readAuditEntry");VR=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(LH,"readKeySafely")});var KR={};Ve(KR,{add:()=>hE,applyReverse:()=>xH,getRecordAtTime:()=>YR,rebuildUpdateBefore:()=>mE});function hE(e,t,r){isNaN(e[t])?e[t]=r.value:e[t]+=r.value}function mE(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,hE(r,n,s)}}else r||(r={}),r[n]=e[n];return r}function xH(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Bne[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=FH}}function YR(e,t,r){let n=r.rootStore.auditStore,s=Object.assign({},e.value),i=e.localTime;for(;i>t;){let u=n.get(i),_=It(u);switch(_.type){case"put":s=_.getValue(r);break;case"patch":xH(s,_.getValue(r));break;case"delete":s=null}i=_.previousLocalTime}let o={},c=0;for(let u in s)s[u]===FH&&(o[u]=!0,c++);for(;c>0&&i>0;){let u=n.get(i),_=It(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 Bne,FH,EE=Oe(()=>{wi();a(hE,"add");hE.reverse=function(e,t,r){isNaN(e[t])||(e[t]-=r.value)};Bne={add:hE};a(mE,"rebuildUpdateBefore");a(xH,"applyReverse");FH={};a(YR,"getRecordAtTime")});function Gr(e){return e[yt]||(e[yt]=Object.create(null))}function RE(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[Ne])},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 dn.ClientError(`${c} must be a string, attempt to assign ${l}`);Gr(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 dn.ClientError(`${c} must be a string, attempt to assign ${l}`);Gr(this)[c]=l},"set");break;case"Float":case"Number":u=a(function(l){if(!(typeof l=="number"||l==null&&o.nullable!==!1))throw new dn.ClientError(`${c} must be a number, attempt to assign ${l}`);Gr(this)[c]=l},"set");break;case"Int":u=a(function(l){if(!(l>>0===l||l==null&&o.nullable!==!1))if(typeof l=="number"&&Math.abs((l>>0)-l)<=1)l=Math.round(l);else throw new dn.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${l}`);Gr(this)[c]=l},"set");break;case"Long":u=a(function(l){if(!(Math.round(l)===l&&Math.abs(l)<=9007199254740992||l==null&&o.nullable!==!1))if(typeof l=="number"&&Math.abs(l)<=9007199254740992)l=Math.round(l);else throw new dn.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${l}`);Gr(this)[c]=l},"set");break;case"BigInt":u=a(function(l){if(!(typeof l=="bigint"||l==null&&o.nullable!==!1))if(typeof l=="string"||typeof l=="number")l=BigInt(l);else throw new dn.ClientError(`${c} must be a number, attempt to assign ${l}`);Gr(this)[c]=l},"set");break;case"Boolean":u=a(function(l){if(!(typeof l=="boolean"||l==null&&o.nullable!==!1))throw new dn.ClientError(`${c} must be a boolean, attempt to assign ${l}`);Gr(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 dn.ClientError(`${c} must be a Date, attempt to assign ${l}`);Gr(this)[c]=l},"set");break;case"Bytes":u=a(function(l){if(!(l instanceof Uint8Array||l==null&&o.nullable!==!1))throw new dn.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${l}`);Gr(this)[c]=l},"set");break;case"Any":case void 0:u=a(function(l){Gr(this)[c]=l},"set");break;default:u=a(function(l){if(!(typeof l=="object"||l==null&&o.nullable!==!1))throw new dn.ClientError(`${c} must be an object, attempt to assign ${l}`);Gr(this)[c]=l},"set")}_={get(){let l=this[yt];if(l&&c in l){let f=l[c];if(f?.__op__){let E=this[Re]?.[c];return f.update(E)}return f}let d=this[Re]?.[c];if(d&&typeof d=="object"){let f=qH(d,o);if(f)return l||(l=this[yt]=Object.create(null)),l[c]=f}return d},set:u,enumerable:!0,configurable:!0}}_.get.isAttribute=!0,n[c]=_,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,_)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let u=this[yt];return u?.[o]!==void 0?u[o]:this[Re]?.[o]}),i("set",function(o,c){let u=n[o];if(u)return u.set.call(this,c);if(t.sealed)throw new dn.ClientError("Can not add a property to a sealed table schema");Gr(this)[o]=c}),i("deleteProperty",function(o){Gr(this)[o]=void 0}),i("toJSON",function(){let o=this[yt],c;for(let _ in o){c||(c=Object.assign({},this[Re]));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[Re])),Object.assign(c,this)),c||this[Re]}),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 qH(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?.[Re])throw new Error("Can not track an already tracked object, check for circular references");this[Re]=s}},RE(r,t)),new r(e)):new pE(e);case Array:let n=new TE(e.length);n[Re]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=qH(o,t?.elements)),n[s]=o}return n;default:return e}}function q_(e){let t=e[yt],r;for(let s in t){r||(r=Object.assign({},e[Re]));let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=q_(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=Object.assign({},e[Re])),Object.assign(r,e)),r||e[Re]}function Ro(e,t=e[yt]){let r;if(e[Re]&&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=Ro(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[Re]));let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=KR[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Ro(s);r[n]=s}return r?Object.freeze(r):e[Re]||e}function SE(e){let t=e[Re];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[go]||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?.[Re]===s){if(SE(i))return!0}else return!0}}else{let r=e[yt];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[Re]===i){if(SE(s))return!0}else return!0}else return!0}}return!1}var dn,yt,pE,go,TE,gE,G_=Oe(()=>{Sn();dn=B(ee());EE();yt=Symbol("own-data");a(Gr,"getChanges");a(RE,"assignTrackedAccessors");a(qH,"trackObject");pE=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[Re])throw new Error("Can not track an already tracked object, check for circular references");this[Re]=t}};RE(pE,{});a(q_,"collapseData");a(Ro,"deepFreeze");a(SE,"hasChanges");go=Symbol.for("has-array-changes"),TE=class extends Array{static{a(this,"TrackedArray")}[go];constructor(t){super(t)}splice(...t){return this[go]=!0,super.splice(...t)}push(...t){return this[go]=!0,super.push(...t)}pop(){return this[go]=!0,super.pop()}unshift(...t){return this[go]=!0,super.unshift(...t)}shift(){return this[go]=!0,super.shift()}};TE.prototype.constructor=Array;gE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var up={};Ve(up,{CONTEXT:()=>Ne,ID_PROPERTY:()=>Me,IS_COLLECTION:()=>fn,RECORD_PROPERTY:()=>Re,Resource:()=>Bt,snake_case:()=>xne,transformForSelect:()=>OE});function xne(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function GH(e,t){if(ol=!1,e==="")return null;if(e=e.slice(1),e.indexOf("/")===-1)return e===""?(ol=!0,null):(e.startsWith("$")&&(e=parseInt(e,36)),t.coerceId(decodeURIComponent(e)));let r=e.split("/"),n=new QR;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){ol=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}function kr(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[Ne]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(l=s,c=l[this.primaryKey]??null,o=i[Ne]||i):l=i:(l=s,c=l[Me]??l[this.primaryKey]??null),c==null&&(_=!0)):i?o=i[Ne]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="string")c=s;else if(typeof s=="object"&&s)if(u=s,s[Symbol.iterator]){c=[],_=!0;for(let E of s){if(typeof E=="object"&&E)break;c.push(E)}c.length===0?c=null:(c.length===1&&(c=c[0]),u.slice&&(u=u.slice(c.length,u.length),u.length===0&&(u=null,_=!1)))}else{if(typeof(c=s.url)=="string"){let E=c.indexOf("?");if(E>-1){let p=this.parseQuery(c.slice(E+1));u?u=Object.assign(p,u):u=p,c=c.slice(0,E)}let h=this.parsePath(c,o,u);h?.id!==void 0?(h.query&&(u?u=Object.assign(h.query,u):u=h.query),_=h.isCollection,c=h.id):c=h}c===void 0&&(c=s.id??null,c==null&&(_=!0))}else c=s??null,c==null&&(_=!0);o||(o={});let d;if(u?.ensureLoaded!=null||u?.async||_?(d=Object.assign({},t),u?.ensureLoaded!=null&&(d.ensureLoaded=u.ensureLoaded),u?.async&&(d.async=u.async),_&&(d.isCollection=!0)):d=t,o.transaction){let E=this.getResource(c,o,d);return E.then?E.then(f):f(E)}else return d.resetTransaction=!0,We(o,()=>{let E=this.getResource(c,o,d);return E.then?E.then(f):f(E)},d);function f(E){if(o.authorize){o.authorize=!1;let h=t.type==="read"?E.allowRead(o.user,u,o):t.type==="update"?E.doesExist?.()===!1?E.allowCreate(o.user,l,o):E.allowUpdate(o.user,l,o):t.type==="create"?E.allowCreate(o.user,l,o):E.allowDelete(o.user,u,o);if(h?.then)return h.then(p=>{if(!p)throw new AE(o.user);return typeof l?.then=="function"?l.then(S=>e(E,u,o,S)):e(E,u,o,l)});if(!h)throw new AE(o.user)}return typeof l?.then=="function"?l.then(h=>e(E,u,o,h)):e(E,u,o,l)}a(f,"authorizeActionOnResource")}}function Vr(e,t){let r=new $H.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 WR(e,t,r){let n=e[Re];if(n){let s=e[yt];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 OE(e,t){let r=t?.propertyResolvers,n=t[Ne],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):WR(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(WR(u,r,n));for(let d of e)_.push(l(d));return _},"transform");let o=e.forceNulls;return a(function c(u){if(u.then)return u.then(c);if(Array.isArray(u))return u.map(f=>f&&typeof f=="object"?c(f):f);let _={},l=i(WR(u,r,n)),d;for(let f of e){let E=l(f);E===void 0&&o&&(E=null),E?.then?(d||(d=[]),d.push(E.then(h=>_[f.name||f]=h))):_[f.name||f]=E}return d?Promise.all(d).then(()=>_):_},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let u=s[c.name];if(!u){let l=r[c.name]?.definition?.tableClass;u=s[c.name]=OE(c.select||c,l)}let _=o(c.name);return u(_)}else return o(c);else return c}}a(i,"handleProperty")}var kH,VH,$H,Ne,Me,fn,Re,Hne,Bt,AE,ol,QR,Sn=Oe(()=>{kH=require("crypto");oc();VH=require("../../index"),$H=B(ee());G_();Ki();mf();Ne=Symbol.for("context"),Me=Symbol.for("primary-key"),fn=Symbol("is-collection"),Re=Symbol("stored-record"),Hne={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Bt=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[Me]=t;let n=r?.[Ne];this[Ne]=n!==void 0?n:r||null}static get=kr(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 _=OE(u,t.constructor);return typeof c?.map=="function"?c.map(_):_(c)}return c}},{type:"read",resetTransaction:!0,ensureLoaded:!0,async:!0});static put=kr(function(t,r,n,s){if(Array.isArray(s)&&t[fn]){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):Vr(t,"put")},{hasContent:!0,type:"update"});static patch=kr(function(t,r,n,s){return t.patch?t.patch(s,r):Vr(t,"patch")},{hasContent:!0,type:"update"});static delete=kr(function(t,r,n,s){return t.delete?t.delete(r):Vr(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,kH.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),We(n,()=>{let i=new this(s,n),o=i.update?i.update(r):Vr(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>s):s})}static invalidate=kr(function(t,r,n,s){return t.invalidate?t.invalidate(r):Vr(t,"delete")},{hasContent:!1,type:"update"});static post=kr(function(t,r,n,s){return t[Me]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=kr(function(t,r,n,s){return t.connect?t.connect(s,r):Vr(t,"connect")},{hasContent:!0,type:"read"});static subscribe=kr(function(t,r,n,s){return t.subscribe?t.subscribe(r):Vr(t,"subscribe")},{type:"read"});static publish=kr(function(t,r,n,s){return t[Me]!=null&&t.update?.(),t.publish?t.publish(s,r):Vr(t,"publish")},{hasContent:!0,type:"create"});static search=kr(function(t,r,n,s){let i=t.search?t.search(r):Vr(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=OE(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=kr(function(t,r,n,s){return t.search?t.search(s,r):Vr(t,"search")},{hasContent:!0,type:"read"});static copy=kr(function(t,r,n,s){return t.copy?t.copy(s,r):Vr(t,"copy")},{type:"create"});static move=kr(function(t,r,n,s){return t.move?t.move(s,r):Vr(t,"move")},{type:"delete"});post(t){if(this[fn])return this.constructor.create(this[Me],t,this[Ne]);Vr(this,"post")}static isCollection(t){return t?.[fn]}static coerceId(t){return t}static parseQuery(t){return hf(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&&Hne[o];if(c)r.headers.set("accept",c);else if(n)n.property=o;else return{query:{property:o},id:GH(t,this),isCollection:ol}}let i=GH(t,this);return ol?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[Ne],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let u;if(i.resourceCache?u=i.resourceCache:u=i.resourceCache=[],u.asMap){let _=u.asMap.get(t);if(s=_?.find(l=>l.constructor===c),s)return s;_||u.asMap.set(t,_=[]),_.push(s=new c(t,i))}else{if(s=u.find(_=>_[Me]===t&&_.constructor===c),s)return s;if(u.push(s=new c(t,i)),u.length>10){let _=new Map;for(let l of u){let d=l[Me],f=_.get(d);f?f.push(l):_.set(d,[l])}i.resourceCache.length=0,i.resourceCache.asMap=_}}}else s=new c(t,i);return o&&(s[fn]=!0),s}subscribe(t){return new pn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new pn}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[Ne]}};Bt.prototype[Ne]=null;(0,VH._assignPackageExport)("Resource",Bt);a(xne,"snake_case");AE=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(GH,"pathToId");QR=class extends Array{static{a(this,"MulitPartId")}toString(){return this.join("/")}};a(kr,"transactional");a(Vr,"missingMethod");a(WR,"selectFromObject");a(OE,"transformForSelect")});function KH(e,t,r,n){let s=e.primaryStore.env.path,i=e.primaryStore.tableId;Fa||((0,bE.onMessageByType)(YH,l=>{WH(l.path)}),Fa=Object.create(null));let o=Fa[s]||(Fa[s]=[]);o.auditStore=e.auditStore,o.lastTxnTime==null&&(o.lastTxnTime=Date.now());let c=o[i];c||(c=o[i]=new Map,c.envs=o,c.tableId=i,c.store=e.primaryStore),t=fa(t);let u=new JR(r);u.startTime=n;let _=c.get(t);return _?_.push(u):(c.set(t,_=[u]),_.tables=c,_.key=t),u.subscriptions=_,u}function WH(e,t){if(!Fa)return;let r=Fa[e];if(!r)return;try{r.auditStore.resetReadTxn()}catch(s){throw s.message+=" in "+e,s}let n;for(let{key:s,value:i}of r.auditStore.getRange({start:r.lastTxnTime,exclusiveStart:!0})){r.lastTxnTime=s;let o=It(i),c=r[o.tableId];if(!c)continue;let u=o.recordId,_,l=fa(o.recordId),d=0;do{let f=c.get(l);if(f){for(let h of f)if(!(d>0&&!(h.includeDescendants&&!(h.onlyChildren&&d>1)))){if(h.startTime>=s){(0,zR.info)("omitting",u,h.startTime,s);continue}try{if(h.crossThreads===!1&&!t)continue;let p;h.supportsTransactions&&h.txnInProgress!==o.version&&(p=!0,h.txnInProgress||(n?n.push(h):n=[h]),h.txnInProgress=o.version),h.listener(u,o,s,p)}catch(p){console.error(p),(0,zR.info)(p)}}}if(l==null)break;let E=l.lastIndexOf?.("/",l.length-2);E>-1?l=l.slice(0,E):l=null,d++}while(!0)}if(n)for(let s of n)s.txnInProgress=null,s.listener(null,{type:"end_txn"},r.lastTxnTime,!0)}function QH(e,t){let r=t||e,n=r.env;if(t&&!t.cache&&(t.cache=new Map),!n.hasBroadcastListener){n.hasBroadcastListener=!0;let s=n.path;r.on("aftercommit",()=>{(0,bE.broadcast)({type:YH,path:s}),WH(s,!0)})}}var zR,bE,YH,Fa,mme,JR,zH=Oe(()=>{zR=B(Y()),bE=B(je());oc();wu();wi();YH="transaction",mme=Buffer.alloc(4096);a(KH,"addSubscription");JR=class extends pn{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(WH,"notifyFromTransactionData");a(QH,"listenToCommits")});var vg={};Ve(vg,{coerceType:()=>NE,makeTable:()=>IE,setServerUtilities:()=>Wne,updateResource:()=>yE});function IE(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:u,schemaDefined:_,dbisDB:l}=e,{expirationMS:d,evictionMS:f,audit:E,trackDeletes:h}=e,{attributes:p}=e;p||(p=[]),QH(i,u);let S=Bh(i,n,u),T=0,A,b,H={},F=Promise.resolve(),v,P,z;for(let $ of p)($.assignCreatedTime||$.name==="__createdtime__")&&(v=$),($.assignUpdatedTime||$.name==="__updatedtime__")&&(P=$),$.expiresAt&&(z=$),$.isPrimaryKey&&(H=$);let W,Q=[],se=[],pe=1,oe=2,xe={},le={},wt=864e5,Ol,bl,Fs,EA=!1,VE,qx=i.getRange({start:!1,end:!1}).constructor,Gx=10,kx=6;E&&pA();class Qe extends Bt{static name=s;static primaryStore=i;static auditStore=u;static primaryKey=t;static tableName=s;static indices=r;static audit=E;static databasePath=o;static databaseName=c;static attributes=p;static expirationTimer;static createdTimeProperty=v;static updatedTimeProperty=P;static propertyResolvers;static sources=[];static get expirationMS(){return d}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),b=m.get&&(!m.get.reliesOnPrototype||m.prototype.get);let I=a(w=>{let y=this.sources.slice(0,-1);if(y=y.filter(U=>U[w]&&(!U[w].reliesOnPrototype||U.prototype[w])),y.length>0)if(y.length===1){let U=y[0];return(L,D,x)=>{if(L?.source!==U)return U[w](D,x,L)}}else return(U,L,D)=>{let x=[];for(let k of y){if(U?.source===k)break;x.push(k[w](L,D,U))}return Promise.all(x)}},"getApplyToIntermediateSource"),O=this.sources[this.sources.length-1],N=a(w=>{if(O[w]&&(!O[w].reliesOnPrototype||O.prototype[w]))return(y,U,L)=>{if(!y?.source)return O[w](U,L,y)}},"getApplyToCanonicalSource");return xe={put:N("put"),patch:N("patch"),delete:N("delete"),publish:N("publish")},le={put:I("put"),patch:I("patch"),delete:I("delete"),publish:I("publish"),invalidate:I("invalidate")},(async()=>{let w=!1,y=a(async(U,L)=>{let D=U.value,x=U.table?Ze[c][U.table]:Qe;if(c===Pn.SYSTEM_SCHEMA_NAME&&(U.table===Pn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||U.table===Pn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(w=!0),U.id===void 0&&(U.id=D[x.primaryKey],U.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(U));U.source=m;let k=await x.getResource(U.id,L,qa);switch(U.type){case"put":return k._writeUpdate(D,!0,qa);case"patch":return k._writeUpdate(D,!1,qa);case"delete":return k._writeDelete(qa);case"publish":return k._writePublish(D,qa);case"invalidate":return k.invalidate(qa);default:ze.error("Unknown operation",U.type,U.id)}},"writeUpdate");try{let U=m.subscribe;U&&h==null&&(h=!0);let L=m.subscribeOnThisThread?m.subscribeOnThisThread((0,Oo.getWorkerIndex)()):(0,Oo.getWorkerIndex)()===0,D=U&&L&&await m.subscribe?.({crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0});if(D){let x;for await(let k of D)try{if(!(k.type==="transaction"?k.writes[0]:k)){ze.error("Bad subscription event",k);continue}if(k.source=m,x)if(k.beginTxn)x.resolve();else{y(k,x);continue}if(k.type==="end_txn")continue;let _e=We(k,()=>{if(k.type==="transaction"){let re=[];for(let ae of k.writes)try{re.push(y(ae,k))}catch(ve){throw ve.message+=" writing "+JSON.stringify(ae)+" of event "+JSON.stringify(k),ve}return Promise.all(re)}else if(k.type==="define_schema"){let re=this.attributes.slice(0),ae;for(let ve of k.attributes)re.find(ne=>ne.name===ve.name)||(re.push(ve),ae=!0);ae&&(ot({table:s,database:c,attributes:re,origin:"cluster"}),fl.signalSchemaChange(new El.SchemaEventMsg(process.pid,Pn.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return k.beginTxn?(x=k,y(k,k),new Promise(re=>{x.resolve=re})):y(k,k)});w&&(await _e,fl.signalUserChange(new El.UserEventMsg(process.pid))),k.onCommit&&(_e?.then?_e.then(k.onCommit):k.onCommit())}catch(ie){ze.error("error in subscription handler",ie)}}}catch(U){ze.error(U)}})(),this}static getResource(m,R,I){let O=super.getResource(m,R,I);if(m!=null){Ya(m);try{if(O.hasOwnProperty(Re))return O;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let N=!I?.async||i.cache?.get(m),w=Rr(R),y=w.getReadTxn();if(y?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return $E(m,R,{transaction:y},N,U=>{if(U?yE(O,U):O[Re]=null,R.onlyIfCached&&R.noCacheStore){if(!O.doesExist())throw new En.ServerError("Entry is not cached",504)}else if(I?.ensureLoaded){let L=YE(m,U,R,O);if(L)return w?.disregardReadTxn(),O[XR]=!0,ZR(L,D=>(yE(O,D),O))}return O})}catch(N){throw N.message.includes("Unable to serialize object")&&(N.message+=": "+JSON.stringify(m)),N}}return O}ensureLoaded(){let m=YE(this[Me],this[$r],this[Ne]);if(m)return this[XR]=!0,ZR(m,R=>{this[$r]=R,this[Re]=R.value,this[_l]=R.version})}static setTTLExpiration(m){if(typeof m=="number")d=m*1e3,f||(f=0);else if(m&&typeof m=="object")d=m.expiration*1e3,f=(m.eviction||0)*1e3,wt=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(d<0)throw new Error("Expiration can not be negative");wt=wt||(d+f)/4,WE()}static enableAuditing(m=!0){E=m,m&&pA(),Qe.audit=m}static coerceId(m){return m===""?null:NE(m,H)}static async dropTable(){if(delete Ze[c][s],c===o){for(let m of p)l.remove(Qe.tableName+"/"+m.name),r[m.name]?.drop();l.remove(Qe.tableName+"/"),i.drop(),await l.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));fl.signalSchemaChange(new El.SchemaEventMsg(process.pid,Pn.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this[fn])return this.search(m);if(this[Me]===null){if(m?.conditions)return this.search(m);let R=Qe.getRecordCount();return{recordCount:R.recordCount,estimatedRecordRange:R.estimatedRange,records:"./",name:s,database:c,attributes:p}}if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this[Ne]?.returnNonexistent)return this}allowRead(m,R){let I=yl(m);if(I?.read){if(I.isSuperUser)return!0;let O=I.attribute_permissions,N=R?.select;if(O?.length>0||EA&&N){if(R||(R={}),N){let w=O?.length>0&&jR(O,"read");R.select=N.map(y=>{let U=y.name||y;if(!w||w[U]){let L=Fs[U]?.definition?.tableClass;if(L){if(y.name||(y={name:y}),!L.prototype.allowRead.call(null,m,y))return!1;if(!y.select)return y.name}return y}}).filter(Boolean)}else R.select=O.filter(w=>w.read&&!Fs[w.attribute_name]).map(w=>w.attribute_name);return R}else return!0}}allowUpdate(m,R){let I=yl(m);if(I?.update){let O=I.attribute_permissions;if(O?.length>0){let N=jR(O,"update");for(let w in R)if(!N[w])return!1;for(let w of O){let y=w.attribute_name;!w.update&&!(y in R)&&(R[y]=this.getProperty(y))}}return!0}}allowCreate(m,R){if(this[fn]){let I=yl(m);if(I?.insert){let O=I.attribute_permissions;if(O?.length>0){let N=jR(O,"insert");for(let w in R)if(!N[w])return!1}else return!0}}else return this.allowUpdate(m,{})}allowDelete(m){return yl(m)?.delete}update(m,R){if(!Rr(this[Ne]))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[Re]={},this[yt]=m):(O=this[yt],O&&(m=Object.assign(O,m)),this[yt]=O=m)),this._writeUpdate(this[yt],R),this}addTo(m,R){if(typeof R=="number")this[al]===XH?this.set(m,(+this.getProperty(m)||0)+R):(this[al]||this.update(),this.set(m,new gE(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")}invalidate(m){let R=this[Ne],I=this[Me];Ya(I),Rr(this[Ne]).addWrite({key:I,store:i,invalidated:!0,entry:this[$r],nodeName:this[Ne]?.nodeName,before:xe.invalidate?.bind(this,R,I),beforeIntermediate:le.invalidate?.bind(this,R,I),commit:(N,w)=>{if(w?.version>N)return;let y=null;for(let U in r)y||(y={}),y[U]=this.getProperty(U);S(I,y,this[$r],N,cl,E,this[Ne],0,"invalidate")}})}static evict(m,R,I){let O=this.Source,N;if(!((b||E)&&(!R||(N=i.getEntry(m),!N||!R)||N.version!==I))){if(b){if(i.hasLock(m,N.version))return;let w;for(let y in r)w||(w={}),w[y]=R[y];if(w)return S(m,w,N,I,ul,null,null,0,null,!0)}return i.ifVersion(I,()=>{Nl(m,R,null)}),E?S(m,null,N,I,ul,null,null,0,null,!0):i.remove(m,I)}}lock(){throw new Error("Not yet implemented")}static operation(m,R){return m.table||=s,m.schema||=c,nx.operation(m,R)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,R,I){let O=this[Ne],N=Rr(O),w=this[Me];Ya(w);let y=this[$r];this[al]=R?XH:$ne;let U={key:w,store:i,entry:y,nodeName:O?.nodeName,validate:L=>{m||(m=this[yt]),R||m&&SE(m)?(this.validate(m,!R),O?.source||(P&&(m[P.name]=P.type==="Date"?new Date(L):P.type==="String"?new Date(L).toISOString():L),R&&(t&&m[t]!==w&&(m[t]=w),v&&(y?.value?m[v.name]=y?.value[v.name]:m[v.name]=v.type==="Date"?new Date(L):v.type==="String"?new Date(L).toISOString():L),m=Ro(m)))):N.removeWrite(U)},before:R?xe.put?()=>xe.put(O,w,m):null:xe.patch?()=>xe.patch(O,w,m):xe.put?()=>xe.put(O,w,Ro(this)):null,beforeIntermediate:R?le.put?()=>le.put(O,w,m):null:le.patch?()=>le.patch(O,w,m):le.put?()=>le.put(O,w,Ro(this)):null,commit:(L,D,x)=>{if(x){if(O&&D?.version>(O.lastModified||0)&&(O.lastModified=D.version),this[$r]=D,D?.value?.[Re])throw new Error("Can not assign a record to a record, check for circular references");R||(this[Re]=D?.value??null)}this[yt]=m,this[_l]=L;let k=D?.value,ie=m;if(this[al]=0,D?.version>L)if(E){let ve=D.localTime,ne=D.version;for(;ie&&(ve>L||ne>L&&ve>0);){let X=u.get(ve),de=It(X);if(ne=de.version,ne>L)if(de.type==="patch"){let Se=de.getValue(i);ie=mE(ie,Se)}else(de.type==="put"||de.type==="delete")&&(ie=null);ve=de.previousLocalTime}}else R?ie=null:ie=mE(ie,k);let _e=Ro(this,ie);if(_e?.[Re])throw new Error("Can not assign a record to a record, check for circular references");this[Re]=_e;let re;R||(re=m),Nl(w,k,_e);let ae=R?"put":"patch";S(w,_e,D,L,0,E,O,O.expiresAt||(d?d+Date.now():0),ae,!1,re)}};N.addWrite(U)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this[fn]){for await(let R of this.search(m))(await Qe.getResource(R[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this[Re]?this._writeDelete(m):!1}_writeDelete(m){let R=Rr(this[Ne]),I=this[Me];Ya(I);let O=this[Ne];return R.addWrite({key:I,store:i,resource:this,nodeName:O?.nodeName,before:xe.delete?.bind(this,O,I),beforeIntermediate:le.delete?.bind(this,O,I),commit:(N,w,y)=>{let U=w?.value;y&&(O&&w?.version>(O.lastModified||0)&&(O.lastModified=w.version),yE(this,w)),!(w?.version>N)&&(Nl(this[Me],U),ze.trace("Write delete entry",I,N),E||h?(S(I,null,this[$r],N,0,E,this[Ne],0,"delete"),E||WE()):i.remove(this[Me]))}}),!0}search(m){let R=this[Ne],I=Rr(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,w={};function y(X,de){let Se;switch(de){case"and":case void 0:if(X.length<1)throw new Error('An "and" operator requires at least one condition');Se=!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 "+de)}let Bn=Se&&{},qs;for(let ke of X){if(ke.conditions){ke.conditions=y(ke.conditions,ke.operator);continue}let Pt=ke[0]??ke.attribute,Qr=Pt==null?H:Ds(p,Pt);if(Qr){if(Se){let Hn=Dn(Pt),vt=Bn[Hn];vt?(vt.push(ke),qs=!0):Bn[Hn]=[ke]}(Qr.type||_g[ke.comparator])&&(ke[1]===void 0?ke.value=L(ke.value,Qr):ke[1]=L(ke[1],Qr))}else if(Pt!=null)throw(0,En.handleHDBError)(new Error,`${Pt} is not a defined attribute`,404)}if(m.enforceExecutionOrder)return X;if(qs)for(let ke in Bn){let Pt=Bn[ke],Qr=Pt.length;if(Qr>1)for(let Hn=0;Hn<Qr;Hn++){let vt=Pt[Hn];if(vt.comparator==="ge"||vt.comparator==="greater_than_equal")for(let Gs=0;Gs<Qr;Gs++){let Io=Pt[Gs];(Io.comparator==="le"||Io.comparator==="less_than_equal")&&(vt.comparator="between",vt.value=[vt.value,Io.value],X.splice(X.indexOf(Io),1))}if(vt.comparator==="equals"||!vt.comparator){for(let Gs=0;Gs<Qr;Gs++)if(Gs!==Hn){let Io=Pt[Gs];X.splice(X.indexOf(Io),1)}break}}}return X}a(y,"prepareConditions");function U(X,de){if(m.enforceExecutionOrder)return X;for(let Se of X)Se.conditions&&(Se.conditions=U(Se.conditions,Se.operator));return X.length>1&&de!=="or"?(0,rx.sortBy)(X,Ef(Qe)):X}a(U,"orderConditions");function L(X,de){return Array.isArray(X)?X.map(Se=>NE(Se,de)):NE(X,de)}a(L,"coerceTypedValues");let D=m.operator;(O.length>0||D)&&(O=y(O,D));let x=typeof m.sort=="object"&&m.sort,k;if(x&&D!=="or"){let X=x.attribute;if(N=O.find(de=>Dn(de.attribute)===Dn(X)),!N){if(!Ds(p,X))throw(0,En.handleHDBError)(new Error,`${Array.isArray(X)?X.join("."):X} is not a defined attribute`,404);N={attribute:X},O.push(N)}N.descending=!!x.descending}O=U(O,D),x&&(O[0]===N?x.next&&(k={dbOrderedAttribute:x.attribute,attribute:x.next.attribute,descending:x.next.descending,next:x.next.next}):(N&&O.splice(O.indexOf(N),1),k=x));let ie=m.select;if(O.length===0&&(O=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:O,operator:D,postOrdering:k,selectApplied:!!ie};let _e=I.useReadTxn(),re=dg(O,D,Qe,_e,m,R,(X,de)=>hA(X,ie,R,de),w);(m.offset||m.limit!==void 0)&&(re=re.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0));let ae=m.ensureLoaded!==!1,ve=Qe.transformEntryForSelect(ie,R,w,ae,!0),ne=Qe.transformToOrderedSelect(re,ie,k,R,ve);return ne.onDone=()=>{ne.onDone=null,I.doneReadTxn()},ne.selectApplied=!0,ne.getColumns=()=>{if(ie){let X=[];for(let de of ie)de==="*"?X.push(...p.map(Se=>Se.name)):X.push(de.name||de);return X}return p.map(X=>X.name)},ne}static transformToOrderedSelect(m,R,I,O,N){let w=new qx;if(I){m=hA(m,R,O,null);let y;w.iterate=function(){let L,D=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),x,k=I.dbOrderedAttribute,ie,_e,re=!0;function ae(ne){let X=ne.next&&ae(ne.next),de=ne.descending;return(Se,Bn)=>{let qs=KE(Se,ne.attribute,O),ke=KE(Bn,ne.attribute,O),Pt=de?(0,bo.compareKeys)(ke,qs):(0,bo.compareKeys)(qs,ke);return Pt===0?X?.(Se,Bn)||0:Pt}}a(ae,"createComparator");let ve=ae(I);return{async next(){let ne;if(L)if(ne=L.next(),ne.done){if(x)return w.onDone&&w.onDone(),ne}else return{value:await N(ne.value)};y=[],ie&&y.push(ie);do if(ne=await D.next(),ne.done){if(x=!0,y.length)break;return w.onDone&&w.onDone(),ne}else{let X=ne.value;if(X?.then&&(X=await X),k){let de=KE(X,k,O);if(re)re=!1,_e=de;else if(de!==_e){_e=de,ie=X;break}}y.push(X)}while(!0);return I.isGrouped,y.sort(ve),L=y[Symbol.iterator](),ne=L.next(),ne.done?(w.onDone&&w.onDone(),ne):{value:await N(ne.value)}},return(){w.onDone&&w.onDone(),D.return()},throw(){w.onDone&&w.onDone(),D.throw()}}};let U=a(L=>{if(typeof R=="object"&&Array.isArray(L.attribute))for(let D=0;D<R.length;D++){let x=R[D],k;if(x.name===L.attribute[0]){for(k=x.sort||(x.sort={});k.next;)k=k.next;k.attribute=L.attribute.slice(1),k.descending=L.descending}else x===L.attribute[0]&&(R[D]=k={name:x,sort:{attribute:L.attribute.slice(1),descending:L.descending}})}L.next&&U(L.next)},"applySortingOnSelect");U(I)}else w.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),w=w.map(N);return w}static transformEntryForSelect(m,R,I,O,N){if(m&&(m===t||m?.length===1&&m[0]===t)){let L=a(D=>D?.key??D,"transform");return m===t?L:m.asArray?D=>[L(D)]:D=>({[t]:L(D)})}let w;O&&b&&!m?.every(L=>{let D;return typeof L=="object"?D=L.name:D=L,r[D]||D===t})&&(w=!0);let y,U=a(L=>{let D;if(L){if(VE=L,D=L.value||L.deref?.(),!D&&(L.key===void 0||L.deref)){if(L=$E(L.key??L,R,{transaction:Rr(R).getReadTxn(),lazy:m?.length<4},!1,x=>x),L?.then)return L.then(U);D=L?.value}if(w&&(L.metadataFlags&(cl|ul)||L.expiresAt&&L.expiresAt<Date.now())){let x=YE(L.key??L,L,R);if(x?.then)return x.then(U)}}if(D==null)return N?Ao.SKIP:D;if(m&&!(m[0]==="*"&&m.length===1)){let x,k=a((_e,re)=>{let ae;typeof _e=="object"?ae=_e.name:ae=_e;let ve=Fs?.[ae],ne;if(ve){let X=I?.[ae];if(X)if(X.hasMappings){let Se=ve.from?D[ve.from]:Dn(L.key);ne=X.get(Se),ne||(ne=[])}else ne=X.fromRecord?.(D);else ne=ve(D,R,L);let de=a(Se=>{if(Se&&typeof Se=="object"){let Bn=ve.definition?.tableClass||Qe;y||(y={});let qs=y[ae]||(y[ae]=Bn.transformEntryForSelect(ae===_e?null:_e.select||(Array.isArray(_e)?_e:null),R,X,O));if(Array.isArray(Se)){let ke=[],Pt=Bn.transformToOrderedSelect(Se,_e.select,typeof _e.sort=="object"&&_e.sort,R,qs)[Symbol.asyncIterator](),Qr=a(vt=>{for(;!vt.done;){if(vt?.then)return vt.then(Qr);ke.push(vt.value),vt=Pt.next()}re(ke,ae)},"nextValue"),Hn=Qr(Pt.next());Hn&&(x||(x=[]),x.push(Hn));return}else if(Se=qs(Se),Se?.then){x||(x=[]),x.push(Se.then(ke=>re(ke,ae)));return}}re(Se,ae)},"handleResolvedValue");ne?.then?(x||(x=[]),x.push(ne.then(de))):de(ne);return}else ne=D[ae],ne&&typeof ne=="object"&&ae!==_e&&(ne=this.transformEntryForSelect(_e.select||_e,R,null)({value:ne}));re(ne,ae)},"selectAttribute"),ie;if(typeof m=="string")k(m,_e=>{ie=_e});else if(Array.isArray(m))if(m.asArray)ie=[],m.forEach((_e,re)=>{_e==="*"?m[re]=D:k(_e,ae=>ie[re]=ae)});else{ie={};let _e=m.forceNulls;for(let re of m)if(re==="*")for(let ae in D)ie[ae]=D[ae];else k(re,(ae,ve)=>{ae===void 0&&_e&&(ae=null),ie[ve]=ae})}else throw new En.ClientError("Invalid select"+m);return x?Promise.all(x).then(()=>ie):ie}return D},"transform");return U}async subscribe(m){if(!u)throw new Error("Can not subscribe to a table without an audit log");E||ot({table:s,database:c,schemaDefined:_,attributes:p,audit:!0}),m||(m={});let R=!m.rawEvents,I=KH(Qe,this[Me]??null,function(y,U,L,D){try{let x=U.getValue?.(i,R);if(!x&&U.type==="patch"&&R){let k=i.getEntry(y);k?.version===U.version?x=k.value:x=U.getValue?.(i,!0,L),U.type="put"}this.send({id:y,timestamp:L,value:x,version:U.version,type:U.type,beginTxn:D})}catch(x){ze.error(x)}},m.startTime||0,this[fn]);this[fn]&&(I.includeDescendants=!0,m.onlyChildren&&(I.onlyChildren=!0)),m.crossThreads===!1&&(I.crossThreads=!1),m.supportsTransactions&&(I.supportsTransactions=!0);let O=this[Me],N=m.previousCount;N>1e3&&(N=1e3);let w=m.startTime;if(this[fn]){if(w){if(N)throw new En.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:y,value:U}of u.getRange({start:w,exclusiveStart:!0})){let L=It(U);if(L.tableId!==n)continue;let D=L.recordId;(O==null||ex(O,D))&&I.send({id:D,timestamp:y,...L}),I.startTime=y}}else if(N){let y=[];for(let{key:U,value:L}of u.getRange({start:"z",end:!1,reverse:!0}))try{let D=It(L);if(D.tableId!==n)continue;let x=D.recordId;if(O==null||ex(O,x)){let k=D.getValue(i,R,U);if(y.push({id:x,timestamp:U,value:k,version:D.version,type:D.type}),--N<=0)break}}catch(D){ze.error("Error getting history entry",U,D)}for(let U=y.length;U>0;)I.send(y[--U]);y[0]&&(I.startTime=y[0].timestamp)}else if(!m.omitCurrent)for(let{key:y,value:U,version:L,localTime:D}of i.getRange({start:O??!1,end:O==null?void 0:[O,bo.MAXIMUM_KEY],versions:!0}))U&&I.send({id:y,version:L,timestamp:D,value:U})}else{N&&!w&&(w=0);let y=this[$r]?.localTime;if(y===vh&&(i.cache?.delete(O),this[$r]=i.getEntry(O),ze.trace("re-retrieved record",y,this[$r]?.localTime),y=this[$r]?.localTime),ze.trace("Subscription from",w,"from",O,y),w<y){let U=[],L=y;do{let D=u.get(L);if(D){m.omitCurrent=!0;let x=It(D),k=x.getValue(i,R,L);R&&(x.type="put"),U.push({id:O,value:k,timestamp:L,...x}),L=x.previousLocalTime}else break;N&&N--}while(L>w&&N!==0);for(let D=U.length;D>0;)I.send(U[--D]);I.startTime=y}!m.omitCurrent&&this.doesExist()&&I.send({id:O,version:this[_l],timestamp:y,value:this})}return m.listener&&I.on("data",m.listener),I}doesExist(){return!!(this[Re]||this[al])}publish(m,R){this._writePublish(m,R)}_writePublish(m,R){let I=Rr(this[Ne]),O=this[Me]||null;Ya(O);let N=this[Ne];I.addWrite({key:O,store:i,entry:this[$r],nodeName:N?.nodeName,validate:()=>{this.validate(m)},before:xe.publish?.bind(this,N,O,m),beforeIntermediate:le.publish?.bind(this,N,O,m),commit:(w,y,U)=>{y===void 0&&h&&!E&&WE(),S(O,y?.value??null,y,y?.version||w,0,!0,N,y?.expiresAt,"message",!1,m)}})}validate(m,R){let I,O=a((N,w,y)=>{if(w.type&&N!=null)if(R&&N.__op__&&(N=N.value),w.properties){typeof N!="object"&&(I||(I=[])).push(`Property ${y} must be an object${w.type?" ("+w.type+")":""}`);let U=w.properties;for(let L=0,D=U.length;L<D;L++){let x=U[L],k=O(N[x.name],x,y+"."+x.name);k&&(N[x.name]=k)}}else switch(w.type){case"Int":(typeof N!="number"||N>>0!==N)&&(I||(I=[])).push(`Property ${y} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof N!="number"||!(Math.floor(N)===N&&Math.abs(N)<=9007199254740992))&&(I||(I=[])).push(`Property ${y} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof N!="number"&&(I||(I=[])).push(`Property ${y} must be a number`);break;case"ID":typeof N=="string"||N?.length>0&&N.every?.(U=>typeof U=="string")||(I||(I=[])).push(`Property ${y} must be a string, or an array of strings`);break;case"String":typeof N!="string"&&(I||(I=[])).push(`Property ${y} must be a string`);break;case"Boolean":typeof N!="boolean"&&(I||(I=[])).push(`Property ${y} must be a boolean`);break;case"Date":if(!(N instanceof Date)){if(typeof N=="string"||typeof N=="number")return new Date(N);(I||(I=[])).push(`Property ${y} must be a Date`)}break;case"BigInt":if(typeof N!="bigint"){if(typeof N=="string"||typeof N=="number")return BigInt(N);(I||(I=[])).push(`Property ${y} must be a bigint`)}break;case"Bytes":N instanceof Uint8Array||(I||(I=[])).push(`Property ${y} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(N)){if(w.elements)for(let U=0,L=N.length;U<L;U++){let D=N[U],x=O(D,w.elements,y+"[*]");x&&(N[U]=x)}}else(I||(I=[])).push(`Property ${y} must be a Buffer or Uint8Array`);break}w.nullable===!1&&N==null&&(I||(I=[])).push(`Property ${y} is required (and not does not allow null values)`)},"validateValue");for(let N=0,w=p.length;N<w;N++){let y=p[N];if(!y.relationship&&(!R||y.name in m)){let U=O(m[y.name],y,y.name);U&&(m[y.name]=U)}}if(I)throw new En.ClientError(I.join(". "))}getUpdatedTime(){return this[_l]}wasLoadedFromSource(){return b?!!this[XR]:void 0}static async addAttributes(m){let R=p.slice(0);for(let I of m){if(!I.name)throw new En.ClientError("Attribute name is required");if(I.name.match(/[`/]/))throw new En.ClientError("Attribute names cannot include backticks or forward slashes");R.push(I)}return ot({table:s,database:c,schemaDefined:_,attributes:R}),Qe.indexingOperation}static async removeAttributes(m){let R=p.filter(I=>!m.includes(I.name));return ot({table:s,database:c,schemaDefined:_,attributes:R}),Qe.indexingOperation}static getRecordCount(m){let R=i.getStats().entryCount,I=5e3,O=1e3,N;R>I&&!m?.exactCount&&(N=O);let w=0;for(let{value:y}of i.getRange({start:!0,lazy:!0,limit:N}))y!=null&&w++;if(N){let y=w;w=0;for(let{value:ae}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:N}))ae!=null&&w++;let U=N*2,L=(w+y)/U,D=Math.pow((w-y+1)/N/2,2)+L*(1-L)/U,x=Math.max(Math.sqrt(D)*R,1),k=Math.round(L*R),ie=Math.max(k-1.96*x,0),_e=Math.min(k+1.96*x,R),re=Math.pow(10,Math.round(Math.log10(x)));return re>k&&(re=re/10),w=Math.round(k/re)*re,{recordCount:w,estimatedRange:[Math.round(ie),Math.round(_e)]}}return{recordCount:w}}static updatedAttributes(){Fs=this.propertyResolvers={$id:(m,R,I)=>({value:I.key}),$updatedtime:(m,R,I)=>I.version,$record:(m,R,I)=>I?{value:m}:m};for(let m of this.attributes){m.resolve=null;let R=m.relationship;if(R)if(EA=!0,R.to)m.elements?.definition?(Fs[m.name]=m.resolve=(I,O,N)=>{let w=I[R.from?R.from:t],y=m.elements.definition.tableClass;return N?Oa({attribute:R.to,value:w},Rr(O).getReadTxn(),!1,y).asArray:y.search([{attribute:R.to,value:w}],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 I=m.definition||m.elements?.definition;I?(Fs[m.name]=m.resolve=(O,N,w)=>{let y=O[R.from];if(y!==void 0){if(m.elements){let U,L=y.map(D=>{let x=w?I.tableClass.primaryStore.getEntry(D,{transaction:Rr(N).getReadTxn()}):I.tableClass.get(D,N);return x?.then&&(U=!0),x});return R.filterMissing?U?Promise.all(L).then(D=>D.filter(tx)):L.filter(tx):U?Promise.all(L):L}return w?I.tableClass.primaryStore.getEntry(y,{transaction:Rr(N).getReadTxn()}):I.tableClass.get(y,N)}},m.set=(O,N)=>{if(Array.isArray(N)){let w=N.map(y=>y[Me]||y[I.tableClass.primaryKey]);O[R.from]=w}else{let w=N[Me]||N[I.tableClass.primaryKey];O[R.from]=w}},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`)}RE(this,this)}static async deleteHistory(m=0){let R;for(let{key:I,value:O}of u.getRange({start:0,end:m}))await ll(),It(O).tableId===n&&(R=u.remove(I));await R}static async*getHistory(m=0,R=1/0){for(let{key:I,value:O}of u.getRange({start:m,end:R})){await ll();let N=It(O);N.tableId===n&&(yield{id:N.recordId,localTime:I,version:N.version,type:N.type,value:N.getValue(i,!0,I),user:N.user})}}static async getHistoryOfRecord(m){let R=[];if(m==null)throw new Error("An id is required");let I=i.getEntry(m);if(!I)return R;let O=I.localTime;if(!O)throw new Error("The entry does not have a local audit time");let N=0;do{await ll();let w=u.get(O);if(w){let y=It(w);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(){W?.remove()}}Qe.updatedAttributes();let Vx=Qe.prototype;return Vx[Vne]=!0,d&&Qe.setTTLExpiration(d/1e3),z&&$x(),Qe;function Nl($,m,R){let I;for(let O in r){let N=r[O],w=N.isIndexing,y=R?.[O],U=m?.[O];if(y===U&&!w)continue;I=!0;let L=N.indexNulls,D=(0,dl.getIndexedValues)(U,L);if(D){JH&&N.prefetch(D.map(x=>({key:x,value:$})),ZH);for(let x=0,k=D.length;x<k;x++)N.remove(D[x],$)}if(D=(0,dl.getIndexedValues)(y,L),D){JH&&N.prefetch(D.map(x=>({key:x,value:$})),ZH);for(let x=0,k=D.length;x<k;x++)N.put(D[x],$)}}return I}a(Nl,"updateIndices");function Ya($){switch(typeof $){case"number":return!0;case"string":if($.length<659)return!0;if($.length>jH)throw new Error("Primary key size is too large: "+$.length);break;case"object":if($===null)return!0;break;case"bigint":if($<2n**64n&&$>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof $)}if((0,bo.writeKey)($,Yne,0)>jH)throw new Error("Primary key size is too large: "+$.length);return!0}a(Ya,"checkValidId");function $E($,m,R,I,O){let N=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),R.transaction?.isDone)return O(null,$);let w=i.getEntry($,R);return w&&m&&(w?.version>(m.lastModified||0)&&(m.lastModified=w.version),w?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=w.localTime)),O(w,$)},"whenPrefetched");return I?N():pe>0?(pe--,N()):new Promise((w,y)=>{pe===0?(pe--,i.prefetch([$],()=>{U(),L()})):(Q.push($),se.push(L),Q.length>kx&&(pe--,U()));function U(){if(Q.length>0){let D=se;i.prefetch(Q,()=>{pe===-1?U():pe++;for(let x of D)x()}),Q=[],se=[],oe>2&&oe--}else pe=oe,oe<Gx&&oe++}a(U,"prefetch");function L(){try{w(N())}catch(D){y(D)}}a(L,"load")})}a($E,"loadLocalRecord");function yl($){if(!$?.role)return;let m=$.role.permission;if(m.super_user)return Kne;let R=m[c],I,O=R?.tables;if(O)return O[s];if(c==="data"&&(I=m[s])&&!I.tables)return I}a(yl,"getTablePermissions");function YE($,m,R,I){if(b){let O;if(R.noCache?O=!0:(m?(!m.value||m.metadataFlags&(cl|ul)||m.expiresAt&&m.expiresAt<Date.now())&&(O=!0):O=!0,en(!O,"cache-hit",s)),O){let N=mA($,m,R).then(w=>(w?.value?.[Re]&&ze.error("Can not assign a record with a record property"),R&&(w?.version>(R.lastModified||0)&&(R.lastModified=w.version),R.lastRefreshed=Date.now()),w));if(R?.onlyIfCached||m?.value&&I?.allowStaleWhileRevalidate?.(m,$)){if(N.catch(w=>ze.warn(w)),R?.onlyIfCached&&!I.doesExist())throw new En.ServerError("Entry is not cached",504);return}else return N}}}a(YE,"ensureLoadedFromSource");function Rr($){let m=$?.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 Yi,m.lmdbDb=i,m;m=R}while(!0)}else return new x_}a(Rr,"txnForContext");function KE($,m,R){if(!$)return;VE=$;let I=$.value||$.deref?.()||(VE=i.getEntry($.key))?.value;if(typeof m=="object"){let N=Fs,w=I;for(let y=0,U=m.length;y<U;y++){let L=m[y],D=N?.[L];w=D&&w?D(w,R,!0)?.value:w?.[L],N=D?.definition?.tableClass?.propertyResolvers}return w}let O=Fs[m];return O?O(I,R):I[m]}a(KE,"getAttributeValue");function hA($,m,R,I){let O=Rr(R).getReadTxn(),N=I?.length,w={transaction:O,lazy:N>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},y;function U(L,D){let x=L?.value;if(!x)return Ao.SKIP;for(let k=0;k<N;k++)if(!y?.includes(k)&&!I[k](x,L))return Ao.SKIP;return D!==void 0&&(L.key=D),L}if(a(U,"processEntry"),N>0||!$.hasEntries){let L=$.map(D=>{if(y=null,typeof D=="object"&&D.key!==void 0)return N>0?U(D):D;if(D==null)return Ao.SKIP;for(let x=0;x<N;x++){let ie=I[x].idFilter;if(ie){if(!ie(D))return Ao.SKIP;y||(y=[]),y.push(x)}}return $E(D,R,w,!1,U)});return Array.isArray($)&&(L=L.filter(D=>D!==Ao.SKIP)),L.hasEntries=!0,L}return $}a(hA,"transformToEntries");async function mA($,m,R){let I=m?.metadataFlags,O=m?.version,N,w;if(!i.attemptLock($,O,()=>{clearTimeout(w);let D=i.getEntry($);!D||!D.value||D.metadataFlags&(cl|ul)?N(mA($,i.getEntry($),R)):N(D)}))return new Promise(D=>{N=D,w=setTimeout(()=>{i.unlock($,O)},kne)});let y=m?.value,U={requestContext:R,replacingRecord:y,replacingVersion:O,source:null,resourceCache:R?.resourceCache},L=R?.responseHeaders;return new Promise((D,x)=>{let k;ZR(We(U,async ie=>{let _e=performance.now(),re,ae,ve;try{for(let Se of Qe.sources)if(Se.get&&(!Se.get.reliesOnPrototype||Se.prototype.get)&&(U.source=Se,re=await Se.get($,U),re))break;ve=I&cl;let X=U.lastModified||ve&&O;ae=ve||X>O||!y,X||(X=(0,dl.getNextMonotonicTime)());let de=performance.now()-_e;if(vr(de,"cache-resolution",s),L&&L.append("Server-Timing",`cache-resolve;dur=${de.toFixed(2)}`),ie.timestamp=X,d&&!U.expiresAt&&(U.expiresAt=Date.now()+d),re){if(typeof re!="object")throw new Error("Only objects can be cached and stored in tables");typeof re.toJSON=="function"&&(re=re.toJSON()),t&&re[t]!==$&&(re[t]=$)}k=!0,D({version:X,value:re})}catch(X){X.message+=` while resolving record ${$} for ${s}`,y&&((X.code==="ECONNRESET"||X.code==="ECONNREFUSED"||X.code==="EAI_AGAIN")&&!R?.mustRevalidate||R?.staleIfError&&(X.statusCode===500||X.statusCode===502||X.statusCode===503||X.statusCode===504))?(D({version:O,value:y}),ze.trace(X.message,"(returned stale record)")):x(X),U.transaction.abort();return}if(R?.noCacheStore){U.transaction.abort();return}Rr(U).addWrite({key:$,store:i,entry:m,nodeName:"source",commit:(X,de)=>{if(de?.version!==O)return;let Se=Nl($,y,re);re?(le.put?.(U,$,re),S($,re,de,X,0,E&&ae||null,U,U.expiresAt,"put",!!ve)):(le.delete?.(U,$),E||h?S($,null,de,X,0,E&&ae||null,U,0,"delete",!!ve):i.remove($,O))}})}),()=>{i.unlock($,O)},ie=>{i.unlock($,O),k&&ze.error("Error committing cache update",ie)})})}a(mA,"getFromSource");function WE(){if(wt!==Ol&&(Ol=wt,(0,Oo.getWorkerIndex)()===(0,Oo.getWorkerCount)()-1)){if(bl&&clearTimeout(bl),!wt)return;let $=new Date;$.setMonth(0),$.setDate(1),$.setHours(0),$.setMinutes(0),$.setSeconds(0);let m=Math.ceil((Date.now()-$.getTime())/wt)*wt+$.getTime(),R=a(I=>{ze.trace(`Scheduled next cleanup scan at ${new Date(I)}ms`),bl=setTimeout(()=>F=F.then(async()=>{if(R(Math.max(I+wt,Date.now())),i.rootStore.status!=="open"){clearTimeout(bl);return}let O=50,N=new Array(O),w=0;ze.trace(`Starting cleanup scan for ${s}`);try{let y=0;for(let{key:U,value:L,version:D,expiresAt:x}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let k;L===null&&!E&&D+Gne<Date.now()?k=i.remove(U,D):x&&x+f<Date.now()&&(k=Qe.evict(U,L,D),y++),k&&(await N[w],N[w]=k.catch(ie=>{ze.error("Cleanup error",ie)}),++w>=O&&(w=0)),await ll()}ze.trace(`Finished cleanup scan for ${s}, evicted ${y} entries`)}catch(y){ze.trace(`Error in cleanup scan for ${s}:`,y)}}),Math.min(I-Date.now(),2147483647)).unref()},"startNextTimer");R(m)}}a(WE,"scheduleCleanup");function pA(){W=u?.addDeleteRemovalCallback(n,$=>{let m=i.getEntry($);m?.value===null&&i.remove($,m.version)})}a(pA,"addDeleteRemoval");function $x(){(0,Oo.getWorkerIndex)()===0&&setInterval(async()=>{try{let $=z.name,m=r[$];if(!m)throw new Error(`expiresAt attribute ${z} must be indexed`);for(let{value:R}of m.getRange({start:!0,end:Date.now(),versions:!0,snapshot:!1})){let I=i.getEntry(R);I?.value?.[$]<Date.now()&&Qe.evict(R,I.value,I.version),await ll()}}catch($){ze.error("Error in evicting old records",$)}},qne).unref()}a($x,"runRecordExpirationEviction")}function jR(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 ZH(){}function Wne(e){nx=e}function NE(e,t){let r=t?.type;return e===null?e:r==="Int"||r==="Long"?e==="null"?null:parseInt(e):r==="Float"?e==="null"?null:parseFloat(e):r==="BigInt"?e==="null"?null:BigInt(e):r==="Date"?(typeof e!="number"&&!Qne.test(e)&&(e+="Z"),e==="null"?null:new Date(e)):!r||r==="Any"?(0,wE.autoCast)(e):e}function ex(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 ZR(e,t,r){return e?.then?e.then(t,r):t(e)}function yE(e,t){e[$r]=t,e[Re]=t?.value??null,e[_l]=t?.version}function tx(e){return e!=null}var Pn,Ao,dl,rx,hl,En,fl,El,ze,bo,Oo,wE,Fne,nx,qne,Gne,JH,kne,_l,Vne,$r,al,XH,$ne,XR,qa,cl,ul,Yne,jH,Kne,Ume,Qne,ll,Mf=Oe(()=>{Pn=B(M()),Ao=require("lmdb"),dl=B(br()),rx=require("lodash");Sn();Lp();hl=B(Z());zH();En=B(ee()),fl=B(hs()),El=B(bn());be();mf();ze=B(Y());G_();Ki();bo=require("ordered-binary"),Oo=B(je());wi();wE=B(J());Uo();Ts();EE();Fne=new Uint8Array(9);Fne[8]=192;qne=6e4,Gne=864e5;hl.initSync();JH=hl.get(Pn.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),kne=1e4,_l=Symbol.for("version"),Vne=Symbol.for("incremental-update"),$r=Symbol("entry"),al=Symbol("is-saving"),XH=1,$ne=2,XR=Symbol("loaded-from-source"),qa={isNotification:!0,ensureLoaded:!1},cl=1,ul=8,Yne=Buffer.allocUnsafeSlow(8192),jH=1978,Kne={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},Ume=(0,wE.convertToMS)(hl.get(Pn.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(IE,"makeTable");a(jR,"attributesAsObject");a(ZH,"noop");a(Wne,"setServerUtilities");Qne=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(NE,"coerceType");a(ex,"isDescendantId");ll=a(()=>new Promise(setImmediate),"rest");a(ZR,"when");a(yE,"updateResource");a(tx,"exists")});var Fe={};Ve(Fe,{database:()=>kc,databases:()=>Ze,dropDatabase:()=>Bp,dropTableMeta:()=>ese,getDatabases:()=>yn,getTables:()=>zne,onUpdatedTable:()=>pR,readMetaDb:()=>ml,resetDatabases:()=>Jne,table:()=>ot,tables:()=>Nr});function zne(){return UE||yn(),Nr||{}}function yn(){if(UE)return Ze;UE=!0,Va=new Map;let e=(0,zt.getHdbBasePath)()&&(0,Je.join)((0,zt.getHdbBasePath)(),Kr.DATABASES_DIR_NAME),t=(0,zt.get)(Kr.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,zt.get)(Kr.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,Yr.existsSync)(e)?e:(0,Je.join)((0,zt.getHdbBasePath)(),Kr.LEGACY_DATABASES_DIR_NAME)),!!e){if((0,Yr.existsSync)(e))for(let r of(0,Yr.readdirSync)(e,{withFileTypes:!0})){let n=(0,Je.basename)(r.name,".mdb");r.isFile()&&(0,Je.extname)(r.name).toLowerCase()===".mdb"&&!t[n]?.path&&ml((0,Je.join)(e,r.name),null,n)}if((0,Yr.existsSync)((0,ka.getBaseSchemaPath)())){for(let r of(0,Yr.readdirSync)((0,ka.getBaseSchemaPath)(),{withFileTypes:!0}))if(!r.isFile()){let n=(0,Je.join)((0,ka.getBaseSchemaPath)(),r.name),s=(0,Je.join)((0,ka.getTransactionAuditStoreBasePath)(),r.name);for(let i of(0,Yr.readdirSync)(n,{withFileTypes:!0}))if(i.isFile()&&(0,Je.extname)(i.name).toLowerCase()===".mdb"){let o=(0,Je.join)(s,i.name);ml((0,Je.join)(n,i.name),(0,Je.basename)(i.name,".mdb"),r.name,o,!0)}}}if(t)for(let r in t){let n=t[r],s=n.path;if((0,Yr.existsSync)(s))for(let o of(0,Yr.readdirSync)(s,{withFileTypes:!0}))o.isFile()&&(0,Je.extname)(o.name).toLowerCase()===".mdb"&&ml((0,Je.join)(s,o.name),(0,Je.basename)(o.name,".mdb"),r);let i=n.tables;if(i)for(let o in i){let c=i[o],u=(0,Je.join)(c.path,(0,Je.basename)(o+".mdb"));(0,Yr.existsSync)(u)&&ml(u,o,r,null,!0)}}for(let r in Ze){let n=Va.get(r);if(n){let s=Ze[r];r.includes("delete")&&hn.trace(`defined tables ${Array.from(n.keys())}`);for(let i in s)n.has(i)||(hn.trace(`delete table class ${i}`),delete s[i])}else if(delete Ze[r],r==="data"){for(let s in Nr)delete Nr[s];delete Nr[PE]}}return Va=null,Ze}}function Jne(){UE=!1;for(let[,e]of gi)e.needsDeletion=!0;yn();for(let[e,t]of gi)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),gi.delete(e));return Ze}function ml(e,t,r=rA,n,s){let i=new eA.default(e,!1);try{let o=gi.get(e);o?o.needsDeletion=!1:(o=(0,DE.open)(i),gi.set(e,o));let c=new No.default(!1),u=o.dbisDb||(o.dbisDb=o.openDB(CE.INTERNAL_DBIS_NAME,c)),_=o.auditStore;_||(n?(0,Yr.existsSync)(n)&&(i.path=n,_=(0,DE.open)(i),_.isLegacy=!0):_=fE(o));let l=ax(r),d=l[PE],f=new Map;for(let{key:E,value:h}of u.getRange({start:!1})){let[p,S]=E.toString().split("/");S===""?S=h.name:S||(S=p,p=t,h.name||(h.name=S,h.indexed=!h.is_hash_attribute)),d?.add(p);let T=f.get(p);T||f.set(p,T={attributes:[]}),(S==null||h.is_hash_attribute)&&(T.primary=h),S!=null&&T.attributes.push(h),Object.defineProperty(h,"key",{value:E,configurable:!0})}for(let[E,h]of f){let{attributes:p,primary:S}=h;if(!S){for(let Q of p)if(Q.is_hash_attribute||Q.isPrimaryKey){S=Q;break}if(!S){hn.fatal(`Unable to find a primary key attribute on table ${E}, with attributes: ${JSON.stringify(p)}`);continue}}let T=l[E],A={},b=[],H,F,v=typeof S.audit=="boolean"?S.audit:(0,zt.get)(Kr.CONFIG_PARAMS.LOGGING_AUDITLOG),P=S.trackDeletes,z=S.expiration,W=S.eviction;if(T)A=T.indices,b=T.attributes,T.schemaVersion++;else{H=S.tableId,H?H>=(u.get(Ga)||0)&&u.putSync(Ga,H+1):(S.tableId=H=u.get(Ga),H||(H=1),u.putSync(Ga,H+1),u.putSync(S.key,S));let Q=new No.default(!S.is_hash_attribute,S.is_hash_attribute);F=Wl(o.openDB(S.key,Q)),F.rootStore=o,F.tableId=H}for(let Q of p){Q.attribute=Q.name;try{if(!Q.is_hash_attribute&&(Q.indexed||Q.attribute&&!Q.name)){if(!A[Q.name]){let pe=new No.default(!Q.is_hash_attribute,Q.is_hash_attribute);A[Q.name]=o.openDB(Q.key,pe),A[Q.name].indexNulls=Q.indexNulls}let se=b.find(pe=>pe.name===Q.name);se?b.splice(b.indexOf(se),1,Q):b.push(Q)}}catch(se){hn.error("Error trying to update attribute",Q,b,A,se)}}if(!T){T=cx(l,E,IE({primaryStore:F,auditStore:_,audit:v,expirationMS:z&&z*1e3,evictionMS:W&&W*1e3,trackDeletes:P,tableName:E,tableId:H,primaryKey:S.name,databasePath:s?r+"/"+E:r,databaseName:r,indices:A,attributes:p,schemaDefined:S.schemaDefined,dbisDB:u})),T.schemaVersion=1;for(let Q of nA)Q(T)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function ax(e){let t=Ze[e];if(t||(e==="data"?t=Ze[e]=Nr:e==="system"?Object.defineProperty(Ze,"system",{value:t=Object.create(null),configurable:!0}):t=Ze[e]=Object.create(null)),Va&&!Va.has(e)){let r=new Set;t[PE]=r,Va.set(e,r)}return t}function cx(e,t,r){return e[t]=r,r}function kc({database:e,table:t}){e||(e=rA),yn();let r=ax(e),n=(0,Je.join)((0,zt.getHdbBasePath)(),Kr.DATABASES_DIR_NAME),s=(0,zt.get)(Kr.CONFIG_PARAMS.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,zt.get)(Kr.CONFIG_PARAMS.STORAGE_PATH)||((0,Yr.existsSync)(n)?n:(0,Je.join)((0,zt.getHdbBasePath)(),Kr.LEGACY_DATABASES_DIR_NAME));let o=(0,Je.join)(n,(i?t:e)+".mdb"),c=gi.get(o);if(!c){let u=new eA.default(o,!1);c=(0,DE.open)(u),gi.set(o,c)}return c}async function Bp(e){if(!Ze[e])throw new Error("Schema does not exist");let t=Ze[e];for(let r in t){let s=t[r].primaryStore.rootStore;gi.delete(s.path),s.status==="open"&&(await s.close(),await sx.remove(s.path))}if(e==="data"){for(let r in Nr)delete Nr[r];delete Nr[PE]}delete Ze[e]}function ot({table:e,database:t,expiration:r,eviction:n,scanInterval:s,attributes:i,audit:o,trackDeletes:c,schemaDefined:u,origin:_}){t||(t=rA);let l=kc({database:t,table:e}),d=Ze[t],f=d?.[e];if(l.status==="closed")throw new Error(`Can not use a closed data store for ${e}`);let E,h,p,S;u==null&&(u=!0);let T=new No.default(!1);for(let P of i)P.attribute?(P.name=P.attribute,P.indexed=!0):P.attribute=P.name,P.expiresAt&&(P.indexed=!0);let A,b;if(f){if(E=f.primaryKey,f.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${e} class`);f.attributes.splice(0,f.attributes.length,...i)}else{let P=l.auditStore;P||(P=fE(l)),h=i.find(se=>se.isPrimaryKey)||{},E=h.name,h.is_hash_attribute=!0,h.schemaDefined=u,c&&(h.trackDeletes=!0),o=h.audit=typeof o=="boolean"?o:(0,zt.get)(Kr.CONFIG_PARAMS.LOGGING_AUDITLOG),r&&(h.expiration=r),n&&(h.eviction=n),_&&(h.origins?h.origins.includes(_)||h.origins.push(_):h.origins=[_]),hn.trace(`${e} table loading, opening primary store`);let z=new No.default(!1,!0),W=e+"/",Q=Wl(l.openDB(W,z));Q.rootStore=l,S=l.dbisDb=l.openDB(CE.INTERNAL_DBIS_NAME,T),Q.tableId=S.get(Ga),Q.tableId||(Q.tableId=1),S.putSync(Ga,Q.tableId+1),h.tableId=Q.tableId,f=cx(d,e,IE({primaryStore:Q,auditStore:P,audit:o,trackDeletes:c,expirationMS:r&&r*1e3,evictionMS:n&&n*1e3,primaryKey:E,tableName:e,tableId:Q.tableId,databasePath:t,databaseName:t,indices:{},attributes:i,schemaDefined:u,dbisDB:S})),f.schemaVersion=1,A=!0,v(),S.put(W,h)}p=f.indices,S=S||(l.dbisDb=l.openDB(CE.INTERNAL_DBIS_NAME,T)),f.dbisDB=S;let H=[];for(let{key:P,value:z}of S.getRange({start:!0})){let[W,Q]=P.toString().split("/");if(Q===""&&(Q=z.name),Q){if(W!==e)continue}else Q=W;if(!i.find(pe=>pe.name===Q)?.indexed&&z.indexed&&!z.isPrimaryKey){v(),A=!0,S.remove(P);let pe=f.indices[W];pe&&H.push(pe)}}let F=[];try{for(let P of i||[]){if(P.relationship)continue;let z=e+"/"+(P.name||"");Object.defineProperty(P,"key",{value:z,configurable:!0});let W=S.get(z);if(P.isPrimaryKey){if(W=W||S.get(z=e+"/")||{},o!==f.audit||(+r||void 0)!==(+W.expiration||void 0)||(+n||void 0)!==(+W.eviction||void 0)){let se=Object.assign({},W);typeof o=="boolean"&&(o&&f.enableAuditing(o),se.audit=o),r&&(se.expiration=+r),n&&(se.eviction=+n),A=!0,v(),S.put(z,se)}continue}W?.attribute&&!W.name&&(W.indexed=!0);let Q=!W||W.type!==P.type||W.indexed!==P.indexed||JSON.stringify(W.attributes)!==JSON.stringify(P.attributes)||JSON.stringify(W.elements)!==JSON.stringify(P.elements);if(P.indexed){let se=new No.default(!0,!1),pe=l.openDB(z,se);(Q||W.indexingPID&&W.indexingPID!==process.pid||W.restartNumber<pl.workerData?.restartNumber)&&(A=!0,v(),W=S.get(z),(Q||W.indexingPID&&W.indexingPID!==process.pid||W.restartNumber<pl.workerData?.restartNumber)&&(A=!0,P.lastIndexedKey=W?.lastIndexedKey||!1,P.indexingPID=process.pid,pe.isIndexing=!0,Object.defineProperty(P,"dbi",{value:pe}),P.indexNulls===void 0&&(P.indexNulls=!0),F.push(P)),S.put(z,P)),W?.indexNulls&&P.indexNulls===void 0&&(P.indexNulls=!0),pe.indexNulls=P.indexNulls,p[P.name]=pe}else Q&&(A=!0,v(),S.put(z,P))}}finally{b&&b()}if(A&&(f.schemaVersion++,f.updatedAttributes()),hn.trace(`${e} table loading, running index`),F.length>0||H.length>0?f.indexingOperation=Zne(f,F,H):A&&LE.signalSchemaChange(new ME.SchemaEventMsg(process.pid,"schema-change",f.databaseName,f.tableName)),f.origin=_,A)for(let P of nA)P(f,_!=="cluster");return(r||n||s)&&f.setTTLExpiration({expiration:r,eviction:n,scanInterval:s}),hn.trace(`${e} table loaded`),f;function v(){b||l.transactionSync(()=>({then(P){b=P}}))}a(v,"startTxn")}async function Zne(e,t,r){try{let n=e.schemaVersion;await LE.signalSchemaChange(new ME.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o=0,c=t.length;if(await new Promise(u=>setImmediate(u)),c>0){let u=0;for(let{key:_,value:l,version:d}of e.primaryStore.getRange({start:t[0].lastIndexedKey,lazy:c<4,versions:!0,snapshot:!1}))if(l){if(u++,s=e.primaryStore.ifVersion(_,d,()=>{for(let f=0;f<c;f++){let E=t[f],h=E.name,p=(0,ix.getIndexedValues)(l[h]);if(p)for(let S=0,T=p.length;S<T;S++)E.dbi.put(p[S],_)}}),s.then(()=>u--,f=>{u--,hn.error(f)}),pl.workerData&&pl.workerData.restartNumber!==ox.restartNumber&&(i=!0),++o%100===0||i){for(let f of t)f.lastIndexedKey=_,e.dbisDB.put(f.key,f);if(i)return}u>Xne?await s:u>jne&&await new Promise(f=>setImmediate(f))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await LE.signalSchemaChange(new ME.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName))}catch(n){hn.error("Error in indexing",n)}}function ese({table:e,database:t}){let r=kc({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 pR(e){nA.push(e)}var zt,CE,DE,Je,Yr,ka,No,eA,Kr,sx,tA,ix,LE,ME,pl,hn,ox,rA,PE,Nr,Ze,Ga,nA,UE,gi,Va,Xne,jne,be=Oe(()=>{zt=B(Z()),CE=B(lt()),DE=require("lmdb"),Je=require("path"),Yr=require("fs"),ka=B(Ke());Mf();No=B(Ql()),eA=B(Jl()),Kr=B(M()),sx=B(require("fs-extra")),tA=require("../../index"),ix=B(br()),LE=B(hs()),ME=B(bn()),pl=require("worker_threads"),hn=B(Y()),ox=B(je());wi();Uo();rA="data",PE=Symbol("defined-tables");(0,zt.initSync)();Nr=Object.create(null),Ze=Object.create(null);(0,tA._assignPackageExport)("databases",Ze);(0,tA._assignPackageExport)("tables",Nr);Ga=Symbol.for("next-table-id"),nA=[],gi=new Map;a(zne,"getTables");a(yn,"getDatabases");a(Jne,"resetDatabases");a(ml,"readMetaDb");a(ax,"ensureDB");a(cx,"setTable");a(kc,"database");a(Bp,"dropDatabase");a(ot,"table");Xne=1e3,jne=10;a(Zne,"runIndexing");a(ese,"dropTableMeta");a(pR,"onUpdatedTable")});var J=g((kme,Ax)=>{"use strict";var Ri=require("path"),fx=require("fs-extra"),Tr=Y(),ux=require("fs-extra"),vE=require("os"),tse=require("net"),rse=require("recursive-iterator"),it=M(),nse=JA(),lx=require("papaparse"),BE=require("moment"),{inspect:sse}=require("util"),_x=require("is-number"),Gme=require("lodash"),ise=require("minimist"),ose=require("https"),ase=require("http"),{hdb_errors:HE}=ee(),cse=/^((\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)))$/,Ex=require("util").promisify(setTimeout),use=100,lse=5,_se="",dse=4,dx={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};Ax.exports={isEmpty:Wr,isEmptyOrZeroLength:os,arrayHasEmptyValues:hse,arrayHasEmptyOrZeroLengthValues:mse,buildFolderPath:pse,isBoolean:hx,errorizeMessage:fse,stripFileExtension:Tse,autoCast:gse,autoCastJSON:mx,autoCastJSONDeep:iA,removeDir:Rse,compareVersions:Ase,isCompatibleDataVersion:Ose,escapeRawValue:bse,unescapeValue:Nse,stringifyProps:yse,timeoutPromise:Ise,isClusterOperation:Dse,getClusterUser:Mse,checkGlobalSchemaTable:Lse,getHomeDir:Sx,getPropsFilePath:wse,promisifyPapaParse:Use,removeBOM:Tx,createEventPromise:Pse,checkProcessRunning:vse,checkSchemaTableExist:Bse,checkSchemaExists:gx,checkTableExists:Rx,getStartOfTomorrowInSeconds:Hse,getLimitKey:xse,isObject:Sse,isNotEmptyAndHasValue:Ese,autoCasterIsNumberCheck:px,backtickASTSchemaItems:Fse,isPortTaken:Cse,createForkArgs:qse,autoCastBoolean:Gse,async_set_timeout:Ex,getTableHashAttribute:kse,doesSchemaExist:Vse,doesTableExist:$se,stringifyObj:Yse,ms_to_time:Kse,changeExtension:Wse,getEnvCliRootPath:oA,noBootFile:Qse,httpRequest:zse,transformReq:Jse,convertToMS:Xse,PACKAGE_ROOT:it.PACKAGE_ROOT};function fse(e){return e instanceof Error?e:new Error(e)}a(fse,"errorizeMessage");function Wr(e){return e==null}a(Wr,"isEmpty");function Ese(e){return!Wr(e)&&(e||e===0||e===""||hx(e))}a(Ese,"isNotEmptyAndHasValue");function os(e){return Wr(e)||e.length===0||e.size===0}a(os,"isEmptyOrZeroLength");function hse(e){if(Wr(e))return!0;for(let t=0;t<e.length;t++)if(Wr(e[t]))return!0;return!1}a(hse,"arrayHasEmptyValues");function mse(e){if(os(e))return!0;for(let t=0;t<e.length;t++)if(os(e[t]))return!0;return!1}a(mse,"arrayHasEmptyOrZeroLengthValues");function pse(...e){try{return e.join(Ri.sep)}catch{console.error(e)}}a(pse,"buildFolderPath");function hx(e){return Wr(e)?!1:e===!0||e===!1}a(hx,"isBoolean");function Sse(e){return Wr(e)?!1:typeof e=="object"}a(Sse,"isObject");function Tse(e){return os(e)?_se:e.slice(0,-dse)}a(Tse,"stripFileExtension");function gse(e){return Wr(e)||e===""||typeof e!="string"?e:dx[e]!==void 0?dx[e]:px(e)===!0?Number(e):cse.test(e)?new Date(e):e}a(gse,"autoCast");function mx(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(mx,"autoCastJSON");function iA(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=iA(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=iA(r);n!==r&&(e[t]=n)}return e}else return mx(e)}a(iA,"autoCastJSONDeep");function px(e){if(e.startsWith("0.")&&_x(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&_x(e))}a(px,"autoCasterIsNumberCheck");async function Rse(e){if(os(e))throw new Error(`Directory path: ${e} does not exist`);try{await ux.emptyDir(e),await ux.remove(e)}catch(t){throw Tr.error(`Error removing files in ${e} -- ${t}`),t}}a(Rse,"removeDir");function Ase(e,t){if(os(e)){Tr.info("Invalid current version sent as parameter.");return}if(os(t)){Tr.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(Ase,"compareVersions");function Ose(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(Ose,"isCompatibleDataVersion");function bse(e){if(Wr(e))return e;let t=String(e);return t==="."?it.UNICODE_PERIOD:t===".."?it.UNICODE_PERIOD+it.UNICODE_PERIOD:t.replace(it.FORWARD_SLASH_REGEX,it.UNICODE_FORWARD_SLASH)}a(bse,"escapeRawValue");function Nse(e){if(Wr(e))return e;let t=String(e);return t===it.UNICODE_PERIOD?".":t===it.UNICODE_PERIOD+it.UNICODE_PERIOD?"..":String(e).replace(it.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(Nse,"unescapeValue");function yse(e,t){if(Wr(e))return Tr.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+vE.EOL}!os(n)&&n[0]===";"?r+=" "+n+s+vE.EOL:os(n)||(r+=n+"="+s+vE.EOL)}catch{Tr.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(yse,"stringifyProps");function Sx(){let e;try{e=vE.homedir()}catch{e=process.env.HOME}return e||(e="~/"),e}a(Sx,"getHomeDir");function wse(){let e=Ri.join(Sx(),it.HDB_HOME_DIR_NAME,it.BOOT_PROPS_FILE_NAME);return fx.existsSync(e)||(e=Ri.join(__dirname,"../","hdb_boot_properties.file")),e}a(wse,"getPropsFilePath");function Ise(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:function(){clearTimeout(r)}}}a(Ise,"timeoutPromise");async function Cse(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=tse.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(Cse,"isPortTaken");function Dse(e){try{return it.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Tr.error(`Error checking operation against cluster ops ${t}`)}return!1}a(Dse,"isClusterOperation");function Lse(e,t){let r=(be(),te(Fe)).getDatabases();if(!r[e])return HE.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return HE.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Lse,"checkGlobalSchemaTable");function Mse(e,t){if(Wr(t)){Tr.warn("No CLUSTERING_USER defined, clustering disabled");return}if(Wr(e)||os(e)){Tr.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){Tr.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){Tr.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(Mse,"getClusterUser");function Use(){lx.parsePromise=function(e,t,r){return new Promise(function(n,s){lx.parse(e,{header:!0,transformHeader:Tx,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(Use,"promisifyPapaParse");function Tx(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(Tx,"removeBOM");function Pse(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;Tr.info(`Got cluster status event response: ${sse(s)}`);try{i.cancel()}catch{Tr.error("Error trying to cancel timeout.")}n(s)})})}a(Pse,"createEventPromise");async function vse(e){let t=!0,r=0;do await Ex(use*r++),(await nse.findPs(e)).length>0&&(t=!1);while(t&&r<lse);if(t)throw new Error(`process ${e} was not started`)}a(vse,"checkProcessRunning");function Bse(e,t){let r=gx(e);if(r)return r;let n=Rx(e,t);if(n)return n}a(Bse,"checkSchemaTableExist");function gx(e){let{getDatabases:t}=(be(),te(Fe));if(!t()[e])return HE.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(gx,"checkSchemaExists");function Rx(e,t){let{getDatabases:r}=(be(),te(Fe));if(!r()[e][t])return HE.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Rx,"checkTableExists");function Hse(){let e=BE().utc().add(1,it.MOMENT_DAYS_TAG).startOf(it.MOMENT_DAYS_TAG).unix(),t=BE().utc().unix();return e-t}a(Hse,"getStartOfTomorrowInSeconds");function xse(){return BE().utc().format("DD-MM-YYYY")}a(xse,"getLimitKey");function Fse(e){try{let t=new rse(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){Tr.error("Got an error back ticking items."),Tr.error(t)}}a(Fse,"backtickASTSchemaItems");function qse(e){return[e]}a(qse,"createForkArgs");function Gse(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(Gse,"autoCastBoolean");function kse(e,t){let{getDatabases:r}=(be(),te(Fe)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(kse,"getTableHashAttribute");function Vse(e){let{getDatabases:t}=(be(),te(Fe));return t()[e]!==void 0}a(Vse,"doesSchemaExist");function $se(e,t){let{getDatabases:r}=(be(),te(Fe));return r()[e]?.[t]!==void 0}a($se,"doesTableExist");function Yse(e){try{return JSON.stringify(e)}catch{return e}}a(Yse,"stringifyObj");function Kse(e){let t=BE.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(Kse,"ms_to_time");function Wse(e,t){let r=Ri.basename(e,Ri.extname(e));return Ri.join(Ri.dirname(e),r+t)}a(Wse,"changeExtension");function oA(){if(process.env[it.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[it.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=ise(process.argv);if(e[it.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[it.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(oA,"getEnvCliRootPath");var sA;function Qse(){if(sA)return sA;let e=oA();oA()&&fx.pathExistsSync(Ri.join(e,it.HDB_CONFIG_FILE))&&(sA=!0)}a(Qse,"noBootFile");function zse(e,t){let r;return e.protocol==="http:"?r=ase:r=ose,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(zse,"httpRequest");function Jse(e){if(!e.schema&&!e.database){e.schema=it.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(Jse,"transformReq");function Xse(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(Xse,"convertToMS")});var Z=g(($me,yx)=>{"use strict";var aA=require("fs-extra"),yo=require("path"),Ox=require("os"),jse=require("properties-reader"),Tl=Y(),Sl=J(),ue=M(),xE=Dr(),Zse="Error initializing environment manager",FE="BOOT_PROPS_FILE_PATH",bx=!1,eie={[ue.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},xs={};yx.exports={BOOT_PROPS_FILE_PATH:FE,getHdbBasePath:tie,setHdbBasePath:rie,get:Nx,initSync:sie,setProperty:Ue,initTestEnvironment:iie};function tie(){return xs[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(tie,"getHdbBasePath");function rie(e){xs[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(rie,"setHdbBasePath");function Nx(e){let t=xE.getConfigValue(e);return t===void 0?xs[e]:t}a(Nx,"get");function Ue(e,t){eie[e]&&(xs[e]=t),xE.updateConfigObject(e,t)}a(Ue,"setProperty");function nie(){let e;try{e=Sl.getPropsFilePath(),aA.accessSync(e,aA.constants.F_OK|aA.constants.R_OK),bx=!0;let t=jse(e);return xs[ue.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(ue.HDB_SETTINGS_NAMES.INSTALL_USER),xs[ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),xs[FE]=e,!0}catch{return Tl.trace(`Environment manager found no properties file at ${e}`),!1}}a(nie,"doesPropFileExist");function sie(e=!1){try{(bx||nie()||Sl.noBootFile())&&(xE.initConfig(e),xs[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=xE.getConfigValue(ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Tl.error(Zse),Tl.error(t),console.error(t),process.exit(1)}}a(sie,"initSync");function iie(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=yo.join(__dirname,"../../","unitTests");xs[FE]=yo.join(u,"hdb_boot_properties.file"),Ue(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,yo.join(u,"settings.test")),Ue(ue.HDB_SETTINGS_NAMES.INSTALL_USER,Ox.userInfo()?Ox.userInfo().username:void 0),Ue(ue.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Ue(ue.HDB_SETTINGS_NAMES.LOG_PATH_KEY,yo.join(u,"envDir","log")),Ue(ue.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Ue(ue.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Ue(ue.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Ue(ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,yo.join(u,"envDir")),Ue(ue.CONFIG_PARAMS.STORAGE_PATH,yo.join(u,"envDir")),s&&(Ue(ue.CONFIG_PARAMS.HTTP_SECUREPORT,Nx(ue.CONFIG_PARAMS.HTTP_PORT)),Ue(ue.CONFIG_PARAMS.HTTP_PORT,null)),Ue(ue.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Ue(ue.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Ue(ue.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Sl.isEmpty(i)?!1:i),Ue(ue.CONFIG_PARAMS.HTTP_CORS,Sl.isEmpty(i)?!1:i),Ue(ue.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Ue(ue.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Ue(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Ue(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Ue(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,yo.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Ue(ue.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Sl.isEmpty(c)?!1:c),o&&(Ue("CORS_ACCESSLIST",o),Ue(ue.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Ue(ue.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Ue(ue.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Ue(ue.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Ue(ue.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Ue(ue.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Ue(ue.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${FE}. Please check your boot props and settings files`;Tl.fatal(r),Tl.error(t)}}a(iie,"initTestEnvironment")});var KB=g(wo=>{var{isMainThread:oie,parentPort:Al,threadId:gl}=require("worker_threads"),{Socket:aie,createServer:cie}=require("net"),{createServer:uie,IncomingMessage:lie}=require("http"),{createServer:_ie}=require("https"),{readFileSync:$a,unlinkSync:wx,existsSync:die}=require("fs"),vn=Y(),He=Z(),gr=M(),{server:kE}=(Zt(),te(bi)),{WebSocketServer:fie}=require("ws"),{createServer:Eie}=require("tls"),{getTicketKeys:hie,restartNumber:mie,getWorkerIndex:Ix}=je(),{Headers:Ux}=(qd(),te(yU)),{recordAction:Rl,recordActionBinary:pie}=(Ts(),te(Jc)),{Request:Px,createReuseportFd:Cx}=(Wf(),te(aR)),{checkMemoryLimit:Sie}=qi(),vx=require("tls"),Dx=vx.createSecureContext;vx.createSecureContext=function(e){if(!e.cert||!e.key)return Dx(e);let t={...e};delete t.key,delete t.cert;let r=Dx(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};if(process.env.DEV_MODE)try{require("inspector").open(9229)}catch(e){mie<=1&&vn.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:Kme,CONFIG_PARAMS:Tie}=gr;He.initSync();var gie=He.get(Tie.HTTP_SESSIONAFFINITY),as={};wo.registerServer=dA;wo.httpServer=fA;wo.deliverSocket=_A;wo.startServers=Bx;wo.when_components_loaded=null;kE.http=fA;kE.request=bie;kE.socket=Nie;kE.ws=yie;var cA={},qE={},Rie,Ai={},GE={},Aie=[],uA=[];function Bx(){return wo.when_components_loaded=DR().loadRootComponents(!0).then(()=>{Al?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)_A(n,r,s);else if(t.requestId)Oie(t);else if(t.type===gr.ITC_EVENT_TYPES.SHUTDOWN){vn.trace("received shutdown request",gl);for(let i in as){let o=as[i],c;o.closeIdleConnections&&(setInterval(()=>{o.closeIdleConnections()},25).unref(),setTimeout(()=>{o.closeAllConnections(),vn.info("Closed all http connections",i,gl)},4e3).unref()),o.close?.(()=>{if(He.get(gr.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&Ix()==0)try{wx(He.get(gr.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,gl),o.cantCleanupProperly||vn.warn("Had to forcefully exit the thread",gl),process.exit(0)},5e3).unref()})}if(process.env.DEV_MODE)try{require("inspector").close()}catch(i){console.error("Could not close debugger",i)}}}).ref();let e=[];if(Cx&&!gie)for(let t in as){let r=as[t];if(isNaN(t)&&Ix()==0){die(t)&&wx(t),e.push(new Promise((s,i)=>{r.listen({path:t},()=>{s(),vn.info("Domain socket listening on "+t)}).on("error",i)}));continue}let n;try{n=Cx(+t,"::")}catch(s){console.error(`Unable to bind to port ${t}`,s);continue}e.push(new Promise((s,i)=>{r.listen({fd:n},()=>{s(),vn.trace("Listening on port "+t,gl)}).on("error",i)}))}Promise.all(e).then(()=>{Al?.postMessage({type:gr.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(Bx,"startServers");oie||Bx();function _A(e,t,r){let n=e?.read?e:new aie({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=as[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=as[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(vn.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(_A,"deliverSocket");var Lx=new Map;function Oie(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=Lx.get(s),r){case"connection":i=_A(void 0,t),Lx.set(s,i),i.write=(c,u,_)=>(Al.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),_&&_(),!0),i.end=(c,u,_)=>(Al.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),_&&_(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),Al.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(Oie,"proxyRequest");function dA(e,t,r=!0){!+t&&t!==He.get(gr.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&(t=parseInt(He.get(gr.CONFIG_PARAMS.HTTP_PORT),10));let n=as[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",Mx),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else as[t]=e;e.on("unhandled",Mx)}a(dA,"registerServer");function Hx(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=[],He.get(gr.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:He.get(gr.CONFIG_PARAMS.HTTP_PORT),secure:He.get(gr.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),He.get(gr.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:He.get(gr.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&He.get(gr.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:He.get(gr.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),secure:!1}),t}a(Hx,"getPorts");function fA(e,t){for(let{port:r,secure:n}of Hx(t))xx(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)),GE[r]=lA(uA,r),Rie=lA(Aie,r)}a(fA,"httpServer");function xx(e,t,r){if(!Ai[e]){let n=r?"operationsApi_network":"http",s={keepAliveTimeout:He.get(n+"_keepAliveTimeout"),headersTimeout:He.get(n+"_headersTimeout"),requestTimeout:He.get(n+"_timeout")},i=He.get(n+"_mtls"),o=He.get(n+"_mtls_required");if(t){n=r?"operationsApi_":"";let u=He.get(n+"tls_privateKey"),_=He.get(n+"tls_certificate"),l=He.get(n+"tls_certificateAuthority");Object.assign(s,{allowHTTP1:!0,key:$a(u),ciphers:He.get("tls_ciphers"),cert:$a(_),ca:l&&$a(l),rejectUnauthorized:!!o,requestCert:!!i,ticketKeys:hie()})}let c=Sie();Ai[e]=(t?_ie:uie)(s,async(u,_)=>{try{let d=performance.now(),f=new Px(u,_);r&&(f.isOperationsServer=!0);let E=await GE[e](f);if(!E){if(f._nodeResponse.statusCode)return;E=Fx(f)}if(c?E.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):E.headers?.set?.("Server","HarperDB"),E.status===-1){for(let F of E.headers||[])_.setHeader(F[0],F[1]);return u.baseRequest=f,_.baseResponse=E,Ai[e].emit("unhandled",u,_)}let h=E.status||200,p=performance.now(),S=p-d,T=E.body,A;if(!E.handlesHeaders){let F=E.headers||new Ux;if(T?T.length>=0&&(typeof T=="string"?F.set("Content-Length",Buffer.byteLength(T)):F.set("Content-Length",T.length),A=!0):(F.set("Content-Length","0"),A=!0),F.append){let v=`hdb;dur=${S.toFixed(2)}`;E.wasCacheMiss&&(v+=", miss"),F.append("Server-Timing",v,!0)}_.writeHead(h,F&&(F[Symbol.iterator]?Array.from(F):F)),A&&_.end(T)}let b=f.handlerPath,H=f.method;if(Rl(S,"duration",b,H,E.wasCacheMiss==null?void 0:E.wasCacheMiss?"cache-miss":"cache-hit"),pie(h<400,"success",b,H),!A)if(T?.pipe){T.pipe(_),T.destroy&&_.on("close",()=>{T.destroy()});let F=0;T.on("data",v=>{F+=v.length}),T.on("end",()=>{Rl(performance.now()-p,"transfer",b,H),Rl(F,"bytes-sent",b,H)})}else T?.then?T.then(F=>{_.end(F)},l):_.end(T)}catch(d){l(d)}function l(d){let f=d.headers;_.writeHead(d.statusCode||500,f&&(f[Symbol.iterator]?Array.from(f):f)),_.end(d.toString()),d.statusCode?d.statusCode===500?vn.warn(d):vn.info(d):vn.error(d)}a(l,"onError")}),i&&(Ai[e].mtlsConfig=i),t&&(Ai[e].on("secureConnection",u=>{u._parent.startTime&&Rl(performance.now()-u._parent.startTime,"tls-handshake",e),Rl(u.isSessionReused(),"tls-reused",e)}),Ai[e].isSecure=!0),dA(Ai[e],e)}return Ai[e]}a(xx,"getHTTPServer");function lA(e,t){let r=Fx;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 Fx(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new Ux}}a(Fx,"unhandled");function bie(e,t){fA(e,{requestOnly:!0,...t})}a(bie,"onRequest");function Nie(e,t){let r;if(t.securePort){let n=He.get("tls_privateKey"),s=He.get("tls_certificate"),i=t.mtls?.certificateAuthority||He.get("tls_certificateAuthority");r=Eie({ciphers:He.get("tls_ciphers"),key:$a(n),cert:$a(s),ca:i&&$a(i),rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls},e),as[t.securePort]=r}return t.port&&(r=cie(e),as[t.port]=r),r}a(Nie,"onSocket");Object.defineProperty(lie.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.startsWith("Upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});function yie(e,t){let r;for(let{port:n,secure:s}of Hx(t)){qE[n]||(qE[n]=new fie({server:r=xx(n,s)}),qE[n].on("connection",async(c,u)=>{try{let _=new Px(u);_.isWebSocket=!0;let l=GE[n](_),d=u.headers["sec-websocket-protocol"]||"",f=cA[n];if(d){let E;for(let h=0;h<f.length;h++){let p=f[h];p.protocol===d&&(E=!0,p.listener(c,_,l))}if(E)return}for(let E=0;E<f.length;E++){let h=f[E];h.protocol||h.listener(c,_,l)}}catch(_){vn.warn("Error handling WebSocket connection",_)}}),qE[n].on("error",c=>{console.log("Error in setting up WebSocket server",c)}));let i=t?.subProtocol||"",o=cA[n];o||(o=cA[n]=[]),o.push({listener:e,protocol:i}),GE[n]=lA(uA,n)}return r}a(yie,"onWebSocket");function Mx(e,t){t.writeHead(404),t.end(`Not found
|
|
27
|
-
|
|
26
|
+
`},compressible:!1,q:.8});Pt.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()}});sv={type:"application/json",serializeStream:_c,serialize:$u,deserialize:c7,q:.8};Pt.set("*/*",sv);Pt.set("",sv);a(c7,"tryJSONParse");a(cg,"registerContentHandlers");u7=require("fastify-plugin"),l7=u7(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=_f(n.raw);s.type(c),s.serializer(function(u){return(o.serializeStream||o.serialize)(u,{headers:{set:(_,l)=>{s.header(_,l)}}})})}),r()},{name:"content-type-negotiation"});a(_f,"findBestSerializer");ZP=sg.default.get(ig.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(df,"serialize");a(Ei,"serializeMessage");a(_7,"streamToBuffer");a(fo,"getDeserializer");a(ev,"deserializerUnknownType");a(d7,"transformIterable")});function _g(e,t,r,n,s,i,o,c){let u=e[0];if(t==="or"){let d=_(u);for(let E=1;E<e.length;E++){let h=e[E],p=_(h);d=d.concat(p)}let f=new Set;return d.filter(E=>{let h=E.key??E;return f.has(h)?!1:(f.add(h),!0)})}else{let d=_(u),f=l(e.slice(1),!0,u.estimated_count);return f.length>0?o(d,f):d}function _(d){return d.conditions?_g(d.conditions,d.operator,r,n,s,i,o,c):Na(d,n,d.descending||s.reverse===!0,r,s.allowFullScan,c)}a(_,"executeCondition");function l(d,f,E){return d.map((h,p)=>{if(h.conditions){let g=h.operator==="or",R=l(h.conditions,!g,E);return g?(B,H)=>R.some(v=>v(B,H)):(B,H)=>R.every(v=>v(B,H))}let S=(h.attribute||h[0])===r.primaryKey,O=fg(h,r,i,c,S,E);return f&&p<d.length-1&&E&&(E=R7(r.primaryStore,h.estimated_count,E)),O}).filter(Boolean)}a(l,"mapConditionsToFilters")}function Na(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 g=o[0],R=Us(n.attributes,g);if(R.relationship){if(o.length<2)throw new Ms.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let B=R.definition?.tableClass||R.elements?.definition?.tableClass,H=new Map,v=Na({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:u},t,r,B,s,H);if(R.relationship.to){i[o[0]]=H;let M=!!Us(B.attributes,R.relationship.to)?.elements;v=p7(v,R,B.primaryStore,M,H)}if(R.relationship.from){let M=a($=>Na({attribute:R.relationship.from,value:$},t,r,n,s,H),"searchEntry");R.elements?(i[o[0]]=H,v=S7(v,R,B.primaryStore,H,M)):v=v.flatMap(M)}return v}else if(o.length===1)o=o[0];else throw new Ms.ClientError("Unable to query by attribute "+JSON.stringify(o))}let _,l,d,f;c instanceof Date&&(c=c.getTime());let E;switch(dg[u]||u){case"lt":_=!0,l=c;break;case"le":_=!0,l=c,d=!0;break;case"gt":_=c,f=!0;break;case"ge":_=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],_=c,l=c.slice(0),l[l.length-1]=ss.MAXIMUM_KEY;break;case"starts_with":_=c.toString(),l=c+"\uFFFF";break;case"between":_=c[0],_ instanceof Date&&(_=_.getTime()),l=c[1],l instanceof Date&&(l=l.getTime()),d=!0;break;case"equals":case void 0:_=c,l=c,d=!0;break;case"ne":if(c===null){_=c,f=!0;break}case"sort":case"contains":case"ends_with":_=!0,E=!0;break;default:throw new Ms.ClientError(`Unknown query comparator "${u}"`)}if(r){let g=_;_=l,l=g,g=!f,f=!d,d=g}let h=o===n.primaryKey||o==null,p=h?n.primaryStore:n.indices[o],S;if(!p||p.isIndexing||E||c===null&&!p.indexNulls){if(!s)throw new Ms.ClientError(E?`Can not use ${u} operator without combining with a condition that uses an index`:`"${o}" is not indexed${c===null&&!p.indexNulls?" for nulls, index needs to be rebuilt to search for nulls":p?.isIndexing?" yet":""}, can not search for this attribute`,404);if(S=fg(e),!S)throw new Ms.ClientError(`Unknown search operator ${e.comparator}`)}let O={start:_,end:l,inclusiveEnd:d,exclusiveStart:f,values:!0,versions:h,transaction:t,reverse:r};if(h){let g=p.getRange(O).map(S?({key:R,value:B})=>new Promise((H,v)=>setImmediate(()=>{try{H(B&&S(B)?R:Ku.SKIP)}catch(M){v(M)}})):R=>R.value==null?Ku.SKIP:R);return g.hasEntries=!0,g}else return p?p.getRange(O).map(S?({key:g,value:R})=>new Promise((B,H)=>setImmediate(()=>{try{B(S({[o]:g})?R:Ku.SKIP)}catch(v){H(v)}})):({value:g})=>g):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(({key:g,value:R})=>new Promise((B,H)=>setImmediate(()=>{try{B(R&&S(R)?g:Ku.SKIP)}catch(v){H(v)}})))}function Us(e,t){if(Array.isArray(t))if(t.length>1){let r=Us(e,t[0]),n=(r?.definition?.tableClass||r?.elements.definition?.tableClass)?.attributes;return n?Us(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 p7(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;return(async()=>{let _=a((d,f)=>{let E=d;Array.isArray(d)&&(E=Mn(d),o=!0);let h=s.get(E);h?h.push(f):s.set(E,h=[f]),d!==E&&(h.key=d)},"add_entry"),l=0;for await(let d of e){let f=d.value??r.get(d.key??d),E=f?.[u];if(E!=null&&!s.filters?.some(h=>!h(f))){if(n)for(let h=0;h<E.length;h++)_(E[h],d);else _(E,d);l++>100&&(await new Promise(setImmediate),l=0)}}return i=(o?s:s.keys())[Symbol.iterator](),this.next()})()}let c=i.next();return c.done?c:{value:o?c.value[1].key||c.value[0]:c.value}}}}})}function S7(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let u;if(o)for(;u=o.next(),!u.done;){let _=Mn(u.value);if(!c.has(_))return c.add(_),u}if(!i)return(async()=>{let _=new Map;n.fromRecord=d=>d[t.relationship.from]?.filter?.(f=>_.has(Mn(f)));let l=0;for await(let d of e){if(n.filters){let f=r.get(d);if(n.filters.some(E=>!E(f)))continue}_.set(Mn(d),d),l++>100&&(await new Promise(setImmediate),l=0)}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 fg(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=Us(t.attributes,l),f=d.definition?.tableClass||d.elements.definition?.tableClass,E=n?.[l],h=fg({attribute:c.length>2?c.slice(1):c[1],value:u,comparator:o},f,r,E?.[l]?.joined,c[1]===f.primaryKey,i);if(!h)return;if(E){E.filters||(E.filters=[]),E.filters.push(h);return}let p=t.propertyResolvers?.[l],S,O=a((g,R)=>{let B,H;if(p){if(p.from&&h.idFilter){if(!S)if(h.idFilter.idSet?.size===1){for(let M of h.idFilter.idSet)e={attribute:p.from,value:M};S=_(p.from,h.idFilter,!0)}else S=_(p.from,h.idFilter,!1);let v=S(g);return S.idFilter&&(O.idFilter=S.idFilter),v}H=p(g,r,R),B=H?.value}else B=g[l];return B?Array.isArray(B)?B.some(h):h(B,H):!1},"recordFilter");return O}}switch(u instanceof Date&&(u=u.getTime()),dg[o]||o){case ug.SEARCH_TYPES.EQUALS:case void 0:return _(c,l=>l===u,!0);case"contains":return _(c,l=>l?.toString().includes(u));case"ends_with":return _(c,l=>l?.toString().endsWith(u));case"starts_with":return _(c,l=>typeof l=="string"&&l.startsWith(u),!0);case"prefix":return Array.isArray(u)?u[u.length-1]==null&&(u=u.slice(0,-1)):u=[u],_(c,l=>{if(!Array.isArray(l))return!1;for(let d=0,f=u.length;d<f;d++)if(l[d]!==u[d])return!1;return!0},!0);case"between":return u[0]instanceof Date&&(u[0]=u[0].getTime()),u[1]instanceof Date&&(u[1]=u[1].getTime()),_(c,l=>(0,ss.compareKeys)(l,u[0])>=0&&(0,ss.compareKeys)(l,u[1])<=0,!0);case"gt":return _(c,l=>(0,ss.compareKeys)(l,u)>0);case"ge":return _(c,l=>(0,ss.compareKeys)(l,u)>=0);case"lt":return _(c,l=>(0,ss.compareKeys)(l,u)<0);case"le":return _(c,l=>(0,ss.compareKeys)(l,u)<=0);case"ne":return _(c,l=>(0,ss.compareKeys)(l,u)!==0);case"sort":return()=>!0;default:throw new Ms.ClientError(`Unknown query comparator "${o}"`)}function _(l,d,f){let E;f=f&&!s&&t?.indices[l]&&i>3,f&&(e.estimated_count==null&&Ef(t)(e),E=e.estimated_count>>4,(isNaN(E)||E>=i)&&(f=!1));let h=0,p=3;function S(O){let g=O[l],R;if(typeof g!="object"||!g?R=d(g):Array.isArray(g)?R=g.some(d):g instanceof Date&&(R=d(g.getTime())),f&&(p++,!R&&!S.idFilter&&++h/p*(i-p)>E)){let B=Na(e,r.transaction.getReadTxn(),!1,t).map(Mn),H=new Set(B);S.idFilter=v=>H.has(Mn(v)),S.idFilter.idSet=H}return R}return a(S,"recordFilter"),s&&(S.idFilter=d),S}a(_,"attributeComparator")}function Ef(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/Ls(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=dg[n]||n,n===ug.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=Us(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=Ef(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"});r.estimated_count=c*Ls(e.indices[i.relationship.from]||e.primaryStore)/(Ls(o.primaryStore)||1)}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=Ls(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=h7*Ls(e.primaryStore)+1:n==="between"?r.estimated_count=E7*Ls(e.primaryStore)+1:n==="sort"?r.estimated_count=Ls(e.primaryStore)+1:r.estimated_count=f7*Ls(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function hf(e){if(e)if(pi=e,Oa.lastIndex=0,T7.test(e))try{let t=Wu(new ba,"");if(hr!==pi.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 ${hr} in '${pi}'`,t}else{let t=new URLSearchParams(e);return t.conditions=t,t}}function Wu(e,t){let r=Oa,n,s,i,o,c,u=decodeURIComponent,_;for(;n=r.exec(pi);){hr=r.lastIndex;let[,l,d]=n;if(o){if(l)throw new SyntaxError(`expected operator, but encountered '${l}'`);o=!1,c=!1}else c=!0;let f;switch(d){case"=":if(s){if(l.length<=2)i=l;else throw new SyntaxError(`invalid FIQL operator ${l}`);u=ov}else{if(u=decodeURIComponent,i="equals",!l)throw new SyntaxError("attribute must be specified before equality comparator");s=Qu(l)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=m7[d],u=lg[i]?ov:decodeURIComponent,!l)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=Qu(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"&&av(h,l),ff(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(Qu(l)),s=void 0;break;case"(":Oa.lastIndex=hr;let E=Wu(l?[]:new ba,")");switch(l){case"":ff(e,_),e.conditions.push(E);break;case"limit":switch(E.length){case 1:e.limit=+E[0];break;case 2:e.offset=+E[0],e.limit=E[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(E[0])&&E.length===1&&!E[0].name?(e.select=E[0],e.select.asArray=!0):E.length===1?e.select=E[0]:E.length===2&&E[1]===""?e.select=E.slice(0,1):e.select=E;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=cv(E);break;default:throw new SyntaxError(`unknown query function call ${l}`)}pi[hr]===","?r.lastIndex=++hr: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");Oa.lastIndex=hr,f=Wu([],"}"),f.name=l,e.push(f),pi[hr]===","?r.lastIndex=++hr:o=!0;break;case"[":Oa.lastIndex=hr,l?(f=Wu(new ba,"]"),f.name=l):f=Wu(e.conditions?new ba:[],"]"),e.conditions?(ff(e,_),e.conditions.push(f),s=null):e.push(f),pi[hr]===","?r.lastIndex=++hr: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"&&av(h,l),ff(e,_),e.conditions.push(h)}else if(l)throw new SyntaxError("no attribute or comparison specified")}else(l||e.length>0&&c)&&e.push(Qu(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?g7:Oa,r.lastIndex=hr),hr===pi.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function ff(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 Qu(e){return e.indexOf(".")>-1?e.split(".").map(Qu):decodeURIComponent(e)}function ov(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(decodeURIComponent(r));if(t==="string")return decodeURIComponent(r);throw new Ms.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function av(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new Ms.ClientError("wildcard can only be used at the end of a string")}function cv(e){let t=uv(e[0]);return e.length>1&&(t.next=cv(e.slice(1))),t}function uv(e){if(Array.isArray(e)){let t=uv(e[0]);return e[0]=t.attribute,t.attribute=e,t}if(typeof e=="string")switch(e[0]){case"-":return{attribute:e.slice(1),descending:!0};case"+":return{attribute:e.slice(1),descending:!1};default:return{attribute:e,descending:!1}}throw new SyntaxError(`Unknown sort type ${e}`)}function Mn(e){return Array.isArray(e)?e.join("\0"):e}function Ls(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function R7(e,t,r){return t*r/Ls(e)}var Ms,ug,ss,Ku,f7,E7,h7,m7,lg,dg,T7,Oa,g7,hr,pi,ba,mf=Oe(()=>{Ms=x(ee()),ug=x(lt()),ss=require("ordered-binary"),Ku=require("lmdb"),f7=.3,E7=.1,h7=.05,m7={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},lg={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(_g,"executeConditions");a(Na,"searchByIndex");a(Us,"findAttribute");a(p7,"joinTo");a(S7,"joinFrom");dg={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(fg,"filterByType");a(Ef,"estimateCondition");T7=/[()[\]|!<>.]|(=\w*=)/,Oa=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,g7=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(hf,"parseQuery");a(Wu,"parseBlock");a(ff,"assignOperator");a(Qu,"decodeProperty");a(ov,"typedDecoding");a(av,"wildcardDecoding");a(cv,"toSortObject");a(uv,"toSortEntry");ba=class{static{a(this,"Query")}constructor(){this.conditions=[]}[Symbol.iterator](){return this.conditions[Symbol.iterator]()}get(t){for(let r=0;r<this.conditions.length;r++){let n=this.conditions[r];if(n.attribute===t)return n.value}}};a(Mn,"flattenKey");a(Ls,"estimatedEntryCount");a(R7,"intersectionEstimate")});function Ev(e){let t={openapi:A7,info:{title:"HarperDB HTTP REST interface",version:(0,fv.version)()},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:u}=n.Resource;if(c=c??"id",!c)continue;let _={},l=[];if(o)for(let{type:R,name:B,elements:H,relationship:v,definition:M}of o){if(v)R==="array"?_[B]={type:"array",items:{$ref:Si+H.type}}:_[B]={$ref:Si+R};else{let $=M??H?.definition;if($){if(!t.components.schemas[$.type]){let K={};$.properties.forEach(z=>{K[z.name]=new pg(Eg[z.type],z.type)}),t.components.schemas[$.type]=new dv(K)}R==="array"?_[B]={type:"array",items:{$ref:Si+$.type}}:_[B]={$ref:Si+$.type}}else R==="array"?H.type==="Any"||H.type=="ID"?_[B]={type:"array",items:{format:H.type}}:_[B]={type:"array",items:new pg(Eg[H.type],H.type)}:R==="Any"||R=="ID"?_[B]={format:R}:_[B]=new pg(Eg[R],R)}l.push(new Sg(B,"query",_[B]))}let d=Object.keys(_),f=new Sg(c,"path",{format:"ID"});f.required=!0,f.description="primary key of record";let E=new Sg("property","path",{enum:d});E.required=!0,t.components.schemas[i]=new dv(_);let h=u.post!==Resource.prototype.post||u.update,p=typeof u.put=="function",S=typeof u.get=="function",O=typeof u.delete=="function",g="/"+s+"/";h&&(t.paths[g]={},t.paths[g].post=new O7(i,r,"create a new record auto-assigning a primary key")),S&&(t.paths[g]||(t.paths[g]={}),t.paths[g].get=new hg(l,r,{200:new mg({$ref:Si+i})},"search for records by the specified property name and value pairs")),O&&(t.paths[g]||(t.paths[g]={}),t.paths[g].delete=new _v(l,r,"delete all the records that match the provided query",{204:new lv})),g="/"+s+"/{"+c+"}",S&&(t.paths[g]={},t.paths[g].get=new hg([f],r,{200:new mg({$ref:Si+i})},"retrieve a record by its primary key")),p&&(t.paths[g]||(t.paths[g]={}),t.paths[g].put=new b7([f],r,i,"create or update the record with the URL path that maps to the record's primary key")),O&&(t.paths[g]||(t.paths[g]={}),t.paths[g].delete=new _v([f],r,"delete a record with the given primary key",{204:new lv})),S&&E.schema.enum.length>0&&(g="/"+s+"/{"+c+"}.{property}",t.paths[g]={},t.paths[g].get=new hg([f,E],r,{200:new mg({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function O7(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Si+e}}}},this.security=t,this.responses={200:{description:Tg,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function hg(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function mg(e){this.description=Tg,this.content={"application/json":{schema:e}}}function lv(){this.description="successfully processed request, no content returned to client"}function b7(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Si+r}}}},this.responses={200:{description:Tg}}}function _v(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function dv(e){this.type="object",this.properties=e}function pg(e,t){this.type=e,this.format=t}function Sg(e,t,r){this.name=e,this.in=t,this.schema=r}var fv,A7,Eg,Si,Tg,hv=Oe(()=>{fv=x(Ed()),A7="3.0.3",Eg={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Si="#/components/schemas/",Tg="successful operation";a(Ev,"generateJsonApi");a(O7,"Post");a(hg,"Get");a(mg,"Response200");a(lv,"Response204");a(b7,"Put");a(_v,"Delete");a(dv,"ResourceSchema");a(pg,"Type");a(Sg,"Parameter")});var Sf={};ke(Sf,{start:()=>w7});async function y7(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream"?"CONNECT":e.method;e.search&&hf(e);let s=new fi;try{e.responseHeaders=s;let i=e.url.slice(1),o,c;if(i!==mv){let h=pf.getMatch(i);if(!h)return t(e);e.handlerPath=h.path,o={url:h.relativeURL,async:!0},c=h.Resource}let u=r["cache-control"];if(u){u=u.toLowerCase();let h=u.match(/max-age=(\d+)/)?.[1];h&&(e.expiresAt=h*1e3+Date.now()),u.includes("only-if-cached")&&(e.onlyIfCached=!0),u.includes("no-cache")&&(e.noCache=!0),u.includes("no-store")&&(e.noCacheStore=!0),u.includes("stale-if-error")&&(e.staleIfError=!0),u.includes("must-revalidate")&&(e.mustRevalidate=!0)}let _=await Ke(e,()=>{if(n==="POST"||n==="PUT"||n==="PATCH"||n==="QUERY")try{e.data=fo(r["content-type"],!0)(e.body)}catch(h){throw new ya.ClientError(h,400)}if(e.authorize=!0,i===mv&&n==="GET"){if(e?.user?.role?.permission?.super_user)return Ev(pf);throw new ya.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 ya.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new ya.ServerError(`Method ${n} is not recognized`,501)}}),l=200,d;if(_==null)l=n==="GET"||n==="HEAD"?404:204,gg.lastModified&&e.lastModified&&s.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d=e.lastModified){N7[0]=d;let h=String.fromCharCode(34,(qt[0]&63)+62,(qt[0]>>6)+(qt[1]<<2&63)+62,(qt[1]>>4)+(qt[2]<<4&63)+62,(qt[2]>>2)+62,(qt[3]&63)+62,(qt[3]>>6)+(qt[4]<<2&63)+62,(qt[4]>>4)+(qt[5]<<4&63)+62,(qt[5]>>2)+62,(qt[6]&63)+62,(qt[6]>>6)+(qt[7]<<2&63)+62,34),p=r["if-none-match"];p&&h==p?(_?.onDone&&_.onDone(),l=304,_=void 0):s.setIfNone("ETag",h),gg.lastModified&&s.setIfNone("Last-Modified",new Date(d).toUTCString())}e.createdResource&&(l=201),e.newLocation&&s.setIfNone("Location",e.newLocation);let f={status:l,headers:s,body:void 0},E=_?.wasLoadedFromSource?.();return E!==void 0&&(f.wasCacheMiss=E,!E&&d&&s.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||d))/1e3))),_!==void 0&&(f.body=df(_,e,f),n==="HEAD"&&(f.body=void 0)),f}catch(i){i.statusCode?i.statusCode===500?Eo.warn(i):Eo.info(i):Eo.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=df(i.contentType?i:i.toString(),e,o),o}}function w7(e){gg=e,!pv&&(pv=!0,pf=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return y7(t,r)}),e.server.ws(async(t,r,n)=>{zu++;let s=new Tn;Sv||(Sv=!0,jc(l=>{zu>0&&l.push({metric:"ws-connections",connections:zu,byThread:!0})}));let i;t.on("error",l=>{i=!0,Eo.warn(l)});let o;t.on("message",a(function(d){o||(o=fo(r.headers.asObject["content-type"]));let f=o(d);s.push(f)},"message"));let c;t.on("close",()=>{zu--,tn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()}),await n;let u=r.url.slice(1),_=pf.getMatch(u);if(tn(!!_,"connection","ws","connect"),!_)t.send(Ei(`No resource was found to handle ${r.pathname}`,r));else{r.handlerPath=_.path,Br(h=>({count:h.count,total:zu}),"connections",r.handlerPath,"connect","ws");let l={url:_.relativeURL,async:!0},d=_.Resource;c=(await Ke(r,()=>d.connect(l,s,r)))[Symbol.asyncIterator]();let E;for(;!(E=await c.next()).done;){let h=Ei(E.value,r);t.send(h),Br(h.length,"bytes-sent",r.handlerPath,"message","ws")}}t.close()}))}var Eo,ya,qt,N7,gg,mv,pv,pf,Sv,zu,Tv=Oe(()=>{ma();Rs();Eo=x(W()),ya=x(ee());mf();uc();Qi();qd();hv();qt=new Uint8Array(8),N7=new Float64Array(qt.buffer,0,1),gg={},mv="openapi";a(y7,"http");zu=0;a(w7,"start")});var Rg=T((EEe,gv)=>{var{recordAction:Tf,recordActionBinary:I7}=(Rs(),te(Zc)),C7=require("fastify-plugin"),D7=200;gv.exports=C7(function(e,t,r){e.addHook("onResponse",async(n,s)=>{s.getResponseTime()}),e.addHook("onSend",async(n,s,i)=>{let o=s.getResponseTime(),c=performance.now(),u=s.request.routeOptions,_,l,d;u.config?.isOperation?(_=n.body?.operation,l="operation"):(_=u.url,l="fastify-route",d=u.method),Tf(o,"duration",_,d,l),I7(s.raw.statusCode<400,"success",_,d,l);let f=D7;i?.pipe?(i.on("data",h=>{f+=h.length}),i.on("end",()=>{Tf(performance.now()-c,"transfer",_,d,l),Tf(f,"bytes-sent",_,d,l)})):(f+=i?.length||0,Tf(f,"bytes-sent",_,d,l));let E=o.toFixed(3);s.header("Server-Timing",`db;dur=${E}`)}),r()},{name:"hdb-request-time"})});var wg=T((pEe,bv)=>{var Of=require("clone"),bf=et(),L7=J(),Rf=U(),hEe=W(),Ag=require("fs"),bg=require("joi"),{string:Af}=bg.types(),{hdb_errors:M7,handleHDBError:gf}=ee(),{HDB_ERROR_MSGS:mEe,HTTP_STATUS_CODES:Og}=M7,{common_validators:wa}=Vn(),Rv=" is required",U7=["insert","update","upsert"],Ng={database:{presence:!1,format:wa.schema_format,length:wa.schema_length},schema:{presence:!1,format:wa.schema_format,length:wa.schema_length},table:{presence:!0,format:wa.schema_format,length:wa.schema_length},action:{inclusion:{within:U7,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},P7={schema:Af.required(),table:Af.required(),action:Af.valid("insert","update","upsert")},{AWS_ACCESS_KEY:v7,AWS_SECRET:B7,AWS_BUCKET:H7,AWS_FILE_KEY:x7,REGION:F7}=Rf.S3_BUCKET_AUTH_KEYS,q7={s3:{presence:!0},[`s3.${v7}`]:{presence:!0,type:"String"},[`s3.${B7}`]:{presence:!0,type:"String"},[`s3.${H7}`]:{presence:!0,type:"String"},[`s3.${x7}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${F7}`]:{presence:!0,type:"String"}},Av=Of(Ng);Av.data.presence={message:Rv};var Ov=Of(Ng);Ov.file_path.presence={message:Rv};var G7=Object.assign(Of(Ng),q7),yg=Of(P7);yg.csv_url=Af.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();yg.passthrough_headers=bg.object();function k7(e){let t=bf.validateObject(e,Av);return Nf(e,t)}a(k7,"dataObject");function V7(e){let t=bf.validateBySchema(e,bg.object(yg));return Nf(e,t)}a(V7,"urlObject");function $7(e){let t=bf.validateObject(e,Ov);return Nf(e,t)}a($7,"fileObject");function Y7(e){let t=bf.validateObject(e,G7);return Nf(e,t)}a(Y7,"s3FileObject");function Nf(e,t){if(!t){let r=L7.checkGlobalSchemaTable(e.schema,e.table);if(r)return gf(new Error,r,Og.BAD_REQUEST);if(e.operation===Rf.OPERATIONS_ENUM.CSV_FILE_LOAD)try{Ag.accessSync(e.file_path,Ag.constants.R_OK|Ag.constants.F_OK)}catch(n){return n.code===Rf.NODE_ERROR_CODES.ENOENT?gf(n,`No such file or directory ${n.path}`,Og.BAD_REQUEST):n.code===Rf.NODE_ERROR_CODES.EACCES?gf(n,`Permission denied ${n.path}`,Og.BAD_REQUEST):gf(n)}}return t}a(Nf,"postValidateChecks");bv.exports={dataObject:k7,urlObject:V7,fileObject:$7,s3FileObject:Y7}});var Ig=T((TEe,Nv)=>{"use strict";var Ju=W(),yf=U();async function K7(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===yf.OPERATIONS_ENUM.INSERT||t.operation===yf.OPERATIONS_ENUM.UPDATE||t.operation===yf.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===yf.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(Ju.info(i.message),i):i.http_resp_msg?(Ju.error(`Error calling operation: ${e.name}`),Ju.error(i.http_resp_msg),i):(Ju.error(`Error calling operation: ${e.name}`),Ju.error(i),i)}}a(K7,"callOperationFunctionAsAwait");Nv.exports={callOperationFunctionAsAwait:K7}});var wv=T((REe,yv)=>{"use strict";var Cg=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}},Dg=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};yv.exports={BulkLoadFileObject:Cg,BulkLoadDataObject:Dg}});var Cv=T((OEe,Iv)=>{"use strict";var Lg=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};Iv.exports=Lg});var Hg=T((CEe,Kv)=>{"use strict";var wf=Zr(),Cf=wg(),W7=require("needle"),Un=U(),NEe=tt(),Ia=J(),{handleHDBError:nt,hdb_errors:xv}=ee(),{HTTP_STATUS_CODES:Gt,HDB_ERROR_MSGS:Nt,CHECK_LOGS_WRAPPER:mo}=xv,Ca=W(),Mg=require("papaparse");Ia.promisifyPapaParse();var Pn=require("fs-extra"),Q7=require("path"),{chain:Dv}=require("stream-chain"),Lv=require("stream-json/streamers/StreamArray"),Mv=require("stream-json/utils/Batch"),Uv=require("stream-chain/utils/comp"),{finished:Pv}=require("stream"),z7=Z(),Fv=Ig(),J7=eg(),{BulkLoadFileObject:Pg,BulkLoadDataObject:X7}=wv(),vg=$T(),{verifyBulkLoadAttributePerms:qv}=of(),yEe=Cv(),wEe=At(),IEe=ms(),{databases:j7}=(be(),te(Fe)),{coerceType:Z7}=(Df(),te(xg)),vv="No records parsed from csv file.",ho=`${z7.get("HDB_ROOT")}/tmp`,{schema_regex:eee}=Vn(),Bv=1024*1024*2,Hv=5e3,tee={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};Kv.exports={csvDataLoad:ree,csvURLLoad:nee,csvFileLoad:see,importFromS3:iee};async function ree(e,t){let r=Cf.dataObject(e);if(r)throw nt(r,r.message,Gt.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=Vv(e.schema,e.table),i=Mg.parse(e.data,{header:!0,skipEmptyLines:!0,transform:Ug.bind(null,s),dynamicTyping:!1}),o=new vg;e.hdb_user&&e.hdb_user.role&&e.hdb_user.role.permission&&e.hdb_user.role.permission.super_user!==!0&&qv(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 nt(new Error,c,Gt.BAD_REQUEST,void 0,void 0,!0);let u=new X7(e.action,e.schema,e.table,i.data);return n=await Fv.callOperationFunctionAsAwait($v,u,null),n.message===vv?vv:Yv(n.records,n.number_written)}catch(s){throw po(s)}}a(ree,"csvDataLoad");async function nee(e){let t=Cf.urlObject(e);if(t)throw nt(t,t.message,Gt.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${ho}/${r}`;try{await oee(e,r)}catch(s){throw Ca.error(Nt.DOWNLOAD_FILE_ERR(r)+" - "+s),nt(s,mo(Nt.DOWNLOAD_FILE_ERR(r)))}try{let s=new Pg(this.job_operation_function.name,e.action,e.schema,e.table,n,Un.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission),i=await Bg(s);return await If(n),i}catch(s){throw await If(n),po(s)}}a(nee,"csvURLLoad");async function see(e){let t=Cf.fileObject(e);if(t)throw nt(t,t.message,Gt.BAD_REQUEST,void 0,void 0,!0);let r=new Pg(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,Un.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission);try{return await Bg(r)}catch(n){throw po(n)}}a(see,"csvFileLoad");async function iee(e){let t=Cf.s3FileObject(e);if(t)throw nt(t,t.message,Gt.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=Q7.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${ho}/${s}`;let i=new Pg(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user.role.permission);await aee(s,e);let o=await Bg(i);return await If(r),o}catch(n){throw await If(r),po(n)}}a(iee,"importFromS3");async function oee(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await W7("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 nt(n,s,n.statusCode,Un.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}uee(r,e.csv_url),await cee(t,r.raw)}a(oee,"downloadCSVFile");async function aee(e,t){try{let r=`${ho}/${e}`;await Pn.mkdirp(ho),await Pn.writeFile(`${ho}/${e}`,"",{flag:"a+"});let n=await Pn.createWriteStream(r),s=await J7.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(){Ca.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Ca.error(Nt.S3_DOWNLOAD_ERR+" - "+r),nt(r,mo(Nt.S3_DOWNLOAD_ERR))}}a(aee,"downloadFileFromS3");async function cee(e,t){try{await Pn.mkdirp(ho),await Pn.writeFile(`${ho}/${e}`,t)}catch(r){throw Ca.error(Nt.WRITE_TEMP_FILE_ERR),nt(r,mo(Nt.DEFAULT_BULK_LOAD_ERR))}}a(cee,"writeFileToTempFolder");async function If(e){if(e)try{await Pn.access(e),await Pn.unlink(e)}catch{Ca.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(If,"deleteTempFile");function uee(e,t){if(e.statusCode!==xv.HTTP_STATUS_CODES.OK)throw nt(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Gt.BAD_REQUEST);if(!tee[e.headers["content-type"]])throw nt(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Gt.BAD_REQUEST);if(!e.raw)throw nt(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Gt.BAD_REQUEST)}a(uee,"validateURLResponse");async function Bg(e){try{let t;switch(e.file_type){case Un.VALID_S3_FILE_TYPES.CSV:t=await lee(e);break;case Un.VALID_S3_FILE_TYPES.JSON:t=await _ee(e);break;default:throw nt(new Error,Nt.DEFAULT_BULK_LOAD_ERR,Gt.BAD_REQUEST,Un.LOG_LEVELS.ERROR,Nt.INVALID_FILE_EXT_ERR(e))}return Yv(t.records,t.number_written)}catch(t){throw po(t)}}a(Bg,"fileLoad");async function Gv(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 wf.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&qv(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let u=nt(c);r(u)}}a(Gv,"validateChunk");async function kv(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Ia.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Ia.isEmpty(c)&&!Ia.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 Fv.callOperationFunctionAsAwait($v,c,null);t.records+=u.records,t.number_written+=u.number_written,s&&s.resume()}catch(c){let u=nt(c,mo(Nt.INSERT_CSV_ERR),Gt.INTERNAL_SERVER_ERROR,Un.LOG_LEVELS.ERROR,Nt.INSERT_CSV_ERR+" - "+c);r(u)}}a(kv,"insertChunk");async function lee(e){let t={records:0,number_written:0},r=Vv(e.schema,e.table);try{let n=new vg,s=Pn.createReadStream(e.file_path,{highWaterMark:Bv});s.setEncoding("utf8"),await Mg.parsePromise(s,Gv.bind(null,e,n),Ug.bind(null,r));let i=n.getPermsResponse();if(i)throw nt(new Error,i,Gt.BAD_REQUEST);return s=Pn.createReadStream(e.file_path,{highWaterMark:Bv}),s.setEncoding("utf8"),await Mg.parsePromise(s,kv.bind(null,e,t),Ug.bind(null,r)),s.destroy(),t}catch(n){throw nt(n,mo(Nt.PAPA_PARSE_ERR),Gt.INTERNAL_SERVER_ERROR,Un.LOG_LEVELS.ERROR,Nt.PAPA_PARSE_ERR+n)}}a(lee,"callPapaParse");function Vv(e,t){let r=j7[e][t].attributes,n=new Map;for(let s of r)s.type&&n.set(s.name,i=>Z7(i,s));return n}a(Vv,"createTransformMap");function Ug(e,t,r){let n=e.get(r);return n?n(t):Ia.autoCast(t)}a(Ug,"typeFunction");async function _ee(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new vg,s=Dv([Pn.createReadStream(e.file_path,{encoding:"utf-8"}),Lv.withParser(),c=>c.value,new Mv({batchSize:Hv}),Uv(async c=>{await Gv(e,n,r,c)})]);await new Promise((c,u)=>{Pv(s,_=>{_?u(_):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw nt(new Error,i,Gt.BAD_REQUEST);let o=Dv([Pn.createReadStream(e.file_path,{encoding:"utf-8"}),Lv.withParser(),c=>c.value,new Mv({batchSize:Hv}),Uv(async c=>{await kv(e,t,r,c)})]);return await new Promise((c,u)=>{Pv(o,_=>{_?u(_):c()}),o.resume()}),t}catch(n){throw nt(n,mo(Nt.INSERT_JSON_ERR),Gt.INTERNAL_SERVER_ERROR,Un.LOG_LEVELS.ERROR,Nt.INSERT_JSON_ERR+n)}}a(_ee,"insertJson");async function $v(e){let t={};try{e.data&&e.data.length>0&&dee(e.data[0])?t=await fee(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Ca.info(t.message))}catch(r){throw po(r)}return t}a($v,"callBulkFileLoad");function dee(e){let t=Object.keys(e);for(let r of t)if(!eee.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(dee,"validateColumnNames");async function fee(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=wf.insert;break;case"update":i=wf.update;break;case"upsert":i=wf.upsert;break;default:throw nt(new Error,Nt.INVALID_ACTION_PARAM_ERR(n),Gt.BAD_REQUEST,Un.LOG_LEVELS.ERROR,Nt.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=Ia.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:u,new_attributes:o.new_attributes}}catch(o){throw po(o)}}a(fee,"bulkFileLoad");function Yv(e,t){return`successfully loaded ${t} of ${e} records`}a(Yv,"buildResponseMsg");function po(e){return nt(e,mo(Nt.DEFAULT_BULK_LOAD_ERR),Gt.INTERNAL_SERVER_ERROR,Un.LOG_LEVELS.ERROR,Nt.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(po,"buildTopLevelErrMsg")});var Qv=T((LEe,Wv)=>{"use strict";var Fg=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};Wv.exports=Fg});var Xv=T((UEe,Jv)=>{"use strict";var Eee=U(),zv=require("moment"),hee=require("uuid").v4,qg=class{static{a(this,"JobObject")}constructor(){this.id=hee(),this.type=void 0,this.start_datetime=zv().valueOf(),this.created_datetime=zv().valueOf(),this.end_datetime=void 0,this.status=Eee.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};Jv.exports=qg});var Gg=T((vEe,n0)=>{"use strict";var mee=require("uuid").v4,e0=Zr(),t0=jr(),pee=Qn(),See=Xo(),Tee=Qv(),st=U(),gee=Xv(),Ree=TS(),ln=W(),Aee=Oc(),Da=J(),{promisify:Oee}=require("util"),So=require("moment"),bee=cf(),Lf=wg(),jv=Em(),{deleteTransactionLogsBeforeValidator:Nee}=FT(),{handleHDBError:yee,hdb_errors:wee}=ee(),{HTTP_STATUS_CODES:Iee}=wee,Zv=t0.searchByValue,Cee=t0.searchByHash,Dee=e0.insert,Lee=Oee(bee.evaluateSQL),Mee=e0.update;n0.exports={addJob:vee,updateJob:Hee,handleGetJob:Uee,handleGetJobsByStartDate:Pee,getJobById:r0};async function Uee(e){try{let t=await r0(e.id);return Da.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 ln.error("There was an error getting job",t),new Error(r)}}a(Uee,"handleGetJob");async function Pee(e){try{let t=await Bee(e);if(ln.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=So(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=So(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 ln.error(r),new Error(r)}}a(Pee,"handleGetJobsByStartDate");async function vee(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||Da.isEmptyOrZeroLength(e.operation)){let l="job parameter is invalid";return ln.info(l),t.error=l,t}if(!st.JOB_TYPE_ENUM[e.operation])return ln.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case st.OPERATIONS_ENUM.CSV_FILE_LOAD:n=Lf.fileObject(e);break;case st.OPERATIONS_ENUM.CSV_URL_LOAD:n=Lf.urlObject(e);break;case st.OPERATIONS_ENUM.CSV_DATA_LOAD:n=Lf.dataObject(e);break;case st.OPERATIONS_ENUM.IMPORT_FROM_S3:n=Lf.s3FileObject(e);break;case st.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case st.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=jv(e,"date");break;case st.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=jv(e,"timestamp");break;case st.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=Nee(e);break;default:break}if(n)throw yee(n,n.message,Iee.BAD_REQUEST,void 0,void 0,!0);let s=new gee;s.type=e.operation===st.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?st.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user.username;let i=new pee(st.SYSTEM_SCHEMA_NAME,st.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await Zv(i))}catch(l){let d=`There was an error inserting a new job: ${l}`;return ln.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=mee();try{o=await Zv(i)}catch(l){let d=`There was an error inserting a new job: ${l}`;return ln.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return ln.error("Error creating a job, could not find a unique job id."),t}s.request=e;let u=new Aee(st.SYSTEM_SCHEMA_NAME,st.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),_;try{_=await Dee(u)}catch(l){return ln.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,ln.trace(l)}return t}a(vee,"addJob");async function Bee(e){let t=So(e.from_date,So.ISO_8601),r=So(e.to_date,So.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 Tee(n,e.hdb_user);try{return await Lee(s)}catch(i){throw ln.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(Bee,"getJobsInDateRange");async function r0(e){if(Da.isEmptyOrZeroLength(e))return Da.errorizeMessage("Invalid job ID specified.");let t=new See(st.SYSTEM_SCHEMA_NAME,st.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await Cee(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return ln.error(n),Da.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(r0,"getJobById");async function Hee(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(Da.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===st.JOB_STATUS_ENUM.COMPLETE||e.status===st.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=So().valueOf());let t=new Ree(st.SYSTEM_SCHEMA_NAME,st.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await Mee(t),r}a(Hee,"updateJob")});var u0=T((HEe,c0)=>{"use strict";var s0=J(),mr=U(),xee=require("moment"),Mf=Hg(),Uf=W(),i0=Gg(),o0=uf(),a0=xi(),Fee=je(),qee=tf(),kg=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function Gee(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(s0.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(s0.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case mr.JOB_TYPE_ENUM.csv_file_load:await Ps(e,Mf.csvFileLoad);break;case mr.JOB_TYPE_ENUM.csv_url_load:await Ps(e,Mf.csvURLLoad);break;case mr.JOB_TYPE_ENUM.csv_data_load:await Ps(e,Mf.csvDataLoad);break;case mr.JOB_TYPE_ENUM.import_from_s3:await Ps(e,Mf.importFromS3);break;case mr.JOB_TYPE_ENUM.empty_trash:break;case mr.JOB_TYPE_ENUM.export_local:await Ps(e,o0.export_local);break;case mr.JOB_TYPE_ENUM.export_to_s3:await Ps(e,o0.export_to_s3);break;case mr.JOB_TYPE_ENUM.delete_files_before:case mr.JOB_TYPE_ENUM.delete_records_before:await Ps(e,a0.deleteFilesBefore);break;case mr.JOB_TYPE_ENUM.delete_audit_logs_before:await Ps(e,a0.deleteAuditLogsBefore);break;case mr.JOB_TYPE_ENUM.delete_transaction_logs_before:await Ps(e,qee.deleteTransactionLogsBefore);break;default:return`Invalid operation ${e.json.operation} specified`}}a(Gee,"parseMessage");async function Ps(e,t){try{e.job.status=mr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=xee().valueOf(),await i0.updateJob(e.job),await kee(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):Uf.error(`There was an error running ${t.name} job with id ${e.job.id}`),Uf.error(n),e.job.message=n,e.job.status=mr.JOB_STATUS_ENUM.ERROR;try{await i0.updateJob(e.job)}catch(s){throw Uf.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Ps,"runJob");async function kee(e){Uf.trace("launching job thread:",e),Fee.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:Object.assign({},process.env,{[mr.PROCESS_NAME_ENV_PROP]:`JOB-${e}`})})}a(kee,"launchJobThread");c0.exports={parseMessage:Gee,RunnerMessage:kg}});var _0=T((FEe,l0)=>{"use strict";var Vg=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};l0.exports=Vg});var I0=T((GEe,zg)=>{"use strict";var Hf=jr(),Kg=cf(),Pf=Hg(),vs=rd(),vf=Ui(),ju=xi(),Vee=sS(),Xu=en(),Bf=fS(),kt=xT(),yt=W(),$ee=mS(),Yee=Td(),d0=jS(),Kee=Rd(),Wee=ZS(),Qee=eT(),zee=nT(),Jee=iT(),$g=cT(),f0=uf(),Xee=of(),Wg=Gg(),q=U(),{hdb_errors:el,handleHDBError:Zu}=ee(),{HTTP_STATUS_CODES:E0}=el,Yg=fT(),h0=xd(),b0=require("util"),La=Zr(),jee=zs(),Zee=ca(),m0=u0(),p0=_u(),S0=($d(),te(Lu)),T0=Lr(),g0=tf(),R0=zd(),{setServerUtilities:ete}=(Df(),te(xg)),{CONTEXT:tte}=(gn(),te(up)),{_assignPackageExport:rte}=require("../../index"),{transformReq:nte}=J(),{server:ste}=(jt(),te(yi)),ite=Ig(),A0=Hf.searchByHash,ote=Hf.searchByValue,ate=b0.promisify(Hf.search),cte=b0.promisify(Kg.evaluateSQL),ute={[q.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[q.OPERATIONS_ENUM.CREATE_TABLE]:!0,[q.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[q.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[q.OPERATIONS_ENUM.DROP_TABLE]:!0,[q.OPERATIONS_ENUM.DROP_SCHEMA]:!0},V=_0();async function N0(e,t){try{if(e.body.operation!=="read_log"&&(yt.log_level===q.LOG_LEVELS.INFO||yt.log_level===q.LOG_LEVELS.DEBUG||yt.log_level===q.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,...o}=e.body;yt.info(o)}}catch(n){yt.error(n)}let r=await ite.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return ute[e.body.operation]&&jee.setSchemaDataToGlobal(n=>{n&&yt.error(n)}),r}a(N0,"processLocalTransaction");var O0=_te();zg.exports={chooseOperation:y0,getOperationFunction:w0,operation:Qg,processLocalTransaction:N0};ete(zg.exports);ste.operation=Qg;function y0(e){let t;try{t=w0(e)}catch(s){throw yt.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=Kg.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=Kg.checkASTPermissions(e,i);if(o)throw yt.error(`${E0.FORBIDDEN} from operation ${e.operation}`),yt.warn(`User '${e.hdb_user.username}' is not permitted to ${e.operation}`),Zu(new Error,o,el.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==q.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==q.OPERATIONS_ENUM.LOGIN&&e.operation!==q.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=Xee.verifyPerms(i,s);if(o)throw yt.error(`${E0.FORBIDDEN} from operation ${e.operation}`),yt.warn(`User '${i.hdb_user.username}' is not permitted to ${i.operation}`),Zu(new Error,o,el.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw Zu(s,"There was an error when trying to choose an operation path")}return r}a(y0,"chooseOperation");function w0(e){if(yt.trace(`getOperationFunction with operation: ${e.operation}`),O0.has(e.operation))return O0.get(e.operation);throw Zu(new Error,el.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),el.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(w0,"getOperationFunction");rte("operation",Qg);function Qg(e,t){e.hdb_user=this[tte]?.user,e.bypass_auth=!t;let r=y0(e);return N0({body:e},r)}a(Qg,"operation");async function lte(e){yt.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[q.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case q.OPERATIONS_ENUM.INSERT:o=await La.insert(i);break;case q.OPERATIONS_ENUM.UPDATE:o=await La.update(i);break;case q.OPERATIONS_ENUM.UPSERT:o=await La.upsert(i);break;case q.OPERATIONS_ENUM.DELETE:o=await ju.deleteRecord(i);break;default:yt.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){yt.info("Invalid operation in transaction"),yt.error(o)}}a(lte,"catchup");async function is(e){nte(e);let t,r;try{r=await Wg.addJob(e),t=r.createdJob,yt.info("addJob result",r);let n=new m0.RunnerMessage(t,e);return await m0.parseMessage(n),{message:`Starting job with id ${t.id}`,job_id:t.id}}catch(n){let s=`There was an error executing job: ${n.http_resp_msg?n.http_resp_msg:n}`;throw yt.error(s),Zu(n,s)}}a(is,"executeJob");function _te(){let e=new Map;return e.set(q.OPERATIONS_ENUM.INSERT,new V(La.insert)),e.set(q.OPERATIONS_ENUM.UPDATE,new V(La.update)),e.set(q.OPERATIONS_ENUM.UPSERT,new V(La.upsert)),e.set(q.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new V(Hf.searchByConditions)),e.set(q.OPERATIONS_ENUM.SEARCH_BY_HASH,new V(A0)),e.set(q.OPERATIONS_ENUM.SEARCH_BY_ID,new V(A0)),e.set(q.OPERATIONS_ENUM.SEARCH_BY_VALUE,new V(ote)),e.set(q.OPERATIONS_ENUM.SEARCH,new V(ate)),e.set(q.OPERATIONS_ENUM.SQL,new V(cte)),e.set(q.OPERATIONS_ENUM.CSV_DATA_LOAD,new V(is,Pf.csvDataLoad)),e.set(q.OPERATIONS_ENUM.CSV_FILE_LOAD,new V(is,Pf.csvFileLoad)),e.set(q.OPERATIONS_ENUM.CSV_URL_LOAD,new V(is,Pf.csvURLLoad)),e.set(q.OPERATIONS_ENUM.IMPORT_FROM_S3,new V(is,Pf.importFromS3)),e.set(q.OPERATIONS_ENUM.CREATE_SCHEMA,new V(vs.createSchema)),e.set(q.OPERATIONS_ENUM.CREATE_DATABASE,new V(vs.createSchema)),e.set(q.OPERATIONS_ENUM.CREATE_TABLE,new V(vs.createTable)),e.set(q.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new V(vs.createAttribute)),e.set(q.OPERATIONS_ENUM.DROP_SCHEMA,new V(vs.dropSchema)),e.set(q.OPERATIONS_ENUM.DROP_DATABASE,new V(vs.dropSchema)),e.set(q.OPERATIONS_ENUM.DROP_TABLE,new V(vs.dropTable)),e.set(q.OPERATIONS_ENUM.DROP_ATTRIBUTE,new V(vs.dropAttribute)),e.set(q.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new V(vf.describeSchema)),e.set(q.OPERATIONS_ENUM.DESCRIBE_DATABASE,new V(vf.describeSchema)),e.set(q.OPERATIONS_ENUM.DESCRIBE_TABLE,new V(vf.describeTable)),e.set(q.OPERATIONS_ENUM.DESCRIBE_ALL,new V(vf.describeAll)),e.set(q.OPERATIONS_ENUM.DELETE,new V(ju.deleteRecord)),e.set(q.OPERATIONS_ENUM.ADD_USER,new V(Xu.addUser)),e.set(q.OPERATIONS_ENUM.ALTER_USER,new V(Xu.alterUser)),e.set(q.OPERATIONS_ENUM.DROP_USER,new V(Xu.dropUser)),e.set(q.OPERATIONS_ENUM.LIST_USERS,new V(Xu.listUsersExternal)),e.set(q.OPERATIONS_ENUM.LIST_ROLES,new V(Bf.listRoles)),e.set(q.OPERATIONS_ENUM.ADD_ROLE,new V(Bf.addRole)),e.set(q.OPERATIONS_ENUM.ALTER_ROLE,new V(Bf.alterRole)),e.set(q.OPERATIONS_ENUM.DROP_ROLE,new V(Bf.dropRole)),e.set(q.OPERATIONS_ENUM.USER_INFO,new V(Xu.userInfo)),e.set(q.OPERATIONS_ENUM.READ_LOG,new V($ee)),e.set(q.OPERATIONS_ENUM.ADD_NODE,new V(Yee)),e.set(q.OPERATIONS_ENUM.UPDATE_NODE,new V(d0)),e.set(q.OPERATIONS_ENUM.SET_NODE_REPLICATION,new V(d0)),e.set(q.OPERATIONS_ENUM.REMOVE_NODE,new V(Kee)),e.set(q.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new V(Wee)),e.set(q.OPERATIONS_ENUM.PURGE_STREAM,new V(Qee)),e.set(q.OPERATIONS_ENUM.SET_CONFIGURATION,new V(T0.setConfiguration)),e.set(q.OPERATIONS_ENUM.CLUSTER_STATUS,new V(zee.clusterStatus)),e.set(q.OPERATIONS_ENUM.CLUSTER_NETWORK,new V(Jee)),e.set(q.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new V($g.setRoutes)),e.set(q.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new V($g.getRoutes)),e.set(q.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new V($g.deleteRoutes)),e.set(q.OPERATIONS_ENUM.EXPORT_TO_S3,new V(is,f0.export_to_s3)),e.set(q.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new V(is,ju.deleteFilesBefore)),e.set(q.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new V(is,ju.deleteFilesBefore)),e.set(q.OPERATIONS_ENUM.EXPORT_LOCAL,new V(is,f0.export_local)),e.set(q.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new V(Wg.handleGetJobsByStartDate)),e.set(q.OPERATIONS_ENUM.GET_JOB,new V(Wg.handleGetJob)),e.set(q.OPERATIONS_ENUM.GET_FINGERPRINT,new V(Yg.getFingerprint)),e.set(q.OPERATIONS_ENUM.SET_LICENSE,new V(Yg.setLicense)),e.set(q.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new V(Yg.getRegistrationInfo)),e.set(q.OPERATIONS_ENUM.RESTART,new V(h0.restart)),e.set(q.OPERATIONS_ENUM.RESTART_SERVICE,new V(h0.restartService)),e.set(q.OPERATIONS_ENUM.CATCHUP,new V(lte)),e.set(q.OPERATIONS_ENUM.SYSTEM_INFORMATION,new V(Zee.systemInformation)),e.set(q.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new V(is,ju.deleteAuditLogsBefore)),e.set(q.OPERATIONS_ENUM.READ_AUDIT_LOG,new V(Vee)),e.set(q.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new V(p0.createTokens)),e.set(q.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new V(p0.refreshOperationToken)),e.set(q.OPERATIONS_ENUM.LOGIN,new V(S0.login)),e.set(q.OPERATIONS_ENUM.LOGOUT,new V(S0.logout)),e.set(q.OPERATIONS_ENUM.GET_CONFIGURATION,new V(T0.getConfiguration)),e.set(q.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new V(kt.customFunctionsStatus)),e.set(q.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new V(kt.getCustomFunctions)),e.set(q.OPERATIONS_ENUM.GET_COMPONENT_FILE,new V(kt.getComponentFile)),e.set(q.OPERATIONS_ENUM.GET_COMPONENTS,new V(kt.getComponents)),e.set(q.OPERATIONS_ENUM.SET_COMPONENT_FILE,new V(kt.setComponentFile)),e.set(q.OPERATIONS_ENUM.DROP_COMPONENT,new V(kt.dropComponent)),e.set(q.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new V(kt.getCustomFunction)),e.set(q.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new V(kt.setCustomFunction)),e.set(q.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new V(kt.dropCustomFunction)),e.set(q.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new V(kt.addComponent)),e.set(q.OPERATIONS_ENUM.ADD_COMPONENT,new V(kt.addComponent)),e.set(q.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new V(kt.dropCustomFunctionProject)),e.set(q.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new V(kt.packageComponent)),e.set(q.OPERATIONS_ENUM.PACKAGE_COMPONENT,new V(kt.packageComponent)),e.set(q.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new V(kt.deployComponent)),e.set(q.OPERATIONS_ENUM.DEPLOY_COMPONENT,new V(kt.deployComponent)),e.set(q.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new V(g0.readTransactionLog)),e.set(q.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new V(is,g0.deleteTransactionLogsBefore)),e.set(q.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new V(R0.installModules)),e.set(q.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new V(R0.auditModules)),e.set(q.OPERATIONS_ENUM.GET_BACKUP,new V(vs.getBackup)),e}a(_te,"initializeOperationFunctionMap")});var Ff=T((VEe,L0)=>{"use strict";var Jg=U(),dte=J(),tl=W(),{handleHDBError:Xg,hdb_errors:xf}=ee(),{isMainThread:fte}=require("worker_threads"),{Readable:Ete}=require("stream"),C0=require("os"),hte=require("util"),mte=wS(),pte=hte.promisify(mte.authorize),D0=I0(),{createGzip:Ste,constants:Tte}=require("zlib");function gte(e){let t=`Found an uncaught exception with message: ${e.message}. ${C0.EOL}Stack: ${e.stack} ${C0.EOL}Terminating ${fte?"HDB":"thread"}.`;console.error(t),tl.fatal(t),process.exit(1)}a(gte,"handleServerUncaughtException");function Rte(e,t,r){if(tl[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:xf.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(Rte,"serverErrorHandler");function Ate(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=Xg(new Error,"Invalid JSON.",xf.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(dte.isEmpty(e.body.operation)){let n=Xg(new Error,"Request body must include an 'operation' property.",xf.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Ate,"reqBodyValidationHandler");function Ote(e,t,r){let n;e.body.operation!==Jg.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==Jg.OPERATIONS_ENUM.LOGIN&&e.body.operation!==Jg.OPERATIONS_ENUM.LOGOUT?pte(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{tl.warn(s),tl.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r(Xg(s,i,xf.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(Ote,"authHandler");async function bte(e,t,r=!1){let n;try{r&&(e.body.operation!=="configure_cluster"||e.body.operation!=="set_configuration")&&(e.body.bypass_auth=r),n=D0.chooseOperation(e.body);let s=await D0.processLocalTransaction(e,n);if(s instanceof Ete&&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(Ste({level:Tte.Z_BEST_SPEED})))}return s}catch(s){throw tl.error(s),s}}a(bte,"handlePostRequest");L0.exports={authHandler:Ote,handlePostRequest:bte,handleServerUncaughtException:gte,serverErrorHandler:Rte,reqBodyValidationHandler:Ate}});var v0=T((YEe,P0)=>{"use strict";var Nte=require("fastify-plugin"),{handlePostRequest:M0,authHandler:yte,reqBodyValidationHandler:wte}=Ff();async function Ite(e){e.decorate("hdbCore",{preValidation:[wte,yte],request:t=>U0(M0(t,response)),requestWithoutAuthentication:(t,r)=>U0(M0(t,r,!0))})}a(Ite,"hdbCore");async function U0(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(U0,"convertAsyncIterators");P0.exports=Nte(Ite)});var x0=T((QEe,H0)=>{"use strict";var WEe=require("fs"),jg=Z();jg.initSync();var{CONFIG_PARAMS:B0}=U(),Cte=1024*1024*1024;function Dte(e){let t=jg.get(B0.HTTP_TIMEOUT),r=jg.get(B0.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:Cte,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,https:e}}a(Dte,"getServerOptions");H0.exports=Dte});var G0=T((JEe,q0)=>{"use strict";var Zg=Z();Zg.initSync();var{CONFIG_PARAMS:F0}=U();function Lte(){let e=Zg.get(F0.HTTP_CORSACCESSLIST),t=Zg.get(F0.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(Lte,"getCORSOptions");q0.exports=Lte});var $0=T((jEe,V0)=>{"use strict";var k0=Z();k0.initSync();var Mte=U();function Ute(){return k0.get(Mte.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(Ute,"getHeaderTimeoutConfig");V0.exports=Ute});var tR={};ke(tR,{customFunctionsServer:()=>Bte,ready:()=>iB,start:()=>vte});function vte(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){Bs||(Bs=sB(t),Xe.http((await Bs).server));let o=await Bs,c=(0,eR.dirname)(s),u=(0,eR.dirname)(n);if(u.startsWith("/")&&(u=u.slice(1)),!Y0.has(c)){Y0.add(c);try{o.register(xte(c,u))}catch(_){if(_.message==="Root plugin has already booted")Ge.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw _}}},ready:iB}}async function Bte(){try{Ge.info("In Custom Functions Fastify server"+process.cwd()),Ge.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Ge.debug(`Custom Functions server process ${process.pid} starting up.`),await Hte();let e=X0.get(j0.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=Bs=await sB(e)}catch(r){throw Ge.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw Ge.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){Ge.error(`Custom Functions ${process.pid} Error: ${e}`),Ge.error(e),process.exit(1)}}async function Hte(){try{Ge.info("Custom Functions starting configuration."),await Z0.setUsersToGlobal(),Ge.info("Custom Functions completed configuration.")}catch(e){Ge.error(e)}}function xte(e,t){return async function(r){try{Ge.info("Custom Functions starting buildRoutes"),Ge.trace("Loading fastify routes folder "+e),(0,K0.existsSync)(e)&&r.register(J0.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:Ge.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?Ge.error(s.message):s&&Ge.error(s),o()})}catch(n){Ge.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function sB(e){Ge.info("Custom Functions starting buildServer.");let t=(0,eB.default)(e),r=(0,W0.default)(t);r.server.headersTimeout=(0,rB.default)(),r.setErrorHandler(nB.serverErrorHandler);let n=(0,tB.default)();return n&&r.register(Q0.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,u){r.server.emit("unhandled",c.raw,u.raw)}),o()}),r.register(z0.default),await r.register(Pte),await r.after(),cg(r),Ge.info("Custom Functions completed buildServer."),r}function iB(){if(Bs)return Bs.then?Bs.then(e=>e.ready()):Bs.ready()}var eR,K0,W0,Q0,z0,J0,X0,j0,Ge,Pte,Z0,eB,tB,rB,nB,Bs,Y0,oB=Oe(()=>{eR=require("path"),K0=require("fs"),W0=x(require("fastify")),Q0=x(require("@fastify/cors")),z0=x(Rg()),J0=x(require("@fastify/autoload")),X0=x(Z()),j0=x(U()),Ge=x(W()),Pte=x(v0()),Z0=x(en()),eB=x(x0()),tB=x(G0()),rB=x($0()),nB=x(Ff());ma();jt();Y0=new Set;a(vte,"start");a(Bte,"customFunctionsServer");a(Hte,"setUp");a(xte,"buildRouteFolder");a(sB,"buildServer");a(iB,"ready")});var rR={};ke(rR,{start:()=>Fte});function Fte(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,_B.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){cB||(cB=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=aB.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,uB.default)(s,(0,lB.realpathSync)(o))}}return i(s)},{runFirst:!0})),aB.set(r,n)}}}var uB,lB,_B,aB,cB,dB=Oe(()=>{uB=x(require("send")),lB=require("fs"),_B=x(require("serve-static")),aB=new Map;a(Fte,"start")});function kte(e,t=1,r){if(nR++,(0,To.startWorker)("server/threads/threadServer.js",{name:kf.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function u(_){_.type===kf.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",u),o(n))}a(u,"onMessage"),n.on("message",u),n.on("error",c)});Gte.push(s),await s,Ma.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=Gf.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Ma.indexOf(n);o>-1&&Ma.splice(o,1)}if(a(i,"removeWorker"),Ua){let o=Ua;Ua=[];for(let c of o)mB[c.localPort](null,c)}}}),r){let n=setInterval(()=>{sR?sR=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,To.shutdownWorkers)(),nR=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function pB(e=0,t){if(typeof e=="string")try{(0,Vf.existsSync)(e)&&(0,Vf.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=Vte:r=$te(t):r=oR;let n=(0,Pa.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=mB[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),sR=!0,r(o,(c,u)=>{if(!c){if(fB){let l=o._socket||new Pa.Socket({handle:o,writable:!0,readable:!0});fB.deliverSocket(l,e,u),l.resume()}else nR>0?(Ua.length===0&&setTimeout(()=>{Ua.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,Ua.push(o)):(console.log("start up a dynamic thread to handle request"),kte(0));Br(!1,"socket-routed");return}c.requests++;let _=o.fd;if(_>=0)c.postMessage({port:e,fd:_,data:u});else{let l=o._socket||new Pa.Socket({handle:o,writable:!0,readable:!0});Qte(l,c,e)}Br(!0,"socket-routed")})};let s=zc();iR.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 oR(e,t){let r,n=0;for(let s of Ma){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=qf)return qf=i,t(r);n=i}qf=0,t(r)}function Vte(e,t){let r={};e.getpeername(r);let n=r.address,s=va.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);oR(e,o=>{va.set(n,{worker:o,lastUsed:i}),t(o)})}function $te(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new Pa.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let u=o.toString("latin1").match(t)?.[1],_=va.get(u),l=Date.now();if(_&&_.worker.threadId!==-1)return _.lastUsed=l,s(_.worker);oR(n,d=>{va.set(u,{worker:d,lastUsed:l}),s(d,o)})})}a(r,"findByHeaderAffinity")}function Kte(){qf=0;for(let e of Ma)e.expectedIdle=e.recentELU.idle+Yte,e.requests=1;Ma.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function Qte(e,t,r){let n=Wte++;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(),Gf.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")),Gf.delete(n)),s.event=="destroy"&&(e.destroy(),Gf.delete(n))})}var To,Pa,kf,iR,Vf,hB,qte,Ma,Ua,mB,fB,nR,Gte,sR,qf,EB,va,Yte,Gf,Wte,SB=Oe(()=>{To=x(je()),Pa=require("net"),kf=x(U()),iR=x(W()),Vf=require("fs");Rs();hB=require("worker_threads"),qte=x(ki()),Ma=[],Ua=[],mB=[],nR=0,Gte=[];hB.isMainThread&&process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)});a(kte,"startHTTPWorker");a(pB,"startSocketServer");qf=0;a(oR,"findMostIdleWorker");EB=36e5,va=new Map;a(Vte,"findByRemoteAddressAffinity");a($te,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of va)r.lastUsed+EB<e&&va.delete(t)},EB).unref();Yte=1e3;a(Kte,"updateWorkerIdleness");(0,To.setMonitorListener)(Kte);Gf=new Map,Wte=1;a(Qte,"proxySocket")});var lR={};ke(lR,{Request:()=>aR,createReuseportFd:()=>$f});var TB,aR,cR,uR,$f,Yf=Oe(()=>{TB=require("os"),aR=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 uR(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 cR(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},cR=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}},uR=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,TB.platform)()!="win32"&&($f=require("node-unix-socket").createReuseportFd)});var OB=T((fhe,AB)=>{"use strict";var zte=require("cluster"),go=Z();go.initSync();var RB=U(),che=require("util"),Hs=W(),uhe=require("fs"),Jte=require("fastify"),lhe=zc(),Xte=require("@fastify/cors"),jte=require("@fastify/compress"),Zte=require("@fastify/static"),ere=Rg(),tre=require("path"),{PACKAGE_ROOT:rre}=U(),nre=zs(),sre=J(),ire=en(),ore=ki(),{server:are}=(jt(),te(yi)),{node_request_key:_he}=(Yf(),te(lR)),{authHandler:cre,handlePostRequest:ure,serverErrorHandler:lre,reqBodyValidationHandler:_re}=Ff(),dhe=require("net"),{registerContentHandlers:dre}=(ma(),te(iv)),fre=6e4,Ere=1024*1024*1024,hre="TRUE",{CONFIG_PARAMS:rl}=RB,Ba;AB.exports={hdbServer:gB,start:gB};async function gB(e){try{Hs.info("In Fastify server"+process.cwd()),Hs.info(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Hs.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=zte.isMaster,await mre();let t=e.securePort>0;Ba=pre(t),await Ba.ready(),e||(e={}),e.isOperationsServer=!0;try{are.http(Ba.server,e),Ba.server.closeIdleConnections||await Ba.listen({port:0,host:"::"})}catch(r){throw Ba.close(),Hs.error(r),Hs.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Hs.fatal(t),process.exit(1)}}a(gB,"operationsServer");async function mre(){Hs.trace("Configuring HarperDB process."),nre.setSchemaDataToGlobal(),await ire.setUsersToGlobal(),await ore.getLicense()}a(mre,"setUp");function pre(e){Hs.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=Sre(e),r=Jte(t);r.server.headersTimeout=gre(),r.setErrorHandler(lre);let n=Tre();n&&r.register(Xte,n),r.register(function(i,o,c){i.setNotFoundHandler(function(u,_){r.server.emit("unhandled",u.raw,_.raw)}),c()}),r.register(ere),r.register(jte),r.register(Zte,{root:tre.join(rre,"studio/build-local")}),dre(r);let s=go.get(RB.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!sre.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[_re,cre],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),ure(i,o)}),r.get("/health",()=>"HarperDB is running."),Hs.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(pre,"buildServer");function Sre(e){let t=go.get(rl.OPERATIONSAPI_NETWORK_TIMEOUT),r=go.get(rl.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:Ere,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(Sre,"getServerOptions");function Tre(){let e=go.get(rl.OPERATIONSAPI_NETWORK_CORS),t=go.get(rl.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===hre)&&(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(Tre,"getCORSOpts");function gre(){return go.get(rl.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??fre}a(gre,"getHeaderTimeoutConfig")});var UB=T((She,MB)=>{"use strict";var{decode:Rre}=require("msgpackr"),{isMainThread:hhe,parentPort:Are,threadId:mhe}=require("worker_threads"),dR=At(),xs=tt(),Ore=U(),Ti=W(),bB=Z(),yB=U();je();var bre=ms(),{recordAction:Nre,recordActionBinary:yre}=(Rs(),te(Zc)),{publishToStream:wre}=dR,{ConsumerEvents:Ire}=require("nats"),phe={durable:xs.WORK_QUEUE_CONSUMER_NAMES.durable_name,queue:xs.WORK_QUEUE_CONSUMER_NAMES.deliver_group},Cre,Dre,Lre,wB,IB;MB.exports={initialize:fR,workQueueListener:LB,setSubscription:Mre,setIgnoreOrigin:Pre,getDatabaseSubscriptions:Ure};async function fR(){IB=!0,Ti.notify("Starting clustering ingest service.");let{connection:e,jsm:t,js:r}=await dR.getNATSReferences();Cre=e,Dre=e.info.server_name,Lre=t,wB=r}a(fR,"initialize");var Wf=new Map;function Mre(e,t,r){let n=Wf.get(e);n||Wf.set(e,n=new Map),n.set(t,r),IB||fR().then(LB)}a(Mre,"setSubscription");function Ure(){return Wf}a(Ure,"getDatabaseSubscriptions");var CB;function Pre(e){CB=e}a(Pre,"setIgnoreOrigin");var DB=100,NB=new Array(DB),Kf=0;async function LB(){let e=await wB.consumers.get(xs.WORK_QUEUE_CONSUMER_NAMES.stream_name,xs.WORK_QUEUE_CONSUMER_NAMES.durable_name),t=!1,r;for(Are?.on("message",async n=>{let{type:s}=n;s===yB.ITC_EVENT_TYPES.SHUTDOWN&&(t=!0,r&&r.close?.()&&r.close())});!t;){r=await e.consume(),(async()=>{for await(let n of await r.status())if(n.type===Ire.HeartbeatsMissed){let s=n.data;Ti.trace(`${s} clustering ingest consumer heartbeats missed`),s===2&&(Ti.warn("Restarting clustering ingest consumer due to missed heartbeat threshold being met"),r.stop())}})();try{for await(let n of r)await NB[Kf],NB[Kf]=vre(n).catch(s=>{Ti.error(s)}),++Kf>=DB&&(Kf=0)}catch(n){Ti.error("Error consuming clustering ingest, restarting consumer",n)}dR.clearClientCache(),await fR()}}a(LB,"workQueueListener");async function vre(e){let t=Rre(e.data);Nre(e.data.length,"bytes-received",e.subject,t.operation,"ingest");let r=e.headers,n=!1,s=bB.get(Ore.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(xs.MSG_HEADERS.TRANSACTED_NODES)&&r.values(xs.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(xs.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!CB),yre(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(xs.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:u,table:_,records:l,hash_values:d,__origin:f,expiresAt:E}=t;Ti.trace("processing message:",o,c,_,(l?"records: "+l.map(R=>R?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),Ti.trace(`messageProcessor nats msg id: ${e.headers.get(xs.MSG_HEADERS.NATS_MSG_ID)}`);let h;l||(l=d);let{timestamp:p,user:S,node_name:O}=f||{},g=Wf.get(c)?.get(_);if(!g)throw new Error("Missing table for replication message",_);if(o==="define_schema")t.type=o,g.send(t);else if(l.length===1&&!u)g.send({type:_R(o),value:l[0],id:d?.[0],expiresAt:E,timestamp:p,table:_,onCommit:h,user:S,nodeName:O});else{let R=l.map((B,H)=>({type:_R(o),value:B,expiresAt:E,id:d?.[H],table:_}));for(;u;)R.push({type:_R(u.operation),value:u.record,expiresAt:u.expiresAt,id:u.id,table:u.table}),u=u.next;g.send({type:"transaction",writes:R,table:_,timestamp:p,onCommit:h,user:S,nodeName:O})}bB.get(yB.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&wre(e.subject.split(".").slice(0,-1).join("."),bre.createNatsTableStreamName(c,_),e.headers,e.data)}catch(o){Ti.error(o)}e.ack()}a(vre,"messageProcessor");function _R(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(_R,"convertOperation")});var TR={};ke(TR,{disableNATS:()=>Hre,publishToStream:()=>jf,setNATSReplicator:()=>ER,setPublishToStream:()=>xre,setSubscription:()=>SR,start:()=>Bre});function Bre(){zf.default.get(Jf.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&qre()}function Hre(e=!0){xB=e}function xre(e,t){jf=e,SR=t}function qre(){if(xB||process.env._DISABLE_NATS)return;let e=In(),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];ER(s,r,i)}}gR((r,n)=>{ER(r.tableName,r.databaseName,r),n&&qB(r)}),!PB&&(PB=!0)}function ER(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 vt{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){qB(i)}static subscribe(){let i=new Tn;return SR(t,e,i),i}static subscribeOnThisThread(i){return i<Fre}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 Qf(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=FB;return i}a(n,"getNATSTransaction")}function qB(e){let t=zf.default.get(Jf.default.CONFIG_PARAMS.CLUSTERING_NODENAME);jf(`${mR.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,pR.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 vB,mR,pR,BB,HB,zf,Jf,Xf,xB,jf,SR,Fre,FB,PB,Qf,hR,GB=Oe(()=>{be();gn();vB=x(At()),mR=x(tt()),pR=x(ms());uc();BB=x(UB()),HB=x(Nr()),zf=x(Z()),Jf=x(U()),Xf=x(W());a(Bre,"start");a(Hre,"disableNATS");jf=vB.publishToStream,SR=BB.setSubscription;a(xre,"setPublishToStream");Fre=2;a(qre,"assignReplicationSource");a(ER,"setNATSReplicator");a(qB,"publishSchema");Qf=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=zf.default.get(Jf.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],u,_;for(let l of i){let d=l.table,f=l.operation=="put"?"upsert":l.operation;u||(Xf.trace(`Sending transaction event ${f}`),_=u={operation:f,schema:s,table:d,__origin:{user:this.user?.username,timestamp:t,node_name:r}},u.hash_values=c,f!=="delete"&&f!=="invalidate"&&(u.records=o)),u.table===d&&u.operation===f?(o.push(l.record),c.push(l.id)):_=_.next={operation:f,table:d,id:l.id,record:l.record},l.expiresAt&&(_.expiresAt=l.expiresAt)}u&&n.push(jf(`${mR.SUBJECT_PREFIXES.TXN}.${s}.${u.table}`,(0,pR.createNatsTableStreamName)(s,u.table),void 0,u)?.catch(l=>{throw Xf.error("An error has occurred trying to replicate transaction",u,l),l.statusCode=504,l}))}return Promise.all(n)}},hR=class extends Qf{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,HB.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};FB=new hR});async function YB({clientId:e,user:t,clean:r,will:n}){let s;if(e&&!r){let i=await RR.getResource(e,{});s=new bR(e,t,i),i&&(s.sessionWasPresent=!0)}else{if(e){let i=await RR.get(e);i&&i.delete()}s=new eE(e,t)}return n&&(n.id=e,n.user={username:t?.username},nl.put(n)),s}function AR(){return Zf++,Zf>65500&&(Zf=1),Zf}function OR(e,t,r=e){let{topic:n,retain:s}=e;e.data=t,e.async=!0,e.authorize=!0;let i=di.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 Ke(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var kB,Ro,VB,$B,RR,nl,Zf,eE,bR,KB=Oe(()=>{be();Du();kB=x(Nr()),Ro=x(W());Qi();VB=x(je()),$B=x(WB());jt();RR=ot({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"}]}}]}),nl=ot({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,VB.getWorkerIndex)()===0&&(async()=>{await $B.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of nl.search({})){let t=e.data,r=Object.assign({},e);r.user?.username&&(r.user=await Xe.getUser(r.user.username)),Ke(r,()=>{try{OR(r,t)}finally{nl.delete(e.id,r)}})}})();a(YB,"getSession");Zf=1;a(AR,"getNextMessageId");eE=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;subscriptions=[];awaitingAcks;sessionWasPresent;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),u,_;if(c>-1?(u=s.slice(c),_=s.slice(0,c)):_=s,!_)throw new Error("No topic provided");if(_.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let l=this.subscriptions.find(O=>O.topic===s),d;l?(d=i>0,l.end(),this.subscriptions.splice(this.subscriptions.indexOf(l),1)):d=i===2;let f={search:u,async:!0,authorize:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,Ro.trace)("Resuming subscription from",s,"from",o);let E=di.getMatch(_);if(!E){let O=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw O.statusCode=404,O}if(f.url=E.relativeURL,f.url.indexOf("+")>-1||f.url.indexOf("#")>-1){let O=f.url.slice(1);if(O.indexOf("#")>-1&&O.indexOf("#")!==O.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(f.isCollection=!0,O.indexOf("+")===O.length-1)f.onlyChildren=!0,f.url="/"+O.slice(0,O.length-1);else{let g=O.split("/"),R;for(let v=0;v<g.length;v++)if(g[v].indexOf("+")>-1)if(g[v]==="+")R=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&R)throw new Error("Filters can not be combined");let B=!0;g[g.length-1]==="#"&&(g.length--,B=!1),R&&(n=a(v=>{let M=v.id;if(!Array.isArray(M)||B&&M.length!==g.length)return!1;for(let $=0;$<g.length;$++)if(g[$]!=="+"&&g[$]!==M[$])return!1;return!0},"filter"));let H=g.indexOf("+");f.url="/"+(H>-1?g.slice(0,H):g).concat("").join("/")}}let h=E.path,p=E.Resource,S=await Ke(f,async()=>{let O=await p.subscribe(f);if(!O)throw new Error(`No subscription was returned from subscribe for topic ${s}`);if(!O[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);return(async()=>{for await(let g of O)try{let R;if(g.type&&g.type!=="put"&&g.type!=="delete"&&g.type!=="message"&&g.type!=="patch"||n&&!n(g))continue;r?(g.topic=s,R=this.needsAcknowledge(g)):(g.acknowledge?.(),R=AR());let B=g.id;Array.isArray(B)&&(B=ha(B)),B==null&&(B=""),this.listener(h+"/"+B,g.value,R,t)}catch(R){(0,Ro.warn)(R)}})(),O});return S.topic=s,S.qos=t.qos,this.subscriptions.push(S),S}resume(){}needsAcknowledge(t){let r=AR();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,t.acknowledge)),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),!0}async publish(t,r){return t.user=this.user,OR(t,r)}setListener(t){this.listener=t}disconnect(t){let r={};Ke(r,async()=>{if(!t){let n=await nl.get(this.sessionId,r);n?.doesExist()&&await OR(n,n.data,r)}await nl.delete(this.sessionId,r)}).catch(n=>{(0,Ro.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}};a(OR,"publish");bR=class extends eE{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=AR(),n={topic:t.topic,timestamp:t.timestamp};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks.get(t);this.awaitingAcks.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,Ro.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&(this.sessionRecord.subscriptions=this.subscriptions.map(i=>{let o=i.startTime;return o||(o=i.startTime=(0,kB.getNextMonotonicTime)()),(0,Ro.trace)("Added durable subscription",i.topic,o),{qos:i.qos,topic:i.topic,startTime:o}}),RR.put(this.sessionRecord)),t.qos}}});var NR={};ke(NR,{bypassAuth:()=>Gre,start:()=>kre});function Gre(){jB=!0}function kre({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){let o=e.mqtt={requireAuthentication:i,sessions:new Set},c,u=r?.mtls;return n&&(c=e.ws((_,l,d)=>{if(_.protocol==="mqtt"){let{onMessage:f,onClose:E}=JB(_,(h,p)=>{if(_.send(h),p&&_._socket.writableNeedDrain)return new Promise(S=>this._socket.once("drain",S))},l,Promise.resolve(d).then(()=>l?.user),o);_.on("message",f),_.on("close",E),_.on("error",h=>{(0,pr.info)("WebSocket error",h)})}},Object.assign({subProtocol:"mqtt"},n))),(t||s)&&(c=e.socket(async _=>{let l;if(u){if(_.authorized)try{let E=u.user;E!==null&&((E===void 0||E==="Common Name"||E==="CN")&&(E=_.getPeerCertificate().subject.CN),l=await e.getUser(E,null,null))}catch(E){(0,pr.error)(E)}else if(u.required)return(0,pr.info)(`Unauthorized connection attempt, no authorized client certificate provided, error: ${_.authorizationError}`),_.end()}!l&&jB&&_.remoteAddress.includes("127.0.0.1")&&(l=await(0,XB.getSuperUser)());let{onMessage:d,onClose:f}=JB(_,E=>_.write(E),null,l,o);_.on("data",d),_.on("close",f),_.on("error",E=>{(0,pr.info)("Socket error",E)})},{port:t,securePort:s,mtls:u})),c}function JB(e,t,r,n,s){zB||(zB=!0,jc(d=>{tE>0&&d.push({metric:"mqtt-connections",connections:tE,byThread:!0})}));let i;tE++;let o,c={protocolVersion:4},u=(0,nE.parser)({protocolVersion:5});function _(d){u.parse(d)}a(_,"onMessage");function l(){tE--,i||(i=!0,o?.disconnect(),s.sessions.delete(o),tn(!1,"connection","mqtt","disconnect"))}return a(l,"onClose"),u.on("packet",async d=>{n?.then&&(n=await n),o?.then&&await o;try{switch(d.cmd){case"connect":if(c.protocolVersion=d.protocolVersion,d.username)try{n=await Xe.getUser(d.username,d.password.toString(),r),(0,rE.get)(os.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&QB.notify({username:n.username,status:os.AUTH_AUDIT_STATUS.SUCCESS,type:os.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch{return(0,rE.get)(os.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&QB.error({username:n.username,status:os.AUTH_AUDIT_STATUS.FAILURE,type:os.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),f({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return tn(!1,"connection","mqtt","connect"),f({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let R=e.deserialize||(e.deserialize=fo(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?R(d.will.payload):void 0,delete d.will.payload}o=YB({user:n,...d}),o=await o,s.sessions.add(o)}catch(R){return(0,pr.error)(R),tn(!1,"connection","mqtt","connect"),f({cmd:"connack",reasonCode:R.code||5,returnCode:R.code||128})}tn(!0,"connection","mqtt","connect"),f({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((R,B,H,v)=>{try{let M=R.indexOf("/",1),$=M>0?R.slice(0,M):R;f({cmd:"publish",topic:R,payload:E(B),messageId:H||Math.floor(Math.random()*1e8),qos:v.qos},$)}catch(M){(0,pr.error)(M),o?.disconnect(),s.sessions.delete(o)}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let h=[];for(let R of d.subscriptions){let B;try{B=(await o.addSubscription(R,R.qos>=1)).qos||0}catch(H){(0,pr.error)(H),B=c.protocolVersion<5?128:H.statusCode===403?135:H.statusCode===404?143:128}h.push(B)}await o.committed,f({cmd:"suback",granted:h,messageId:d.messageId});break;case"unsubscribe":{let R=[];for(let B of d.unsubscriptions)R.push(o.removeSubscription(B)?0:17);f({cmd:"unsuback",granted:R,messageId:d.messageId});break}case"pubrel":f({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let p=d.qos===2?"pubrec":"puback",S=e.deserialize||(e.deserialize=fo(r?.headers.get?.("content-type"))),O=d.payload?.length>0?S(d.payload):void 0,g;try{g=await o.publish(d,O)}catch(R){(0,pr.warn)(R),d.qos>0&&f({cmd:p,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&f({cmd:p,messageId:d.messageId,reasonCode:g===!1?144:0},d.topic);break;case"pubrec":f({cmd:"pubrel",messageId:d.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(d.messageId);break;case"pingreq":f({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.sessions.delete(o),tn(!0,"connection","mqtt","disconnect"),e.close?e.close():e.end();break}}catch(h){(0,pr.error)(h),f({cmd:"disconnect"})}function f(h,p){let S=(0,nE.generate)(h,c);t(S),Br(S.length,"bytes-sent",p,h.cmd,"mqtt")}a(f,"sendPacket");function E(h){return Ei(h,r)}a(E,"serialize")}),{onMessage:_,onClose:l}}var nE,XB,rE,os,pr,QB,jB,zB,tE,ZB=Oe(()=>{nE=require("mqtt-packet");KB();XB=x(en());ma();Rs();jt();rE=x(Z()),os=x(U()),pr=x(W()),QB=(0,pr.loggerWithTag)("auth-event"),jB=(0,rE.get)(os.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(Gre,"bypassAuth");a(kre,"start");tE=0;a(JB,"onSocket")});var jd={};ke(jd,{component_errors:()=>xa,loadComponent:()=>sE,loadComponentDirectories:()=>cH,setErrorReporter:()=>Kre});function cH(e,t){t&&(wR=t),e&&(IR=e);let r=[];if((0,vn.existsSync)(yR)){let s=(0,vn.readdirSync)(yR,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,pt.join)(yR,o);r.push(sE(c,wR,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(sE(n,wR,n,!1,null,process.env.DEV_MODE)),Promise.all(r).then(()=>{aH=!0})}function Kre(e){il=e}async function sE(e,t,r,n,s,i){if(!tH.has(e)){tH.set(e,!0),s&&(IR=s);try{let o;n&&(xa=new Map);let c=(0,pt.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,vn.existsSync)(c)?o=n?(0,oH.getConfigObj)():(0,rH.parseDocument)((0,vn.readFileSync)(c,"utf8"),{simpleKeys:!0}).toJSON():o=CR;let u=[],_=n;for(let l in o){let d=o[l];if(xa.set(n?l:(0,pt.basename)(e),!1),!d)continue;let f,E=d.package;try{if(E){let g=e,R;for(;!(0,vn.existsSync)(R=(0,pt.join)(g,"node_modules",l));)if(g=(0,pt.dirname)(g),g.length<(0,iH.getHdbBasePath)().length){R=null;break}if(R)f=await sE(R,t,r,!1),_=!0;else throw new Error(`Unable to find package ${l}:${E}`)}else f=Yre[l];if(!f)continue;u.push(f);let h=a(g=>(g.origin=r,ot(g)),"ensureTable"),p=d.network||(d.port||d.securePort)&&d,S=p?.securePort||p?.https&&p.port,O=!p?.https&&p?.port;if(Ha.isMainThread&&(f=await f.startOnMainThread?.({server:Xe,ensureTable:h,port:O,securePort:S,resources:t,...d})||f,n&&p))for(let g of[O,S])try{if(+g&&!eH.includes(g)){let R=DR.get(LR.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);R&&sl.default.warn("Session affinity is not recommended and may cause memory leaks"),(R||!$f)&&(eH.push(g),pB(g,R))}}catch(R){console.error("Error listening on socket",g,R,l)}if(t.isWorker&&(f=await f.start?.({server:Xe,ensureTable:h,port:O,securePort:S,resources:t,...d})||f),IR.set(f,!0),(f.handleFile||f.handleDirectory)&&d.files){if(d.files.includes(".."))throw(0,sH.handleHDBError)("Can not reference parent directories");let g=(0,pt.join)(e,d.files).replace(/\\/g,"/"),R=g.indexOf("/*");if(R>-1&&d.files!==CR[l]?.files&&!(0,vn.existsSync)(g.slice(0,R)))throw new Error(`The path '${g.slice(0,R)}' does not exist and cannot be used as the base of the resolved 'files' path value '${d.files}'`);let B=(0,pt.basename)(e),H=d.path||"/";H=H.startsWith("/")?H:H.startsWith("./")?"/"+B+H.slice(2):H==="."?"/"+B:"/"+B+"/"+H;let v,M,$;if(d.root){let z=d.root;z.startsWith("/")&&(z=z.slice(1)),z.endsWith("/")&&(z=z.slice(0,-1)),z+="/",M=(0,pt.join)(e,z)}else($=g.indexOf("/*"))>-1&&(M=g.slice(0,$+1),v=(0,pt.relative)(e,M));let K=!1;if(Ha.isMainThread&&f.setupDirectory&&(K=await f.setupDirectory?.(H,M,t)),t.isWorker&&f.handleDirectory&&(K=await f.handleDirectory?.(H,M,t)),K)continue;for(let z of await(0,nH.default)(g,{onlyFiles:!1,objectMode:!0})){let{path:se,dirent:Te}=z;_=!0;let oe=(0,pt.relative)(e,se).replace(/\\/g,"/");if(v)if(oe.startsWith(v))oe=oe.slice(v.length+1);else throw new Error(`The root path '${d.root}' does not reference a valid part of the file path '${oe}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let xe=H+(H.endsWith("/")?"":"/")+oe;try{if(Te.isFile()){let de=await $re(se);Ha.isMainThread&&await f.setupFile?.(de,xe,se,t),t.isWorker&&await f.handleFile?.(de,xe,se,t)}else Ha.isMainThread&&await f.setupDirectory?.(xe,se,t),t.isWorker&&await f.handleDirectory?.(xe,se,t)}catch(de){de.message=`Could not load ${Te.isFile()?"file":"directory"} '${se}'${d.module?" using '"+d.module+"'":""} for application '${e}' due to: ${de.message}`,il?.(de),((0,Fa.getWorkerIndex)()===0?console:sl.default).error(de),t.set(d.path||"/",new ol(de)),xa.set(n?l:(0,pt.basename)(e),de.message)}}}}catch(h){h.message=`Could not load component '${l}' for application '${(0,pt.basename)(e)}' due to: ${h.message}`,il?.(h),((0,Fa.getWorkerIndex)()===0?console:sl.default).error(h),t.set(d.path||"/",new ol(h),null,!0),xa.set(n?l:(0,pt.basename)(e),h.message)}}if(Ha.isMainThread&&!aH&&i&&(0,Fa.watchDir)(e,async()=>cH()),o.extensionModule)return await ql((0,pt.join)(e,o.extensionModule));if(!_&&t.isWorker){let l=`${e} did not load any modules, resources, or files, is this a valid component?`;il?.(new Error(l)),((0,Fa.getWorkerIndex)()===0?console:sl.default).error(l),xa.set((0,pt.basename)(e),l)}}catch(o){console.error(`Could not load application directory ${e}`,o),o.message=`Could not load application due to ${o.message}`,il?.(o),t.set("",new ol(o))}}}var vn,pt,Ha,rH,DR,LR,nH,Fa,sl,sH,iH,Vre,oH,$re,yR,IR,aH,wR,xa,Yre,CR,eH,tH,il,ol,Zd=Oe(()=>{vn=require("fs"),pt=require("path"),Ha=require("worker_threads"),rH=require("yaml"),DR=x(Z()),LR=x(U());CO();UO();PO();Tv();oB();dB();nH=x(require("fast-glob")),Fa=x(je()),sl=x(W());dh();jt();sH=x(ee());gn();be();SB();iH=x(Z()),Vre=x(OB());$d();GB();ZB();oH=x(Lr());Yf();({readFile:$re}=vn.promises),yR=DR.get(LR.CONFIG_PARAMS.COMPONENTSROOT),IR=new Map,xa=new Map;a(cH,"loadComponentDirectories");Yre={REST:Sf,rest:Sf,graphqlSchema:_h,jsResource:Eh,fastifyRoutes:tR,login:mh,static:rR,operationsApi:Vre,customFunctions:{},http:{},clustering:TR,authentication:Lu,mqtt:NR},CR={rest:!0,graphqlSchema:{files:"*.graphql"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(CR,"static",{value:{files:"web/**"}});eH=[],tH=new Map;a(Kre,"setErrorReporter");a(sE,"loadComponent");ol=class extends vt{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 UR=T((Qhe,lH)=>{var{isMainThread:uH}=require("worker_threads"),{getTables:Wre}=(be(),te(Fe)),{loadComponentDirectories:Qre,loadComponent:zre}=(Zd(),te(jd)),{resetResources:Jre}=(Du(),te(IU)),Xre=vT(),jre=Lr(),{dirname:Zre}=require("path"),{getConnection:ene}=At(),tne=Z(),rne=U(),MR=new Map;async function nne(e=!1){!uH&&tne.get(rne.CONFIG_PARAMS.CLUSTERING_ENABLED)&&ene();try{uH&&await Xre()}catch(n){console.error(n)}let t=Jre();Wre(),t.isWorker=e,await zre(Zre(jre.getConfigFilePath()),t,"hdb",!0,MR),await Qre(MR,t);let r=[];for(let[n]of MR)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(nne,"loadRootComponents");lH.exports.loadRootComponents=nne});var je=T((Jhe,Ri)=>{"use strict";var{Worker:sne,MessageChannel:ine,parentPort:as,isMainThread:xR,threadId:one,workerData:Fs}=require("worker_threads"),{PACKAGE_ROOT:ane}=U(),{join:EH,isAbsolute:cne,extname:une}=require("path"),{server:hH}=(jt(),te(yi)),{watch:lne,readdir:_ne}=require("fs/promises"),{totalmem:_H}=require("os"),al=U(),mH=Z(),qs=W(),{randomBytes:dne}=require("crypto"),{_assignPackageExport:fne}=require("../../index"),Ene=U(),dH=1024*1024,gi=[],_n=[],hne=50,FR=1e4,mne="restart",pH="request_thread_info",SH="resource_report",TH="thread_info",gH="added-port",pne="ack",PR;fne("threads",_n);Ri.exports={startWorker:vR,restartWorkers:GR,shutdownWorkers:Ane,workers:gi,setMonitorListener:Dne,onMessageFromWorkers:One,onMessageByType:wH,broadcast:Nne,broadcastWithAcknowledgement:wne,setChildListenerByType:Rne,getWorkerIndex:RH,getWorkerCount:AH,getTicketKeys:bH,setMainIsWorker:Tne,setTerminateTimeout:Sne,restartNumber:Fs?.restartNumber||1};_n.onMessageByType=wH;_n.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=_n.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};var qR;function Sne(e){FR=e}a(Sne,"setTerminateTimeout");function RH(){return Fs?Fs.workerIndex:qR?0:void 0}a(RH,"getWorkerIndex");function AH(){return Fs?Fs.workerCount:qR?1:void 0}a(AH,"getWorkerCount");function Tne(e){qR=e}a(Tne,"setMainIsWorker");var OH=1,iE;function bH(){return iE||(iE=xR?dne(48):Fs.ticketKeys,iE)}a(bH,"getTicketKeys");Object.defineProperty(hH,"workerIndex",{get(){return RH()}});Object.defineProperty(hH,"workerCount",{get(){return AH()}});var NH={[pH](e,t){Ine(t)},[SH](e,t){Cne(t,e)}};function vR(e,t={}){let r=process.constrainedMemory?.()||_H();r=Math.min(r,_H(),2e4*dH);let n=mH.get(al.CONFIG_PARAMS.MAXHEAPMEMORY)??Math.max(Math.floor(r/dH/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let u of _n){let _=new ine;_.existingPort=u,i.push(_),o.push(_.port2)}une(e)||(e+=".js");let c=new sne(cne(e)?e:EH(ane,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:OH=t.threadCount,name:t.name,restartNumber:Ri.exports.restartNumber,ticketKeys:bH()},transferList:o},t));for(let{port1:u,existingPort:_}of i)_.postMessage({type:gH,port:u,threadId:c.threadId},[u]);return aE(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>vR(e,t),c.on("error",u=>{console.error("Worker error:",u),qs.error("Worker error:",u)}),c.on("exit",u=>{gi.splice(gi.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<hne?(t.unexpectedRestarts=c.unexpectedRestarts+1,vR(e,t)):qs.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",u=>{NH[u.type]?.(u,c)}),gi.push(c),Mne(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(vR,"startWorker");var gne=[al.THREAD_TYPES.HTTP];async function GR(e=null,t=Math.max(OH>3,1),r=!0){if(xR){if(r){let{loadRootComponents:o}=UR();await o()}Ri.exports.restartNumber++,t<1&&(t=t*gi.length);let n=[],s=[];for(let o of gi.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;qs.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Ri.exports.restartNumber,type:al.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=gne.indexOf(o.name)>-1,u=new Promise(_=>{let l=setTimeout(()=>o.terminate(),FR*2).unref();o.on("exit",()=>{clearTimeout(l),n.splice(n.indexOf(u)),!c&&r&&o.startCopy(),_()})});if(n.push(u),c&&r){let _=o.startCopy(),l=new Promise(d=>{let f=a(E=>{E.type===Ene.ITC_EVENT_TYPES.CHILD_STARTED&&(qs.trace("Worker has started",_.threadId),d(),s.splice(s.indexOf(l)),_.off("message",f))},"startListener");qs.trace("Waiting for worker to start",_.threadId),_.on("message",f)});s.push(l),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=xd();r&&(e==="http"||!e)&&mH.get(al.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else as.postMessage({type:mne,workerType:e})}a(GR,"restartWorkers");function Rne(e,t){NH[e]=t}a(Rne,"setChildListenerByType");function Ane(e){return GR(e,1/0,!1)}a(Ane,"shutdownWorkers");var yH=[];function One(e){yH.push(e)}a(One,"onMessageFromWorkers");var BR=new Map;function wH(e,t){let r=BR.get(e);r||BR.set(e,r=[]),r.push(t)}a(wH,"onMessageByType");var bne=10;async function Nne(e){let t=0;for(let r of _n)try{r.postMessage(e),t++>bne&&(t=0,await new Promise(setImmediate))}catch(n){qs.error("Unable to send message to worker",n)}}a(Nne,"broadcast");var oE=new Map,yne=1;function wne(e){return new Promise(t=>{let r=0;for(let n of _n)try{let s=yne++,i=a(()=>{oE.delete(s),--r===0&&t(),n!==as&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,oE.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of oE)o.port===n&&o()})),n.postMessage(e),r++}catch(s){qs.error("Unable to send message to worker",s)}r===0&&t()})}a(wne,"broadcastWithAcknowledgement");function Ine(e){e.postMessage({type:TH,workers:IH()})}a(Ine,"sendThreadInfo");function IH(){let e=Date.now();return gi.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(IH,"getChildWorkerInfo");function Cne(e,t){e.resources=t,e.resources.updated=Date.now()}a(Cne,"recordResourceReport");var HR;function Dne(e){HR=e}a(Dne,"setMonitorListener");var Lne=1e3,fH=!1;function Mne(){fH||(fH=!0,setInterval(()=>{for(let e of gi){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}HR&&HR()},Lne).unref())}a(Mne,"startMonitoring");var Une=1e3;if(as){aE(as);for(let e=0,t=Fs.addPorts.length;e<t;e++){let r=Fs.addPorts[e];r.threadId=Fs.addThreadIds[e],aE(r)}setInterval(()=>{let e=process.memoryUsage();as.postMessage({type:SH,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},Une).unref(),PR=a(()=>new Promise((e,t)=>{as.on("message",r),as.postMessage({type:pH});function r(n){n.type===TH&&(as.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else PR=IH;Ri.exports.getThreadInfo=PR;function aE(e,t){_n.push(e),e.on("message",r=>{if(r.type===gH)r.port.threadId=r.threadId,aE(r.port);else if(r.type===pne){let n=oE.get(r.id);n&&n()}else{for(let s of yH)s(r,e);let n=BR.get(r.type);if(n)for(let s of n)try{s(r,e)}catch(i){qs.error(i)}}}).on("close",()=>{_n.splice(_n.indexOf(e),1)}).on("exit",()=>{_n.splice(_n.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(aE,"addPort");if(xR){let e,t,r=a(async(n,s)=>{s&&(e=s);for(let i of await _ne(n,{withFileTypes:!0}))i.isDirectory()&&i.name!=="node_modules"&&r(EH(n,i.name));try{for await(let{filename:i}of lne(n,{persistent:!1}))t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await GR(),console.log("Reloaded HarperDB components")},100)}catch(i){console.warn("Error trying to watch component directory",n,i)}},"watch_dir");Ri.exports.watchDir=r,process.env.WATCH_DIR&&r(process.env.WATCH_DIR)}else as.on("message",async e=>{let{type:t}=e;t===al.ITC_EVENT_TYPES.SHUTDOWN&&(Ri.exports.restartNumber=e.restartNumber,as.unref(),setTimeout(()=>{qs.warn("Thread did not voluntarily terminate",one),process.exit(0)},FR).unref())})});var FI={};ke(FI,{AUDIT_STORE_OPTIONS:()=>xH,createAuditEntry:()=>Yl,openAuditStore:()=>_E,readAuditEntry:()=>Ct,setAuditRetention:()=>vne,transactionKeyEncoder:()=>HH});function _E(e){let t=e.auditStore=e.openDB(PH.AUDIT_STORE_NAME,xH);t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,{remove(){delete r[i]}}};let n=null;function s(i=cE){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed")return;let o=0,c;try{for(let{key:u,value:_}of t.getRange({start:0,snapshot:!1,end:Date.now()-kR})){if((_[0]&15)===YR){let l=Ct(_),d=l.tableId;r[d]?.(l.recordId)}if(c=t.remove(u),await new Promise(setImmediate),++o>=Pne){i=10;break}}await c}finally{o===0&&(i=Math.min(i<<1,kR/10)),s(i)}},i).unref()}return a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,lE.getWorkerIndex)()===(0,lE.getWorkerCount)()-1&&s(cE),t}function vne(e,t=cE){kR=e,cE=t}function Yl(e,t,r,n,s,i,o){let c=FH[i];if(!c)throw new Error(`Invalid audit entry type ${i}`);let u=1;n&&(n>1?qa.setFloat64(0,n):dn.set(Uh),u=9),f(0),f(t),d(r),qa.setFloat64(u,e),u+=8,s?d(s):dn[u++]=0,dn[n?8:0]=c;let l=dn.subarray(0,u);if(o)return Buffer.concat([l,o]);return l;function d(E){let h=u;u+=1,u=(0,Ga.writeKey)(E,dn,u);let p=u-h-1;p>127?p>16383?(WR.error("Key or username was too large for audit entry",E),u=h+1,dn[h]=0):(dn.copyWithin(h+2,h+1,u),qa.setUint16(h,p|32768),u++):dn[h]=p}function f(E){E<128?dn[u++]=E:E<16384?(qa.setUint16(u,E|32768),u+=2):E<1056964608?(qa.setUint32(u,E|3221225472),u+=4):(dn[u]=255,qa.setUint32(u+1,E),u+=5)}}function Ct(e){try{let t=e.dataView||(e.dataView=new KR(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:FH[n&7],tableId:i,get recordId(){return UH(e,c,u)},version:_,previousLocalTime:r,get user(){return d>l?UH(e,l,d):void 0},getValue(f,E,h){if(n&VR||n&$R&&!E)return f.decoder.decode(e.subarray(t.position));if(n&$R&&h)return QR(f.getEntry(this.recordId),h,f)}}}catch{return WR.error("Reading audit entry error",e),{}}}function UH(e,t,r){let n=e.subarray(t,r);return(0,Ga.readKey)(n,0,r-t)}var Ga,uE,PH,vH,lE,BH,WR,dn,qa,HH,xH,kR,Pne,cE,VR,$R,CH,YR,DH,LH,MH,FH,KR,Ci=Oe(()=>{Ga=require("ordered-binary"),uE=x(Z()),PH=x(lt()),vH=x(U()),lE=x(je()),BH=x(J());vo();WR=x(W());dE();(0,uE.initSync)();dn=Buffer.alloc(1024),qa=new DataView(dn.buffer,dn.byteOffset,1024),HH={writeKey(e,t,r){return e===hc?(t.set(hc,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Ga.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,Ga.readKey)(e,t,r)}},xH={encoding:"binary",keyEncoder:HH},kR=(0,BH.convertToMS)((0,uE.get)(vH.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,Pne=1e3,cE=1e4;a(_E,"openAuditStore");a(vne,"setAuditRetention");VR=16,$R=32,CH=1,YR=2,DH=3,LH=4,MH=5,FH={put:CH|VR,[CH]:"put",delete:YR,[YR]:"delete",message:DH|VR,[DH]:"message",invalidate:LH,[LH]:"invalidate",patch:MH|$R,[MH]:"patch"};a(Yl,"createAuditEntry");a(Ct,"readAuditEntry");KR=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(UH,"readKeySafely")});var zR={};ke(zR,{add:()=>fE,applyReverse:()=>qH,getRecordAtTime:()=>QR,rebuildUpdateBefore:()=>EE});function fE(e,t,r){isNaN(e[t])?e[t]=r.value:e[t]+=r.value}function EE(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,fE(r,n,s)}}else r||(r={}),r[n]=e[n];return r}function qH(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Bne[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=GH}}function QR(e,t,r){let n=r.rootStore.auditStore,s=Object.assign({},e.value),i=e.localTime;for(;i>t;){let u=n.get(i),_=Ct(u);switch(_.type){case"put":s=_.getValue(r);break;case"patch":qH(s,_.getValue(r));break;case"delete":s=null}i=_.previousLocalTime}let o={},c=0;for(let u in s)s[u]===GH&&(o[u]=!0,c++);for(;c>0&&i>0;){let u=n.get(i),_=Ct(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 Bne,GH,dE=Oe(()=>{Ci();a(fE,"add");fE.reverse=function(e,t,r){isNaN(e[t])||(e[t]-=r.value)};Bne={add:fE};a(EE,"rebuildUpdateBefore");a(qH,"applyReverse");GH={};a(QR,"getRecordAtTime")});function kr(e){return e[wt]||(e[wt]=Object.create(null))}function TE(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[Ne])},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 fn.ClientError(`${c} must be a string, attempt to assign ${l}`);kr(this)[c]=l},"set");break;case"ID":u=a(function(l){if(!(typeof l=="string"||l?.length>0&&l.every?.(d=>typeof d=="string")||l==null&&o.nullable!==!1))throw new fn.ClientError(`${c} must be a string, attempt to assign ${l}`);kr(this)[c]=l},"set");break;case"Float":case"Number":u=a(function(l){if(!(typeof l=="number"||l==null&&o.nullable!==!1))throw new fn.ClientError(`${c} must be a number, attempt to assign ${l}`);kr(this)[c]=l},"set");break;case"Int":u=a(function(l){if(!(l>>0===l||l==null&&o.nullable!==!1))if(typeof l=="number"&&Math.abs((l>>0)-l)<=1)l=Math.round(l);else throw new fn.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${l}`);kr(this)[c]=l},"set");break;case"Long":u=a(function(l){if(!(Math.round(l)===l&&Math.abs(l)<=9007199254740992||l==null&&o.nullable!==!1))if(typeof l=="number"&&Math.abs(l)<=9007199254740992)l=Math.round(l);else throw new fn.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${l}`);kr(this)[c]=l},"set");break;case"BigInt":u=a(function(l){if(!(typeof l=="bigint"||l==null&&o.nullable!==!1))if(typeof l=="string"||typeof l=="number")l=BigInt(l);else throw new fn.ClientError(`${c} must be a number, attempt to assign ${l}`);kr(this)[c]=l},"set");break;case"Boolean":u=a(function(l){if(!(typeof l=="boolean"||l==null&&o.nullable!==!1))throw new fn.ClientError(`${c} must be a boolean, attempt to assign ${l}`);kr(this)[c]=l},"set");break;case"Date":u=a(function(l){if(!(l instanceof Date||l==null&&o.nullable!==!1))if(typeof l=="string"||typeof l=="number")l=new Date(l);else throw new fn.ClientError(`${c} must be a Date, attempt to assign ${l}`);kr(this)[c]=l},"set");break;case"Bytes":u=a(function(l){if(!(l instanceof Uint8Array||l==null&&o.nullable!==!1))throw new fn.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${l}`);kr(this)[c]=l},"set");break;case"Any":case void 0:u=a(function(l){kr(this)[c]=l},"set");break;default:u=a(function(l){if(!(typeof l=="object"||l==null&&o.nullable!==!1))throw new fn.ClientError(`${c} must be an object, attempt to assign ${l}`);kr(this)[c]=l},"set")}_={get(){let l=this[wt];if(l&&c in l){let f=l[c];if(f?.__op__){let E=this[he]?.[c];return f.update(E)}return f}let d=this[he]?.[c];if(d&&typeof d=="object"){let f=VH(d,o);if(f)return l||(l=this[wt]=Object.create(null)),l[c]=f}return d},set:u,enumerable:!0,configurable:!0}}_.get.isAttribute=!0,n[c]=_,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,_)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let u=this[wt];return u?.[o]!==void 0?u[o]:this[he]?.[o]}),i("set",function(o,c){let u=n[o];if(u)return u.set.call(this,c);if(t.sealed)throw new fn.ClientError("Can not add a property to a sealed table schema");kr(this)[o]=c}),i("deleteProperty",function(o){kr(this)[o]=void 0}),i("toJSON",function(){let o=this[wt],c;for(let _ in o){c||(c=Object.assign({},this[he]));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[he])),Object.assign(c,this)),c||this[he]}),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 VH(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?.[he])throw new Error("Can not track an already tracked object, check for circular references");this[he]=s}},TE(r,t)),new r(e)):new hE(e);case Array:let n=new pE(e.length);n[he]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=VH(o,t?.elements)),n[s]=o}return n;default:return e}}function q_(e){let t=e[wt],r;for(let s in t){r||(r=Object.assign({},e[he]));let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=q_(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=Object.assign({},e[he])),Object.assign(r,e)),r||e[he]}function Oo(e,t=e[wt]){let r;if(kH.call(e,he)&&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=Oo(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[he]));let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=zR[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Oo(s);r[n]=s}return r?Object.freeze(r):kH.call(e,he)?e[he]:e}function mE(e){let t=e[he];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[Ao]||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?.[he]===s){if(mE(i))return!0}else return!0}}else{let r=e[wt];if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s[he]===i){if(mE(s))return!0}else return!0}else return!0}}return!1}var fn,wt,hE,kH,Ao,pE,SE,G_=Oe(()=>{gn();fn=x(ee());dE();wt=Symbol("own-data");a(kr,"getChanges");a(TE,"assignTrackedAccessors");a(VH,"trackObject");hE=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[he])throw new Error("Can not track an already tracked object, check for circular references");this[he]=t}};TE(hE,{});a(q_,"collapseData");kH=Object.prototype.hasOwnProperty;a(Oo,"deepFreeze");a(mE,"hasChanges");Ao=Symbol.for("has-array-changes"),pE=class extends Array{static{a(this,"TrackedArray")}[Ao];constructor(t){super(t)}splice(...t){return this[Ao]=!0,super.splice(...t)}push(...t){return this[Ao]=!0,super.push(...t)}pop(){return this[Ao]=!0,super.pop()}unshift(...t){return this[Ao]=!0,super.unshift(...t)}shift(){return this[Ao]=!0,super.shift()}};pE.prototype.constructor=Array;SE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var up={};ke(up,{CONTEXT:()=>Ne,ID_PROPERTY:()=>Me,IS_COLLECTION:()=>En,RECORD_PROPERTY:()=>he,Resource:()=>vt,snake_case:()=>xne,transformForSelect:()=>RE});function xne(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function $H(e,t){if(cl=!1,e==="")return null;if(e=e.slice(1),e.indexOf("/")===-1)return e===""?(cl=!0,null):(e.startsWith("$")&&(e=parseInt(e,36)),t.coerceId(decodeURIComponent(e)));let r=e.split("/"),n=new XR;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){cl=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}function Vr(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[Ne]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(l=s,c=l[this.primaryKey]??null,o=i[Ne]||i):l=i:(l=s,c=l[Me]??l[this.primaryKey]??null),c==null&&(_=!0)):i?o=i[Ne]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="string")c=s;else if(typeof s=="object"&&s)if(u=s,s[Symbol.iterator]){c=[],_=!0;for(let E of s){if(typeof E=="object"&&E)break;c.push(E)}c.length===0?c=null:(c.length===1&&(c=c[0]),u.slice&&(u=u.slice(c.length,u.length),u.length===0&&(u=null,_=!1)))}else{if(typeof(c=s.url)=="string"){let E=c.indexOf("?");if(E>-1){let p=this.parseQuery(c.slice(E+1));u?u=Object.assign(p,u):u=p,c=c.slice(0,E)}let h=this.parsePath(c,o,u);h?.id!==void 0?(h.query&&(u?u=Object.assign(h.query,u):u=h.query),_=h.isCollection,c=h.id):c=h}c===void 0&&(c=s.id??null,c==null&&(_=!0))}else c=s??null,c==null&&(_=!0);o||(o={});let d;if(u?.ensureLoaded!=null||u?.async||_?(d=Object.assign({},t),u?.ensureLoaded!=null&&(d.ensureLoaded=u.ensureLoaded),u?.async&&(d.async=u.async),_&&(d.isCollection=!0)):d=t,o.transaction){let E=this.getResource(c,o,d);return E.then?E.then(f):f(E)}else return d.resetTransaction=!0,Ke(o,()=>{let E=this.getResource(c,o,d);return E.then?E.then(f):f(E)},d);function f(E){if(o.authorize){o.authorize=!1;let h=t.type==="read"?E.allowRead(o.user,u,o):t.type==="update"?E.doesExist?.()===!1?E.allowCreate(o.user,l,o):E.allowUpdate(o.user,l,o):t.type==="create"?E.allowCreate(o.user,l,o):E.allowDelete(o.user,u,o);if(h?.then)return h.then(p=>{if(!p)throw new gE(o.user);return typeof l?.then=="function"?l.then(S=>e(E,u,o,S)):e(E,u,o,l)});if(!h)throw new gE(o.user)}return typeof l?.then=="function"?l.then(h=>e(E,u,o,h)):e(E,u,o,l)}a(f,"authorizeActionOnResource")}}function $r(e,t){let r=new WH.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 JR(e,t,r){let n=e[he];if(n){let s=e[wt];return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function RE(e,t){let r=t?.propertyResolvers,n=t[Ne],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):JR(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(JR(u,r,n));for(let d of e)_.push(l(d));return _},"transform");let o=e.forceNulls;return a(function c(u){if(u.then)return u.then(c);if(Array.isArray(u))return u.map(f=>f&&typeof f=="object"?c(f):f);let _={},l=i(JR(u,r,n)),d;for(let f of e){let E=l(f);E===void 0&&o&&(E=null),E?.then?(d||(d=[]),d.push(E.then(h=>_[f.name||f]=h))):_[f.name||f]=E}return d?Promise.all(d).then(()=>_):_},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let u=s[c.name];if(!u){let l=r[c.name]?.definition?.tableClass;u=s[c.name]=RE(c.select||c,l)}let _=o(c.name);return u(_)}else return o(c);else return c}}a(i,"handleProperty")}var YH,KH,WH,Ne,Me,En,he,Hne,vt,gE,cl,XR,gn=Oe(()=>{YH=require("crypto");uc();KH=require("../../index"),WH=x(ee());G_();Qi();mf();Ne=Symbol.for("context"),Me=Symbol.for("primary-key"),En=Symbol("is-collection"),he=Symbol("stored-record"),Hne={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},vt=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[Me]=t;let n=r?.[Ne];this[Ne]=n!==void 0?n:r||null}static get=Vr(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 _=RE(u,t.constructor);return typeof c?.map=="function"?c.map(_):_(c)}return c}},{type:"read",resetTransaction:!0,ensureLoaded:!0,async:!0});static put=Vr(function(t,r,n,s){if(Array.isArray(s)&&t[En]){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):$r(t,"put")},{hasContent:!0,type:"update"});static patch=Vr(function(t,r,n,s){return t.patch?t.patch(s,r):$r(t,"patch")},{hasContent:!0,type:"update"});static delete=Vr(function(t,r,n,s){return t.delete?t.delete(r):$r(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,YH.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),Ke(n,()=>{let i=new this(s,n),o=i.update?i.update(r):$r(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>s):s})}static invalidate=Vr(function(t,r,n,s){return t.invalidate?t.invalidate(r):$r(t,"delete")},{hasContent:!1,type:"update"});static post=Vr(function(t,r,n,s){return t[Me]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=Vr(function(t,r,n,s){return t.connect?t.connect(s,r):$r(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Vr(function(t,r,n,s){return t.subscribe?t.subscribe(r):$r(t,"subscribe")},{type:"read"});static publish=Vr(function(t,r,n,s){return t[Me]!=null&&t.update?.(),t.publish?t.publish(s,r):$r(t,"publish")},{hasContent:!0,type:"create"});static search=Vr(function(t,r,n,s){let i=t.search?t.search(r):$r(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=RE(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=Vr(function(t,r,n,s){return t.search?t.search(s,r):$r(t,"search")},{hasContent:!0,type:"read"});static copy=Vr(function(t,r,n,s){return t.copy?t.copy(s,r):$r(t,"copy")},{type:"create"});static move=Vr(function(t,r,n,s){return t.move?t.move(s,r):$r(t,"move")},{type:"delete"});post(t){if(this[En])return this.constructor.create(this[Me],t,this[Ne]);$r(this,"post")}static isCollection(t){return t?.[En]}static coerceId(t){return t}static parseQuery(t){return hf(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&&Hne[o];if(c)r.headers.set("accept",c);else if(n)n.property=o;else return{query:{property:o},id:$H(t,this),isCollection:cl}}let i=$H(t,this);return cl?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[Ne],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let u;if(i.resourceCache?u=i.resourceCache:u=i.resourceCache=[],u.asMap){let _=u.asMap.get(t);if(s=_?.find(l=>l.constructor===c),s)return s;_||u.asMap.set(t,_=[]),_.push(s=new c(t,i))}else{if(s=u.find(_=>_[Me]===t&&_.constructor===c),s)return s;if(u.push(s=new c(t,i)),u.length>10){let _=new Map;for(let l of u){let d=l[Me],f=_.get(d);f?f.push(l):_.set(d,[l])}i.resourceCache.length=0,i.resourceCache.asMap=_}}}else s=new c(t,i);return o&&(s[En]=!0),s}subscribe(t){return new Tn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Tn}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[Ne]}};vt.prototype[Ne]=null;(0,KH._assignPackageExport)("Resource",vt);a(xne,"snake_case");gE=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($H,"pathToId");XR=class extends Array{static{a(this,"MulitPartId")}toString(){return this.join("/")}};a(Vr,"transactional");a($r,"missingMethod");a(JR,"selectFromObject");a(RE,"transformForSelect")});function zH(e,t,r,n){let s=e.primaryStore.env.path,i=e.primaryStore.tableId;ka||((0,AE.onMessageByType)(QH,l=>{JH(l.path)}),ka=Object.create(null));let o=ka[s]||(ka[s]=[]);o.auditStore=e.auditStore,o.lastTxnTime==null&&(o.lastTxnTime=Date.now());let c=o[i];c||(c=o[i]=new Map,c.envs=o,c.tableId=i,c.store=e.primaryStore),t=ha(t);let u=new ZR(r);u.startTime=n;let _=c.get(t);return _?_.push(u):(c.set(t,_=[u]),_.tables=c,_.key=t),u.subscriptions=_,u}function JH(e,t){if(!ka)return;let r=ka[e];if(!r)return;try{r.auditStore.resetReadTxn()}catch(s){throw s.message+=" in "+e,s}let n;for(let{key:s,value:i}of r.auditStore.getRange({start:r.lastTxnTime,exclusiveStart:!0})){r.lastTxnTime=s;let o=Ct(i),c=r[o.tableId];if(!c)continue;let u=o.recordId,_,l=ha(o.recordId),d=0;do{let f=c.get(l);if(f){for(let h of f)if(!(d>0&&!(h.includeDescendants&&!(h.onlyChildren&&d>1)))){if(h.startTime>=s){(0,jR.info)("omitting",u,h.startTime,s);continue}try{if(h.crossThreads===!1&&!t)continue;let p;h.supportsTransactions&&h.txnInProgress!==o.version&&(p=!0,h.txnInProgress||(n?n.push(h):n=[h]),h.txnInProgress=o.version),h.listener(u,o,s,p)}catch(p){console.error(p),(0,jR.info)(p)}}}if(l==null)break;let E=l.lastIndexOf?.("/",l.length-2);E>-1?l=l.slice(0,E):l=null,d++}while(!0)}if(n)for(let s of n)s.txnInProgress=null,s.listener(null,{type:"end_txn"},r.lastTxnTime,!0)}function XH(e,t){let r=t||e,n=r.env;if(t&&!t.cache&&(t.cache=new Map),!n.hasBroadcastListener){n.hasBroadcastListener=!0;let s=n.path;r.on("aftercommit",()=>{(0,AE.broadcast)({type:QH,path:s}),JH(s,!0)})}}var jR,AE,QH,ka,Sme,ZR,jH=Oe(()=>{jR=x(W()),AE=x(je());uc();Du();Ci();QH="transaction",Sme=Buffer.alloc(4096);a(zH,"addSubscription");ZR=class extends Tn{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(JH,"notifyFromTransactionData");a(XH,"listenToCommits")});var xg={};ke(xg,{coerceType:()=>OE,makeTable:()=>yE,setServerUtilities:()=>Wne,updateResource:()=>bE});function yE(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:u,schemaDefined:_,dbisDB:l}=e,{expirationMS:d,evictionMS:f,audit:E,trackDeletes:h}=e,{attributes:p}=e;p||(p=[]),XH(i,u);let S=Bh(i,n,u),O=0,g,R,B={},H=Promise.resolve(),v,M,$;for(let Y of p)(Y.assignCreatedTime||Y.name==="__createdtime__")&&(v=Y),(Y.assignUpdatedTime||Y.name==="__updatedtime__")&&(M=Y),Y.expiresAt&&($=Y),Y.isPrimaryKey&&(B=Y);let K,z=[],se=[],Te=1,oe=2,xe={},de={},It=864e5,bl,Nl,ks,pA=!1,kE,Vx=i.getRange({start:!1,end:!1}).constructor,$x=10,Yx=6;E&&gA();class We extends vt{static name=s;static primaryStore=i;static auditStore=u;static primaryKey=t;static tableName=s;static indices=r;static audit=E;static databasePath=o;static databaseName=c;static attributes=p;static expirationTimer;static createdTimeProperty=v;static updatedTimeProperty=M;static propertyResolvers;static sources=[];static get expirationMS(){return d}static dbisDB=l;static schemaDefined=_;static sourcedFrom(m,A){A&&(this.sourceOptions=A,(A.expiration||A.eviction||A.scanInterval)&&this.setTTLExpiration(A)),A?.intermediateSource?(m.intermediateSource=!0,this.sources.unshift(m)):this.sources.push(m),R=m.get&&(!m.get.reliesOnPrototype||m.prototype.get);let I=a(w=>{let y=this.sources.slice(0,-1);if(y=y.filter(P=>P[w]&&(!P[w].reliesOnPrototype||P.prototype[w])),y.length>0)if(y.length===1){let P=y[0];return(L,D,F)=>{if(L?.source!==P)return P[w](D,F,L)}}else return(P,L,D)=>{let F=[];for(let G of y){if(P?.source===G)break;F.push(G[w](L,D,P))}return Promise.all(F)}},"getApplyToIntermediateSource"),b=this.sources[this.sources.length-1],N=a(w=>{if(b[w]&&(!b[w].reliesOnPrototype||b.prototype[w]))return(y,P,L)=>{if(!y?.source)return b[w](P,L,y)}},"getApplyToCanonicalSource");return xe={put:N("put"),patch:N("patch"),delete:N("delete"),publish:N("publish")},de={put:I("put"),patch:I("patch"),delete:I("delete"),publish:I("publish"),invalidate:I("invalidate")},(async()=>{let w=!1,y=a(async(P,L)=>{let D=P.value,F=P.table?Ze[c][P.table]:We;if(c===Bn.SYSTEM_SCHEMA_NAME&&(P.table===Bn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||P.table===Bn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(w=!0),P.id===void 0&&(P.id=D[F.primaryKey],P.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(P));P.source=m;let G=await F.getResource(P.id,L,Va);switch(P.type){case"put":return G._writeUpdate(D,!0,Va);case"patch":return G._writeUpdate(D,!1,Va);case"delete":return G._writeDelete(Va);case"publish":return G._writePublish(D,Va);case"invalidate":return G.invalidate(Va);default:ze.error("Unknown operation",P.type,P.id)}},"writeUpdate");try{let P=m.subscribe;P&&h==null&&(h=!0);let L=m.subscribeOnThisThread?m.subscribeOnThisThread((0,No.getWorkerIndex)()):(0,No.getWorkerIndex)()===0,D=P&&L&&await m.subscribe?.({crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0});if(D){let F;for await(let G of D)try{if(!(G.type==="transaction"?G.writes[0]:G)){ze.error("Bad subscription event",G);continue}if(G.source=m,F)if(G.beginTxn)F.resolve();else{y(G,F);continue}if(G.type==="end_txn")continue;let ae=Ke(G,()=>{if(G.type==="transaction"){let re=[];for(let ce of G.writes)try{re.push(y(ce,G))}catch(ve){throw ve.message+=" writing "+JSON.stringify(ce)+" of event "+JSON.stringify(G),ve}return Promise.all(re)}else if(G.type==="define_schema"){let re=this.attributes.slice(0),ce;for(let ve of G.attributes)re.find(ne=>ne.name===ve.name)||(re.push(ve),ce=!0);ce&&(ot({table:s,database:c,attributes:re,origin:"cluster"}),hl.signalSchemaChange(new ml.SchemaEventMsg(process.pid,Bn.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return G.beginTxn?(F=G,y(G,G),new Promise(re=>{F.resolve=re})):y(G,G)});w&&(await ae,hl.signalUserChange(new ml.UserEventMsg(process.pid))),G.onCommit&&(ae?.then?ae.then(G.onCommit):G.onCommit())}catch(ie){ze.error("error in subscription handler",ie)}}}catch(P){ze.error(P)}})(),this}static getResource(m,A,I){let b=super.getResource(m,A,I);if(m!=null){Qa(m);try{if(b.hasOwnProperty(he))return b;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let N=!I?.async||i.cache?.get(m),w=gr(A),y=w.getReadTxn();if(y?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return VE(m,A,{transaction:y},N,P=>{if(P?bE(b,P):b[he]=null,A.onlyIfCached&&A.noCacheStore){if(!b.doesExist())throw new hn.ServerError("Entry is not cached",504)}else if(I?.ensureLoaded){let L=$E(m,P,A,b);if(L)return w?.disregardReadTxn(),b[eA]=!0,rA(L,D=>(bE(b,D),b))}return b})}catch(N){throw N.message.includes("Unable to serialize object")&&(N.message+=": "+JSON.stringify(m)),N}}return b}ensureLoaded(){let m=$E(this[Me],this[Yr],this[Ne]);if(m)return this[eA]=!0,rA(m,A=>{this[Yr]=A,this[he]=A.value,this[fl]=A.version})}static setTTLExpiration(m){if(typeof m=="number")d=m*1e3,f||(f=0);else if(m&&typeof m=="object")d=m.expiration*1e3,f=(m.eviction||0)*1e3,It=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(d<0)throw new Error("Expiration can not be negative");It=It||(d+f)/4,KE()}static enableAuditing(m=!0){E=m,m&&gA(),We.audit=m}static coerceId(m){return m===""?null:OE(m,B)}static async dropTable(){if(delete Ze[c][s],c===o){for(let m of p)l.remove(We.tableName+"/"+m.name),r[m.name]?.drop();l.remove(We.tableName+"/"),i.drop(),await l.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));hl.signalSchemaChange(new ml.SchemaEventMsg(process.pid,Bn.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this[En])return this.search(m);if(this[Me]===null){if(m?.conditions)return this.search(m);let A=We.getRecordCount();return{recordCount:A.recordCount,estimatedRecordRange:A.estimatedRange,records:"./",name:s,database:c,attributes:p}}if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this[Ne]?.returnNonexistent)return this}allowRead(m,A){let I=wl(m);if(I?.read){if(I.isSuperUser)return!0;let b=I.attribute_permissions,N=A?.select;if(b?.length>0||pA&&N){if(A||(A={}),N){let w=b?.length>0&&tA(b,"read");A.select=N.map(y=>{let P=y.name||y;if(!w||w[P]){let L=ks[P]?.definition?.tableClass;if(L){if(y.name||(y={name:y}),!L.prototype.allowRead.call(null,m,y))return!1;if(!y.select)return y.name}return y}}).filter(Boolean)}else A.select=b.filter(w=>w.read&&!ks[w.attribute_name]).map(w=>w.attribute_name);return A}else return!0}}allowUpdate(m,A){let I=wl(m);if(I?.update){let b=I.attribute_permissions;if(b?.length>0){let N=tA(b,"update");for(let w in A)if(!N[w])return!1;for(let w of b){let y=w.attribute_name;!w.update&&!(y in A)&&(A[y]=this.getProperty(y))}}return!0}}allowCreate(m,A){if(this[En]){let I=wl(m);if(I?.insert){let b=I.attribute_permissions;if(b?.length>0){let N=tA(b,"insert");for(let w in A)if(!N[w])return!1}else return!0}}else return this.allowUpdate(m,{})}allowDelete(m){return wl(m)?.delete}update(m,A){if(!gr(this[Ne]))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let b;return typeof m=="object"&&m&&(A?(Object.isFrozen(m)&&(m=Object.assign({},m)),this[he]={},this[wt]=m):(b=this[wt],b&&(m=Object.assign(b,m)),this[wt]=b=m)),this._writeUpdate(this[wt],A),this}addTo(m,A){if(typeof A=="number")this[ul]===ex?this.set(m,(+this.getProperty(m)||0)+A):(this[ul]||this.update(),this.set(m,new SE(A)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,A){if(typeof A=="number")return this.addTo(m,-A);throw new Error("Can not subtract a non-numeric value")}invalidate(m){let A=this[Ne],I=this[Me];Qa(I),gr(this[Ne]).addWrite({key:I,store:i,invalidated:!0,entry:this[Yr],nodeName:this[Ne]?.nodeName,before:xe.invalidate?.bind(this,A,I),beforeIntermediate:de.invalidate?.bind(this,A,I),commit:(N,w)=>{if(w?.version>N)return;let y=null;for(let P in r)y||(y={}),y[P]=this.getProperty(P);S(I,y,this[Yr],N,ll,E,this[Ne],0,"invalidate")}})}static evict(m,A,I){let b=this.Source,N;if(!((R||E)&&(!A||(N=i.getEntry(m),!N||!A)||N.version!==I))){if(R){if(i.hasLock(m,N.version))return;let w;for(let y in r)w||(w={}),w[y]=A[y];if(w)return S(m,w,N,I,_l,null,null,0,null,!0)}return i.ifVersion(I,()=>{yl(m,A,null)}),E?S(m,null,N,I,_l,null,null,0,null,!0):i.remove(m,I)}}lock(){throw new Error("Not yet implemented")}static operation(m,A){return m.table||=s,m.schema||=c,ox.operation(m,A)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,A,I){let b=this[Ne],N=gr(b),w=this[Me];Qa(w);let y=this[Yr];this[ul]=A?ex:$ne;let P={key:w,store:i,entry:y,nodeName:b?.nodeName,validate:L=>{m||(m=this[wt]),A||m&&mE(m)?(this.validate(m,!A),b?.source||(M&&(m[M.name]=M.type==="Date"?new Date(L):M.type==="String"?new Date(L).toISOString():L),A&&(t&&m[t]!==w&&(m[t]=w),v&&(y?.value?m[v.name]=y?.value[v.name]:m[v.name]=v.type==="Date"?new Date(L):v.type==="String"?new Date(L).toISOString():L),m=Oo(m)))):N.removeWrite(P)},before:A?xe.put?()=>xe.put(b,w,m):null:xe.patch?()=>xe.patch(b,w,m):xe.put?()=>xe.put(b,w,Oo(this)):null,beforeIntermediate:A?de.put?()=>de.put(b,w,m):null:de.patch?()=>de.patch(b,w,m):de.put?()=>de.put(b,w,Oo(this)):null,commit:(L,D,F)=>{if(F){if(b&&D?.version>(b.lastModified||0)&&(b.lastModified=D.version),this[Yr]=D,D?.value?.[he])throw new Error("Can not assign a record to a record, check for circular references");A||(this[he]=D?.value??null)}this[wt]=m,this[fl]=L;let G=D?.value,ie=m;if(this[ul]=0,D?.version>=L)if(E){let ve=D.localTime,ne=D.version;for(;ie&&(ve>L||ne>=L&&ve>0);){let fe=u.get(ve),j=Ct(fe);if(ne=j.version,ne>L){if(j.type==="patch"){let le=j.getValue(i);ie=EE(ie,le)}else if(j.type==="put"||j.type==="delete")return}else if(ne===L)return;ve=j.previousLocalTime}}else{if(A)return;ie=EE(ie,G)}let ae;if(A?ae=ie:(this[he]=G,ae=A?ie:Oo(this,ie)),this[he]=ae,ae?.[he])throw new Error("Can not assign a record to a record, check for circular references");let re;A||(re=m),yl(w,G,ae);let ce=A?"put":"patch";S(w,ae,D,L,0,E,b,b.expiresAt||(d?d+Date.now():0),ce,!1,re)}};N.addWrite(P)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this[En]){for await(let A of this.search(m))(await We.getResource(A[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this[he]?this._writeDelete(m):!1}_writeDelete(m){let A=gr(this[Ne]),I=this[Me];Qa(I);let b=this[Ne];return A.addWrite({key:I,store:i,resource:this,nodeName:b?.nodeName,before:xe.delete?.bind(this,b,I),beforeIntermediate:de.delete?.bind(this,b,I),commit:(N,w,y)=>{let P=w?.value;y&&(b&&w?.version>(b.lastModified||0)&&(b.lastModified=w.version),bE(this,w)),!(w?.version>N)&&(yl(this[Me],P),ze.trace("Write delete entry",I,N),E||h?(S(I,null,this[Yr],N,0,E,this[Ne],0,"delete"),E||KE()):i.remove(this[Me]))}}),!0}search(m){let A=this[Ne],I=gr(A);if(!m)throw new Error("No query provided");let b=m.conditions;b?b.length===void 0&&(b=b[Symbol.iterator]?Array.from(b):[b]):b=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this[Me]&&(b=[{attribute:null,comparator:"prefix",value:this[Me]}].concat(b));let N,w={};function y(j,le){let St;switch(le){case"and":case void 0:if(j.length<1)throw new Error('An "and" operator requires at least one condition');St=!0;break;case"or":if(j.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+le)}let Hn=St&&{},xn;for(let Qe of j){if(Qe.conditions){Qe.conditions=y(Qe.conditions,Qe.operator);continue}let Rr=Qe[0]??Qe.attribute,zr=Rr==null?B:Us(p,Rr);if(zr){if(St){let Ar=Mn(Rr),Fn=Hn[Ar];Fn?(Fn.push(Qe),xn=!0):Hn[Ar]=[Qe]}(zr.type||lg[Qe.comparator])&&(Qe[1]===void 0?Qe.value=L(Qe.value,zr):Qe[1]=L(Qe[1],zr))}else if(Rr!=null)throw(0,hn.handleHDBError)(new Error,`${Rr} is not a defined attribute`,404)}if(m.enforceExecutionOrder)return j;if(xn)for(let Qe in Hn){let Rr=Hn[Qe],zr=Rr.length;if(zr>1)for(let Ar=0;Ar<zr;Ar++){let Fn=Rr[Ar];if(Fn.comparator==="ge"||Fn.comparator==="greater_than_equal")for(let Vs=0;Vs<zr;Vs++){let Do=Rr[Vs];(Do.comparator==="le"||Do.comparator==="less_than_equal")&&(Fn.comparator="between",Fn.value=[Fn.value,Do.value],j.splice(j.indexOf(Do),1))}if(Fn.comparator==="equals"||!Fn.comparator){for(let Vs=0;Vs<zr;Vs++)if(Vs!==Ar){let Do=Rr[Vs];j.splice(j.indexOf(Do),1)}break}}}return j}a(y,"prepareConditions");function P(j,le){if(m.enforceExecutionOrder)return j;for(let St of j)St.conditions&&(St.conditions=P(St.conditions,St.operator));return j.length>1&&le!=="or"?(0,ix.sortBy)(j,Ef(We)):j}a(P,"orderConditions");function L(j,le){return Array.isArray(j)?j.map(St=>OE(St,le)):OE(j,le)}a(L,"coerceTypedValues");let D=m.operator;(b.length>0||D)&&(b=y(b,D));let F=typeof m.sort=="object"&&m.sort,G;if(F&&D!=="or"){let j=F.attribute;if(N=b.find(le=>Mn(le.attribute)===Mn(j)),!N){if(!Us(p,j))throw(0,hn.handleHDBError)(new Error,`${Array.isArray(j)?j.join("."):j} is not a defined attribute`,404);N={attribute:j,comparator:"sort"},b.push(N)}N.descending=!!F.descending}b=P(b,D),F&&(b[0]===N?F.next&&(G={dbOrderedAttribute:F.attribute,attribute:F.next.attribute,descending:F.next.descending,next:F.next.next}):(N&&b.splice(b.indexOf(N),1),G=F));let ie=m.select;if(b.length===0&&(b=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:b,operator:D,postOrdering:G,selectApplied:!!ie};let ae=I.useReadTxn(),re=_g(b,D,We,ae,m,A,(j,le)=>SA(j,ie,A,le),w),ce=m.ensureLoaded!==!1;G||(re=fe(re));let ve=We.transformEntryForSelect(ie,A,w,ce,!0),ne=We.transformToOrderedSelect(re,ie,G,A,ve);function fe(j){return m.offset||m.limit!==void 0?j.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):j}return a(fe,"applyOffset"),G&&(ne=fe(ne)),ne.onDone=()=>{ne.onDone=null,I.doneReadTxn()},ne.selectApplied=!0,ne.getColumns=()=>{if(ie){let j=[];for(let le of ie)le==="*"?j.push(...p.map(St=>St.name)):j.push(le.name||le);return j}return p.map(j=>j.name)},ne}static transformToOrderedSelect(m,A,I,b,N){let w=new Vx;if(I){m=SA(m,A,b,null);let y;w.iterate=function(){let L,D=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),F,G=I.dbOrderedAttribute,ie,ae,re=!0;function ce(ne){let fe=ne.next&&ce(ne.next),j=ne.descending;return(le,St)=>{let Hn=YE(le,ne.attribute,b),xn=YE(St,ne.attribute,b),Qe=j?(0,yo.compareKeys)(xn,Hn):(0,yo.compareKeys)(Hn,xn);return Qe===0?fe?.(le,St)||0:Qe}}a(ce,"createComparator");let ve=ce(I);return{async next(){let ne;if(L)if(ne=L.next(),ne.done){if(F)return w.onDone&&w.onDone(),ne}else return{value:await N(ne.value)};y=[],ie&&y.push(ie);do if(ne=await D.next(),ne.done){if(F=!0,y.length)break;return w.onDone&&w.onDone(),ne}else{let fe=ne.value;if(fe?.then&&(fe=await fe),G){let j=YE(fe,G,b);if(re)re=!1,ae=j;else if(j!==ae){ae=j,ie=fe;break}}y.push(fe)}while(!0);return I.isGrouped,y.sort(ve),L=y[Symbol.iterator](),ne=L.next(),ne.done?(w.onDone&&w.onDone(),ne):{value:await N(ne.value)}},return(){w.onDone&&w.onDone(),D.return()},throw(){w.onDone&&w.onDone(),D.throw()}}};let P=a(L=>{if(typeof A=="object"&&Array.isArray(L.attribute))for(let D=0;D<A.length;D++){let F=A[D],G;if(F.name===L.attribute[0]){for(G=F.sort||(F.sort={});G.next;)G=G.next;G.attribute=L.attribute.slice(1),G.descending=L.descending}else F===L.attribute[0]&&(A[D]=G={name:F,sort:{attribute:L.attribute.slice(1),descending:L.descending}})}L.next&&P(L.next)},"applySortingOnSelect");P(I)}else w.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),w=w.map(N);return w}static transformEntryForSelect(m,A,I,b,N){if(m&&(m===t||m?.length===1&&m[0]===t)){let L=a(D=>D?.key??D,"transform");return m===t?L:m.asArray?D=>[L(D)]:D=>({[t]:L(D)})}let w;b&&R&&!m?.every(L=>{let D;return typeof L=="object"?D=L.name:D=L,r[D]||D===t})&&(w=!0);let y,P=a(L=>{let D;if(L!=null){if(kE=L,D=L.value||L.deref?.(),!D&&(L.key===void 0||L.deref)){if(L=VE(L.key??L,A,{transaction:gr(A).getReadTxn(),lazy:m?.length<4},!1,F=>F),L?.then)return L.then(P);D=L?.value}if(w&&(L.metadataFlags&(ll|_l)||L.expiresAt&&L.expiresAt<Date.now())){let F=$E(L.key??L,L,A);if(F?.then)return F.then(P)}}if(D==null)return N?bo.SKIP:D;if(m&&!(m[0]==="*"&&m.length===1)){let F,G=a((ae,re)=>{let ce;typeof ae=="object"?ce=ae.name:ce=ae;let ve=ks?.[ce],ne;if(ve){let fe=I?.[ce];if(fe)if(fe.hasMappings){let le=ve.from?D[ve.from]:Mn(L.key);ne=fe.get(le),ne||(ne=[])}else ne=fe.fromRecord?.(D);else ne=ve(D,A,L);let j=a(le=>{if(le&&typeof le=="object"){let St=ve.definition?.tableClass||We;y||(y={});let Hn=y[ce]||(y[ce]=St.transformEntryForSelect(ce===ae?null:ae.select||(Array.isArray(ae)?ae:null),A,fe,b));if(Array.isArray(le)){let xn=[],Qe=St.transformToOrderedSelect(le,ae.select,typeof ae.sort=="object"&&ae.sort,A,Hn)[Symbol.asyncIterator](),Rr=a(Ar=>{for(;!Ar.done;){if(Ar?.then)return Ar.then(Rr);xn.push(Ar.value),Ar=Qe.next()}re(xn,ce)},"nextValue"),zr=Rr(Qe.next());zr&&(F||(F=[]),F.push(zr));return}else if(le=Hn(le),le?.then){F||(F=[]),F.push(le.then(xn=>re(xn,ce)));return}}re(le,ce)},"handleResolvedValue");ne?.then?(F||(F=[]),F.push(ne.then(j))):j(ne);return}else ne=D[ce],ne&&typeof ne=="object"&&ce!==ae&&(ne=this.transformEntryForSelect(ae.select||ae,A,null)({value:ne}));re(ne,ce)},"selectAttribute"),ie;if(typeof m=="string")G(m,ae=>{ie=ae});else if(Array.isArray(m))if(m.asArray)ie=[],m.forEach((ae,re)=>{ae==="*"?m[re]=D:G(ae,ce=>ie[re]=ce)});else{ie={};let ae=m.forceNulls;for(let re of m)if(re==="*")for(let ce in D)ie[ce]=D[ce];else G(re,(ce,ve)=>{ce===void 0&&ae&&(ce=null),ie[ve]=ce})}else throw new hn.ClientError("Invalid select"+m);return F?Promise.all(F).then(()=>ie):ie}return D},"transform");return P}async subscribe(m){if(!u)throw new Error("Can not subscribe to a table without an audit log");E||ot({table:s,database:c,schemaDefined:_,attributes:p,audit:!0}),m||(m={});let A=!m.rawEvents,I=zH(We,this[Me]??null,function(y,P,L,D){try{let F=P.getValue?.(i,A);if(!F&&P.type==="patch"&&A){let G=i.getEntry(y);G?.version===P.version?F=G.value:F=P.getValue?.(i,!0,L),P.type="put"}this.send({id:y,timestamp:L,value:F,version:P.version,type:P.type,beginTxn:D})}catch(F){ze.error(F)}},m.startTime||0,this[En]);this[En]&&(I.includeDescendants=!0,m.onlyChildren&&(I.onlyChildren=!0)),m.crossThreads===!1&&(I.crossThreads=!1),m.supportsTransactions&&(I.supportsTransactions=!0);let b=this[Me],N=m.previousCount;N>1e3&&(N=1e3);let w=m.startTime;if(this[En]){if(w){if(N)throw new hn.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:y,value:P}of u.getRange({start:w,exclusiveStart:!0})){let L=Ct(P);if(L.tableId!==n)continue;let D=L.recordId;(b==null||nx(b,D))&&I.send({id:D,timestamp:y,...L}),I.startTime=y}}else if(N){let y=[];for(let{key:P,value:L}of u.getRange({start:"z",end:!1,reverse:!0}))try{let D=Ct(L);if(D.tableId!==n)continue;let F=D.recordId;if(b==null||nx(b,F)){let G=D.getValue(i,A,P);if(y.push({id:F,timestamp:P,value:G,version:D.version,type:D.type}),--N<=0)break}}catch(D){ze.error("Error getting history entry",P,D)}for(let P=y.length;P>0;)I.send(y[--P]);y[0]&&(I.startTime=y[0].timestamp)}else if(!m.omitCurrent)for(let{key:y,value:P,version:L,localTime:D}of i.getRange({start:b??!1,end:b==null?void 0:[b,yo.MAXIMUM_KEY],versions:!0}))P&&I.send({id:y,version:L,timestamp:D,value:P})}else{N&&!w&&(w=0);let y=this[Yr]?.localTime;if(y===vh&&(i.cache?.delete(b),this[Yr]=i.getEntry(b),ze.trace("re-retrieved record",y,this[Yr]?.localTime),y=this[Yr]?.localTime),ze.trace("Subscription from",w,"from",b,y),w<y){let P=[],L=y;do{let D=u.get(L);if(D){m.omitCurrent=!0;let F=Ct(D),G=F.getValue(i,A,L);A&&(F.type="put"),P.push({id:b,value:G,timestamp:L,...F}),L=F.previousLocalTime}else break;N&&N--}while(L>w&&N!==0);for(let D=P.length;D>0;)I.send(P[--D]);I.startTime=y}!m.omitCurrent&&this.doesExist()&&I.send({id:b,version:this[fl],timestamp:y,value:this})}return m.listener&&I.on("data",m.listener),I}doesExist(){return!!(this[he]||this[ul])}publish(m,A){this._writePublish(m,A)}_writePublish(m,A){let I=gr(this[Ne]),b=this[Me]||null;Qa(b);let N=this[Ne];I.addWrite({key:b,store:i,entry:this[Yr],nodeName:N?.nodeName,validate:()=>{this.validate(m)},before:xe.publish?.bind(this,N,b,m),beforeIntermediate:de.publish?.bind(this,N,b,m),commit:(w,y,P)=>{y===void 0&&h&&!E&&KE(),S(b,y?.value??null,y,y?.version||w,0,!0,N,y?.expiresAt,"message",!1,m)}})}validate(m,A){let I,b=a((N,w,y)=>{if(w.type&&N!=null)if(A&&N.__op__&&(N=N.value),w.properties){typeof N!="object"&&(I||(I=[])).push(`Property ${y} must be an object${w.type?" ("+w.type+")":""}`);let P=w.properties;for(let L=0,D=P.length;L<D;L++){let F=P[L],G=b(N[F.name],F,y+"."+F.name);G&&(N[F.name]=G)}}else switch(w.type){case"Int":(typeof N!="number"||N>>0!==N)&&(I||(I=[])).push(`Property ${y} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof N!="number"||!(Math.floor(N)===N&&Math.abs(N)<=9007199254740992))&&(I||(I=[])).push(`Property ${y} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof N!="number"&&(I||(I=[])).push(`Property ${y} must be a number`);break;case"ID":typeof N=="string"||N?.length>0&&N.every?.(P=>typeof P=="string")||(I||(I=[])).push(`Property ${y} must be a string, or an array of strings`);break;case"String":typeof N!="string"&&(I||(I=[])).push(`Property ${y} must be a string`);break;case"Boolean":typeof N!="boolean"&&(I||(I=[])).push(`Property ${y} must be a boolean`);break;case"Date":if(!(N instanceof Date)){if(typeof N=="string"||typeof N=="number")return new Date(N);(I||(I=[])).push(`Property ${y} must be a Date`)}break;case"BigInt":if(typeof N!="bigint"){if(typeof N=="string"||typeof N=="number")return BigInt(N);(I||(I=[])).push(`Property ${y} must be a bigint`)}break;case"Bytes":N instanceof Uint8Array||(I||(I=[])).push(`Property ${y} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(N)){if(w.elements)for(let P=0,L=N.length;P<L;P++){let D=N[P],F=b(D,w.elements,y+"[*]");F&&(N[P]=F)}}else(I||(I=[])).push(`Property ${y} must be a Buffer or Uint8Array`);break}w.nullable===!1&&N==null&&(I||(I=[])).push(`Property ${y} is required (and not does not allow null values)`)},"validateValue");for(let N=0,w=p.length;N<w;N++){let y=p[N];if(!y.relationship&&(!A||y.name in m)){let P=b(m[y.name],y,y.name);P&&(m[y.name]=P)}}if(I)throw new hn.ClientError(I.join(". "))}getUpdatedTime(){return this[fl]}wasLoadedFromSource(){return R?!!this[eA]:void 0}static async addAttributes(m){let A=p.slice(0);for(let I of m){if(!I.name)throw new hn.ClientError("Attribute name is required");if(I.name.match(/[`/]/))throw new hn.ClientError("Attribute names cannot include backticks or forward slashes");A.push(I)}return ot({table:s,database:c,schemaDefined:_,attributes:A}),We.indexingOperation}static async removeAttributes(m){let A=p.filter(I=>!m.includes(I.name));return ot({table:s,database:c,schemaDefined:_,attributes:A}),We.indexingOperation}static getRecordCount(m){let A=i.getStats().entryCount,I=5e3,b=1e3,N;A>I&&!m?.exactCount&&(N=b);let w=0;for(let{value:y}of i.getRange({start:!0,lazy:!0,limit:N}))y!=null&&w++;if(N){let y=w;w=0;for(let{value:ce}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:N}))ce!=null&&w++;let P=N*2,L=(w+y)/P,D=Math.pow((w-y+1)/N/2,2)+L*(1-L)/P,F=Math.max(Math.sqrt(D)*A,1),G=Math.round(L*A),ie=Math.max(G-1.96*F,0),ae=Math.min(G+1.96*F,A),re=Math.pow(10,Math.round(Math.log10(F)));return re>G&&(re=re/10),w=Math.round(G/re)*re,{recordCount:w,estimatedRange:[Math.round(ie),Math.round(ae)]}}return{recordCount:w}}static updatedAttributes(){ks=this.propertyResolvers={$id:(m,A,I)=>({value:I.key}),$updatedtime:(m,A,I)=>I.version,$record:(m,A,I)=>I?{value:m}:m};for(let m of this.attributes){m.resolve=null;let A=m.relationship;if(A)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),pA=!0,A.to)m.elements?.definition?(ks[m.name]=m.resolve=(I,b,N)=>{let w=I[A.from?A.from:t],y=m.elements.definition.tableClass;return N?Na({attribute:A.to,value:w},gr(b).getReadTxn(),!1,y).asArray:y.search([{attribute:A.to,value:w}],b).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,A.from&&(m.resolve.from=A.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(A.from){let I=m.definition||m.elements?.definition;I?(ks[m.name]=m.resolve=(b,N,w)=>{let y=b[A.from];if(y!==void 0){if(m.elements){let P,L=y.map(D=>{let F=w?I.tableClass.primaryStore.getEntry(D,{transaction:gr(N).getReadTxn()}):I.tableClass.get(D,N);return F?.then&&(P=!0),F});return A.filterMissing?P?Promise.all(L).then(D=>D.filter(sx)):L.filter(sx):P?Promise.all(L):L}return w?I.tableClass.primaryStore.getEntry(y,{transaction:gr(N).getReadTxn()}):I.tableClass.get(y,N)}},m.set=(b,N)=>{if(Array.isArray(N)){let w=N.map(y=>y[Me]||y[I.tableClass.primaryKey]);b[A.from]=w}else{let w=N[Me]||N[I.tableClass.primaryKey];b[A.from]=w}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=A.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`)}TE(this,this)}static async deleteHistory(m=0){let A;for(let{key:I,value:b}of u.getRange({start:0,end:m}))await dl(),Ct(b).tableId===n&&(A=u.remove(I));await A}static async*getHistory(m=0,A=1/0){for(let{key:I,value:b}of u.getRange({start:m,end:A})){await dl();let N=Ct(b);N.tableId===n&&(yield{id:N.recordId,localTime:I,version:N.version,type:N.type,value:N.getValue(i,!0,I),user:N.user})}}static async getHistoryOfRecord(m){let A=[];if(m==null)throw new Error("An id is required");let I=i.getEntry(m);if(!I)return A;let b=I.localTime;if(!b)throw new Error("The entry does not have a local audit time");let N=0;do{await dl();let w=u.get(b);if(w){let y=Ct(w);A.push({id:y.recordId,localTime:b,version:y.version,type:y.type,value:y.getValue(i,!0,b),user:y.user}),b=y.previousLocalTime}else break}while(N<1e3&&b);return A.reverse()}static cleanup(){K?.remove()}}We.updatedAttributes();let Kx=We.prototype;return Kx[Vne]=!0,d&&We.setTTLExpiration(d/1e3),$&&Wx(),We;function yl(Y,m,A){let I;for(let b in r){let N=r[b],w=N.isIndexing,y=A?.[b],P=m?.[b];if(y===P&&!w)continue;I=!0;let L=N.indexNulls,D=(0,El.getIndexedValues)(P,L);if(D){ZH&&N.prefetch(D.map(F=>({key:F,value:Y})),rx);for(let F=0,G=D.length;F<G;F++)N.remove(D[F],Y)}if(D=(0,El.getIndexedValues)(y,L),D){ZH&&N.prefetch(D.map(F=>({key:F,value:Y})),rx);for(let F=0,G=D.length;F<G;F++)N.put(D[F],Y)}}return I}a(yl,"updateIndices");function Qa(Y){switch(typeof Y){case"number":return!0;case"string":if(Y.length<659)return!0;if(Y.length>tx)throw new Error("Primary key size is too large: "+Y.length);break;case"object":if(Y===null)return!0;break;case"bigint":if(Y<2n**64n&&Y>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof Y)}if((0,yo.writeKey)(Y,Yne,0)>tx)throw new Error("Primary key size is too large: "+Y.length);return!0}a(Qa,"checkValidId");function VE(Y,m,A,I,b){let N=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),A.transaction?.isDone)return b(null,Y);let w=i.getEntry(Y,A);return w&&m&&(w?.version>(m.lastModified||0)&&(m.lastModified=w.version),w?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=w.localTime)),b(w,Y)},"whenPrefetched");return I?N():Te>0?(Te--,N()):new Promise((w,y)=>{Te===0?(Te--,i.prefetch([Y],()=>{P(),L()})):(z.push(Y),se.push(L),z.length>Yx&&(Te--,P()));function P(){if(z.length>0){let D=se;i.prefetch(z,()=>{Te===-1?P():Te++;for(let F of D)F()}),z=[],se=[],oe>2&&oe--}else Te=oe,oe<$x&&oe++}a(P,"prefetch");function L(){try{w(N())}catch(D){y(D)}}a(L,"load")})}a(VE,"loadLocalRecord");function wl(Y){if(!Y?.role)return;let m=Y.role.permission;if(m.super_user)return Kne;let A=m[c],I,b=A?.tables;if(b)return b[s];if(c==="data"&&(I=m[s])&&!I.tables)return I}a(wl,"getTablePermissions");function $E(Y,m,A,I){if(R){let b;if(A.noCache?b=!0:(m?(!m.value||m.metadataFlags&(ll|_l)||m.expiresAt&&m.expiresAt<Date.now())&&(b=!0):b=!0,tn(!b,"cache-hit",s)),b){let N=TA(Y,m,A).then(w=>(w?.value?.[he]&&ze.error("Can not assign a record with a record property"),A&&(w?.version>(A.lastModified||0)&&(A.lastModified=w.version),A.lastRefreshed=Date.now()),w));if(A?.onlyIfCached||m?.value&&I?.allowStaleWhileRevalidate?.(m,Y)){if(N.catch(w=>ze.warn(w)),A?.onlyIfCached&&!I.doesExist())throw new hn.ServerError("Entry is not cached",504);return}else return N}}}a($E,"ensureLoadedFromSource");function gr(Y){let m=Y?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let A=m.next;if(!A)return m=m.next=new Wi,m.lmdbDb=i,m;m=A}while(!0)}else return new x_}a(gr,"txnForContext");function YE(Y,m,A){if(!Y)return;kE=Y;let I=Y.value||Y.deref?.()||(kE=i.getEntry(Y.key))?.value;if(typeof m=="object"){let N=ks,w=I;for(let y=0,P=m.length;y<P;y++){let L=m[y],D=N?.[L];w=D&&w?D(w,A,!0)?.value:w?.[L],N=D?.definition?.tableClass?.propertyResolvers}return w}let b=ks[m];return b?b(I,A):I[m]}a(YE,"getAttributeValue");function SA(Y,m,A,I){let b=gr(A).getReadTxn(),N=I?.length,w={transaction:b,lazy:N>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},y;function P(L,D){let F=L?.value;if(!F)return bo.SKIP;for(let G=0;G<N;G++)if(!y?.includes(G)&&!I[G](F,L))return bo.SKIP;return D!==void 0&&(L.key=D),L}if(a(P,"processEntry"),N>0||!Y.hasEntries){let L=Y.map(D=>{if(y=null,typeof D=="object"&&D.key!==void 0)return N>0?P(D):D;if(D==null)return bo.SKIP;for(let F=0;F<N;F++){let ie=I[F].idFilter;if(ie){if(!ie(D))return bo.SKIP;y||(y=[]),y.push(F)}}return VE(D,A,w,!1,P)});return Array.isArray(Y)&&(L=L.filter(D=>D!==bo.SKIP)),L.hasEntries=!0,L}return Y}a(SA,"transformToEntries");async function TA(Y,m,A){let I=m?.metadataFlags,b=m?.version,N,w;if(!i.attemptLock(Y,b,()=>{clearTimeout(w);let D=i.getEntry(Y);!D||!D.value||D.metadataFlags&(ll|_l)?N(TA(Y,i.getEntry(Y),A)):N(D)}))return new Promise(D=>{N=D,w=setTimeout(()=>{i.unlock(Y,b)},kne)});let y=m?.value,P={requestContext:A,replacingRecord:y,replacingVersion:b,source:null,resourceCache:A?.resourceCache},L=A?.responseHeaders;return new Promise((D,F)=>{let G;rA(Ke(P,async ie=>{let ae=performance.now(),re,ce,ve;try{for(let le of We.sources)if(le.get&&(!le.get.reliesOnPrototype||le.prototype.get)&&(P.source=le,re=await le.get(Y,P),re))break;ve=I≪let fe=P.lastModified||ve&&b;ce=ve||fe>b||!y,fe||(fe=(0,El.getNextMonotonicTime)());let j=performance.now()-ae;if(Br(j,"cache-resolution",s),L&&L.append("Server-Timing",`cache-resolve;dur=${j.toFixed(2)}`),ie.timestamp=fe,d&&!P.expiresAt&&(P.expiresAt=Date.now()+d),re){if(typeof re!="object")throw new Error("Only objects can be cached and stored in tables");typeof re.toJSON=="function"&&(re=re.toJSON()),t&&re[t]!==Y&&(re[t]=Y)}G=!0,D({version:fe,value:re})}catch(fe){fe.message+=` while resolving record ${Y} for ${s}`,y&&((fe.code==="ECONNRESET"||fe.code==="ECONNREFUSED"||fe.code==="EAI_AGAIN")&&!A?.mustRevalidate||A?.staleIfError&&(fe.statusCode===500||fe.statusCode===502||fe.statusCode===503||fe.statusCode===504))?(D({version:b,value:y}),ze.trace(fe.message,"(returned stale record)")):F(fe),P.transaction.abort();return}if(A?.noCacheStore){P.transaction.abort();return}gr(P).addWrite({key:Y,store:i,entry:m,nodeName:"source",commit:(fe,j)=>{if(j?.version!==b)return;let le=yl(Y,y,re);re?(de.put?.(P,Y,re),S(Y,re,j,fe,0,E&&ce||null,P,P.expiresAt,"put",!!ve)):(de.delete?.(P,Y),E||h?S(Y,null,j,fe,0,E&&ce||null,P,0,"delete",!!ve):i.remove(Y,b))}})}),()=>{i.unlock(Y,b)},ie=>{i.unlock(Y,b),G&&ze.error("Error committing cache update",ie)})})}a(TA,"getFromSource");function KE(){if(It!==bl&&(bl=It,(0,No.getWorkerIndex)()===(0,No.getWorkerCount)()-1)){if(Nl&&clearTimeout(Nl),!It)return;let Y=new Date;Y.setMonth(0),Y.setDate(1),Y.setHours(0),Y.setMinutes(0),Y.setSeconds(0);let m=Math.ceil((Date.now()-Y.getTime())/It)*It+Y.getTime(),A=a(I=>{ze.trace(`Scheduled next cleanup scan at ${new Date(I)}ms`),Nl=setTimeout(()=>H=H.then(async()=>{if(A(Math.max(I+It,Date.now())),i.rootStore.status!=="open"){clearTimeout(Nl);return}let b=50,N=new Array(b),w=0;ze.trace(`Starting cleanup scan for ${s}`);try{let y=0;for(let{key:P,value:L,version:D,expiresAt:F}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let G;L===null&&!E&&D+Gne<Date.now()?G=i.remove(P,D):F&&F+f<Date.now()&&(G=We.evict(P,L,D),y++),G&&(await N[w],N[w]=G.catch(ie=>{ze.error("Cleanup error",ie)}),++w>=b&&(w=0)),await dl()}ze.trace(`Finished cleanup scan for ${s}, evicted ${y} entries`)}catch(y){ze.trace(`Error in cleanup scan for ${s}:`,y)}}),Math.min(I-Date.now(),2147483647)).unref()},"startNextTimer");A(m)}}a(KE,"scheduleCleanup");function gA(){K=u?.addDeleteRemovalCallback(n,Y=>{let m=i.getEntry(Y);m?.value===null&&i.remove(Y,m.version)})}a(gA,"addDeleteRemoval");function Wx(){(0,No.getWorkerIndex)()===0&&setInterval(async()=>{try{let Y=$.name,m=r[Y];if(!m)throw new Error(`expiresAt attribute ${$} must be indexed`);for(let{value:A}of m.getRange({start:!0,end:Date.now(),versions:!0,snapshot:!1})){let I=i.getEntry(A);I?.value?.[Y]<Date.now()&&We.evict(A,I.value,I.version),await dl()}}catch(Y){ze.error("Error in evicting old records",Y)}},qne).unref()}a(Wx,"runRecordExpirationEviction")}function tA(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 rx(){}function Wne(e){ox=e}function OE(e,t){let r=t?.type;return e===null?e:r==="Int"||r==="Long"?e==="null"?null:parseInt(e):r==="Float"?e==="null"?null:parseFloat(e):r==="BigInt"?e==="null"?null:BigInt(e):r==="Boolean"?e==="true"?!0:e==="false"?!1:e:r==="Date"?(typeof e!="number"&&!Qne.test(e)&&(e+="Z"),e==="null"?null:new Date(e)):!r||r==="Any"?(0,NE.autoCast)(e):e}function nx(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 rA(e,t,r){return e?.then?e.then(t,r):t(e)}function bE(e,t){e[Yr]=t,e[he]=t?.value??null,e[fl]=t?.version}function sx(e){return e!=null}var Bn,bo,El,ix,pl,hn,hl,ml,ze,yo,No,NE,Fne,ox,qne,Gne,ZH,kne,fl,Vne,Yr,ul,ex,$ne,eA,Va,ll,_l,Yne,tx,Kne,vme,Qne,dl,Df=Oe(()=>{Bn=x(U()),bo=require("lmdb"),El=x(Nr()),ix=require("lodash");gn();Lp();pl=x(Z());jH();hn=x(ee()),hl=x(ps()),ml=x(yn());be();mf();ze=x(W());G_();Qi();yo=require("ordered-binary"),No=x(je());Ci();NE=x(J());vo();Rs();dE();Fne=new Uint8Array(9);Fne[8]=192;qne=6e4,Gne=864e5;pl.initSync();ZH=pl.get(Bn.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),kne=1e4,fl=Symbol.for("version"),Vne=Symbol.for("incremental-update"),Yr=Symbol("entry"),ul=Symbol("is-saving"),ex=1,$ne=2,eA=Symbol("loaded-from-source"),Va={isNotification:!0,ensureLoaded:!1},ll=1,_l=8,Yne=Buffer.allocUnsafeSlow(8192),tx=1978,Kne={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},vme=(0,NE.convertToMS)(pl.get(Bn.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(yE,"makeTable");a(tA,"attributesAsObject");a(rx,"noop");a(Wne,"setServerUtilities");Qne=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(OE,"coerceType");a(nx,"isDescendantId");dl=a(()=>new Promise(setImmediate),"rest");a(rA,"when");a(bE,"updateResource");a(sx,"exists")});var Fe={};ke(Fe,{database:()=>Yc,databases:()=>Ze,dropDatabase:()=>Bp,dropTableMeta:()=>ese,getDatabases:()=>In,getTables:()=>zne,onUpdatedTable:()=>gR,readMetaDb:()=>Sl,resetDatabases:()=>Jne,table:()=>ot,tables:()=>yr});function zne(){return LE||In(),yr||{}}function In(){if(LE)return Ze;LE=!0,Ka=new Map;let e=(0,Qt.getHdbBasePath)()&&(0,Je.join)((0,Qt.getHdbBasePath)(),Wr.DATABASES_DIR_NAME),t=(0,Qt.get)(Wr.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Qt.get)(Wr.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,Kr.existsSync)(e)?e:(0,Je.join)((0,Qt.getHdbBasePath)(),Wr.LEGACY_DATABASES_DIR_NAME)),!!e){if((0,Kr.existsSync)(e))for(let r of(0,Kr.readdirSync)(e,{withFileTypes:!0})){let n=(0,Je.basename)(r.name,".mdb");r.isFile()&&(0,Je.extname)(r.name).toLowerCase()===".mdb"&&!t[n]?.path&&Sl((0,Je.join)(e,r.name),null,n)}if((0,Kr.existsSync)((0,Ya.getBaseSchemaPath)())){for(let r of(0,Kr.readdirSync)((0,Ya.getBaseSchemaPath)(),{withFileTypes:!0}))if(!r.isFile()){let n=(0,Je.join)((0,Ya.getBaseSchemaPath)(),r.name),s=(0,Je.join)((0,Ya.getTransactionAuditStoreBasePath)(),r.name);for(let i of(0,Kr.readdirSync)(n,{withFileTypes:!0}))if(i.isFile()&&(0,Je.extname)(i.name).toLowerCase()===".mdb"){let o=(0,Je.join)(s,i.name);Sl((0,Je.join)(n,i.name),(0,Je.basename)(i.name,".mdb"),r.name,o,!0)}}}if(t)for(let r in t){let n=t[r],s=n.path;if((0,Kr.existsSync)(s))for(let o of(0,Kr.readdirSync)(s,{withFileTypes:!0}))o.isFile()&&(0,Je.extname)(o.name).toLowerCase()===".mdb"&&Sl((0,Je.join)(s,o.name),(0,Je.basename)(o.name,".mdb"),r);let i=n.tables;if(i)for(let o in i){let c=i[o],u=(0,Je.join)(c.path,(0,Je.basename)(o+".mdb"));(0,Kr.existsSync)(u)&&Sl(u,o,r,null,!0)}}for(let r in Ze){let n=Ka.get(r);if(n){let s=Ze[r];r.includes("delete")&&mn.trace(`defined tables ${Array.from(n.keys())}`);for(let i in s)n.has(i)||(mn.trace(`delete table class ${i}`),delete s[i])}else if(delete Ze[r],r==="data"){for(let s in yr)delete yr[s];delete yr[ME]}}return Ka=null,Ze}}function Jne(){LE=!1;for(let[,e]of Ai)e.needsDeletion=!0;In();for(let[e,t]of Ai)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),Ai.delete(e));return Ze}function Sl(e,t,r=iA,n,s){let i=new nA.default(e,!1);try{let o=Ai.get(e);o?o.needsDeletion=!1:(o=(0,IE.open)(i),Ai.set(e,o));let c=new wo.default(!1),u=o.dbisDb||(o.dbisDb=o.openDB(wE.INTERNAL_DBIS_NAME,c)),_=o.auditStore;_||(n?(0,Kr.existsSync)(n)&&(i.path=n,_=(0,IE.open)(i),_.isLegacy=!0):_=_E(o));let l=lx(r),d=l[ME],f=new Map;for(let{key:E,value:h}of u.getRange({start:!1})){let[p,S]=E.toString().split("/");S===""?S=h.name:S||(S=p,p=t,h.name||(h.name=S,h.indexed=!h.is_hash_attribute)),d?.add(p);let O=f.get(p);O||f.set(p,O={attributes:[]}),(S==null||h.is_hash_attribute)&&(O.primary=h),S!=null&&O.attributes.push(h),Object.defineProperty(h,"key",{value:E,configurable:!0})}for(let[E,h]of f){let{attributes:p,primary:S}=h;if(!S){for(let z of p)if(z.is_hash_attribute||z.isPrimaryKey){S=z;break}if(!S){mn.fatal(`Unable to find a primary key attribute on table ${E}, with attributes: ${JSON.stringify(p)}`);continue}}let O=l[E],g={},R=[],B,H,v=typeof S.audit=="boolean"?S.audit:(0,Qt.get)(Wr.CONFIG_PARAMS.LOGGING_AUDITLOG),M=S.trackDeletes,$=S.expiration,K=S.eviction;if(O)g=O.indices,R=O.attributes,O.schemaVersion++;else{B=S.tableId,B?B>=(u.get($a)||0)&&u.putSync($a,B+1):(S.tableId=B=u.get($a),B||(B=1),u.putSync($a,B+1),u.putSync(S.key,S));let z=new wo.default(!S.is_hash_attribute,S.is_hash_attribute);H=Wl(o.openDB(S.key,z)),H.rootStore=o,H.tableId=B}for(let z of p){z.attribute=z.name;try{if(!z.is_hash_attribute&&(z.indexed||z.attribute&&!z.name)){if(!g[z.name]){let Te=new wo.default(!z.is_hash_attribute,z.is_hash_attribute);g[z.name]=o.openDB(z.key,Te),g[z.name].indexNulls=z.indexNulls}let se=R.find(Te=>Te.name===z.name);se?R.splice(R.indexOf(se),1,z):R.push(z)}}catch(se){mn.error("Error trying to update attribute",z,R,g,se)}}if(!O){O=_x(l,E,yE({primaryStore:H,auditStore:_,audit:v,expirationMS:$&&$*1e3,evictionMS:K&&K*1e3,trackDeletes:M,tableName:E,tableId:B,primaryKey:S.name,databasePath:s?r+"/"+E:r,databaseName:r,indices:g,attributes:p,schemaDefined:S.schemaDefined,dbisDB:u})),O.schemaVersion=1;for(let z of oA)z(O)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function lx(e){let t=Ze[e];if(t||(e==="data"?t=Ze[e]=yr:e==="system"?Object.defineProperty(Ze,"system",{value:t=Object.create(null),configurable:!0}):t=Ze[e]=Object.create(null)),Ka&&!Ka.has(e)){let r=new Set;t[ME]=r,Ka.set(e,r)}return t}function _x(e,t,r){return e[t]=r,r}function Yc({database:e,table:t}){e||(e=iA),In();let r=lx(e),n=(0,Je.join)((0,Qt.getHdbBasePath)(),Wr.DATABASES_DIR_NAME),s=(0,Qt.get)(Wr.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,Qt.get)(Wr.CONFIG_PARAMS.STORAGE_PATH)||((0,Kr.existsSync)(n)?n:(0,Je.join)((0,Qt.getHdbBasePath)(),Wr.LEGACY_DATABASES_DIR_NAME));let o=(0,Je.join)(n,(i?t:e)+".mdb"),c=Ai.get(o);if(!c){let u=new nA.default(o,!1);c=(0,IE.open)(u),Ai.set(o,c)}return c}async function Bp(e){if(!Ze[e])throw new Error("Schema does not exist");let t=Ze[e];for(let r in t){let s=t[r].primaryStore.rootStore;Ai.delete(s.path),s.status==="open"&&(await s.close(),await ax.remove(s.path))}if(e==="data"){for(let r in yr)delete yr[r];delete yr[ME]}delete Ze[e]}function ot({table:e,database:t,expiration:r,eviction:n,scanInterval:s,attributes:i,audit:o,trackDeletes:c,schemaDefined:u,origin:_}){t||(t=iA);let l=Yc({database:t,table:e}),d=Ze[t],f=d?.[e];if(l.status==="closed")throw new Error(`Can not use a closed data store for ${e}`);let E,h,p,S;u==null&&(u=!0);let O=new wo.default(!1);for(let M of i)M.attribute?(M.name=M.attribute,M.indexed=!0):M.attribute=M.name,M.expiresAt&&(M.indexed=!0);let g,R;if(f){if(E=f.primaryKey,f.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${e} class`);f.attributes.splice(0,f.attributes.length,...i)}else{let M=l.auditStore;M||(M=_E(l)),h=i.find(se=>se.isPrimaryKey)||{},E=h.name,h.is_hash_attribute=!0,h.schemaDefined=u,c&&(h.trackDeletes=!0),o=h.audit=typeof o=="boolean"?o:(0,Qt.get)(Wr.CONFIG_PARAMS.LOGGING_AUDITLOG),r&&(h.expiration=r),n&&(h.eviction=n),_&&(h.origins?h.origins.includes(_)||h.origins.push(_):h.origins=[_]),mn.trace(`${e} table loading, opening primary store`);let $=new wo.default(!1,!0),K=e+"/",z=Wl(l.openDB(K,$));z.rootStore=l,S=l.dbisDb=l.openDB(wE.INTERNAL_DBIS_NAME,O),z.tableId=S.get($a),z.tableId||(z.tableId=1),S.putSync($a,z.tableId+1),h.tableId=z.tableId,f=_x(d,e,yE({primaryStore:z,auditStore:M,audit:o,trackDeletes:c,expirationMS:r&&r*1e3,evictionMS:n&&n*1e3,primaryKey:E,tableName:e,tableId:z.tableId,databasePath:t,databaseName:t,indices:{},attributes:i,schemaDefined:u,dbisDB:S})),f.schemaVersion=1,g=!0,v(),S.put(K,h)}p=f.indices,S=S||(l.dbisDb=l.openDB(wE.INTERNAL_DBIS_NAME,O)),f.dbisDB=S;let B=[];for(let{key:M,value:$}of S.getRange({start:!0})){let[K,z]=M.toString().split("/");if(z===""&&(z=$.name),z){if(K!==e)continue}else z=K;if(!i.find(Te=>Te.name===z)?.indexed&&$.indexed&&!$.isPrimaryKey){v(),g=!0,S.remove(M);let Te=f.indices[K];Te&&B.push(Te)}}let H=[];try{for(let M of i||[]){if(M.relationship)continue;let $=e+"/"+(M.name||"");Object.defineProperty(M,"key",{value:$,configurable:!0});let K=S.get($);if(M.isPrimaryKey){if(K=K||S.get($=e+"/")||{},o!==f.audit||(+r||void 0)!==(+K.expiration||void 0)||(+n||void 0)!==(+K.eviction||void 0)){let se=Object.assign({},K);typeof o=="boolean"&&(o&&f.enableAuditing(o),se.audit=o),r&&(se.expiration=+r),n&&(se.eviction=+n),g=!0,v(),S.put($,se)}continue}K?.attribute&&!K.name&&(K.indexed=!0);let z=!K||K.type!==M.type||K.indexed!==M.indexed||JSON.stringify(K.attributes)!==JSON.stringify(M.attributes)||JSON.stringify(K.elements)!==JSON.stringify(M.elements);if(M.indexed){let se=new wo.default(!0,!1),Te=l.openDB($,se);(z||K.indexingPID&&K.indexingPID!==process.pid||K.restartNumber<Tl.workerData?.restartNumber)&&(g=!0,v(),K=S.get($),(z||K.indexingPID&&K.indexingPID!==process.pid||K.restartNumber<Tl.workerData?.restartNumber)&&(g=!0,M.lastIndexedKey=K?.lastIndexedKey||!1,M.indexingPID=process.pid,Te.isIndexing=!0,Object.defineProperty(M,"dbi",{value:Te}),M.indexNulls===void 0&&(M.indexNulls=!0),H.push(M)),S.put($,M)),K?.indexNulls&&M.indexNulls===void 0&&(M.indexNulls=!0),Te.indexNulls=M.indexNulls,p[M.name]=Te}else z&&(g=!0,v(),S.put($,M))}}finally{R&&R()}if(g&&(f.schemaVersion++,f.updatedAttributes()),mn.trace(`${e} table loading, running index`),H.length>0||B.length>0?f.indexingOperation=Zne(f,H,B):g&&CE.signalSchemaChange(new DE.SchemaEventMsg(process.pid,"schema-change",f.databaseName,f.tableName)),f.origin=_,g)for(let M of oA)M(f,_!=="cluster");return(r||n||s)&&f.setTTLExpiration({expiration:r,eviction:n,scanInterval:s}),mn.trace(`${e} table loaded`),f;function v(){R||l.transactionSync(()=>({then(M){R=M}}))}a(v,"startTxn")}async function Zne(e,t,r){try{let n=e.schemaVersion;await CE.signalSchemaChange(new DE.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o=0,c=t.length;if(await new Promise(u=>setImmediate(u)),c>0){let u=0;for(let{key:_,value:l,version:d}of e.primaryStore.getRange({start:t[0].lastIndexedKey,lazy:c<4,versions:!0,snapshot:!1}))if(l){if(u++,s=e.primaryStore.ifVersion(_,d,()=>{for(let f=0;f<c;f++){let E=t[f],h=E.name,p=(0,cx.getIndexedValues)(l[h]);if(p)for(let S=0,O=p.length;S<O;S++)E.dbi.put(p[S],_)}}),s.then(()=>u--,f=>{u--,mn.error(f)}),Tl.workerData&&Tl.workerData.restartNumber!==ux.restartNumber&&(i=!0),++o%100===0||i){for(let f of t)f.lastIndexedKey=_,e.dbisDB.put(f.key,f);if(i)return}u>Xne?await s:u>jne&&await new Promise(f=>setImmediate(f))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await CE.signalSchemaChange(new DE.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName))}catch(n){mn.error("Error in indexing",n)}}function ese({table:e,database:t}){let r=Yc({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 gR(e){oA.push(e)}var Qt,wE,IE,Je,Kr,Ya,wo,nA,Wr,ax,sA,cx,CE,DE,Tl,mn,ux,iA,ME,yr,Ze,$a,oA,LE,Ai,Ka,Xne,jne,be=Oe(()=>{Qt=x(Z()),wE=x(lt()),IE=require("lmdb"),Je=require("path"),Kr=require("fs"),Ya=x(Ye());Df();wo=x(Ql()),nA=x(Jl()),Wr=x(U()),ax=x(require("fs-extra")),sA=require("../../index"),cx=x(Nr()),CE=x(ps()),DE=x(yn()),Tl=require("worker_threads"),mn=x(W()),ux=x(je());Ci();vo();iA="data",ME=Symbol("defined-tables");(0,Qt.initSync)();yr=Object.create(null),Ze=Object.create(null);(0,sA._assignPackageExport)("databases",Ze);(0,sA._assignPackageExport)("tables",yr);$a=Symbol.for("next-table-id"),oA=[],Ai=new Map;a(zne,"getTables");a(In,"getDatabases");a(Jne,"resetDatabases");a(Sl,"readMetaDb");a(lx,"ensureDB");a(_x,"setTable");a(Yc,"database");a(Bp,"dropDatabase");a(ot,"table");Xne=1e3,jne=10;a(Zne,"runIndexing");a(ese,"dropTableMeta");a(gR,"onUpdatedTable")});var J=T(($me,Nx)=>{"use strict";var Oi=require("path"),mx=require("fs-extra"),Sr=W(),dx=require("fs-extra"),UE=require("os"),tse=require("net"),rse=require("recursive-iterator"),it=U(),nse=ZA(),fx=require("papaparse"),PE=require("moment"),{inspect:sse}=require("util"),Ex=require("is-number"),Vme=require("lodash"),ise=require("minimist"),ose=require("https"),ase=require("http"),{hdb_errors:vE}=ee(),cse=/^((\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)))$/,px=require("util").promisify(setTimeout),use=100,lse=5,_se="",dse=4,hx={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};Nx.exports={isEmpty:Qr,isEmptyOrZeroLength:cs,arrayHasEmptyValues:hse,arrayHasEmptyOrZeroLengthValues:mse,buildFolderPath:pse,isBoolean:Sx,errorizeMessage:fse,stripFileExtension:Tse,autoCast:gse,autoCastJSON:Tx,autoCastJSONDeep:cA,removeDir:Rse,compareVersions:Ase,isCompatibleDataVersion:Ose,escapeRawValue:bse,unescapeValue:Nse,stringifyProps:yse,timeoutPromise:Ise,isClusterOperation:Dse,getClusterUser:Mse,checkGlobalSchemaTable:Lse,getHomeDir:Rx,getPropsFilePath:wse,promisifyPapaParse:Use,removeBOM:Ax,createEventPromise:Pse,checkProcessRunning:vse,checkSchemaTableExist:Bse,checkSchemaExists:Ox,checkTableExists:bx,getStartOfTomorrowInSeconds:Hse,getLimitKey:xse,isObject:Sse,isNotEmptyAndHasValue:Ese,autoCasterIsNumberCheck:gx,backtickASTSchemaItems:Fse,isPortTaken:Cse,createForkArgs:qse,autoCastBoolean:Gse,async_set_timeout:px,getTableHashAttribute:kse,doesSchemaExist:Vse,doesTableExist:$se,stringifyObj:Yse,ms_to_time:Kse,changeExtension:Wse,getEnvCliRootPath:uA,noBootFile:Qse,httpRequest:zse,transformReq:Jse,convertToMS:Xse,PACKAGE_ROOT:it.PACKAGE_ROOT};function fse(e){return e instanceof Error?e:new Error(e)}a(fse,"errorizeMessage");function Qr(e){return e==null}a(Qr,"isEmpty");function Ese(e){return!Qr(e)&&(e||e===0||e===""||Sx(e))}a(Ese,"isNotEmptyAndHasValue");function cs(e){return Qr(e)||e.length===0||e.size===0}a(cs,"isEmptyOrZeroLength");function hse(e){if(Qr(e))return!0;for(let t=0;t<e.length;t++)if(Qr(e[t]))return!0;return!1}a(hse,"arrayHasEmptyValues");function mse(e){if(cs(e))return!0;for(let t=0;t<e.length;t++)if(cs(e[t]))return!0;return!1}a(mse,"arrayHasEmptyOrZeroLengthValues");function pse(...e){try{return e.join(Oi.sep)}catch{console.error(e)}}a(pse,"buildFolderPath");function Sx(e){return Qr(e)?!1:e===!0||e===!1}a(Sx,"isBoolean");function Sse(e){return Qr(e)?!1:typeof e=="object"}a(Sse,"isObject");function Tse(e){return cs(e)?_se:e.slice(0,-dse)}a(Tse,"stripFileExtension");function gse(e){return Qr(e)||e===""||typeof e!="string"?e:hx[e]!==void 0?hx[e]:gx(e)===!0?Number(e):cse.test(e)?new Date(e):e}a(gse,"autoCast");function Tx(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(Tx,"autoCastJSON");function cA(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=cA(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=cA(r);n!==r&&(e[t]=n)}return e}else return Tx(e)}a(cA,"autoCastJSONDeep");function gx(e){if(e.startsWith("0.")&&Ex(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&Ex(e))}a(gx,"autoCasterIsNumberCheck");async function Rse(e){if(cs(e))throw new Error(`Directory path: ${e} does not exist`);try{await dx.emptyDir(e),await dx.remove(e)}catch(t){throw Sr.error(`Error removing files in ${e} -- ${t}`),t}}a(Rse,"removeDir");function Ase(e,t){if(cs(e)){Sr.info("Invalid current version sent as parameter.");return}if(cs(t)){Sr.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(Ase,"compareVersions");function Ose(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(Ose,"isCompatibleDataVersion");function bse(e){if(Qr(e))return e;let t=String(e);return t==="."?it.UNICODE_PERIOD:t===".."?it.UNICODE_PERIOD+it.UNICODE_PERIOD:t.replace(it.FORWARD_SLASH_REGEX,it.UNICODE_FORWARD_SLASH)}a(bse,"escapeRawValue");function Nse(e){if(Qr(e))return e;let t=String(e);return t===it.UNICODE_PERIOD?".":t===it.UNICODE_PERIOD+it.UNICODE_PERIOD?"..":String(e).replace(it.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(Nse,"unescapeValue");function yse(e,t){if(Qr(e))return Sr.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+UE.EOL}!cs(n)&&n[0]===";"?r+=" "+n+s+UE.EOL:cs(n)||(r+=n+"="+s+UE.EOL)}catch{Sr.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(yse,"stringifyProps");function Rx(){let e;try{e=UE.homedir()}catch{e=process.env.HOME}return e||(e="~/"),e}a(Rx,"getHomeDir");function wse(){let e=Oi.join(Rx(),it.HDB_HOME_DIR_NAME,it.BOOT_PROPS_FILE_NAME);return mx.existsSync(e)||(e=Oi.join(__dirname,"../","hdb_boot_properties.file")),e}a(wse,"getPropsFilePath");function Ise(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:function(){clearTimeout(r)}}}a(Ise,"timeoutPromise");async function Cse(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=tse.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(Cse,"isPortTaken");function Dse(e){try{return it.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Sr.error(`Error checking operation against cluster ops ${t}`)}return!1}a(Dse,"isClusterOperation");function Lse(e,t){let r=(be(),te(Fe)).getDatabases();if(!r[e])return vE.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return vE.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Lse,"checkGlobalSchemaTable");function Mse(e,t){if(Qr(t)){Sr.warn("No CLUSTERING_USER defined, clustering disabled");return}if(Qr(e)||cs(e)){Sr.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){Sr.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){Sr.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(Mse,"getClusterUser");function Use(){fx.parsePromise=function(e,t,r){return new Promise(function(n,s){fx.parse(e,{header:!0,transformHeader:Ax,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(Use,"promisifyPapaParse");function Ax(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(Ax,"removeBOM");function Pse(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;Sr.info(`Got cluster status event response: ${sse(s)}`);try{i.cancel()}catch{Sr.error("Error trying to cancel timeout.")}n(s)})})}a(Pse,"createEventPromise");async function vse(e){let t=!0,r=0;do await px(use*r++),(await nse.findPs(e)).length>0&&(t=!1);while(t&&r<lse);if(t)throw new Error(`process ${e} was not started`)}a(vse,"checkProcessRunning");function Bse(e,t){let r=Ox(e);if(r)return r;let n=bx(e,t);if(n)return n}a(Bse,"checkSchemaTableExist");function Ox(e){let{getDatabases:t}=(be(),te(Fe));if(!t()[e])return vE.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(Ox,"checkSchemaExists");function bx(e,t){let{getDatabases:r}=(be(),te(Fe));if(!r()[e][t])return vE.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(bx,"checkTableExists");function Hse(){let e=PE().utc().add(1,it.MOMENT_DAYS_TAG).startOf(it.MOMENT_DAYS_TAG).unix(),t=PE().utc().unix();return e-t}a(Hse,"getStartOfTomorrowInSeconds");function xse(){return PE().utc().format("DD-MM-YYYY")}a(xse,"getLimitKey");function Fse(e){try{let t=new rse(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){Sr.error("Got an error back ticking items."),Sr.error(t)}}a(Fse,"backtickASTSchemaItems");function qse(e){return[e]}a(qse,"createForkArgs");function Gse(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(Gse,"autoCastBoolean");function kse(e,t){let{getDatabases:r}=(be(),te(Fe)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(kse,"getTableHashAttribute");function Vse(e){let{getDatabases:t}=(be(),te(Fe));return t()[e]!==void 0}a(Vse,"doesSchemaExist");function $se(e,t){let{getDatabases:r}=(be(),te(Fe));return r()[e]?.[t]!==void 0}a($se,"doesTableExist");function Yse(e){try{return JSON.stringify(e)}catch{return e}}a(Yse,"stringifyObj");function Kse(e){let t=PE.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(Kse,"ms_to_time");function Wse(e,t){let r=Oi.basename(e,Oi.extname(e));return Oi.join(Oi.dirname(e),r+t)}a(Wse,"changeExtension");function uA(){if(process.env[it.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[it.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=ise(process.argv);if(e[it.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[it.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(uA,"getEnvCliRootPath");var aA;function Qse(){if(aA)return aA;let e=uA();uA()&&mx.pathExistsSync(Oi.join(e,it.HDB_CONFIG_FILE))&&(aA=!0)}a(Qse,"noBootFile");function zse(e,t){let r;return e.protocol==="http:"?r=ase:r=ose,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(zse,"httpRequest");function Jse(e){if(!e.schema&&!e.database){e.schema=it.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(Jse,"transformReq");function Xse(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(Xse,"convertToMS")});var Z=T((Kme,Cx)=>{"use strict";var lA=require("fs-extra"),Io=require("path"),yx=require("os"),jse=require("properties-reader"),Rl=W(),gl=J(),_e=U(),BE=Lr(),Zse="Error initializing environment manager",HE="BOOT_PROPS_FILE_PATH",wx=!1,eie={[_e.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[_e.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[_e.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},Gs={};Cx.exports={BOOT_PROPS_FILE_PATH:HE,getHdbBasePath:tie,setHdbBasePath:rie,get:Ix,initSync:sie,setProperty:Ue,initTestEnvironment:iie};function tie(){return Gs[_e.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(tie,"getHdbBasePath");function rie(e){Gs[_e.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(rie,"setHdbBasePath");function Ix(e){let t=BE.getConfigValue(e);return t===void 0?Gs[e]:t}a(Ix,"get");function Ue(e,t){eie[e]&&(Gs[e]=t),BE.updateConfigObject(e,t)}a(Ue,"setProperty");function nie(){let e;try{e=gl.getPropsFilePath(),lA.accessSync(e,lA.constants.F_OK|lA.constants.R_OK),wx=!0;let t=jse(e);return Gs[_e.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(_e.HDB_SETTINGS_NAMES.INSTALL_USER),Gs[_e.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(_e.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),Gs[HE]=e,!0}catch{return Rl.trace(`Environment manager found no properties file at ${e}`),!1}}a(nie,"doesPropFileExist");function sie(e=!1){try{(wx||nie()||gl.noBootFile())&&(BE.initConfig(e),Gs[_e.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=BE.getConfigValue(_e.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Rl.error(Zse),Rl.error(t),console.error(t),process.exit(1)}}a(sie,"initSync");function iie(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=Io.join(__dirname,"../../","unitTests");Gs[HE]=Io.join(u,"hdb_boot_properties.file"),Ue(_e.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Io.join(u,"settings.test")),Ue(_e.HDB_SETTINGS_NAMES.INSTALL_USER,yx.userInfo()?yx.userInfo().username:void 0),Ue(_e.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Ue(_e.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Io.join(u,"envDir","log")),Ue(_e.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Ue(_e.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Ue(_e.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Ue(_e.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Io.join(u,"envDir")),Ue(_e.CONFIG_PARAMS.STORAGE_PATH,Io.join(u,"envDir")),s&&(Ue(_e.CONFIG_PARAMS.HTTP_SECUREPORT,Ix(_e.CONFIG_PARAMS.HTTP_PORT)),Ue(_e.CONFIG_PARAMS.HTTP_PORT,null)),Ue(_e.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Ue(_e.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Ue(_e.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,gl.isEmpty(i)?!1:i),Ue(_e.CONFIG_PARAMS.HTTP_CORS,gl.isEmpty(i)?!1:i),Ue(_e.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Ue(_e.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Ue(_e.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Ue(_e.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Ue(_e.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Io.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Ue(_e.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,gl.isEmpty(c)?!1:c),o&&(Ue("CORS_ACCESSLIST",o),Ue(_e.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Ue(_e.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Ue(_e.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Ue(_e.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Ue(_e.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Ue(_e.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Ue(_e.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${HE}. Please check your boot props and settings files`;Rl.fatal(r),Rl.error(t)}}a(iie,"initTestEnvironment")});var WB=T(Co=>{var{isMainThread:oie,parentPort:Ol,threadId:xE}=require("worker_threads"),{Socket:aie,createServer:cie}=require("net"),{createServer:uie,IncomingMessage:lie}=require("http"),{createServer:_ie}=require("https"),{readFileSync:Wa,unlinkSync:Dx,existsSync:die}=require("fs"),pn=W(),He=Z(),Tr=U(),{server:GE}=(jt(),te(yi)),{WebSocketServer:fie}=require("ws"),{createServer:Eie}=require("tls"),{getTicketKeys:hie,restartNumber:mie,getWorkerIndex:Lx}=je(),{Headers:Bx}=(qd(),te(CU)),{recordAction:Al,recordActionBinary:pie}=(Rs(),te(Zc)),{Request:Hx,createReuseportFd:Mx}=(Yf(),te(lR)),{checkMemoryLimit:Sie}=ki(),xx=require("tls"),Ux=xx.createSecureContext;xx.createSecureContext=function(e){if(!e.cert||!e.key)return Ux(e);let t={...e};delete t.key,delete t.cert;let r=Ux(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};if(process.env.DEV_MODE)try{require("inspector").open(9229)}catch(e){mie<=1&&pn.trace("Could not start debugging on port 9229, you may already be debugging:",e.message)}process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)});var{HDB_SETTINGS_NAMES:Qme,CONFIG_PARAMS:Tie}=Tr;He.initSync();var gie=He.get(Tie.HTTP_SESSIONAFFINITY),us={};Co.registerServer=hA;Co.httpServer=mA;Co.deliverSocket=EA;Co.startServers=Fx;Co.when_components_loaded=null;GE.http=mA;GE.request=bie;GE.socket=Nie;GE.ws=yie;var _A={},FE={},Rie,bi={},qE={},Aie=[],dA=[];function Fx(){return Co.when_components_loaded=UR().loadRootComponents(!0).then(()=>{Ol?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)EA(n,r,s);else if(t.requestId)Oie(t);else if(t.type===Tr.ITC_EVENT_TYPES.SHUTDOWN){pn.trace("received shutdown request",xE);for(let i in us){let o=us[i],c;if(o.closeIdleConnections){let _=Object.getOwnPropertySymbols(o).find(f=>f.description.includes("connections")),l=0,d=setInterval(()=>{l++;let f=l>=100,E=o[_][f?"all":"idle"]();if(E.length===0){f&&clearInterval(d);return}l===1?pn.info(`Closing ${E.length} idle connections`):f&&pn.warn(`Forcefully closing ${E.length} active connections`);for(let h=0,p=E.length;h<p;h++){let S=E[h].socket;S._httpMessage&&!S._httpMessage.finished&&!f||(f?S.destroySoon():S.end(`HTTP/1.1 408 Request Timeout\r
|
|
27
|
+
Connection: close\r
|
|
28
|
+
\r
|
|
29
|
+
`))}},25).unref()}o.close?.(()=>{if(He.get(Tr.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&Lx()==0)try{Dx(He.get(Tr.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,xE),o.cantCleanupProperly||pn.warn("Had to forcefully exit the thread",xE),process.exit(0)},5e3).unref()})}if(process.env.DEV_MODE)try{require("inspector").close()}catch(i){console.error("Could not close debugger",i)}}}).ref();let e=[];if(Mx&&!gie)for(let t in us){let r=us[t];if(isNaN(t)&&Lx()==0){die(t)&&Dx(t),e.push(new Promise((s,i)=>{r.listen({path:t},()=>{s(),pn.info("Domain socket listening on "+t)}).on("error",i)}));continue}let n;try{n=Mx(+t,"::")}catch(s){console.error(`Unable to bind to port ${t}`,s);continue}e.push(new Promise((s,i)=>{r.listen({fd:n},()=>{s(),pn.trace("Listening on port "+t,xE)}).on("error",i)}))}Promise.all(e).then(()=>{Ol?.postMessage({type:Tr.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(Fx,"startServers");oie||Fx();function EA(e,t,r){let n=e?.read?e:new aie({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=us[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=us[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(pn.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(EA,"deliverSocket");var Px=new Map;function Oie(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=Px.get(s),r){case"connection":i=EA(void 0,t),Px.set(s,i),i.write=(c,u,_)=>(Ol.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),_&&_(),!0),i.end=(c,u,_)=>(Ol.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),_&&_(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),Ol.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(Oie,"proxyRequest");function hA(e,t,r=!0){!+t&&t!==He.get(Tr.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&(t=parseInt(He.get(Tr.CONFIG_PARAMS.HTTP_PORT),10));let n=us[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",vx),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else us[t]=e;e.on("unhandled",vx)}a(hA,"registerServer");function qx(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=[],He.get(Tr.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:He.get(Tr.CONFIG_PARAMS.HTTP_PORT),secure:He.get(Tr.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),He.get(Tr.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:He.get(Tr.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&He.get(Tr.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:He.get(Tr.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),secure:!1}),t}a(qx,"getPorts");function mA(e,t){for(let{port:r,secure:n}of qx(t))Gx(r,n,t?.isOperationsServer),typeof e=="function"?dA[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||r}):(e.isSecure=n,hA(e,r,!1)),qE[r]=fA(dA,r),Rie=fA(Aie,r)}a(mA,"httpServer");function Gx(e,t,r){if(!bi[e]){let n=r?"operationsApi_network":"http",s={keepAliveTimeout:He.get(n+"_keepAliveTimeout"),headersTimeout:He.get(n+"_headersTimeout"),requestTimeout:He.get(n+"_timeout")},i=He.get(n+"_mtls"),o=He.get(n+"_mtls_required");if(t){n=r?"operationsApi_":"";let u=He.get(n+"tls_privateKey"),_=He.get(n+"tls_certificate"),l=He.get(n+"tls_certificateAuthority");Object.assign(s,{allowHTTP1:!0,key:Wa(u),ciphers:He.get("tls_ciphers"),cert:Wa(_),ca:l&&Wa(l),rejectUnauthorized:!!o,requestCert:!!i,ticketKeys:hie()})}let c=Sie();bi[e]=(t?_ie:uie)(s,async(u,_)=>{try{let d=performance.now(),f=new Hx(u,_);r&&(f.isOperationsServer=!0);let E=await qE[e](f);if(!E){if(f._nodeResponse.statusCode)return;E=kx(f)}if(c?E.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):E.headers?.set?.("Server","HarperDB"),E.status===-1){for(let H of E.headers||[])_.setHeader(H[0],H[1]);return u.baseRequest=f,_.baseResponse=E,bi[e].emit("unhandled",u,_)}let h=E.status||200,p=performance.now(),S=p-d,O=E.body,g;if(!E.handlesHeaders){let H=E.headers||new Bx;if(O?O.length>=0&&(typeof O=="string"?H.set("Content-Length",Buffer.byteLength(O)):H.set("Content-Length",O.length),g=!0):(H.set("Content-Length","0"),g=!0),H.append){let v=`hdb;dur=${S.toFixed(2)}`;E.wasCacheMiss&&(v+=", miss"),H.append("Server-Timing",v,!0)}_.writeHead(h,H&&(H[Symbol.iterator]?Array.from(H):H)),g&&_.end(O)}let R=f.handlerPath,B=f.method;if(Al(S,"duration",R,B,E.wasCacheMiss==null?void 0:E.wasCacheMiss?"cache-miss":"cache-hit"),pie(h<400,"success",R,B),!g)if(O?.pipe){O.pipe(_),O.destroy&&_.on("close",()=>{O.destroy()});let H=0;O.on("data",v=>{H+=v.length}),O.on("end",()=>{Al(performance.now()-p,"transfer",R,B),Al(H,"bytes-sent",R,B)})}else O?.then?O.then(H=>{_.end(H)},l):_.end(O)}catch(d){l(d)}function l(d){let f=d.headers;_.writeHead(d.statusCode||500,f&&(f[Symbol.iterator]?Array.from(f):f)),_.end(d.toString()),d.statusCode?d.statusCode===500?pn.warn(d):pn.info(d):pn.error(d)}a(l,"onError")}),i&&(bi[e].mtlsConfig=i),t&&(bi[e].on("secureConnection",u=>{u._parent.startTime&&Al(performance.now()-u._parent.startTime,"tls-handshake",e),Al(u.isSessionReused(),"tls-reused",e)}),bi[e].isSecure=!0),hA(bi[e],e)}return bi[e]}a(Gx,"getHTTPServer");function fA(e,t){let r=kx;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(fA,"makeCallbackChain");function kx(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new Bx}}a(kx,"unhandled");function bie(e,t){mA(e,{requestOnly:!0,...t})}a(bie,"onRequest");function Nie(e,t){let r;if(t.securePort){let n=He.get("tls_privateKey"),s=He.get("tls_certificate"),i=t.mtls?.certificateAuthority||He.get("tls_certificateAuthority");r=Eie({ciphers:He.get("tls_ciphers"),key:Wa(n),cert:Wa(s),ca:i&&Wa(i),rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls},e),us[t.securePort]=r}return t.port&&(r=cie(e),us[t.port]=r),r}a(Nie,"onSocket");Object.defineProperty(lie.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.startsWith("Upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});function yie(e,t){let r;for(let{port:n,secure:s}of qx(t)){FE[n]||(FE[n]=new fie({server:r=Gx(n,s)}),FE[n].on("connection",async(c,u)=>{try{let _=new Hx(u);_.isWebSocket=!0;let l=qE[n](_),d=u.headers["sec-websocket-protocol"]||"",f=_A[n];if(d){let E;for(let h=0;h<f.length;h++){let p=f[h];p.protocol===d&&(E=!0,p.listener(c,_,l))}if(E)return}for(let E=0;E<f.length;E++){let h=f[E];h.protocol||h.listener(c,_,l)}}catch(_){pn.warn("Error handling WebSocket connection",_)}}),FE[n].on("error",c=>{console.log("Error in setting up WebSocket server",c)}));let i=t?.subProtocol||"",o=_A[n];o||(o=_A[n]=[]),o.push({listener:e,protocol:i}),qE[n]=fA(dA,n)}return r}a(yie,"onWebSocket");function vx(e,t){t.writeHead(404),t.end(`Not found
|
|
30
|
+
`)}a(vx,"defaultNotFound")});module.exports=WB();
|